/**
 * Fix fixed header overlap (transparent header + low z-index vs hero / AOS).
 * Load after main.css. (Top contact bar removed — offset matches branding + nav only.)
 */
:root {
  /* Match fixed header height (~.branding min 64px + vertical padding 20px) */
  --cw-header-offset: 5.5rem;
}

/* Custom site logo in header only (Admin → Website upload) */
.site-logo-img--header,
#header.header .logo img {
  max-height: 48px;
  width: auto;
  height: auto;
  max-width: min(200px, 36vw);
  display: block;
  object-fit: contain;
}

#header.header .logo h1.sitename {
  font-size: 1.35rem;
}

#header.header .branding {
  min-height: 64px;
  padding: 10px 0;
}

#header.header {
  z-index: 1040;
  background-color: #ffffff;
  --background-color: #ffffff;
}

#header.header .branding {
  background-color: #ffffff;
}

/* Logo + nav aligned from the left; space between logo and menu */
#header.header .header-nav-row {
  justify-content: flex-start;
  flex-wrap: wrap;
  row-gap: 0.75rem;
}

#header.header .header-nav-row .logo {
  flex-shrink: 0;
  margin-right: 0;
}

#header.header .header-nav-row .navmenu {
  flex: 1 1 auto;
  min-width: 0;
  margin-left: 2.5rem;
}

@media (min-width: 768px) {
  #header.header .header-nav-row .navmenu {
    margin-left: 4rem;
  }
}

@media (min-width: 1200px) {
  #header.header .header-nav-row .navmenu {
    margin-left: 5.5rem;
  }
}

/* All pages: clear fixed header (logo + nav) */
body main.main {
  padding-top: var(--cw-header-offset);
}

/* Inner titles already had extra top padding for the old header guess — remove double gap */
body:not(.index-page) .page-title {
  padding-top: 0;
}

/* Home hero: flush under menu — no global section top padding; fill viewport below header */
body.index-page .hero.section {
  min-height: calc(100svh - var(--cw-header-offset));
  padding-top: 0;
  padding-bottom: 60px;
}

/* Compact top nav — avoids overflow when many links are present */
@media (min-width: 1200px) {
  .navmenu > ul > li {
    padding: 15px 9px;
  }

  .navmenu a,
  .navmenu a:focus {
    font-size: 14px;
  }
}

/* Services mega menu (merged treatment categories) */
@media (min-width: 1200px) {
  .navmenu .dropdown-mega > ul {
    width: min(920px, calc(100vw - 2rem));
    padding: 14px 6px 18px;
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 4px 8px;
    left: 0;
    right: auto;
  }

  .navmenu .dropdown-mega > ul > li.mega-menu-col {
    min-width: 0;
    position: static;
  }

  .navmenu .dropdown-mega .mega-menu-category {
    display: block;
    font-weight: 600;
    color: var(--heading-color);
    padding: 6px 14px 4px;
    white-space: normal;
  }

  .navmenu .dropdown-mega .mega-menu-category:before {
    display: none;
  }

  .navmenu .dropdown-mega .mega-menu-treatments {
    position: static;
    visibility: visible;
    opacity: 1;
    display: block;
    margin: 0;
    padding: 0 0 8px;
    background: transparent;
    box-shadow: none;
    border-radius: 0;
  }

  .navmenu .dropdown-mega .mega-menu-treatments li {
    min-width: 0;
  }

  .navmenu .dropdown-mega .mega-menu-treatments a {
    padding: 5px 14px;
    font-size: 13px;
    font-weight: 400;
    white-space: normal;
    line-height: 1.35;
  }

  .navmenu .dropdown-mega .mega-menu-treatments a:before {
    display: none;
  }

  .navmenu .dropdown-mega .mega-menu-view-all {
    font-weight: 600;
    color: var(--accent-color);
  }
}

@media (max-width: 1199px) {
  .navmenu .dropdown-mega .mega-menu-col {
    border-bottom: 1px solid color-mix(in srgb, var(--default-color), transparent 92%);
  }

  .navmenu .dropdown-mega .mega-menu-col:last-child {
    border-bottom: 0;
  }

  .navmenu .dropdown-mega .mega-menu-category {
    font-weight: 600;
    color: var(--heading-color);
  }

  .navmenu .dropdown-mega .mega-menu-treatments {
    display: block;
    position: static;
    visibility: visible;
    opacity: 1;
    padding: 0 0 8px;
    margin: 0 12px 8px 20px;
    background: transparent;
    box-shadow: none;
  }

  .navmenu .dropdown-mega .mega-menu-treatments a {
    font-size: 15px;
    font-weight: 400;
    white-space: normal;
    padding: 6px 12px;
  }
}
