.site-header {
  position: relative;
  width: 100%;
  box-sizing: border-box;
  z-index: 100;
}

.site-header *,
.site-header *::before,
.site-header *::after {
  box-sizing: border-box;
}

/* ── Theme: Light ────────────────────────────────── */

.site-header--light {
  --_sh-bg: var(--white, #ffffff);
  --_sh-text: var(--primary-600, #1B365F);
  --_sh-border: var(--neutral-300, #d7d2cd);
  /* Always fixed so toggling scroll states never causes a layout shift */
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
}

/* ── Theme: Transparent ──────────────────────────── */

.site-header--transparent {
  --_sh-bg: transparent;
  --_sh-text: var(--white, #ffffff);
  --_sh-border: transparent;
}

/* Transparent → Light transition when dropdown open or sticky */
.site-header--transparent.site-header--dropdown-open,
.site-header--transparent.site-header--sticky {
  --_sh-bg: var(--white, #ffffff);
  --_sh-text: var(--primary-600, #1B365F);
  --_sh-border: var(--neutral-300, #d7d2cd);
}

.site-header--transparent .site-header__bar {
  transition: background-color 300ms ease, color 300ms ease, border-color 300ms ease;
}

/* Gradient overlay for transparent header at top */
.site-header--transparent .site-header__bar::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(0, 0, 0, 0.25) 0%, rgba(0, 0, 0, 0.07) 66.67%, rgba(0, 0, 0, 0) 100%);
  opacity: 1;
  transition: opacity 300ms ease;
  pointer-events: none;
  z-index: -1;
}

/* Progressive background blur — 10px at top fading to 0px at bottom */
.site-header--transparent .site-header__bar::after {
  content: '';
  position: absolute;
  inset: 0;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  mask-image: linear-gradient(180deg, black 0%, transparent 100%);
  -webkit-mask-image: linear-gradient(180deg, black 0%, transparent 100%);
  pointer-events: none;
  z-index: -2;
  opacity: 1;
  transition: opacity 300ms ease;
}

/* Hide gradient and blur when transitioning to light (dropdown open or sticky) */
.site-header--transparent.site-header--dropdown-open .site-header__bar::before,
.site-header--transparent.site-header--sticky .site-header__bar::before,
.site-header--transparent.site-header--dropdown-open .site-header__bar::after,
.site-header--transparent.site-header--sticky .site-header__bar::after {
  opacity: 0;
}

.site-header--transparent .site-header__dealer-btn {
  transition: background-color 300ms ease, color 300ms ease, opacity 200ms ease;
}

/* Dealer button colors for transparent theme */
.site-header--transparent:not(.site-header--dropdown-open):not(.site-header--sticky) .site-header__dealer-btn {
  background: var(--white, #ffffff);
  color: var(--_theme---btn-text-secondary, #1B365F);
}

@media (hover: hover) and (pointer: fine) {
  .site-header--transparent:not(.site-header--dropdown-open):not(.site-header--sticky) .site-header__dealer-btn:hover {
    background: var(--_theme---btn-bg-secondary-hover, #1B365F);
    color: var(--_theme---btn-text-secondary-hover, #ffffff);
    border-color: var(--_theme---btn-bg-secondary-hover, #1B365F);
  }
}

/* ── Scroll States ───────────────────────────────── */


.site-header--transparent.site-header--at-top {
  position: absolute;
}

.site-header--light.site-header--scrolled{
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  transform: translateY(-100%);
  transition: transform 300ms ease;

}

.site-header--scrolled {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  transform: translateY(-100%);
}


/* Light at-top inherits position:fixed from .site-header--light.
   Transparent at-top is position:absolute (set above). */

.site-header--hidden {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  transform: translateY(-100%);
  transition: transform 300ms ease;

}

.site-header--sticky {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  transform: translateY(0);
  transition: transform 300ms ease;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
}

/* ── Bar ──────────────────────────────────────────── */

.site-header__bar {
  width: 100%;
  padding-right: max(
    var(--_spacing---container-padding),
    calc((100vw - var(--_spacing---container-lg)) / 2 + var(--_spacing---container-padding))
  );
  padding-left: max(
    var(--_spacing---container-padding),
    calc((100vw - var(--_spacing---container-lg)) / 2 + var(--_spacing---container-padding))
  );
  display: flex;
  align-items: center;
  height: 80px;
  gap: var(--_spacing---spacing-md, 24px);
  background: var(--_sh-bg);
  border-bottom: 1px solid var(--_sh-border);
  position: relative;
  z-index: 100;
}

/* ── Logo ─────────────────────────────────────────── */

.site-header__logo {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  text-decoration: none;
  color: var(--_sh-text);
}

.site-header__logo-img {
  height: 28px;
  width: auto;
  display: block;
}

/* When both logo variants exist, show based on theme */
.site-header--light .site-header__logo-img--transparent,
.site-header--transparent.site-header--dropdown-open .site-header__logo-img--transparent,
.site-header--transparent.site-header--sticky .site-header__logo-img--transparent {
  display: none;
}

.site-header--transparent:not(.site-header--dropdown-open):not(.site-header--sticky) .site-header__logo-img--light {
  display: none;
}

.site-header__logo-text {
  font-family: var(--_typography---font-heading, 'Gelasio Custom', Georgia, serif);
  font-weight: var(--_typography---font-weight-semibold-heading, 550);
  font-size: var(--_typography---text-h5, 1.5rem);
  line-height: var(--_typography---line-height-heading, 1.2);
  color: var(--_sh-text);
}

/* ══════════════════════════════════════════════════════
   Nav — always in DOM. Desktop = inline flex child.
   Mobile = fixed full-screen overlay via CSS.
   ══════════════════════════════════════════════════════ */

.site-header__nav {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;

  height: 100%;
}

/* Mobile-only chrome hidden on desktop */
.site-header__nav-header,
.site-header__nav-footer,
.site-header__nav-subheader {
  display: none;
}

/* Nav body is a flex container. Any Webflow wrapper elements (slot divs,
   code-islands) between nav-body and .nav-item are flattened to
   display:contents via useLayoutEffect in SiteHeader.tsx.
   The CSS rules below pre-flatten wrappers on first paint to prevent FOUC
   (items stacking vertically before JS hydration). */
.site-header__nav-body {
  flex: 1;
  display: flex;
  align-items: center;
  gap: var(--_spacing---spacing-lg, 32px);
  height: 100%;
}

/* Pre-flatten Webflow wrapper divs via CSS (up to 2 levels deep).
   JS MutationObserver handles deeper nesting and dynamic content. */
.site-header__nav-body> :not(.nav-item):not(.nav-item__mobile-row):not(.nav-item__mobile-sub):not(.site-header__mobile-only):not(code-island):not(slot),
.site-header__nav-body> :not(.nav-item):not(.nav-item__mobile-row):not(.nav-item__mobile-sub):not(.site-header__mobile-only):not(code-island):not(slot)> :not(.nav-item):not(.nav-item__mobile-row):not(.nav-item__mobile-sub):not(.site-header__mobile-only):not(code-island):not(slot) {
  display: contents;
}

/* Flatten slotted wrappers projected through Shadow DOM slots */
.site-header__nav-body>slot[name="children"]::slotted(:not(code-island)) {
  display: contents;
}

.site-header__nav-body>slot[name="children"] {
  flex: 1;
  display: flex;
  align-items: center;
  gap: var(--_spacing---spacing-lg, 32px);
  height: 100%;
  justify-content: center;
}

/* ── Actions ──────────────────────────────────────── */

.site-header__actions {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  gap: var(--_spacing---spacing-sm, 16px);
}

.site-header__dealer-btn {
  align-items: center;
  background-color: var(--_theme---btn-bg-primary, #1B365F);
  border-radius: var(--_spacing---radius-full, 100px);
  color: var(--_theme---btn-text-primary, #ffffff);
  display: flex;
  font-family: var(--_typography---font-body, 'Public Sans Custom', 'Helvetica Neue', Arial, sans-serif);
  font-size: var(--_typography---text-btn-sm, 16px);
  font-weight: var(--_typography---font-weight-bold, 700);
  gap: var(--_spacing---btn-gap-sm, 6px);
  justify-content: center;
  line-height: 1;
  min-height: 36px;
  min-width: 100px;
  padding: var(--_spacing---btn-padding-v-sm, 8px) var(--_spacing---btn-padding-h-sm, 16px);
  transition: opacity .2s, color .3s, background-color .3s;
  text-decoration: none;
  white-space: nowrap;
  border: none;
  cursor: pointer;
}

.site-header__search-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  padding: 0;
  background: none;
  border: none;
  cursor: pointer;
  color: var(--_sh-text);
  border-radius: var(--_spacing---radius-full, 12px);
  transition: background-color 0.2s ease;
}

/* ── Search bar ──────────────────────────────────── */

.site-header__search-bar {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 80px;
  padding: 0 var(--_spacing---container-padding, 96px);
  background: var(--white, #ffffff);
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  z-index: 101;
  opacity: 0;
  pointer-events: none;
  transform: translateY(-8px);
  transition: opacity 250ms ease, transform 250ms ease;
}

.site-header--search-open .site-header__search-bar {
  opacity: 1;
  pointer-events: auto;
  transform: translateY(0);
}

.site-header__bar {
  transition: opacity 200ms ease;
}

.site-header--search-open .site-header__bar {
  opacity: 0;
  pointer-events: none;
}

.site-header__search-container {
  display: flex;
  align-items: center;
  gap: 16px;
  width: 100%;
  max-width: 720px;
  transform: scaleX(0.92);
  transition: transform 300ms cubic-bezier(0.2, 0.8, 0.2, 1);
}

.site-header--search-open .site-header__search-container {
  transform: scaleX(1);
}

.site-header__search-input-wrapper {
  display: flex;
  align-items: center;
  flex: 1;
  border: 1px solid var(--primary-600, #1B365F);
  border-radius: var(--_spacing---radius-md, 4px);
  background: var(--white, #ffffff);
  padding: 14px 16px;
  gap: 10px;
  transition: box-shadow 200ms ease;
}

.site-header__search-input-wrapper:focus-within {
  box-shadow: 0 0 0 3px var(--primary-100, rgba(134, 172, 222, 0.6));
}

.site-header__search-input {
  flex: 1;
  border: none;
  outline: none;
  background: transparent;
  font-family: var(--_typography---font-body, 'Public Sans Custom', 'Helvetica Neue', Arial, sans-serif);
  font-weight: 550;
  font-size: var(--_typography---text-paragraph-sm, 1rem);
  line-height: 20px;
  color: var(--primary-600, #1B365F);
  min-width: 0;
}

.site-header__search-input::placeholder {
  color: var(--neutral-500, #75706b);
  font-weight: 550;
}

.site-header__search-submit {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 20px;
  height: 20px;
  padding: 0;
  background: none;
  border: none;
  cursor: pointer;
  color: var(--primary-600, #1B365F);
  flex-shrink: 0;
}

.site-header__search-cancel {
  display: inline-flex;
  align-items: center;
  padding: 0 0 4px;
  background: none;
  border: none;
  border-bottom: 1px solid var(--primary-600, #1B365F);
  cursor: pointer;
  font-family: var(--_typography---font-body, 'Public Sans Custom', 'Helvetica Neue', Arial, sans-serif);
  font-weight: var(--_typography---font-weight-bold, 700);
  font-size: var(--_typography---text-paragraph-sm, 1rem);
  line-height: 1;
  color: var(--primary-600, #1B365F);
  white-space: nowrap;
  flex-shrink: 0;
}

@media (hover: hover) and (pointer: fine) {
  .site-header__dealer-btn:hover {
    border-color: var(--_theme---btn-bg-primary-hover, #1B365F);
    background-color: var(--_theme---btn-bg-primary-hover, #1B365F);
    color: var(--_theme---btn-text-primary-hover, #ffffff);
  }

  .site-header__search-btn:hover {
    background: rgba(0, 0, 0, 0.05);
  }

  .site-header--transparent:not(.site-header--dropdown-open):not(.site-header--sticky) .site-header__search-btn:hover {
    background: var(--_theme---btn-bg-secondary-hover, #ffffff);
    border-color: var(--_theme---btn-bg-secondary-hover, #ffffff);
    color: var(--_theme---btn-text-secondary-hover, #1B365F);
  }

  .site-header__search-cancel:hover {
    opacity: 0.7;
  }
}

/* When search is open, force light theme visuals */
.site-header--search-open {
  --_sh-bg: var(--white, #ffffff);
  --_sh-text: var(--primary-600, #1B365F);
  --_sh-border: var(--neutral-300, #d7d2cd);
}

/* ── Hamburger — hidden on desktop ────────────────── */

.site-header__hamburger {
  display: none;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  padding: 0;
  background: none;
  border: none;
  cursor: pointer;
  color: var(--_sh-text);
}

/* ── Desktop Backdrop ─────────────────────────────── */

.site-header__backdrop {
  height: 100dvh;
  position: fixed;
  inset: 0;
  z-index: 90;
  background: rgba(0, 0, 0, 0.3);
}

/* ── Mobile overlay internals ─────────────────────── */

.site-header__mobile-close,
.site-header__mobile-back {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  padding: 0;
  background: none;
  border: none;
  cursor: pointer;
  color: var(--primary-600, #1B365F);
  flex-shrink: 0;
}

.site-header__mobile-header-spacer {
  width: 40px;
  height: 40px;
  flex-shrink: 0;
}

.site-header__mobile-title {
  flex: 1;
  font-family: var(--_typography---font-heading, 'Gelasio Custom', Georgia, serif);
  font-weight: var(--_typography---font-weight-semibold-heading, 550);
  font-size: var(--_typography---text-h5, 1.5rem);
  line-height: var(--_typography---line-height-heading, 1.2);
  color: var(--primary-600, #1B365F);
  text-decoration: none;
  display: flex;
  align-items: center;
  justify-content: center;
}

.site-header__mobile-dealer {
  align-items: center;
  background: var(--primary-600, #1B365F);
  border-radius: var(--_spacing---radius-full, 100px);
  color: var(--white, #ffffff);
  display: flex;
  font-family: var(--_typography---font-body, 'Public Sans Custom', 'Helvetica Neue', Arial, sans-serif);
  font-size: 1.125rem;
  font-weight: var(--_typography---font-weight-bold, 700);
  gap: var(--_spacing---btn-gap-sm, 6px);
  justify-content: center;
  line-height: 1;
  padding: 14px 24px;
  text-align: center;
  text-decoration: none;
}

/* ── Staggered mobile item load-in ─────────────────── */

.site-header__nav--open .nav-item__mobile-row {
  animation: mobile-item-slide-in 300ms ease both;
}

.site-header__nav--open .nav-item__mobile-row:nth-child(1) {
  animation-delay: 100ms;
}

.site-header__nav--open .nav-item__mobile-row:nth-child(2) {
  animation-delay: 150ms;
}

.site-header__nav--open .nav-item__mobile-row:nth-child(3) {
  animation-delay: 200ms;
}

.site-header__nav--open .nav-item__mobile-row:nth-child(4) {
  animation-delay: 250ms;
}

.site-header__nav--open .nav-item__mobile-row:nth-child(5) {
  animation-delay: 300ms;
}

.site-header__nav--open .nav-item__mobile-row:nth-child(6) {
  animation-delay: 350ms;
}

@keyframes mobile-item-slide-in {
  from {
    opacity: 0;
    transform: translateY(12px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* ── Mobile-only utility ──────────────────────────── */



.site-header__mobile-only {
  display: none;
}

/* ── Focus visible ────────────────────────────────── */

.site-header button:focus-visible,
.site-header a:focus-visible {
  outline: 2px solid var(--primary-600, #1B365F);
  outline-offset: 2px;
}

.site-header--transparent:not(.site-header--dropdown-open):not(.site-header--sticky) button:focus-visible,
.site-header--transparent:not(.site-header--dropdown-open):not(.site-header--sticky) a:focus-visible {
  outline-color: var(--white, #ffffff);
}

/* ══════════════════════════════════════════════════════
   Responsive: 992–1299px condensed desktop
   ══════════════════════════════════════════════════════ */

@media (min-width: 992px) and (max-width: 1299px) {
  .site-header__bar {
    padding: 0 var(--_spacing---spacing-lg, 32px);
    gap: var(--_spacing---spacing-sm, 16px);
  }

  .site-header__nav-body {
    gap: var(--_spacing---spacing-md, 24px);
  }

  .site-header__logo-img {
    height: 20px;
  }

  .site-header__search-bar {
    padding: 0 var(--_spacing---spacing-lg, 32px);
  }

  .site-header__dealer-text {
    display: none;
  }

  .site-header__dealer-text {
    line-height: 1;
  }

  .site-header__dealer-btn {
    width: 40px;
    height: 40px;
    min-width: unset;
    min-height: unset;
    padding: 0;
    border-radius: 50%;
  }
}

/* ══════════════════════════════════════════════════════
   Responsive: mobile (≤991px)
   Nav becomes a fixed full-screen overlay.
   ══════════════════════════════════════════════════════ */

@media (max-width: 991px) {
  /* Keep the mobile header root untransformed so the fixed drawer stays
     anchored to the viewport after the sticky state kicks in. Use top-based
     hiding instead of transforms because the drawer lives inside the bar. */
  .site-header--hidden,
  .site-header--sticky {
    transform: none;
    transition: top 300ms ease, box-shadow 300ms ease;
  }

  .site-header--hidden {
    top: -56px;
    box-shadow: none;
    pointer-events: none;
  }

  .site-header--sticky {
    top: 0;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
  }

  .site-header__bar {
    justify-content: space-between;
    height: 56px;
    padding: 16px 20px;
    gap: 12px;
    transition:
      opacity 200ms ease,
      background-color 300ms ease,
      color 300ms ease,
      border-color 300ms ease;
  }

  /* Hide desktop-only elements */
  .site-header__dealer-btn {
    display: none;
  }

  .site-header__logo {
    left: 50%;
    position: absolute;
    top: 50%;
    transform: translate(-50%, -50%);
    z-index: 1;
  }

  .site-header__logo-img {
    height: 20px;
    max-width: 140px;
  }

  .site-header__logo-text {
    font-size: 1.125rem;
    white-space: nowrap;
  }

  /* Show hamburger */
  .site-header__hamburger {
    display: flex;
    order: -1;
    width: 24px;
    height: 24px;
    color: var(--_sh-text);
    flex-shrink: 0;
    position: relative;
    z-index: 2;
  }


  .site-header__nav-body-wrapper{
    display: flex;
    flex-direction: column;
    height: 100%;
    justify-content: space-between;
    overflow-y: auto;
  }

  /* Show mobile-only content slot */
  .site-header__mobile-only {
    border-top: 1px solid var(--neutral-300, #d7d2cd);
    display: flex;
    flex-direction: column;
    gap: var(--_spacing---stacked-component-sm, 32px);
    justify-content: space-between;
    padding: var(--_spacing---stacked-component-sm, 32px) var(--_spacing---container-padding, 24px);
  }

  .site-header__actions {
    margin-left: auto;
    gap: 0;
    position: relative;
    z-index: 2;
  }

  .site-header__search-btn {
    width: 24px;
    height: 24px;
    border-radius: 0;
  }

  .site-header__search-btn:hover {
    background: none;
  }

  /* ── Nav becomes fixed overlay ────────────────── */
  .site-header__nav {
    position: fixed;
    inset: 0;
    z-index: 200;
    background: var(--white, #ffffff);
    transform: translateY(-100%);
    transition: transform 400ms ease;
    /* Reset desktop flex layout */
    flex-direction: column;
    align-items: stretch;
    height: auto;
    /* override 100% from desktop */
    gap: 0;
    overflow: hidden;
  }

  .site-header__nav--open {
    transform: translateY(0);
  }

  /* ── Show mobile chrome ───────────────────────── */
  .site-header__nav-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    min-height: 56px;
    padding: 16px 20px;
    flex-shrink: 0;
    gap: 12px;
  }

  /* ── Blue subheader (submenu screens) ────────── */
  .site-header__nav-subheader {
    display: flex;
    align-items: center;
    justify-content: space-between;
    min-height: 48px;
    padding: 12px 20px;
    background: var(--primary-100, #c5dbf7);
    flex-shrink: 0;
    gap: 12px;
  }

  .site-header__nav-subheader-title {
    flex: 1;
    font-family: var(--_typography---font-heading, 'Gelasio Custom', Georgia, serif);
    font-weight: var(--_typography---font-weight-semibold-heading, 550);
    font-size: var(--_typography---text-h5, 1.25rem);
    line-height: var(--_typography---line-height-heading, 1.2);
    color: var(--primary-600, #1B365F);
    text-align: center;
  }

  .site-header__nav-footer {
    display: block;
    flex-shrink: 0;
  }

  /* ── Scrollable body for slot content ─────────── */
  .site-header__nav-body {
    display: flex;
    flex-direction: column;
    flex: 1;
    -webkit-overflow-scrolling: touch;
    padding: var(--_spacing---stacked-component-sm, 32px) var(--_spacing---container-padding, 24px);
  }

  .site-header__nav-body>slot[name="children"] {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    justify-content: flex-start;
    gap: 0;
    width: 100%;
    height: auto;
  }

  .site-header__mobile-close,
  .site-header__mobile-back,
  .site-header__mobile-header-spacer {
    width: 24px;
    height: 24px;
  }

  .site-header__mobile-title {
    justify-content: center;
    min-width: 0;
    text-align: center;
  }

  .site-header__mobile-title .site-header__logo-img {
    height: 20px;
    margin: 0 auto;
  }

  /* ── Search bar mobile ──────────────────────────── */
  .site-header__search-bar {
    padding: var(--_spacing---spacing-lg, 32px);
  }

}

