/* Nimble mobile navigation — exact Journal menu design, shared across every page */
@media (max-width: 980px) {
  body.menu-open { overflow: hidden !important; }

  .site-header {
    position: absolute !important;
    inset: 0 0 auto !important;
    z-index: 5000 !important;
    width: 100% !important;
    border: 0 !important;
    border-bottom: 1px solid rgba(31,42,68,.10) !important;
    background: #fff !important;
    box-shadow: 0 8px 25px rgba(17,26,45,.08) !important;
    -webkit-backdrop-filter: none !important;
    backdrop-filter: none !important;
  }

  .site-header .nav-wrap {
    display: flex !important;
    width: min(calc(100% - 2rem), 1200px) !important;
    min-height: 80px !important;
    margin-inline: auto !important;
    padding: 0 !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 1rem !important;
  }

  .site-header .brand {
    display: inline-flex !important;
    width: 145px !important;
    height: 46px !important;
    margin: 0 !important;
    padding: 0 !important;
    align-items: center !important;
    flex: 0 0 145px !important;
    text-decoration: none !important;
  }

  .site-header .brand img {
    display: block !important;
    width: 100% !important;
    height: 100% !important;
    margin: 0 !important;
    object-fit: contain !important;
    object-position: left center !important;
  }

  .site-header .desktop-nav { display: none !important; }

  .site-header .menu-toggle {
    position: relative !important;
    display: block !important;
    width: 48px !important;
    height: 48px !important;
    min-width: 48px !important;
    margin: 0 !important;
    padding: 0 !important;
    border: 1px solid #aeb8c8 !important;
    border-radius: 50% !important;
    background: #fff !important;
    color: #1f2a44 !important;
    box-shadow: none !important;
    cursor: pointer !important;
    appearance: none !important;
    -webkit-appearance: none !important;
  }

  .site-header .menu-toggle span,
  .site-header .menu-toggle::before,
  .site-header .menu-toggle::after {
    position: absolute !important;
    left: 50% !important;
    display: block !important;
    width: 19px !important;
    height: 1.7px !important;
    margin: 0 !important;
    padding: 0 !important;
    border: 0 !important;
    border-radius: 2px !important;
    background: currentColor !important;
    content: "" !important;
    transform: translateX(-50%) !important;
    transition: top .2s ease, transform .2s ease, opacity .2s ease !important;
  }

  .site-header .menu-toggle::before { top: 16px !important; }
  .site-header .menu-toggle span { top: 23px !important; }
  .site-header .menu-toggle::after { top: 30px !important; }

  .site-header .menu-toggle[aria-expanded="true"]::before {
    top: 23px !important;
    transform: translateX(-50%) rotate(45deg) !important;
  }
  .site-header .menu-toggle[aria-expanded="true"] span { opacity: 0 !important; }
  .site-header .menu-toggle[aria-expanded="true"]::after {
    top: 23px !important;
    transform: translateX(-50%) rotate(-45deg) !important;
  }

  .site-header .mobile-panel {
    position: absolute !important;
    top: 80px !important;
    right: 0 !important;
    left: 0 !important;
    z-index: 4999 !important;
    display: none !important;
    width: 100% !important;
    max-width: none !important;
    margin: 0 !important;
    padding: 1rem 1rem 1.45rem !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: #fff !important;
    box-shadow: 0 20px 35px rgba(17,26,45,.14) !important;
  }

  .site-header .mobile-panel.open { display: block !important; }

  .site-header .mobile-panel nav {
    display: grid !important;
    width: 100% !important;
    max-width: none !important;
    margin: 0 !important;
    padding: 0 !important;
    gap: 0 !important;
  }

  .site-header .mobile-panel a {
    display: flex !important;
    min-height: 47px !important;
    margin: 0 !important;
    padding: .78rem .82rem !important;
    align-items: center !important;
    border: 0 !important;
    border-radius: 10px !important;
    background: transparent !important;
    color: #1f2a44 !important;
    font-family: "Montserrat", Arial, sans-serif !important;
    font-size: 1rem !important;
    font-weight: 700 !important;
    letter-spacing: 0 !important;
    line-height: 1.35 !important;
    text-align: left !important;
    text-decoration: none !important;
    text-transform: none !important;
  }

  .site-header .mobile-panel a:hover,
  .site-header .mobile-panel a:focus-visible {
    background: #eef1f7 !important;
    color: #1f2a44 !important;
  }

  .site-header .mobile-panel a[aria-current="page"] {
    background: #dce0f0 !important;
    color: #1f2a44 !important;
  }
}
