/* Patch 0.1.12.0.0 - final floating mobile menu and accessibility select contrast.
   Replaces the broken mobile drawer with a mini-panel style menu and hard-fixes select readability. */

/* Accessibility selects: readable in both themes, including the selected display and opened options. */
.accessibility-panel select,
.accessibility-panel select:focus,
.accessibility-panel select:hover,
.accessibility-panel option,
html[data-theme="light"] .accessibility-panel select,
html[data-theme="light"] .accessibility-panel select:focus,
html[data-theme="light"] .accessibility-panel select:hover,
html[data-theme="light"] .accessibility-panel option{
  -webkit-text-fill-color:initial !important;
  text-shadow:none !important;
  box-shadow:inset 0 1px 1px rgba(255,255,255,.10),0 8px 18px rgba(0,0,0,.12) !important;
  filter:none !important;
}
.accessibility-panel select,
.accessibility-panel option{
  color:#f8fafc !important;
  background:#101827 !important;
  border-color:rgba(145,175,255,.32) !important;
}
html[data-theme="light"] .accessibility-panel select,
html[data-theme="light"] .accessibility-panel option{
  color:#111827 !important;
  background:#ffffff !important;
  border-color:rgba(15,23,42,.18) !important;
}
.accessibility-panel select option:checked{
  color:#ffffff !important;
  background:#263a74 !important;
}
html[data-theme="light"] .accessibility-panel select option:checked{
  color:#ffffff !important;
  background:#3157b8 !important;
}

.mobile-menu-panel{display:none;}

