:root{
  --teal:#39d0d8; --teal2:#7ff0f6; --amber:#ffb020; --red:#ff2a2a;
  --ink:#04070d; --panel:rgba(6,12,20,.82); --line:rgba(90,200,220,.22);
  --line2:rgba(90,200,220,.45); --txt:#cfe6ee; --dim:#6f8a98;
  --mono:'Share Tech Mono',ui-monospace,monospace;
}
*{box-sizing:border-box}
html,body{margin:0;height:100%;background:#01030a;color:var(--txt);
  font-family:var(--mono);overflow:hidden;-webkit-font-smoothing:antialiased}
#map{position:absolute;inset:0;background:#01030a;z-index:1}
#atmosphere{position:absolute;inset:0;z-index:4;pointer-events:none}
.maplibregl-ctrl-attrib{font-family:var(--mono)!important;font-size:9px!important}

/* ---- ambient overlays ---- */
.vignette{position:absolute;inset:0;z-index:5;pointer-events:none;
  background:radial-gradient(130% 100% at 50% 45%,transparent 52%,rgba(0,4,10,.55) 80%,rgba(0,2,6,.92) 100%)}
.scanlines{position:absolute;inset:0;z-index:6;pointer-events:none;opacity:.35;
  background:repeating-linear-gradient(0deg,rgba(0,0,0,0) 0,rgba(0,0,0,0) 2px,rgba(0,10,15,.5) 3px,rgba(0,0,0,0) 4px)}
.brackets{position:absolute;inset:14px;z-index:7;pointer-events:none}
.bk{position:absolute;width:26px;height:26px;border:2px solid var(--line2)}
.bk.tl{top:0;left:0;border-right:0;border-bottom:0}
.bk.tr{top:0;right:0;border-left:0;border-bottom:0}
.bk.bl{bottom:0;left:0;border-right:0;border-top:0}
.bk.br{bottom:0;right:0;border-left:0;border-top:0}

