/* ==========================================================================
   AIM Mobile Hamburger Dropdown — FINAL
   Mobile-only. Fixes invisible/blank dropdown panel by using a fixed menu
   below the mobile header instead of an absolute panel that can be clipped.
   Desktop is untouched.
   ========================================================================== */

@media (max-width: 980px) {
  body .site-header {
    position: sticky !important;
    top: 0 !important;
    z-index: 500 !important;
    background: #ffffff !important;
    overflow: visible !important;
    border-bottom: 1px solid rgba(79, 163, 217, 0.16) !important;
    box-shadow: 0 8px 20px rgba(4, 34, 73, 0.055) !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
  }

  body .site-header .nav-container,
  body .site-header .header-inner {
    position: relative !important;
    width: min(100% - 24px, var(--container, 1180px)) !important;
    min-height: 0 !important;
    padding: 12px 0 10px !important;
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) 52px !important;
    grid-template-rows: auto auto !important;
    grid-template-areas:
      "brand toggle"
      "cta cta" !important;
    gap: 10px 12px !important;
    align-items: center !important;
    overflow: visible !important;
  }

  body .site-header .brand,
  body .site-header .logo-link {
    grid-area: brand !important;
    justify-self: start !important;
    align-self: center !important;
    min-width: 0 !important;
    max-width: 100% !important;
    overflow: visible !important;
  }

  body .site-header .brand-logo,
  body .site-header .logo {
    width: min(230px, calc(100vw - 96px)) !important;
    max-width: min(230px, calc(100vw - 96px)) !important;
    height: auto !important;
  }

  body .site-header .main-nav,
  body .site-header .primary-nav {
    display: none !important;
  }

  body .site-header .mobile-menu-toggle,
  body .site-header button.mobile-menu-toggle,
  body .site-header button[aria-controls="mobile-menu"] {
    grid-area: toggle !important;
    justify-self: end !important;
    align-self: center !important;
    position: relative !important;
    inset: auto !important;
    z-index: 650 !important;

    display: grid !important;
    visibility: visible !important;
    opacity: 1 !important;
    pointer-events: auto !important;

    width: 50px !important;
    height: 50px !important;
    min-width: 50px !important;
    min-height: 50px !important;
    padding: 0 !important;

    place-items: center !important;
    border: 1px solid rgba(79, 163, 217, 0.24) !important;
    border-radius: 15px !important;
    background: #ffffff !important;
    color: var(--aim-blue, #042249) !important;
    box-shadow: 0 10px 24px rgba(4, 34, 73, 0.14) !important;
    cursor: pointer !important;
  }

  body .site-header .mobile-menu-toggle span,
  body .site-header .mobile-menu-toggle span::before,
  body .site-header .mobile-menu-toggle span::after {
    content: "" !important;
    display: block !important;
    width: 25px !important;
    height: 2px !important;
    border-radius: 999px !important;
    background: currentColor !important;
    opacity: 1 !important;
    transition: transform 180ms ease, opacity 180ms ease, top 180ms ease !important;
  }

  body .site-header .mobile-menu-toggle span {
    position: relative !important;
  }

  body .site-header .mobile-menu-toggle span::before,
  body .site-header .mobile-menu-toggle span::after {
    position: absolute !important;
    left: 0 !important;
  }

  body .site-header .mobile-menu-toggle span::before {
    top: -8px !important;
  }

  body .site-header .mobile-menu-toggle span::after {
    top: 8px !important;
  }

  body.menu-open .site-header .mobile-menu-toggle span {
    background: transparent !important;
  }

  body.menu-open .site-header .mobile-menu-toggle span::before {
    top: 0 !important;
    transform: rotate(45deg) !important;
  }

  body.menu-open .site-header .mobile-menu-toggle span::after {
    top: 0 !important;
    transform: rotate(-45deg) !important;
  }

  body .site-header .nav-container > .nav-cta,
  body .site-header .header-inner > .nav-cta,
  body .site-header > .nav-cta {
    grid-area: cta !important;
    grid-column: 1 / -1 !important;
    grid-row: 2 !important;
    display: flex !important;
    width: 100% !important;
    min-height: 44px !important;
    margin: 0 !important;
    align-items: center !important;
    justify-content: center !important;
    border-radius: 999px !important;
    background: var(--aim-olive-900, #4f5d3c) !important;
    border: 1px solid var(--aim-olive-900, #4f5d3c) !important;
    color: #ffffff !important;
    font-size: 12px !important;
    font-weight: 850 !important;
    letter-spacing: 0.07em !important;
    text-transform: uppercase !important;
  }

  /* Fixed dropdown below mobile header. This prevents clipping and blank panels. */
  body .site-header .mobile-menu {
    position: fixed !important;
    top: 154px !important;
    right: 12px !important;
    left: auto !important;
    width: min(360px, calc(100vw - 24px)) !important;
    max-height: calc(100svh - 170px) !important;
    overflow-y: auto !important;

    z-index: 640 !important;
    display: block !important;
    padding: 14px !important;
    border: 1px solid rgba(79, 163, 217, 0.18) !important;
    border-radius: 24px !important;
    background: #ffffff !important;
    box-shadow: 0 28px 70px rgba(4, 34, 73, 0.25) !important;

    opacity: 0 !important;
    visibility: hidden !important;
    pointer-events: none !important;
    transform: translateY(-8px) scale(0.985) !important;
    transform-origin: top right !important;
    transition: opacity 170ms ease, transform 170ms ease, visibility 170ms ease !important;
  }

  body .site-header .mobile-menu.is-open,
  body.menu-open .site-header .mobile-menu {
    opacity: 1 !important;
    visibility: visible !important;
    pointer-events: auto !important;
    transform: translateY(0) scale(1) !important;
  }

  body .site-header .mobile-menu-header,
  body .site-header .mobile-menu .nav-cta {
    display: none !important;
  }

  body .site-header .mobile-menu a:not(.nav-cta) {
    display: flex !important;
    align-items: center !important;
    min-height: 54px !important;
    padding: 0 16px !important;
    border-bottom: 1px solid rgba(4, 34, 73, 0.08) !important;
    background: #ffffff !important;
    color: var(--aim-blue, #042249) !important;
    font-family: var(--font-body, Inter, Arial, sans-serif) !important;
    font-size: 17px !important;
    font-weight: 750 !important;
    line-height: 1.2 !important;
    text-decoration: none !important;
  }

  body .site-header .mobile-menu a:not(.nav-cta)::before {
    content: "" !important;
    width: 9px !important;
    height: 9px !important;
    margin-right: 14px !important;
    border-radius: 50% !important;
    background: var(--aim-olive-900, #4f5d3c) !important;
    opacity: 0.75 !important;
    flex: 0 0 auto !important;
  }

  body .site-header .mobile-menu a:not(.nav-cta):last-of-type {
    border-bottom: 0 !important;
  }

  body .site-header .mobile-menu a.active,
  body .site-header .mobile-menu a[aria-current="page"],
  body .site-header .mobile-menu a:hover,
  body .site-header .mobile-menu a:focus-visible {
    color: var(--aim-olive-900, #4f5d3c) !important;
    background: var(--aim-sky-soft, #eaf5fb) !important;
    border-radius: 14px !important;
  }
}

@media (max-width: 430px) {
  body .site-header .nav-container,
  body .site-header .header-inner {
    width: min(100% - 20px, var(--container, 1180px)) !important;
    grid-template-columns: minmax(0, 1fr) 48px !important;
  }

  body .site-header .mobile-menu-toggle,
  body .site-header button.mobile-menu-toggle,
  body .site-header button[aria-controls="mobile-menu"] {
    width: 48px !important;
    height: 48px !important;
    min-width: 48px !important;
    min-height: 48px !important;
  }

  body .site-header .brand-logo,
  body .site-header .logo {
    width: min(215px, calc(100vw - 88px)) !important;
    max-width: min(215px, calc(100vw - 88px)) !important;
  }

  body .site-header .mobile-menu {
    top: 150px !important;
    right: 10px !important;
    width: calc(100vw - 20px) !important;
    border-radius: 22px !important;
  }
}