@media(max-width:920px){
  .site-header{
    min-height:60px !important;
    padding:10px 14px !important;
    justify-content:center !important;
  }
  .site-header .brand{
    max-width:calc(100vw - 28px) !important;
    justify-content:center !important;
  }
  .site-header .brand-title{display:none !important;}

  /* Original desktop nav is hidden on mobile. A separate floating menu panel handles mobile. */
  .site-nav,
  .site-nav.open,
  body.nav-open .site-nav{
    display:none !important;
    visibility:hidden !important;
    opacity:0 !important;
    pointer-events:none !important;
  }

  .nav-toggle{
    position:fixed !important;
    left:12px !important;
    bottom:12px !important;
    top:auto !important;
    right:auto !important;
    z-index:2205 !important;
    display:flex !important;
    align-items:center !important;
    justify-content:center !important;
    width:52px !important;
    height:52px !important;
    min-width:52px !important;
    min-height:52px !important;
    padding:0 !important;
    margin:0 !important;
    overflow:hidden !important;
    border-radius:999px !important;
    font-size:0 !important;
    line-height:0 !important;
    text-indent:-9999px !important;
    color:transparent !important;
    background:
      radial-gradient(90% 100% at 50% -40%,rgba(255,255,255,.46),rgba(255,255,255,.12) 32%,transparent 56%),
      linear-gradient(180deg,#262d34 0%,#11171e 48%,#05070b 100%) !important;
    border:1px solid rgba(236,244,255,.52) !important;
    box-shadow:
      inset 0 2px 2px rgba(255,255,255,.38),
      inset 0 -3px 8px rgba(0,0,0,.82),
      0 18px 42px rgba(0,0,0,.48),
      0 0 0 1px rgba(255,255,255,.08) !important;
  }
  .nav-toggle::before{
    content:"" !important;
    position:absolute !important;
    left:50% !important;
    top:50% !important;
    width:22px !important;
    height:16px !important;
    display:block !important;
    transform:translate(-50%,-50%) !important;
    background:
      linear-gradient(#ffffff,#ffffff) 0 0/100% 2px no-repeat,
      linear-gradient(#ffffff,#ffffff) 0 7px/100% 2px no-repeat,
      linear-gradient(#ffffff,#ffffff) 0 14px/100% 2px no-repeat !important;
    z-index:3 !important;
    opacity:1 !important;
  }
  .nav-toggle[aria-expanded="true"]::before{
    width:22px !important;
    height:22px !important;
    background:
      linear-gradient(45deg,transparent 45%,#ffffff 47%,#ffffff 53%,transparent 55%),
      linear-gradient(-45deg,transparent 45%,#ffffff 47%,#ffffff 53%,transparent 55%) !important;
  }
  .nav-toggle::after{
    content:"" !important;
    position:absolute !important;
    top:0 !important;
    left:-145% !important;
    width:70% !important;
    height:100% !important;
    transform:skewX(-24deg) !important;
    background:linear-gradient(115deg,transparent 20%,rgba(255,255,255,.38) 50%,transparent 80%) !important;
    opacity:.75 !important;
    transition:left .8s ease !important;
    z-index:2 !important;
  }
  .nav-toggle:hover::after{left:160% !important;}

  .nav-backdrop{
    display:block !important;
    position:fixed !important;
    inset:0 !important;
    z-index:2180 !important;
    opacity:0 !important;
    pointer-events:none !important;
    background:rgba(2,4,10,.54) !important;
    backdrop-filter:blur(10px) !important;
    -webkit-backdrop-filter:blur(10px) !important;
    transition:opacity .28s ease !important;
  }
  body.nav-open .nav-backdrop{opacity:1 !important;pointer-events:auto !important;}

  .mobile-menu-panel{
    display:block !important;
    position:fixed !important;
    left:12px !important;
    right:12px !important;
    bottom:78px !important;
    z-index:2195 !important;
    max-height:min(72vh,620px) !important;
    overflow:auto !important;
    padding:12px !important;
    border:1px solid rgba(140,170,255,.28) !important;
    border-radius:20px !important;
    color:var(--text) !important;
    background:linear-gradient(180deg,rgba(18,22,34,.96),rgba(5,7,12,.975)) !important;
    backdrop-filter:blur(18px) !important;
    -webkit-backdrop-filter:blur(18px) !important;
    box-shadow:0 22px 60px rgba(0,0,0,.55),inset 0 1px 1px rgba(255,255,255,.10) !important;
    transform:translate(-12px,20px) scale(.96) !important;
    transform-origin:left bottom !important;
    opacity:0 !important;
    visibility:hidden !important;
    pointer-events:none !important;
    transition:transform .36s cubic-bezier(.18,.9,.18,1),opacity .28s ease,visibility 0s linear .36s !important;
  }
  html[data-theme="light"] .mobile-menu-panel{
    color:#111827 !important;
    background:linear-gradient(180deg,rgba(255,255,255,.96),rgba(232,237,248,.96)) !important;
    box-shadow:0 18px 44px rgba(20,30,55,.22),inset 0 1px 1px rgba(255,255,255,.9) !important;
  }
  .mobile-menu-panel.open{
    transform:translate(0,0) scale(1) !important;
    opacity:1 !important;
    visibility:visible !important;
    pointer-events:auto !important;
    transition:transform .36s cubic-bezier(.18,.9,.18,1),opacity .28s ease,visibility 0s linear 0s !important;
  }
  .mobile-menu-head{display:flex;align-items:center;gap:10px;justify-content:space-between;margin-bottom:10px;}
  .mobile-menu-mark{
    width:46px;height:46px;border-radius:999px;display:grid;place-items:center;font-weight:900;letter-spacing:-.04em;
    color:#ffffff;background:linear-gradient(135deg,#5d89ff,#7c3cff);box-shadow:0 0 18px rgba(93,137,255,.32),0 12px 28px rgba(0,0,0,.35),inset 0 1px 1px rgba(255,255,255,.16);
  }
  .mobile-menu-title{margin-right:auto;line-height:1.1;}
  .mobile-menu-title strong{display:block;font-size:.82rem;letter-spacing:.06em;text-transform:uppercase;}
  .mobile-menu-title span{display:block;font-size:.72rem;color:var(--muted);}
  .mobile-menu-close{
    min-height:36px;padding:8px 12px;border-radius:12px;font-size:.72rem;cursor:pointer;
    color:#ffffff !important;-webkit-text-fill-color:#ffffff !important;text-shadow:0 1px 2px rgba(0,0,0,.72) !important;
    border:1px solid rgba(150,175,255,.42) !important;
    background:radial-gradient(90% 100% at 50% -42%,rgba(255,255,255,.38),rgba(255,255,255,.08) 35%,transparent 58%),linear-gradient(180deg,#242b34 0%,#111720 48%,#05070b 100%) !important;
    box-shadow:inset 0 2px 2px rgba(255,255,255,.32),inset 0 -3px 8px rgba(0,0,0,.78),0 12px 28px rgba(0,0,0,.24) !important;
  }
  .mobile-menu-links{display:grid;grid-template-columns:1fr;gap:8px;}
  .mobile-menu-link{
    display:flex !important;align-items:center !important;justify-content:space-between !important;min-height:50px !important;
    padding:13px 16px !important;border-radius:16px !important;text-decoration:none !important;font-weight:800 !important;
    color:#f8fafc !important;background:linear-gradient(180deg,rgba(255,255,255,.09),rgba(255,255,255,.028)) !important;
    border:1px solid rgba(140,170,255,.16) !important;box-shadow:inset 0 1px 1px rgba(255,255,255,.09),0 8px 20px rgba(0,0,0,.12) !important;
    transform:translateY(8px) !important;opacity:0 !important;
    transition:transform .28s ease,opacity .28s ease,border-color .22s ease,background .22s ease !important;
  }
  .mobile-menu-panel.open .mobile-menu-link{transform:translateY(0) !important;opacity:1 !important;}
  html[data-theme="light"] .mobile-menu-link{color:#111827 !important;background:linear-gradient(180deg,rgba(255,255,255,.96),rgba(241,245,249,.78)) !important;border-color:rgba(15,23,42,.12) !important;}
  .mobile-menu-link::after{content:"›" !important;color:#8fb0ff !important;font-size:1.35rem !important;line-height:1 !important;opacity:.8 !important;}
  .mobile-menu-link:hover{border-color:rgba(93,137,255,.42) !important;background:linear-gradient(180deg,rgba(93,137,255,.18),rgba(255,255,255,.045)) !important;}
  html[data-theme="light"] .mobile-menu-link:hover{background:linear-gradient(180deg,rgba(224,234,255,.98),rgba(248,250,252,.88)) !important;}
  .mobile-menu-panel.open .mobile-menu-link:nth-child(1){transition-delay:.03s!important}
  .mobile-menu-panel.open .mobile-menu-link:nth-child(2){transition-delay:.055s!important}
  .mobile-menu-panel.open .mobile-menu-link:nth-child(3){transition-delay:.08s!important}
  .mobile-menu-panel.open .mobile-menu-link:nth-child(4){transition-delay:.105s!important}
  .mobile-menu-panel.open .mobile-menu-link:nth-child(5){transition-delay:.13s!important}
  .mobile-menu-panel.open .mobile-menu-link:nth-child(6){transition-delay:.155s!important}
  .mobile-menu-panel.open .mobile-menu-link:nth-child(7){transition-delay:.18s!important}
  .mobile-menu-panel.open .mobile-menu-link:nth-child(8){transition-delay:.205s!important}
  .mobile-menu-panel.open .mobile-menu-link:nth-child(9){transition-delay:.23s!important}
  .mobile-menu-panel.open .mobile-menu-link:nth-child(10){transition-delay:.255s!important}
}

@media(min-width:921px){
  .mobile-menu-panel{display:none !important;}
  .nav-toggle{display:none !important;}
}
