/* ═══════════════════════════════════════════════════
   ACCIPITER // MERIDIAN — Design System
   ═══════════════════════════════════════════════════ */

:root {
  --red:      #ff1500;
  --amber:    #ff8c00;
  --yellow:   #ffd000;
  --cyan:     #00b4ff;
  --green:    #00cc66;
  --purple:   #9040ff;
  --white:    rgba(255,255,255,.88);
  --dim:      rgba(120,160,200,.45);
  --dimmer:   rgba(80,120,170,.3);
  --panel-bg: rgba(2,8,24,.82);
  --border:   rgba(0,180,255,.14);
  --border-hi:rgba(0,180,255,.35);
  --scan:     rgba(0,180,255,.03);
  --font-mono:'Share Tech Mono', monospace;
  --font-disp:'Rajdhani', sans-serif;
  --font-cond:'Barlow Condensed', sans-serif;
}

*{margin:0;padding:0;box-sizing:border-box}
html,body{width:100%;height:100%;background:#000;overflow:hidden;font-family:var(--font-mono);color:var(--dim)}

/* ── CESIUM ─────────────────────────────────────── */
#cesiumContainer{position:absolute;inset:0}
.cesium-viewer-bottom,.cesium-widget-credits,.cesium-viewer-toolbar{display:none!important}

/* ── AMBIENT ────────────────────────────────────── */
#scanlines{
  position:absolute;inset:0;pointer-events:none;z-index:4;
  background:repeating-linear-gradient(0deg,transparent,transparent 2px,var(--scan) 2px,var(--scan) 3px);
}
#vignette{
  position:absolute;inset:0;pointer-events:none;z-index:5;
  background:radial-gradient(ellipse at center,transparent 38%,rgba(0,3,12,.78) 100%);
}

/* ── HUD ────────────────────────────────────────── */
#hud{position:absolute;inset:0;pointer-events:none;z-index:10}

/* ── ALERT TOAST ────────────────────────────────── */
#alert-toast{
  position:absolute;top:72px;left:50%;transform:translateX(-50%);
  background:rgba(2,8,24,.95);border:1px solid var(--red);
  border-radius:2px;backdrop-filter:blur(12px);
  display:flex;align-items:stretch;overflow:hidden;
  min-width:320px;pointer-events:all;z-index:30;
  animation:toast-in .3s ease-out;
}
#alert-toast.hidden{display:none}
@keyframes toast-in{from{opacity:0;transform:translateX(-50%) translateY(-8px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}
.toast-bar{width:3px;background:var(--red);flex-shrink:0}
.toast-inner{padding:8px 14px}
.toast-level{font-family:var(--font-disp);font-weight:700;font-size:10px;letter-spacing:3px;color:var(--red);margin-bottom:3px}
.toast-text{font-size:11px;color:rgba(220,235,255,.8);line-height:1.4}

/* ── TOP BAR ────────────────────────────────────── */
#topbar{
  position:absolute;top:0;left:0;right:0;height:52px;
  display:flex;align-items:center;padding:0 18px;
  background:linear-gradient(180deg,rgba(1,6,20,.97) 0%,rgba(1,6,20,.7) 100%);
  border-bottom:1px solid var(--border);
  pointer-events:all;
}

#tb-left{flex-shrink:0}
#logo{display:flex;align-items:baseline;gap:0}
.logo-acc{font-family:var(--font-disp);font-weight:700;font-size:17px;letter-spacing:4px;color:var(--white)}
.logo-sep{font-family:var(--font-disp);font-size:14px;color:var(--border-hi);margin:0 8px}
.logo-mer{font-family:var(--font-disp);font-weight:700;font-size:17px;letter-spacing:4px;color:var(--cyan)}
.logo-cls{font-size:9px;letter-spacing:3px;color:var(--dimmer);margin-left:14px;text-transform:uppercase;padding-bottom:1px}

#tb-metrics{
  flex:1;display:flex;align-items:center;justify-content:center;gap:0;
  margin:0 24px;
}
.metric{display:flex;flex-direction:column;align-items:center;padding:0 18px}
.metric-val{
  font-family:var(--font-disp);font-weight:600;font-size:20px;
  color:var(--white);letter-spacing:1px;line-height:1;
}
.metric-lbl{font-size:8px;letter-spacing:2px;color:var(--dimmer);margin-top:2px;white-space:nowrap}
.metric-divider{width:1px;height:28px;background:var(--border)}

#tb-right{display:flex;align-items:center;gap:18px;flex-shrink:0}