/* ---- top-left command header ---- */
.cmd{position:absolute;top:24px;left:24px;z-index:20;max-width:340px}
.cmd-logo{display:flex;align-items:center;gap:11px}
.cmd-logo .hex{color:var(--teal);font-size:26px;text-shadow:0 0 12px var(--teal);animation:spin 9s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.cmd-title{font-family:Oswald,sans-serif;font-weight:700;font-size:26px;letter-spacing:5px;
  color:#eafcff;text-shadow:0 0 16px rgba(57,208,216,.5);line-height:1}
.cmd-sub{font-size:10.5px;letter-spacing:2px;color:var(--teal);margin-top:3px}
.classif{margin-top:9px;display:inline-block;font-size:10px;letter-spacing:3px;
  color:var(--amber);border:1px solid rgba(255,176,32,.4);background:rgba(255,176,32,.08);
  padding:2px 9px;border-radius:2px}
.readout{display:none}
.readout div{display:flex;justify-content:space-between;font-size:11.5px}
.readout span{color:var(--dim)}
.readout b{color:var(--teal2);font-weight:400;text-shadow:0 0 8px rgba(127,240,246,.4)}

/* ---- top-center NOW TRACKING bar ---- */
.track{position:absolute;right:24px;bottom:70px;top:auto;left:auto;transform:none;z-index:22;
  display:flex;align-items:stretch;gap:0;background:var(--panel);
  border:1px solid var(--line2);border-radius:6px;backdrop-filter:blur(8px);
  box-shadow:0 8px 32px rgba(0,0,0,.5),0 0 18px rgba(57,208,216,.08);
  width:320px;min-width:0;max-width:320px;overflow:hidden}
.tk-btn{background:transparent;border:0;color:var(--teal2);width:28px;
  cursor:pointer;font-size:12px;letter-spacing:1px;
  border-right:1px solid var(--line);transition:background .15s,color .15s}
.tk-btn:last-child{border-right:0;border-left:1px solid var(--line)}
.tk-btn:hover{background:rgba(57,208,216,.12);color:#fff}
.tk-btn:disabled{opacity:.3;cursor:not-allowed}
.tk-power{width:auto;padding:0 8px;font-size:9.5px;font-family:var(--mono);font-weight:700}
.tk-power.on{background:rgba(255,42,42,.16);color:#ff8a8a;border-color:rgba(255,42,42,.4)}
.tk-card{flex:1;min-width:0;padding:6px 10px;display:flex;flex-direction:column;justify-content:center;gap:2px}
.tk-line1{display:flex;align-items:center;gap:9px;font-size:10.5px;letter-spacing:2px}
.tk-pill{padding:3px 8px;border-radius:3px;background:rgba(57,208,216,.18);
  color:var(--teal2);border:1px solid var(--line2);font-weight:700;font-size:9.5px;
  display:flex;align-items:center;gap:5px;white-space:nowrap}
.tk-pill::before{content:'';width:6px;height:6px;border-radius:50%;background:currentColor;
  flex-shrink:0;opacity:.6}
.tk-pill.live{background:rgba(255,42,42,.3);color:#ff2222;border-color:rgba(255,99,99,.6);
  box-shadow:0 0 14px rgba(255,42,42,.35),inset 0 0 8px rgba(255,42,42,.12)}
.tk-pill.live::before{background:#ff2222;opacity:1;animation:pulse-dot 1.1s ease-in-out infinite}
@keyframes pulse-dot{0%,100%{opacity:.4;transform:scale(1)} 50%{opacity:1;transform:scale(1.15)}}
.tk-pill.idle{background:rgba(127,155,181,.15);color:#9fb8c8;border-color:rgba(127,155,181,.3)}
.tk-loc{color:var(--teal);font-size:10px;letter-spacing:.3px;white-space:nowrap;
  overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0;opacity:.85}
.tk-headline{font-family:Oswald,sans-serif;font-size:12px;line-height:1.2;
  color:#eafcff;letter-spacing:.2px;overflow:hidden;text-overflow:ellipsis;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
@media(max-width:760px){
  .track{top:64px;left:12px;right:12px;transform:none;min-width:0;max-width:none}
  .tk-headline{white-space:normal;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
}

/* ---- top-right status ---- */
.status{position:absolute;top:24px;right:24px;z-index:20;display:flex;flex-direction:column;
  align-items:flex-end;gap:8px}
.rec{display:flex;align-items:center;font-size:12px;letter-spacing:1px;color:#ff5a5a;
  background:var(--panel);border:1px solid rgba(255,42,42,.35);border-radius:4px;
  padding:5px 11px;backdrop-filter:blur(6px)}
.rec b{color:#ff8a8a;font-weight:400;margin-left:2px}
.recdot{width:9px;height:9px;border-radius:50%;background:var(--red);margin-right:8px;
  box-shadow:0 0 0 0 rgba(255,42,42,.7);animation:pulse 1.5s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(255,42,42,.7)}70%{box-shadow:0 0 0 8px rgba(255,42,42,0)}100%{box-shadow:0 0 0 0 rgba(255,42,42,0)}}
.threat{font-size:12px;letter-spacing:2px;color:var(--dim);background:var(--panel);
  border:1px solid var(--line);border-radius:4px;padding:5px 11px;backdrop-filter:blur(6px)}
.threat b{font-weight:400;letter-spacing:1px}
.threat.lvl-normal b{color:#52e08a}.threat.lvl-elev b{color:var(--amber)}.threat.lvl-high b{color:#ff5a5a}
.exit{font-size:11px;letter-spacing:1.5px;color:var(--txt);text-decoration:none;
  background:var(--panel);border:1px solid var(--line);border-radius:4px;padding:5px 11px;
  backdrop-filter:blur(6px);transition:.15s}
.exit:hover{border-color:var(--teal);color:var(--teal2)}

/* ---- right layer panel ---- */
.layers{display:none}
.layers-x{position:absolute;top:140px;right:24px;z-index:18;width:188px;
  background:var(--panel);border:1px solid var(--line);border-radius:6px;
  padding:7px;backdrop-filter:blur(7px)}
.lp-head{font-size:10px;letter-spacing:3px;color:var(--teal);padding:6px 7px 5px;
  border-bottom:1px solid var(--line);margin-bottom:4px}
.lp-head:not(:first-child){margin-top:7px}
.ly{display:flex;align-items:center;gap:8px;font-size:11.5px;color:var(--txt);
  padding:5px 7px;cursor:pointer;border-radius:3px;transition:background .12s}
.ly:hover{background:rgba(57,208,216,.08)}
.ly input{appearance:none;width:13px;height:13px;border:1px solid var(--line2);
  border-radius:2px;cursor:pointer;position:relative;flex:0 0 auto}
.ly input:checked{background:var(--teal);box-shadow:0 0 7px rgba(57,208,216,.6)}
.ly input:checked::after{content:"";position:absolute;left:3px;top:0;width:4px;height:8px;
  border:solid #02141a;border-width:0 2px 2px 0;transform:rotate(45deg)}
.ly span{display:flex;align-items:center;gap:7px}
.sw{width:9px;height:9px;border-radius:50%;display:inline-block}
.c-new{background:var(--red);box-shadow:0 0 7px var(--red)}
.c-day{background:var(--amber);box-shadow:0 0 7px var(--amber)}
.c-old{background:#7f9bb5}

/* ---- event log ---- */
.log{position:absolute;left:24px;bottom:70px;top:auto;z-index:18;width:312px;max-height:46vh;
  background:var(--panel);border:1px solid var(--line);border-radius:6px;
  backdrop-filter:blur(7px);display:flex;flex-direction:column;overflow:hidden;
  transition:transform .25s ease}
.log.collapsed{transform:translateX(-330px)}
.log-head{display:flex;align-items:center;gap:8px;padding:9px 12px;font-size:12px;
  letter-spacing:2.5px;color:var(--teal2);border-bottom:1px solid var(--line);
  background:rgba(57,208,216,.07)}
.log-head .fd{width:8px;height:8px;border-radius:50%;background:var(--red);animation:pulse 1.5s infinite}
.log-head button{margin-left:auto;background:transparent;border:1px solid var(--line);
  color:var(--txt);width:22px;height:22px;border-radius:4px;cursor:pointer;font-size:11px}
.log-head button:hover{border-color:var(--teal);color:var(--teal2)}
.log-list{list-style:none;margin:0;padding:0;overflow-y:auto;flex:1}
.log-list::-webkit-scrollbar{width:6px}
.log-list::-webkit-scrollbar-thumb{background:rgba(57,208,216,.25);border-radius:4px}
.li{padding:9px 12px;border-bottom:1px solid rgba(90,200,220,.08);cursor:pointer;
  display:flex;gap:9px;transition:background .12s}
.li:hover{background:rgba(57,208,216,.09)}
.li .dot{flex:0 0 auto;width:8px;height:8px;border-radius:50%;margin-top:5px}
.li .ft{flex:1;min-width:0}
.li .fh{font-size:12px;font-weight:400;line-height:1.32;margin:0 0 3px;color:#e8f6fa;
  font-family:Oswald,sans-serif;letter-spacing:.2px}
.li .fm{font-size:10px;color:var(--dim);display:flex;gap:8px;flex-wrap:wrap;letter-spacing:.5px}
.li .fm .loc{color:var(--teal)}
.log-foot{padding:7px 12px;font-size:9.5px;color:var(--dim);border-top:1px solid var(--line);
  text-align:center;letter-spacing:1px}

/* ---- map markers (hex blips) ---- */
.mk-wrap{position:relative;width:18px;height:18px;cursor:pointer}
.mk-hex{position:absolute;inset:3px;clip-path:polygon(25% 0,75% 0,100% 50%,75% 100%,25% 100%,0 50%);
  border:1px solid rgba(255,255,255,.85)}
.mk-ring{position:absolute;inset:0;border-radius:50%;border:1px solid currentColor;opacity:0;
  animation:radar 2.2s ease-out infinite}
@keyframes radar{0%{transform:scale(.4);opacity:.9}100%{transform:scale(2.4);opacity:0}}
.mk-wrap.tracking::before{content:"";position:absolute;inset:-9px;border:1.5px dashed var(--teal2);
  border-radius:50%;animation:spin 7s linear infinite;opacity:.95;
  box-shadow:0 0 12px rgba(57,208,216,.55);pointer-events:none}
.mk-wrap.tracking::after{content:"TRACKING";position:absolute;top:-22px;left:50%;
  transform:translateX(-50%);font:9px var(--mono);letter-spacing:2px;color:var(--teal2);
  text-shadow:0 0 8px var(--teal);white-space:nowrap;pointer-events:none}
.mk-new{color:var(--red)} .mk-new .mk-hex{background:var(--red);box-shadow:0 0 10px var(--red)}
.mk-day{color:var(--amber)} .mk-day .mk-hex{background:var(--amber);box-shadow:0 0 9px var(--amber)}
.mk-old{color:#9fb8c8} .mk-old .mk-hex{background:#7f9bb5;box-shadow:0 0 7px rgba(127,155,181,.7)}

/* ---- popups (intel cards) ---- */
.maplibregl-popup{max-width:300px!important}
.maplibregl-popup-content{background:var(--panel)!important;color:var(--txt)!important;
  border:1px solid var(--line2);border-radius:7px;padding:0;overflow:hidden;
  backdrop-filter:blur(8px);box-shadow:0 12px 44px rgba(0,0,0,.7),0 0 24px rgba(57,208,216,.12)}
.maplibregl-popup-close-button{color:#cfe6ee;font-size:18px;padding:1px 7px;z-index:2}
.maplibregl-popup-tip{border-top-color:var(--line2)!important;border-bottom-color:var(--line2)!important}
.pop .pchip{position:absolute;top:8px;left:8px;z-index:2;font-size:9.5px;letter-spacing:2px;
  background:rgba(255,42,42,.85);color:#fff;padding:2px 8px;border-radius:2px}
.pop img{width:100%;height:118px;object-fit:cover;display:block;filter:saturate(.85) contrast(1.05)}
.pop .pb{padding:11px 13px}
.pop h4{margin:0 0 6px;font-size:14px;line-height:1.3;font-family:Oswald,sans-serif;color:#eafcff}
.pop p{margin:0 0 8px;font-size:11.5px;color:var(--dim);line-height:1.45;font-family:var(--mono)}
.pop .meta{font-size:10px;color:var(--teal);display:flex;gap:9px;flex-wrap:wrap;letter-spacing:.5px}
.pop .meta .src{color:var(--dim)}

/* ---- bottom timeline ---- */
.timeline{position:absolute;left:24px;right:24px;bottom:18px;z-index:18;height:40px;
  display:flex;align-items:center;gap:14px;background:var(--panel);border:1px solid var(--line);
  border-radius:6px;padding:0 14px;backdrop-filter:blur(7px)}
.pb-play{flex:0 0 auto;width:28px;height:28px;border-radius:50%;border:1px solid var(--line2);
  background:rgba(57,208,216,.1);color:var(--teal2);cursor:pointer;font-size:12px;line-height:1}
.pb-play:hover{background:rgba(57,208,216,.22)}
.tl-track{position:relative;flex:1;height:14px;cursor:pointer}
.tl-track::before{content:"";position:absolute;top:50%;left:0;right:0;height:2px;
  transform:translateY(-50%);background:rgba(90,200,220,.2)}
.tl-fill{position:absolute;top:50%;left:0;height:2px;transform:translateY(-50%);
  background:var(--teal);box-shadow:0 0 8px var(--teal);width:100%}
.tl-ticks{position:absolute;inset:0;pointer-events:none}
.tl-ticks i{position:absolute;top:50%;width:2px;height:9px;transform:translateX(-50%);
  margin-top:-4px;background:rgba(255,176,32,.55)}
.tl-handle{position:absolute;top:50%;left:100%;width:13px;height:13px;border-radius:50%;
  transform:translate(-50%,-50%);background:var(--teal2);border:2px solid #042;
  box-shadow:0 0 12px var(--teal);cursor:grab}
.tl-time{flex:0 0 auto;min-width:96px;text-align:right;font-size:11px;letter-spacing:1px;color:var(--teal2)}
.live-pill{display:inline-flex;align-items:center;gap:6px;color:#ff6a6a}
.live-pill i{width:7px;height:7px;border-radius:50%;background:var(--red);animation:pulse 1.5s infinite}

@media(max-width:760px){
  .cmd{top:14px;left:14px;max-width:54vw}
  .cmd-title{font-size:19px;letter-spacing:3px}
  .readout{display:none}
  .layers{top:auto;bottom:118px;right:12px;width:150px}
  .log{left:12px;right:12px;width:auto;bottom:118px;max-height:32vh}
  .log.collapsed{transform:translateY(40vh)}
  .timeline{left:12px;right:12px;bottom:64px}
}