/* Final mobile navigation layer. It must load after all page styles. */
@media (max-width: 992px) {
  body.menu-open {
    overflow: hidden !important;
    overscroll-behavior: none;
  }

  body.menu-open .site-header {
    overflow: visible !important;
    z-index: 10020 !important;
  }

  .site-header .header-inner {
    overflow: visible !important;
  }

  .site-header .menu-toggle {
    position: relative !important;
    flex: 0 0 44px !important;
    z-index: 10022 !important;
  }

  .site-header .gnb,
  .site-header.site-header--hero .gnb,
  .site-header.site-header--compact .gnb {
    position: fixed !important;
    top: var(--ksl-mobile-menu-top, var(--header-h, 72px)) !important;
    right: -100% !important;
    bottom: auto !important;
    left: auto !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    justify-content: flex-start !important;
    gap: 0 !important;
    width: min(100%, 380px) !important;
    max-width: 100vw !important;
    height: var(--ksl-mobile-menu-height, calc(100dvh - var(--header-h, 72px))) !important;
    min-height: 0 !important;
    max-height: var(--ksl-mobile-menu-height, calc(100dvh - var(--header-h, 72px))) !important;
    margin: 0 !important;
    padding: 12px 0 calc(28px + env(safe-area-inset-bottom, 0px)) !important;
    overflow-x: hidden !important;
    overflow-y: auto !important;
    overscroll-behavior: contain;
    touch-action: pan-y !important;
    -webkit-overflow-scrolling: touch;
    color: var(--navy) !important;
    background: #fff !important;
    border: 0 !important;
    border-left: 1px solid var(--border-light) !important;
    border-radius: 0 !important;
    box-shadow: -16px 20px 48px rgba(7, 16, 31, 0.2) !important;
    transform: none !important;
    opacity: 1 !important;
    visibility: hidden !important;
    pointer-events: none !important;
    z-index: 10021 !important;
    transition: right 0.28s ease, visibility 0s linear 0.28s !important;
  }

  .site-header .gnb.open,
  .site-header.site-header--hero .gnb.open,
  .site-header.site-header--compact .gnb.open {
    right: 0 !important;
    visibility: visible !important;
    pointer-events: auto !important;
    transition-delay: 0s !important;
  }

  .site-header .gnb .nav-list,
  .site-header.site-header--hero .gnb .nav-list,
  .site-header.site-header--compact .gnb .nav-list {
    display: block !important;
    flex: 0 0 auto !important;
    width: 100% !important;
    height: auto !important;
    min-height: 0 !important;
    max-height: none !important;
    margin: 0 !important;
    padding: 0 14px !important;
    overflow: visible !important;
  }

  .site-header .gnb .nav-item,
  .site-header.site-header--hero .gnb .nav-item,
  .site-header.site-header--compact .gnb .nav-item {
    position: relative !important;
    display: block !important;
    width: 100% !important;
    height: auto !important;
    min-height: 0 !important;
    margin: 0 !important;
    padding: 3px 0 !important;
    overflow: visible !important;
    border: 0 !important;
    border-bottom: 1px solid var(--border-subtle) !important;
  }

  .site-header .gnb .nav-link,
  .site-header.site-header--hero .gnb .nav-link,
  .site-header.site-header--compact .gnb .nav-link {
    position: relative !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    width: 100% !important;
    height: auto !important;
    min-height: 50px !important;
    margin: 0 !important;
    padding: 13px 14px !important;
    color: var(--navy) !important;
    background: transparent !important;
    border: 0 !important;
    border-radius: 8px !important;
    font-size: 16px !important;
    font-weight: 800 !important;
    line-height: 1.4 !important;
    text-align: left !important;
    white-space: normal !important;
  }

  .site-header .gnb .nav-link::after {
    display: none !important;
  }

  .site-header .gnb .nav-link:hover,
  .site-header .gnb .nav-link:focus-visible,
  .site-header .gnb .nav-item.active > .nav-link,
  .site-header .gnb .menu-item-has-children.active > .nav-link {
    color: var(--navy) !important;
    background: rgba(184, 146, 74, 0.14) !important;
  }

  .site-header .gnb .nav-caret {
    flex: 0 0 auto;
    margin-left: 12px !important;
    color: var(--gold) !important;
    font-size: 12px !important;
    line-height: 1 !important;
    transition: transform 0.2s ease;
  }

  .site-header .gnb .nav-item.active > .nav-link .nav-caret,
  .site-header .gnb .menu-item-has-children.active > .nav-link .nav-caret {
    transform: rotate(180deg) !important;
  }

  .site-header .gnb .sub-menu,
  .site-header.site-header--hero .gnb .sub-menu,
  .site-header.site-header--compact .gnb .sub-menu {
    position: static !important;
    display: none !important;
    width: 100% !important;
    min-width: 0 !important;
    height: auto !important;
    margin: 2px 0 6px !important;
    padding: 6px !important;
    overflow: visible !important;
    opacity: 1 !important;
    visibility: visible !important;
    transform: none !important;
    background: var(--bg-warm) !important;
    border: 1px solid var(--border-subtle) !important;
    border-radius: 8px !important;
    box-shadow: none !important;
  }

  .site-header .gnb .nav-item.active > .sub-menu,
  .site-header .gnb .menu-item-has-children.active > .sub-menu {
    display: block !important;
  }

  .site-header .gnb .sub-menu li {
    display: block !important;
    width: 100% !important;
    height: auto !important;
    margin: 0 !important;
    padding: 0 !important;
    border: 0 !important;
  }

  .site-header .gnb .sub-menu a {
    display: flex !important;
    align-items: center !important;
    width: 100% !important;
    min-height: 46px !important;
    margin: 0 !important;
    padding: 11px 16px !important;
    color: var(--navy) !important;
    border: 0 !important;
    border-radius: 6px !important;
    font-size: 14px !important;
    font-weight: 700 !important;
    line-height: 1.45 !important;
  }

  .site-header .gnb .sub-menu a:hover,
  .site-header .gnb .sub-menu a:focus-visible {
    background: rgba(184, 146, 74, 0.14) !important;
  }

  .site-header .gnb .nav-cta,
  .site-header.site-header--hero .gnb .nav-cta,
  .site-header.site-header--compact .gnb .nav-cta {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    flex: 0 0 auto !important;
    width: calc(100% - 28px) !important;
    min-height: 50px !important;
    height: auto !important;
    margin: 18px 14px 0 !important;
    padding: 13px 18px !important;
    color: #fff !important;
    background: var(--navy) !important;
    border-radius: 8px !important;
    font-size: 15px !important;
    font-weight: 800 !important;
  }
}

@media (max-width: 640px) {
  .site-header .gnb,
  .site-header.site-header--hero .gnb,
  .site-header.site-header--compact .gnb {
    width: 100% !important;
    border-left: 0 !important;
  }
}

@media (prefers-reduced-motion: reduce) {
  .site-header .gnb {
    transition: none !important;
  }
}