#gti-block{}
#gti-label-row{display:flex;align-items:center;gap:6px;margin-bottom:4px}
.gti-lbl{font-size:8px;letter-spacing:2.5px;color:var(--dimmer);text-transform:uppercase}
.gti-trend{font-size:9px;color:var(--amber)}
#gti-gauge{display:flex;align-items:center;gap:8px}
#gti-track{width:80px;height:2px;background:rgba(255,255,255,.06);border-radius:1px;overflow:hidden}
#gti-fill{height:100%;border-radius:1px;background:linear-gradient(90deg,#ff5500,#ff0000);box-shadow:0 0 6px rgba(255,50,0,.5);transition:width 3s ease}
#gti-val{font-family:var(--font-disp);font-weight:700;font-size:26px;color:#ff3300;min-width:52px;text-align:right;animation:gti-pulse 4s ease-in-out infinite}
@keyframes gti-pulse{0%,100%{text-shadow:0 0 14px rgba(255,50,0,.7)}50%{text-shadow:0 0 28px rgba(255,50,0,.2)}}

#clock-block{text-align:right;border-left:1px solid var(--border);padding-left:18px}
#utc-time{font-family:var(--font-mono);font-size:22px;color:var(--white);letter-spacing:2px;line-height:1}
#utc-label{font-size:8px;letter-spacing:3px;color:var(--dimmer);margin-top:2px}

/* ── STATUS BAR ─────────────────────────────────── */
#statusbar{
  position:absolute;top:52px;left:0;right:0;height:22px;
  display:flex;align-items:center;padding:0 18px;gap:0;
  background:rgba(1,5,18,.75);border-bottom:1px solid var(--border);
  font-size:9px;letter-spacing:1.5px;color:var(--dimmer);
}
.sb-live{display:flex;align-items:center;gap:5px;color:var(--green);font-size:9px;letter-spacing:2px;flex-shrink:0}
.sb-pulse{width:5px;height:5px;border-radius:50%;background:var(--green);box-shadow:0 0 6px var(--green);animation:blink 1.6s step-end infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:0}}
.sb-sep{width:1px;height:14px;background:var(--border);margin:0 12px;flex-shrink:0}
.sb-item{flex-shrink:0;white-space:nowrap}
#sb-status{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:rgba(100,160,210,.5)}
.sb-spacer{flex:1}
.sb-feeds{display:flex;align-items:center;gap:5px;flex-shrink:0}
.sb-feed-dot{width:5px;height:5px;border-radius:50%;background:#333;display:inline-block;transition:background .3s,box-shadow .3s}
.sb-feed-dot.live{background:var(--green);box-shadow:0 0 5px var(--green)}
.sb-feed-dot.dead{background:var(--red)}

/* ── PANEL CHROME ───────────────────────────────── */
.panel-chrome{
  border-bottom:1px solid var(--border);
  display:flex;align-items:center;justify-content:space-between;
  padding:0 4px;flex-shrink:0;
}
.panel-tabs{display:flex}
.ptab{
  background:none;border:none;cursor:pointer;pointer-events:all;
  font-family:var(--font-mono);font-size:9px;letter-spacing:2px;
  color:var(--dimmer);text-transform:uppercase;padding:8px 10px;
  border-bottom:2px solid transparent;transition:color .2s,border-color .2s;
  position:relative;bottom:-1px;
}
.ptab:hover{color:rgba(160,200,240,.7)}
.ptab.active{color:var(--cyan);border-bottom-color:var(--cyan)}

.tab-pane{display:none;flex:1;overflow-y:auto;scrollbar-width:none}
.tab-pane.active{display:flex;flex-direction:column}

/* ── LEFT PANEL ─────────────────────────────────── */
#left-panel{
  position:absolute;top:74px;left:16px;width:252px;
  max-height:calc(100vh - 140px);
  background:var(--panel-bg);
  border:1px solid var(--border);border-radius:2px;
  backdrop-filter:blur(10px);pointer-events:all;
  display:flex;flex-direction:column;overflow:hidden;
}

/* Hotspot rows */
.hs-row{
  display:flex;align-items:center;padding:7px 12px;gap:9px;
  border-bottom:1px solid rgba(0,180,255,.05);
  cursor:pointer;pointer-events:all;transition:background .15s;
  position:relative;overflow:hidden;
}
.hs-row::before{
  content:'';position:absolute;left:0;top:0;bottom:0;width:2px;
  background:var(--c,transparent);opacity:.7;
}
.hs-row:hover{background:rgba(0,120,220,.07)}
.hs-row.selected{background:rgba(0,120,220,.12)}
.hs-pip{width:6px;height:6px;border-radius:50%;flex-shrink:0}
.hs-name{font-family:var(--font-cond);font-weight:500;font-size:12px;color:rgba(200,220,240,.85);flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;letter-spacing:.3px}
.hs-score-wrap{display:flex;flex-direction:column;align-items:flex-end;gap:2px;flex-shrink:0}
.hs-num{font-family:var(--font-disp);font-weight:700;font-size:14px;line-height:1}
.hs-arrow{font-size:8px;line-height:1}
.hs-bar{width:36px;height:2px;background:rgba(255,255,255,.06);border-radius:1px;overflow:hidden;margin-top:1px}
.hs-bar-fill{height:100%;border-radius:1px;transition:width .5s ease}

