:root{--bg:#080c10;--panel:#0c1118;--border:#182030;--accent:#00e5ff;--accent2:#ff7840;--green:#39ff14;--muted:#607080;--text:#aac0d0;--dim:#8090a0;--mono:Verdana,sans-serif;--sans:Verdana,sans-serif;--footer-h:22px}
:root.light{--bg:#f0f4f8;--panel:#ffffff;--border:#c8d4e0;--accent:#0077aa;--accent2:#d05010;--green:#1a7a1a;--muted:#7a8fa0;--text:#1a2e40;--dim:#4a6070;}
*{margin:0;padding:0;box-sizing:border-box}
.vh{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
body{background:var(--bg);color:var(--text);font-family:var(--sans);height:100vh;display:flex;flex-direction:column;overflow:hidden}
header{display:flex;align-items:center;gap:14px;padding:0 18px;height:44px;border-bottom:1px solid var(--border);background:var(--panel);flex-shrink:0;min-width:0}
.logo{font-family:var(--mono);font-size:12px;color:var(--accent);letter-spacing:4px;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.logo b{color:var(--accent2);font-weight:normal}
.hsep{flex:1}
.chip{font-family:var(--mono);font-size:12px;padding:2px 8px;letter-spacing:2px;border:1px solid;cursor:default}
.chip.g{color:var(--green);border-color:rgba(57,255,20,.25);background:rgba(57,255,20,.05)}
.chip.d{color:var(--dim);border-color:var(--border)}
.chip.w{color:var(--accent2);border-color:rgba(255,120,64,.3);background:rgba(255,120,64,.05)}
.guide-link{display:inline-flex;align-items:center;flex-shrink:0;white-space:nowrap;font-family:var(--mono);font-size:12px;padding:2px 8px;letter-spacing:2px;border:1px solid var(--border);color:var(--dim);text-decoration:none;transition:all .15s}
.guide-link:hover{color:var(--accent);border-color:var(--accent)}
.main{display:flex;flex:1;overflow:hidden}
.side{width:300px;flex-shrink:0;background:var(--panel);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden;transition:width .22s ease,opacity .22s ease,border .22s ease}
.side.collapsed{width:0;opacity:0;border-right:none;pointer-events:none}
/* Mobile: left sidebar overlays the map instead of pushing it */
@media(max-width:600px){
  header{gap:8px;padding:0 10px}
  .logo{font-size:10px;letter-spacing:2px}
  .guide-link{font-size:10px;letter-spacing:1px;padding:3px 6px}
  .side{position:fixed;top:44px;left:0;bottom:var(--footer-h);z-index:1001;width:min(300px,100%);transform:translateX(0);transition:transform .22s ease;box-shadow:4px 0 20px rgba(0,0,0,.35)}
  .side.collapsed{width:min(300px,100%);transform:translateX(-110%);opacity:1;border-right:1px solid var(--border);pointer-events:none}
  .side-right-btn{display:inline-block}
}
.map-col{display:flex;flex-direction:column;flex:1;overflow:hidden;min-width:0}
/* Right articles sidebar — desktop inline; mobile overlay via .open */
.side-right{display:none;width:300px;flex-shrink:0;background:var(--panel);border-left:1px solid var(--border);flex-direction:column;overflow:hidden}
.side-right-btn{flex-shrink:0}
@media(max-width:600px){
  .side-right{display:flex;position:fixed;top:44px;right:0;bottom:var(--footer-h);z-index:1002;width:min(300px,100%);transform:translateX(110%);transition:transform .22s ease;box-shadow:-4px 0 20px rgba(0,0,0,.35);pointer-events:none}
  .side-right.open{transform:translateX(0);pointer-events:auto}
}
.sb-art{flex:1;overflow-y:auto;padding:13px;display:flex;flex-direction:column;gap:14px}
.sb-art::-webkit-scrollbar{width:3px}.sb-art::-webkit-scrollbar-thumb{background:var(--muted)}
.art-side-section{margin:0}
.art-side-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}
.art-side-item{display:flex;flex-direction:column;gap:2px;padding-bottom:8px;border-bottom:1px solid var(--border)}
.art-side-item:last-child{border-bottom:none;padding-bottom:0}
.side-right .lbl{font-size:14px}
.art-side-item a{font-family:var(--sans);font-size:14px;line-height:1.45;color:var(--text);text-decoration:none}
.art-side-item a:hover{color:var(--accent)}
.art-side-date{font-family:var(--mono);font-size:12px;color:var(--muted);letter-spacing:.5px}
.art-side-all{margin:4px 0 0;padding-top:10px;border-top:1px solid var(--border)}
.art-side-all a{font-family:var(--mono);font-size:13px;color:var(--accent);letter-spacing:1px;text-decoration:none}
.art-side-all a:hover{text-decoration:underline}
@media(min-width:601px){
  .side-right{display:flex}
  .side-right-btn{display:none}
}
.sb{flex:1;overflow-y:auto;padding:13px;display:flex;flex-direction:column;gap:11px}
.sb::-webkit-scrollbar{width:3px}.sb::-webkit-scrollbar-thumb{background:var(--muted)}
.lbl{font-family:var(--mono);font-size:12px;color:var(--dim);letter-spacing:3px;margin-bottom:4px}
.field label{font-family:var(--mono);font-size:12px;color:var(--dim);letter-spacing:2px;display:block;margin-bottom:3px}
.field input{width:100%;background:var(--bg);border:1px solid var(--border);color:var(--text);font-family:var(--mono);font-size:12px;padding:8px 10px;letter-spacing:4px;text-transform:uppercase;outline:none;transition:border-color .12s}
.field input:focus{border-color:var(--accent)}
.field input::placeholder{color:var(--muted);letter-spacing:1px;font-size:12px}
.apt-city{font-family:var(--mono);font-size:11px;color:var(--dim);letter-spacing:1px;margin-top:3px;text-transform:capitalize;min-height:13px}
.fields{display:flex;flex-direction:column;gap:4px}
.trow{display:flex;border:1px solid var(--border)}
.tb{flex:1;padding:7px 4px;font-family:var(--sans);font-weight:700;font-size:11px;letter-spacing:2px;text-transform:uppercase;background:transparent;border:none;border-right:1px solid var(--border);color:var(--dim);cursor:pointer;transition:all .12s}
.tb:last-child{border-right:none}
.tb.on{background:var(--accent);color:var(--bg)}
.tb:hover:not(.on){color:var(--text);background:rgba(255,255,255,.04)}
/* random route */
.rand-hint{font-family:var(--mono);font-size:11px;letter-spacing:.5px;color:var(--dim);margin:8px 0 4px;line-height:1.3}
.random-row{display:flex;gap:6px;margin-top:4px}
.rand-btn{flex:1;padding:6px 4px;font-family:var(--mono);font-size:9px;letter-spacing:1.5px;background:transparent;border:1px solid var(--border);color:var(--dim);cursor:pointer;transition:all .12s}
.rand-btn:hover{color:var(--accent);border-color:var(--accent)}
.rand-btn:disabled{opacity:.4;cursor:wait}
.rand-area{display:flex;align-items:center;gap:6px;margin-top:6px;font-family:var(--mono);font-size:11px;letter-spacing:.5px;color:var(--dim);cursor:pointer;line-height:1.3}
.rand-area input[type=checkbox]{accent-color:var(--accent);width:12px;height:12px;flex:0 0 auto;cursor:pointer}
/* swap button */
.swap-btn{align-self:center;background:transparent;border:1px solid var(--border);color:var(--dim);width:26px;height:22px;font-size:12px;cursor:pointer;line-height:1;transition:color .12s,border-color .12s}
.swap-btn:hover{color:var(--accent);border-color:var(--accent)}
/* SID/STAR guidance */
.sid-row{display:grid;grid-template-columns:36px 1fr;gap:4px 8px;margin-bottom:6px;padding-bottom:6px;border-bottom:1px solid var(--border)}
.sid-row:last-child{border-bottom:none;margin-bottom:0}
.sid-badge{font-family:var(--mono);font-size:10px;font-weight:700;letter-spacing:1.5px;padding:2px 4px;text-align:center;align-self:start;margin-top:1px}
.sid-badge.dep{background:var(--accent);color:var(--bg)}
.sid-badge.arr{background:var(--accent2);color:var(--bg)}
.sid-info{display:flex;flex-direction:column;gap:2px}
.sid-track{font-family:var(--mono);font-size:12px;font-weight:700;color:var(--text)}
.sid-detail{font-family:var(--mono);font-size:11px;color:var(--dim);line-height:1.5}
.sid-note{font-family:var(--mono);font-size:10px;color:var(--muted);margin-top:4px;line-height:1.5}
/* fuel estimate */
#sfuel{margin-top:4px;border-top:1px solid var(--border);padding-top:5px}
.fuel-row{display:flex;justify-content:space-between;font-family:var(--mono);font-size:11px;color:var(--dim);letter-spacing:.5px;padding:1px 0}
.fuel-row span:last-child{color:var(--text)}
.fuel-total{display:flex;justify-content:space-between;font-family:var(--mono);font-size:12px;font-weight:700;color:var(--accent);letter-spacing:1px;margin-top:4px;padding-top:4px;border-top:1px solid var(--border)}
/* takeoff performance */
#stof{margin-top:6px;border-top:1px solid var(--border);padding-top:6px}
.tof-title{font-family:var(--mono);font-size:10px;color:var(--dim);letter-spacing:2px;margin-bottom:5px}
.tof-btns{display:flex;gap:4px;margin-bottom:5px}
.tof-btn{flex:1;padding:4px 2px;font-family:var(--mono);font-size:10px;letter-spacing:1px;background:transparent;border:1px solid var(--border);color:var(--dim);cursor:pointer;transition:all .12s;text-align:center}
.tof-btn.active{background:var(--accent);color:var(--bg);border-color:var(--accent)}
.tof-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:4px;margin-top:4px}
.tof-cell{background:var(--bg);padding:5px 6px}
.tof-cell .lk{font-family:var(--mono);font-size:9px;color:var(--dim);letter-spacing:1.5px}
.tof-cell .lv{font-family:var(--mono);font-size:12px;font-weight:700;color:var(--text);letter-spacing:1px}
.tof-cell .lu{font-family:var(--mono);font-size:9px;color:var(--dim)}
.tof-wide{grid-column:span 3;background:var(--bg);padding:5px 8px;display:flex;justify-content:space-between;align-items:center}
.tof-wide .lk{font-family:var(--mono);font-size:10px;color:var(--dim);letter-spacing:1px}
.tof-wide .lv{font-family:var(--mono);font-size:12px;font-weight:700;color:var(--accent);letter-spacing:1px}
.tof-note{font-family:var(--mono);font-size:10px;color:var(--muted);margin-top:5px;line-height:1.5}
.pbtn{width:100%;padding:11px;font-family:var(--sans);font-weight:700;font-size:12px;letter-spacing:4px;text-transform:uppercase;background:var(--accent);color:var(--bg);border:none;cursor:pointer;transition:background .12s}
.pbtn:hover:not(:disabled){background:#33eeff}
.pbtn:disabled{background:var(--muted);cursor:default;color:var(--dim)}
.st{font-family:var(--mono);font-size:12px;padding:6px 9px;min-height:30px;display:flex;align-items:center;gap:6px;border:1px solid transparent}
.st.idle{color:var(--dim)}.st.ok{color:var(--green);background:rgba(57,255,20,.04);border-color:rgba(57,255,20,.12)}
.st.err{color:#ff4466;background:rgba(255,68,102,.04);border-color:rgba(255,68,102,.18)}
.st.busy{color:#cc0000;font-weight:700;border-color:rgba(200,0,0,.2);background:rgba(255,220,220,.45)}
.dot{width:5px;height:5px;border-radius:50%;background:currentColor;flex-shrink:0}
.st.busy .dot{display:none}
.plane-pulse{font-size:12px;animation:planePulse 1.2s ease-in-out infinite;flex-shrink:0;display:none}
.st.busy .plane-pulse{display:inline}
@keyframes planePulse{0%,100%{transform:scale(.75);opacity:.5}50%{transform:scale(1.15);opacity:1}}
@keyframes pu{0%,100%{opacity:1}50%{opacity:.1}}.pulse{animation:pu 1s ease-in-out infinite}
hr{border:none;border-top:1px solid var(--border)}
.card{background:var(--bg);border:1px solid var(--border);padding:10px;display:none;flex-direction:column;gap:6px}
.card.show{display:flex}
.crow{display:flex;justify-content:space-between;align-items:baseline}
.ck{font-family:var(--mono);font-size:11px;color:var(--dim);letter-spacing:2px}
.cv{font-family:var(--mono);font-size:12px;color:var(--accent)}.cv.o{color:var(--accent2)}
.cr{font-family:var(--mono);font-size:12px;color:var(--text);overflow-wrap:anywhere;word-break:normal;line-height:1.9;padding-top:5px;border-top:1px solid var(--border)}
.cr b{font-weight:700;color:var(--text)}
.cr .aw{font-weight:400;color:var(--dim)}
.wpt-link{color:inherit;text-decoration:none}
.wpt-link:hover b{color:var(--accent);text-decoration:underline}
.nt{display:none;flex-direction:column;gap:1px}.nt.show{display:flex}
.nr{display:grid;grid-template-columns:22px 58px 1fr 50px;gap:3px;align-items:center;padding:5px 6px;background:var(--bg);font-family:var(--mono);font-size:12px;border-left:2px solid transparent;cursor:pointer;transition:all .1s}
.nr:hover{background:#101820;border-left-color:var(--accent)}.nr.hi{background:rgba(0,229,255,.05);border-left-color:var(--accent)}
.ns{color:var(--dim);font-size:11px}.ni{color:var(--accent);letter-spacing:1px}.nv{color:var(--dim);font-size:11px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.nd{color:var(--accent2);text-align:right}
/* runway/weather card */
.rwcard{background:var(--bg);border:1px solid var(--border);padding:0;display:none}
.rwcard.show{display:flex}
.rwside{flex:1;padding:9px 10px;display:flex;flex-direction:column;gap:5px}
.rwsep{width:1px;background:var(--border)}
.rwhdr{display:flex;justify-content:space-between;align-items:center}
.rwicao{font-family:var(--mono);font-size:12px;color:var(--accent);letter-spacing:3px}
a.rwicao{text-decoration:none}
a.rwicao:hover{text-decoration:underline}
.rwmetalink{margin-top:6px;font-family:var(--mono);font-size:10px;letter-spacing:1px}
.rwmetalink a{color:var(--accent);text-decoration:none}
.rwmetalink a:hover{text-decoration:underline}
.rwsrc{font-family:var(--mono);font-size:8px;letter-spacing:2px;color:var(--dim);padding:1px 5px;border:1px solid var(--border)}
.rwwind{font-family:var(--mono);font-size:9px;color:var(--dim);letter-spacing:2px;display:flex;justify-content:space-between;align-items:center}
.rwwind span{color:var(--text);letter-spacing:1px}
.rwrwy{font-family:var(--mono);font-size:9px;color:var(--dim);letter-spacing:2px;margin-top:2px}
.rwbig{display:block;font-family:var(--mono);font-size:13px;font-weight:bold;color:var(--accent2);letter-spacing:3px;line-height:1.1;margin-top:2px}
.rwcomp{font-family:var(--mono);font-size:10px;color:var(--text);letter-spacing:1px}
.rwnote{font-family:var(--mono);font-size:9px;color:#ff4466;letter-spacing:1px}
.rwmetarow{display:flex;justify-content:space-between;align-items:baseline;margin-top:1px}
.rwmetarow.rwtight{justify-content:flex-start;gap:6px}
.rwmetarow.rwtemp{gap:2px}
.rwmetarow.rwtemp .rwval{letter-spacing:0}
.rwlbl{font-family:var(--mono);font-size:9px;color:var(--dim);letter-spacing:2px}
.rwval{font-family:var(--mono);font-size:10px;color:var(--text);letter-spacing:1px}
.rwcat{font-family:var(--mono);font-size:9px;letter-spacing:2px;font-weight:bold}
.rwdisc{font-family:var(--mono);font-size:11px;color:var(--accent2);letter-spacing:.5px;line-height:1.6;padding:6px 8px;border:1px solid rgba(255,120,64,.2);background:rgba(255,120,64,.04);margin-top:4px}
/* export buttons */
.expbtns{display:flex;flex-direction:column;gap:4px;margin-top:6px}
.expbtn{width:100%;padding:7px 10px;font-family:var(--mono);font-size:12px;letter-spacing:2px;text-align:left;background:rgba(57,255,20,.04);border:1px solid var(--border);color:var(--dim);cursor:pointer;transition:all .12s}
.expbtn:hover{color:var(--accent);border-color:var(--accent);background:rgba(57,255,20,.10)}
.expnote{font-family:var(--mono);font-size:11px;color:var(--muted);line-height:1.6;padding:5px 2px;letter-spacing:.3px}
.howto-link{display:inline-block;margin-top:6px;font-family:var(--mono);font-size:12px;letter-spacing:1px;color:var(--accent);cursor:pointer;border-bottom:1px dotted var(--accent);transition:color .12s}
.howto-link:hover{color:var(--accent2);border-bottom-color:var(--accent2)}
.howto-overlay{position:fixed;inset:0;z-index:5000;display:none;align-items:center;justify-content:center;padding:24px;background:rgba(2,6,12,.66);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);opacity:0;transition:opacity .18s ease}
.howto-overlay.open{display:flex;opacity:1}
.howto-modal{position:relative;width:min(820px,100%);height:min(86vh,820px);background:var(--panel);border:1px solid var(--border);box-shadow:0 18px 60px rgba(0,0,0,.55);display:flex;flex-direction:column;transform:translateY(8px) scale(.985);transition:transform .2s ease}
.howto-overlay.open .howto-modal{transform:translateY(0) scale(1)}
.howto-bar{display:flex;align-items:center;justify-content:space-between;height:40px;flex-shrink:0;padding:0 8px 0 14px;border-bottom:1px solid var(--border)}
.howto-bar span{font-family:var(--mono);font-size:12px;letter-spacing:2px;color:var(--dim);text-transform:uppercase}
.howto-close{width:30px;height:30px;border:1px solid var(--border);background:transparent;color:var(--dim);font-family:var(--mono);font-size:12px;line-height:1;cursor:pointer;transition:all .12s}
.howto-close:hover{color:var(--bg);background:var(--accent2);border-color:var(--accent2)}
.howto-frame{flex:1;width:100%;border:0;background:var(--bg)}
/* SIGMET panel */
#sigmet-section .lbl{color:var(--accent2)}
.sigmet-card{padding:6px 10px;margin-bottom:4px;background:var(--bg);border-left:3px solid #ff9600}
.sigmet-type{font-family:var(--mono);font-size:12px;font-weight:700;letter-spacing:1.5px}
.sigmet-meta{font-family:var(--mono);font-size:11px;color:var(--dim);letter-spacing:.5px;margin-top:2px}
.sigmet-raw{font-family:var(--mono);font-size:10px;color:var(--muted);margin-top:3px;line-height:1.5;white-space:pre-wrap;word-break:break-word}
/* aircraft selector */
.ac-select{width:100%;font-family:var(--mono);font-size:11px;letter-spacing:1px;background:var(--bg);color:var(--text);border:1px solid var(--border);padding:6px 8px;cursor:pointer;appearance:none;-webkit-appearance:none;outline:none}
.ac-select:focus{border-color:var(--accent)}
.ac-select option,.ac-select optgroup{background:var(--bg);color:var(--text)}
/* elevation profile */
#elev-section{background:#0a0f16;border-top:1px solid var(--border);flex-shrink:0;position:relative}
#elevcanvas{display:block;width:100%;cursor:crosshair}
.elev-meta{font-family:var(--mono);font-size:11px;color:var(--dim);letter-spacing:1px;display:flex;justify-content:space-between;padding:3px 10px 4px}
.prog{height:2px;background:var(--bg);border-bottom:1px solid var(--border);display:none}
.prog.show{display:block}.progbar{height:100%;background:var(--accent);width:0;transition:width .3s ease}
/* map */
/* layers control */
.lyr-wrap{position:relative}
.lyr-btn{background:var(--panel);border:1px solid var(--border);color:var(--dim);width:30px;height:30px;font-size:12px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:color .12s}
.lyr-btn:hover{color:var(--accent);border-color:var(--accent)}
.lyr-panel{position:absolute;bottom:36px;right:0;background:var(--panel);border:1px solid var(--border);padding:8px 12px;display:flex;flex-direction:column;gap:7px;white-space:nowrap;box-shadow:0 4px 16px rgba(0,0,0,.5)}
.lyr-panel label{font-family:var(--mono);font-size:11px;color:var(--dim);letter-spacing:1.5px;display:flex;align-items:center;gap:7px;cursor:pointer}
.lyr-panel label:hover{color:var(--text)}
.lyr-panel input[type=checkbox]{accent-color:var(--accent);width:11px;height:11px}
.fix-tt.leaflet-tooltip{font-family:var(--mono)!important;font-size:11px!important;background:var(--panel)!important;border:1px solid var(--border)!important;color:var(--text)!important;box-shadow:none!important;padding:2px 5px!important;border-radius:0!important;letter-spacing:1px}
.fix-tt.leaflet-tooltip::before{display:none}
/* airport popup */
.apt-pop-wrap .leaflet-popup-content-wrapper{padding:0!important}
.apt-pop-wrap .leaflet-popup-content{margin:0!important;width:auto!important}
.apt-pop{display:flex;flex-direction:column;gap:0}
.apt-pop-id{font-family:var(--mono);font-size:12px;font-weight:700;letter-spacing:2px;color:var(--accent);padding:8px 14px 6px;border-bottom:1px solid var(--border)}
.apt-pop-btn{font-family:var(--mono);font-size:11px;letter-spacing:1.5px;background:transparent;border:none;border-bottom:1px solid var(--border);color:var(--dim);padding:8px 14px;text-align:left;cursor:pointer;width:100%;transition:all .1s}
.apt-pop-btn:hover{color:var(--accent);background:rgba(0,229,255,.06)}
.apt-pop-btn:last-child{border-bottom:none}
/* NM scale */
.nm-scale{background:var(--panel);border:1px solid var(--dim);border-top:2px solid var(--dim);font-family:var(--mono);font-size:11px;color:var(--dim);letter-spacing:1px;padding:2px 5px;text-align:center;min-width:40px;pointer-events:none;margin-bottom:8px;margin-left:8px}
#map{flex:1;background:#e8eef4;min-height:0}
.leaflet-container{background:#e8eef4}
.leaflet-tile-pane{filter:none}
:root.light #map{background:#e8eef4}
:root.light .leaflet-container{background:#e8eef4}
:root.light .leaflet-tile-pane{filter:none}
:root.light #elev-section{background:#e8eef4}
/* theme toggle button */
.theme-btn{background:transparent;border:1px solid var(--border);color:var(--dim);font-family:var(--mono);font-size:12px;padding:3px 9px;cursor:pointer;letter-spacing:1px;transition:all .15s}
.theme-btn:hover{color:var(--text);border-color:var(--dim)}
.leaflet-popup-content-wrapper{background:var(--panel)!important;border:1px solid var(--border)!important;border-radius:0!important;box-shadow:0 4px 20px rgba(0,0,0,.7)!important;color:var(--text)!important}
.leaflet-popup-tip{background:var(--panel)!important}
.pp{padding:8px 12px}.pp-id{font-family:var(--mono);font-size:12px;color:var(--accent);letter-spacing:2px}
.pp-r{font-family:var(--mono);font-size:12px;color:var(--dim);margin-top:3px}.pp-r span{color:var(--text)}
.pp-edit-btn{margin-top:7px;width:100%;font-family:var(--mono);font-size:11px;letter-spacing:1px;background:transparent;border:1px solid var(--border);color:var(--dim);padding:5px 8px;cursor:pointer;text-align:left;transition:all .1s}
.pp-edit-btn:hover{color:#ff6060;border-color:#ff6060;background:rgba(255,60,60,.06)}
/* autocomplete dropdown */
.field{position:relative}
.ac-dropdown{position:absolute;top:100%;left:0;right:0;z-index:200;background:var(--panel);border:1px solid var(--border);box-shadow:0 4px 16px rgba(0,0,0,.5);max-height:220px;overflow-y:auto;display:none}
.ac-dropdown.open{display:block}
.ac-item{display:flex;align-items:center;gap:8px;padding:7px 10px;cursor:pointer;border-bottom:1px solid var(--border);transition:background .1s}
.ac-item:last-child{border-bottom:none}
.ac-item:hover,.ac-item.selected{background:var(--bg)}
.ac-icao{font-family:var(--mono);font-size:11px;color:var(--accent);letter-spacing:2px;min-width:40px}
.ac-name{font-family:var(--mono);font-size:10px;color:var(--text);flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ac-meta{font-family:var(--mono);font-size:9px;color:var(--dim);white-space:nowrap}
/* Google login button */
.google-btn{display:inline-flex;align-items:center;gap:8px;padding:4px 12px 4px 8px;background:#fff;border:1px solid #dadce0;border-radius:4px;color:#3c4043;font-family:var(--mono);font-size:12px;letter-spacing:.5px;text-decoration:none;transition:all .15s;white-space:nowrap}
.google-btn:hover{background:#f7f8f8;border-color:#c6c6c6;box-shadow:0 1px 3px rgba(0,0,0,.1)}
.google-btn svg{flex-shrink:0}
/* User menu */
.user-menu{position:relative}
.user-btn{display:flex;align-items:center;gap:6px;padding:4px 10px;background:transparent;border:1px solid var(--border);color:var(--dim);font-family:var(--mono);font-size:11px;letter-spacing:.5px;cursor:pointer;transition:all .12s}
.user-btn:hover{color:var(--text);border-color:var(--dim)}
.user-btn svg{flex-shrink:0}
.user-dropdown{position:absolute;top:calc(100% + 6px);right:0;background:var(--panel);border:1px solid var(--border);box-shadow:0 4px 16px rgba(0,0,0,.4);min-width:180px;display:none;flex-direction:column;z-index:2000}
.user-menu.open .user-dropdown{display:flex}
.user-dropdown-name{font-family:var(--mono);font-size:12px;color:var(--text);padding:10px 12px 2px;letter-spacing:.5px}
.user-dropdown-email{font-family:var(--mono);font-size:10px;color:var(--dim);padding:0 12px 10px;border-bottom:1px solid var(--border)}
.user-dropdown-item{display:block;font-family:var(--mono);font-size:11px;color:var(--dim);letter-spacing:1px;text-decoration:none;padding:10px 12px;border-bottom:1px solid var(--border);transition:all .12s}
.user-dropdown-item:hover{color:var(--accent);background:rgba(0,229,255,.05)}
.user-dropdown-logout{display:block;font-family:var(--mono);font-size:11px;color:var(--dim);letter-spacing:1px;text-decoration:none;padding:10px 12px;transition:all .12s}
.user-dropdown-logout:hover{color:var(--accent2);background:rgba(255,120,64,.05)}
@media(max-width:600px){.user-btn span{display:none}.user-btn{padding:4px 8px}.google-btn span{display:none}}
/* Save button */
.save-btn{background:rgba(0,229,255,.08)!important;border-color:var(--accent)!important;color:var(--accent)!important;margin-bottom:8px;text-decoration:none}
.save-btn:hover{background:rgba(0,229,255,.15)!important}
.save-btn.saved{background:rgba(57,255,20,.12)!important;border-color:var(--green)!important;color:var(--green)!important}
.save-btn:disabled{opacity:.6;cursor:wait}
/* site footer */
.site-footer{flex-shrink:0;display:flex;align-items:center;justify-content:center;gap:10px 14px;flex-wrap:wrap;min-height:var(--footer-h);padding:2px 14px;border-top:1px solid var(--border);background:var(--panel);font-family:var(--mono);font-size:9px;letter-spacing:1px;color:var(--muted)}
.site-footer-copy{color:var(--dim);white-space:nowrap}
.site-footer-nav{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:0}
.site-footer-nav a{color:var(--muted);text-decoration:none;transition:color .12s;white-space:nowrap}
.site-footer-nav a:hover{color:var(--accent)}
.site-footer-sep{color:var(--border);margin:0 5px;user-select:none}
@media(max-width:600px){
  .site-footer{gap:6px 10px;padding:3px 10px;font-size:8px;letter-spacing:.5px}
  .site-footer-sep{margin:0 4px}
}
