/* ==========================================================================
   urban-movement.com archive — custom reconstruction stylesheet
   Approximates the original Avada/Fusion theme look because Wayback has no
   CSS archived for this domain and live domain redirects all asset requests.
   ========================================================================== */

/* ---------- Reset / base ---------- */
* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; overflow-x: hidden; }
body {
  font-family: "PT Sans", "Open Sans", Helvetica, Arial, sans-serif;
  font-size: 14px;
  line-height: 1.7;
  color: #747474;
  background: #fff;
  -webkit-font-smoothing: antialiased;
}
img { max-width: 100%; height: auto; display: inline-block; vertical-align: middle; border: 0; }
a { color: #2869b0; text-decoration: none; }
a:hover { color: #1e4f86; }
h1, h2, h3, h4, h5, h6 {
  font-family: "Oswald", "PT Sans", Helvetica, Arial, sans-serif;
  color: #333;
  font-weight: 400;
  margin: 0 0 .5em;
  line-height: 1.2;
}
h2 { font-size: 34px; letter-spacing: 1px; }
h3 { font-size: 22px; }
p { margin: 0 0 1em; }
ul { margin: 0; padding: 0; list-style: none; }

.skip-link,
.screen-reader-text,
.rich-snippet-hidden,
.vcard.rich-snippet-hidden,
.updated.rich-snippet-hidden,
.entry-title.rich-snippet-hidden {
  position: absolute !important;
  left: -9999px !important;
  width: 1px; height: 1px; overflow: hidden;
}

/* ---------- Container / rows ---------- */
.fusion-row {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 15px;
}
.fusion-row::after { content: ""; display: table; clear: both; }

.fusion-fullwidth,
.fullwidth-box { width: 100%; }

.fullwidth-box {
  background-blend-mode: multiply;  /* lets the inline rgba bg-color act as overlay on images */
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
}

.fusion-builder-row {
  max-width: 1200px;
  margin: 0 auto;
}
.fusion-builder-row::after { content: ""; display: table; clear: both; }

/* full-width (100%) sections shouldn't cap inner row */
.hundred-percent-fullwidth .fusion-builder-row { max-width: none; }

.fusion-layout-column {
  float: left;
  box-sizing: border-box;
  min-height: 1px;
}
.fusion-one-full    { width: 100%; }
.fusion-one-half    { width: 50%; }
.fusion-one-fourth  { width: 25%; }
.fusion-three-fifth { width: 60%; }
.fusion-two-fifth   { width: 40%; }
.fusion-column-last { margin-right: 0 !important; }

.fusion-column-wrapper {
  background-size: cover;
  background-position: left top;
  background-repeat: no-repeat;
}

.fusion-clearfix { clear: both; }
.fusion-clearfix::after { content: ""; display: table; clear: both; }

/* ---------- Header ---------- */
#wrapper { overflow-x: hidden; }

.fusion-header-wrapper {
  background: #222;
  position: sticky;
  top: 0;
  z-index: 1000;
  box-shadow: 0 1px 3px rgba(0,0,0,.3);
}
.fusion-header {
  padding: 0 20px;
}
.fusion-header-sticky-height { display: none; }
.fusion-row.fusion-middle-logo-menu {
  max-width: 1400px;
  padding: 0;
}

/* Primary menu: horizontal flex, logo inlined as center <li> */
.fusion-main-menu { width: 100%; }
.fusion-menu.fusion-middle-logo-ul {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: nowrap;
  gap: 0;
}
.fusion-menu.fusion-middle-logo-ul > li {
  position: relative;
}
.fusion-menu.fusion-middle-logo-ul > li > a.fusion-top-level-link {
  display: block;
  padding: 35px 18px;
  color: #fff;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 1px;
  text-transform: uppercase;
  text-decoration: none;
  white-space: nowrap;
  transition: color .2s;
}
.fusion-menu.fusion-middle-logo-ul > li > a.fusion-top-level-link:hover {
  color: #2869b0;
}

/* Logo item (center) */
.fusion-middle-logo-menu-logo {
  padding: 0 40px;
  display: flex;
  align-items: center;
}
.fusion-middle-logo-menu-logo .fusion-logo-link { display: block; }
.fusion-standard-logo {
  display: block;
  height: 90px;
  width: auto;
  max-width: none;
}
.fusion-mobile-logo { display: none; }

/* Dropdowns */
.fusion-menu .sub-menu {
  position: absolute;
  top: 100%;
  left: 0;
  min-width: 200px;
  background: #2a2a2a;
  padding: 6px 0;
  list-style: none;
  margin: 0;
  display: none;
  box-shadow: 0 2px 8px rgba(0,0,0,.4);
  z-index: 1100;
}
.fusion-menu > li:hover > .sub-menu { display: block; }
.fusion-menu .sub-menu li a {
  display: block;
  padding: 10px 18px;
  color: #bbb;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: .5px;
  text-decoration: none;
}
.fusion-menu .sub-menu li a:hover {
  background: #2869b0;
  color: #fff;
}

/* SIGN UP button in menu */
.fusion-menu-item-button > a > .button-default {
  display: inline-block;
  padding: 10px 22px;
  background: #2869b0;
  color: #fff !important;
  border-radius: 2px;
  letter-spacing: 1px;
  line-height: 1;
}
.fusion-menu-item-button > a { padding: 20px 18px !important; }
.fusion-menu-item-button > a:hover > .button-default { background: #1e4f86; }

/* Mobile menu icons — hidden on desktop */
.fusion-mobile-menu-icons { display: none; }

@media (max-width: 900px) {
  .fusion-menu.fusion-middle-logo-ul { flex-wrap: wrap; justify-content: center; }
  .fusion-menu.fusion-middle-logo-ul > li > a.fusion-top-level-link { padding: 15px 12px; font-size: 11px; }
  .fusion-middle-logo-menu-logo { width: 100%; justify-content: center; padding: 10px; order: -1; }
  .fusion-standard-logo { height: 70px; }
}

/* ---------- Hero / sections ---------- */
/* Reset Avada's "width-100 + negative-margin bleed" trick. The original theme
   relies on #main having 30px padding and .fusion-fullwidth having -30px margin
   to cancel out. We use a simpler, overflow-safe setup: no padding, no neg-margin. */
#main {
  padding: 0 !important;
  margin: 0;
}
/* Only the OUTER fusion-row (direct child of #main) goes full-width.
   Nested .fusion-builder-row.fusion-row keeps the 1200px cap for content. */
#main > .fusion-row { max-width: none; padding: 0; width: 100%; }
.fusion-fullwidth,
.width-100 .fusion-fullwidth,
.fullwidth-box {
  margin-left: 0 !important;
  margin-right: 0 !important;
  width: 100%;
  max-width: 100vw;
}

.post-content > .fusion-fullwidth {
  min-height: 200px;
}

.fusion-title { margin: 0; }
.fusion-title-center h2,
.title-heading-center {
  text-align: center;
  margin: 0;
}

.fusion-text h2 { text-align: center; color: #fff; font-size: 34px; margin: 0 0 25px; letter-spacing: 1px; }
.fusion-text p  { font-size: 15px; color: #c9c9c9; max-width: 900px; margin-left: auto; margin-right: auto; }

/* Dark section variant: any section with dark-ish inline bg-color */
.fullwidth-box { color: #d9d9d9; }
.fullwidth-box h2 { color: #fff; }

/* Separator */
.fusion-separator { width: 100%; }
.fusion-sep-clear { clear: both; }
.fusion-separator.sep-single.sep-solid {
  border-top: 1px solid #2869b0;
}

/* ---------- Buttons ---------- */
.fusion-button-wrapper { margin: 10px 0; }
.fusion-aligncenter, .fusion-button-wrapper.fusion-aligncenter { text-align: center; }

.fusion-button {
  display: inline-block;
  padding: 16px 42px;
  background: #2869b0;
  color: #fff;
  border: 1px solid #2869b0;
  border-radius: 0;
  font-size: 13px;
  letter-spacing: 2px;
  text-transform: uppercase;
  font-weight: 700;
  text-decoration: none;
  cursor: pointer;
  line-height: 1;
  transition: all .2s;
}
.fusion-button:hover {
  background: transparent;
  color: #2869b0;
}
.button-xlarge { padding: 20px 54px; font-size: 15px; }
.button-large  { padding: 14px 32px; font-size: 13px; }
.fusion-button-text { color: inherit; font: inherit; }

.button-default {
  background: transparent;
  border: 1px solid #fff;
  color: #fff;
}
.button-default:hover { background: #fff; color: #222; }

/* ---------- Content-boxes grid (CLASSES / CAMPS / WORKSHOPS / PARTIES) ---------- */
.fusion-content-boxes {
  display: flex;
  flex-wrap: wrap;
  margin: 0;
  padding: 0;
}
.content-box-column {
  padding: 0;
  text-align: center;
  box-sizing: border-box;
  display: flex;
}
.col-lg-6 { flex: 0 0 50%; max-width: 50%; }
.content-box-column .col {
  width: 100%;
  padding: 60px 20px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-height: 220px;
  transition: background-color .2s;
}
.content-box-column:hover .col {
  background-color: rgba(0,0,0,.65) !important;
}
.content-box-column .heading {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.content-box-column .heading .icon {
  margin-bottom: 20px;
}
.content-box-column .heading .icon i {
  font-size: 70px !important;
  line-height: 1;
  color: #fff !important;
  display: block;
}
.content-box-heading {
  color: #fff !important;
  text-transform: uppercase;
  letter-spacing: 2px;
  font-weight: 700;
  margin: 0;
}
.content-box-column .heading-link { text-decoration: none; }

/* ---------- Modal (Contact Us popup) ---------- */
.fusion-modal {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.7);
  z-index: 2000;
  overflow-y: auto;
}
.fusion-modal.show { display: block; }
.fusion-modal .modal-dialog {
  max-width: 900px;
  margin: 60px auto;
}
.fusion-modal .modal-content {
  border-radius: 2px;
  padding: 30px;
  color: #fff;
}
.fusion-modal .modal-title { margin: 0; color: #fff; }
.fusion-modal .close {
  float: right;
  background: none;
  border: 0;
  font-size: 28px;
  color: #fff;
  cursor: pointer;
}
.fusion-modal-content .imageframe-align-center { text-align: center; margin-bottom: 20px; }

/* ---------- Footer ---------- */
.fusion-footer { background: #1e2124; }
.fusion-footer-widget-area {
  padding: 60px 0 30px;
  color: #e0e0e0;
  text-align: center;
}
.fusion-footer-widget-area .textwidget { text-align: center; }
.fusion-footer-widget-column img { max-width: 300px; height: auto; }

.fusion-footer-copyright-area {
  background: #141414;
  padding: 18px 0;
  color: #888;
  font-size: 12px;
}
.fusion-copyright-content {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 15px;
}
.fusion-copyright-notice { flex: 1; text-align: left; }
.fusion-copyright-notice a { color: #888; }

/* Social icons — brand icons via FA5 */
.fusion-social-links-footer .fusion-social-networks-wrapper {
  display: flex;
  gap: 6px;
  align-items: center;
}
.fusion-social-network-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 34px;
  height: 34px;
  background: #2869b0;
  color: #fff;
  border-radius: 2px;
  text-decoration: none;
  font-size: 14px;
  transition: opacity .2s;
}
.fusion-social-network-icon:hover { opacity: .8; }
.fusion-social-network-icon::before {
  font-family: "Font Awesome 5 Brands";
  font-weight: 400;
  display: inline-block;
}
.fusion-icon-facebook::before  { content: "\f39e"; }
.fusion-icon-youtube::before   { content: "\f167"; }
.fusion-icon-twitter::before   { content: "\f099"; }
.fusion-icon-instagram::before { content: "\f16d"; }

/* ---------- Hero typography overrides (inline HTML already sets H2 color white + 75px) ---------- */
h2.title-heading-center {
  text-shadow: 0 2px 12px rgba(0,0,0,.6);
}

/* ---------- Misc Avada imageframe / columns ---------- */
.fusion-imageframe { display: inline-block; }
.imageframe-align-center { text-align: center; }
.img-responsive { max-width: 100%; height: auto; }

.fusion-column-content-centered {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  height: 100%;
  text-align: center;
}

/* Fusion-blend-mode wrapper w/ equal-height columns */
.fusion-equal-height-columns .fusion-layout-column .fusion-column-wrapper {
  min-height: 100%;
}

/* Phone link in contact modal */
.modal-content a[href^="tel:"] { color: #2869b0; }

/* ---------- Responsive tweaks ---------- */
@media (max-width: 768px) {
  h2.title-heading-center { font-size: 38px !important; line-height: 1.1 !important; }
  .fusion-layout-column { float: none !important; width: 100% !important; margin-right: 0 !important; }
  .col-lg-6 { flex: 0 0 100%; max-width: 100%; }
  .fusion-copyright-content { flex-direction: column; text-align: center; }
  .fusion-copyright-notice { text-align: center; }
}