/* Threat rows */
.tsec-label{font-size:8px;letter-spacing:3px;color:var(--dimmer);text-transform:uppercase;padding:8px 12px 4px;border-bottom:1px solid var(--border)}
.threat-row{display:flex;align-items:center;padding:6px 12px;gap:8px;border-bottom:1px solid rgba(0,180,255,.05)}
.tr-pip{width:6px;height:6px;border-radius:50%;flex-shrink:0}
.tr-name{font-family:var(--font-cond);font-size:11px;color:rgba(190,215,240,.8);flex:1;font-weight:500}
.tr-range{font-size:9px;color:var(--dimmer);flex-shrink:0}

/* Asset rows */
.asset-row{display:flex;align-items:center;padding:8px 12px;gap:10px;border-bottom:1px solid rgba(0,180,255,.05)}
.asset-icon{font-family:var(--font-disp);font-weight:700;font-size:16px;width:22px;text-align:center;flex-shrink:0}
.asset-info{flex:1}
.asset-name{font-family:var(--font-cond);font-size:11px;font-weight:600;color:rgba(200,220,240,.85);letter-spacing:.5px}
.asset-sub{font-size:9px;color:var(--dimmer);margin-top:1px}
.asset-dot{font-size:14px;color:#333;transition:color .3s}

/* ── RIGHT PANEL ────────────────────────────────── */
#right-panel{
  position:absolute;top:74px;right:16px;width:272px;
  max-height:calc(100vh - 200px);
  background:var(--panel-bg);
  border:1px solid var(--border);border-radius:2px;
  backdrop-filter:blur(10px);
  display:flex;flex-direction:column;overflow:hidden;
}

#feed-count{font-size:9px;letter-spacing:1px;color:var(--dimmer);padding:0 10px}
#feed{overflow-y:auto;scrollbar-width:none;flex:1}

.feed-item{
  padding:8px 12px;border-bottom:1px solid rgba(0,180,255,.06);
  animation:fi-in .28s ease-out;border-left:2px solid transparent;
}
@keyframes fi-in{from{opacity:0;transform:translateX(8px)}to{opacity:1;transform:translateX(0)}}
.feed-item.sev-critical{border-left-color:var(--red)}
.feed-item.sev-high    {border-left-color:var(--amber)}
.feed-item.sev-seismic {border-left-color:var(--yellow)}
.feed-item.sev-weather {border-left-color:#4488ff}

.f-header{display:flex;align-items:center;gap:6px;margin-bottom:3px}
.f-sev{
  font-size:8px;letter-spacing:1.5px;padding:1px 5px;border-radius:1px;
  font-family:var(--font-disp);font-weight:600;flex-shrink:0;
}
.sev-critical .f-sev{background:rgba(255,21,0,.15);color:var(--red)}
.sev-high     .f-sev{background:rgba(255,140,0,.12);color:var(--amber)}
.sev-seismic  .f-sev{background:rgba(255,208,0,.1); color:var(--yellow)}
.sev-weather  .f-sev{background:rgba(68,136,255,.1); color:#4488ff}
.f-ts{font-size:8px;color:rgba(70,110,165,.5)}
.f-loc{font-family:var(--font-cond);font-weight:600;font-size:12px;color:var(--cyan);letter-spacing:1px;margin-bottom:2px}
.f-txt{font-size:10px;color:rgba(140,168,200,.82);line-height:1.42}
.f-src{font-size:8px;color:rgba(0,180,100,.55);margin-top:2px}
.f-cau{font-size:8px;color:var(--amber);margin-top:2px;opacity:.8}

/* Feed filter hidden state */
.feed-item.hidden-feed{display:none}

/* ── BOTTOM BAR ─────────────────────────────────── */
#bottombar{
  position:absolute;bottom:0;left:0;right:0;height:88px;
  display:flex;align-items:stretch;
  background:linear-gradient(0deg,rgba(1,5,18,.95) 0%,rgba(1,5,18,.7) 100%);
  border-top:1px solid var(--border);
  pointer-events:all;
}

#chain-block{flex:1;padding:8px 20px;display:flex;flex-direction:column;justify-content:space-between}
#chain-header{display:flex;align-items:baseline;gap:12px;margin-bottom:6px}
.chain-eyebrow{font-size:8px;letter-spacing:3px;color:var(--dimmer);text-transform:uppercase;flex-shrink:0}
.chain-title{font-family:var(--font-cond);font-size:11px;color:rgba(160,195,225,.65);letter-spacing:.8px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

#chain-flow{display:flex;align-items:flex-start}
.c-node{flex:1;text-align:center}
.c-dot{width:8px;height:8px;border-radius:50%;margin:0 auto 3px;animation:cd 2.2s ease-in-out infinite}
@keyframes cd{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(.6);opacity:.4}}
.c-lbl{font-size:8px;color:var(--dimmer);line-height:1.3;white-space:pre-line}
.c-arr{font-size:13px;color:rgba(0,200,140,.4);padding-bottom:10px;flex-shrink:0}

#sparkline-block{
  width:200px;padding:10px 16px;border-left:1px solid var(--border);
  display:flex;flex-direction:column;justify-content:space-between;flex-shrink:0;
}
.gh-label{font-size:8px;letter-spacing:2px;color:var(--dimmer)}
#sparkline{display:block}

/* ── LAYER CONTROL ──────────────────────────────── */
#layer-control{
  position:absolute;top:74px;left:284px;
  background:var(--panel-bg);border:1px solid var(--border);
  border-radius:2px;backdrop-filter:blur(10px);
  padding:8px 12px;pointer-events:all;
}
.lc-header{font-size:8px;letter-spacing:3px;color:var(--dimmer);text-transform:uppercase;margin-bottom:6px}
.lc-row{
  display:flex;align-items:center;gap:8px;margin-bottom:5px;
  cursor:pointer;pointer-events:all;transition:opacity .15s;
  font-size:9px;color:rgba(130,170,210,.6);
}
.lc-row:last-child{margin-bottom:0}
.lc-row:hover{color:rgba(200,225,255,.8)}
.lc-icon{font-size:11px;width:14px;text-align:center;flex-shrink:0;color:var(--cyan)}
.lc-name{flex:1;white-space:nowrap}
.lc-tog{
  width:24px;height:12px;border-radius:6px;border:1px solid var(--dimmer);
  position:relative;flex-shrink:0;transition:background .2s,border-color .2s;
}
.lc-tog::after{
  content:'';position:absolute;top:2px;left:2px;width:7px;height:7px;
  border-radius:50%;background:var(--dimmer);transition:transform .2s,background .2s;
}
.lc-tog.on{background:rgba(0,180,255,.15);border-color:var(--cyan)}
.lc-tog.on::after{transform:translateX(11px);background:var(--cyan)}

/* ── DOSSIER ────────────────────────────────────── */
#dossier{
  position:absolute;top:74px;right:304px;width:300px;
  max-height:calc(100vh - 120px);
  background:rgba(2,8,28,.9);
  border:1px solid var(--border-hi);border-radius:2px;
  backdrop-filter:blur(14px);pointer-events:all;z-index:20;
  display:flex;flex-direction:column;overflow:hidden;
  animation:dos-in .28s ease-out;
}
@keyframes dos-in{from{opacity:0;transform:translateX(14px)}to{opacity:1;transform:translateX(0)}}
#dossier.hidden{display:none}

#dossier-titlebar{
  padding:10px 14px 10px;border-bottom:1px solid var(--border);
  flex-shrink:0;position:relative;
}
#dossier-eyebrow{font-size:8px;letter-spacing:3px;color:var(--dimmer);margin-bottom:4px}
#dossier-name{font-family:var(--font-disp);font-weight:700;font-size:14px;letter-spacing:2px;color:var(--white)}
#dossier-meta{display:flex;gap:10px;margin-top:4px;font-size:9px;letter-spacing:1px}
#dossier-score{color:var(--amber)}
#dossier-trend{color:var(--dimmer)}
#dossier-close{
  position:absolute;top:10px;right:12px;
  background:none;border:none;cursor:pointer;pointer-events:all;
  font-size:11px;color:var(--dimmer);transition:color .15s;
}
#dossier-close:hover{color:var(--white)}
#dossier-body{padding:12px 14px;overflow-y:auto;scrollbar-width:none;flex:1}

.dossier-section-label{font-size:8px;letter-spacing:3px;color:var(--dimmer);text-transform:uppercase;margin-bottom:8px;padding-bottom:5px;border-bottom:1px solid var(--border)}
.wiki-text{font-size:10px;color:rgba(160,190,220,.82);line-height:1.6;margin-bottom:8px}
.wiki-link{font-size:9px;color:var(--cyan);text-decoration:none;letter-spacing:1px}
.wiki-link:hover{text-decoration:underline}
.dossier-event{padding:6px 0;border-bottom:1px solid rgba(0,180,255,.07)}
.de-source{font-size:8px;letter-spacing:2px;color:rgba(0,180,100,.6);margin-bottom:2px}
.de-title{font-size:10px;color:rgba(150,178,210,.8);line-height:1.42}
.loading{font-size:9px;letter-spacing:2px;color:var(--dimmer);animation:blink 1.5s step-end infinite}
