/* SPACE v2.0.0 — fullscreen orbital instrument. Black, white, DIN; glass panels over a living globe. */

:root{
  --bg:#000;
  --panel:rgba(10,13,18,.82);
  --panel-solid:#0b0d10;
  --panel-2:#11141a;
  --line:#252a33;
  --line-soft:rgba(255,255,255,.08);
  --txt:#f4f6f8;
  --muted:#9aa3ad;
  --dim:#6b7280;
  --accent:#4d7cfe;
  --ok:#34d399;
  --warn:#fbbf24;
  --bad:#f87171;
  --din:"D-DIN","DIN Alternate","Bahnschrift","Helvetica Neue",Helvetica,Arial,"Segoe UI",sans-serif;
  --blur:saturate(140%) blur(14px);
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;background:var(--bg);color:var(--txt);
  font-family:var(--din);font-size:16px;line-height:1.55;
  overflow:hidden;-webkit-font-smoothing:antialiased;
}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}
abbr{text-decoration:none;border-bottom:1px dotted var(--dim);cursor:help}
.visually-hidden{position:absolute!important;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap}

#scene{position:fixed;inset:0;width:100%;height:100%;display:block;cursor:grab;touch-action:none}
#scene:active{cursor:grabbing}

/* ---------- loader ---------- */
#loader{
  position:fixed;inset:0;z-index:100;background:#000;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:18px;
  transition:opacity .8s ease;
}
#loader.gone{opacity:0;pointer-events:none}
.loader-mark{font-size:13px;letter-spacing:.55em;color:var(--muted);text-transform:uppercase}
.loader-title{font-size:clamp(34px,6vw,58px);font-weight:800;letter-spacing:.1em;text-transform:uppercase}
.loader-bar{width:min(380px,70vw);height:2px;background:#1a1e26;overflow:hidden;border-radius:2px}
.loader-bar i{display:block;height:100%;width:12%;background:linear-gradient(90deg,#27407e,var(--accent));border-radius:2px;transition:width .4s ease}
.loader-status{font-size:11.5px;letter-spacing:.28em;color:var(--dim);text-transform:uppercase;min-height:16px}

/* ---------- top bar ---------- */
.topbar{
  position:fixed;top:0;left:0;right:0;z-index:40;
  display:flex;align-items:center;justify-content:space-between;gap:14px;
  padding:12px 20px;
  background:linear-gradient(180deg,rgba(0,0,0,.75),rgba(0,0,0,0));
  pointer-events:none;
}
.topbar>*{pointer-events:auto}
.brand{display:flex;align-items:center;gap:9px;color:var(--txt);font-weight:800;letter-spacing:.16em;font-size:14px}
.brand:hover{text-decoration:none}
.brand i{font-style:normal;color:var(--dim)}
.unofficial-chip{
  font-style:normal;font-weight:700;font-size:9.5px;letter-spacing:.16em;color:#000;
  background:var(--warn);border-radius:3px;padding:2px 6px;transform:translateY(-1px);
}
.top-right{display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:flex-end}
.clock{font-size:11.5px;letter-spacing:.18em;color:var(--muted);font-variant-numeric:tabular-nums;white-space:nowrap}
.warp{display:flex;border:1px solid var(--line);border-radius:5px;overflow:hidden;backdrop-filter:var(--blur);background:var(--panel)}
.warp button{
  background:none;border:0;color:var(--muted);font-family:var(--din);font-size:10.5px;font-weight:700;
  letter-spacing:.12em;padding:6px 10px;cursor:pointer;border-right:1px solid var(--line);
}
.warp button:last-child{border-right:0}
.warp button.on{background:#fff;color:#000}
.warp button:hover:not(.on){color:var(--txt)}

/* ---------- HUD ---------- */
#hud{
  position:fixed;top:56px;left:20px;z-index:30;
  font-size:11px;letter-spacing:.22em;color:var(--muted);text-transform:uppercase;
  display:flex;flex-direction:column;gap:4px;pointer-events:none;
}
#hud b{color:var(--txt);font-variant-numeric:tabular-nums}
#hud .hud-live{color:var(--ok)}

#hero-copy{
  position:fixed;left:20px;bottom:96px;z-index:30;max-width:560px;pointer-events:none;
  transition:opacity 1s ease,transform 1s ease;
}
#hero-copy.gone{opacity:0;transform:translateY(12px)}
#hero-copy .kicker{color:var(--muted);letter-spacing:.34em;font-size:11px;margin:0 0 10px;text-transform:uppercase}
#hero-copy h1{
  font-size:clamp(26px,4.4vw,46px);font-weight:800;letter-spacing:.05em;line-height:1.08;
  text-transform:uppercase;margin:0 0 10px;text-shadow:0 2px 30px rgba(0,0,0,.8);
}
#hero-copy p{margin:0;color:#cdd3da;font-size:15px;text-shadow:0 1px 16px rgba(0,0,0,.9)}
#hero-copy .hint{margin-top:12px;color:var(--dim);font-size:11.5px;letter-spacing:.2em;text-transform:uppercase}

/* ---------- hover tooltip ---------- */
#tip{
  position:fixed;z-index:35;pointer-events:none;display:none;
  background:var(--panel-solid);border:1px solid var(--line);border-radius:4px;
  padding:4px 9px;font-size:11.5px;letter-spacing:.12em;white-space:nowrap;
}

/* ---------- satellite card ---------- */
#sat-card{
  position:fixed;top:64px;right:16px;z-index:36;width:min(340px,calc(100vw - 32px));
  background:var(--panel);backdrop-filter:var(--blur);
  border:1px solid var(--line);border-left:3px solid var(--accent);border-radius:8px;
  padding:16px 18px 14px;display:none;
}
#sat-card.show{display:block;animation:cardIn .25s ease}
@keyframes cardIn{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:none}}
#sat-card .sc-name{font-size:18px;font-weight:800;letter-spacing:.06em}
#sat-card .sc-sub{color:var(--muted);font-size:11.5px;letter-spacing:.16em;margin:2px 0 12px;text-transform:uppercase}
.sc-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px 14px;margin-bottom:10px}
.sc-cell{display:flex;flex-direction:column;gap:1px}
.sc-cell s{text-decoration:none;font-size:9.5px;letter-spacing:.2em;color:var(--dim);text-transform:uppercase}
.sc-cell b{font-size:14.5px;font-variant-numeric:tabular-nums;font-weight:700}
#sat-card .sc-foot{color:var(--dim);font-size:11px;letter-spacing:.06em;border-top:1px solid var(--line-soft);padding-top:9px;display:flex;justify-content:space-between;gap:8px;align-items:center}
.sc-close{position:absolute;top:8px;right:10px;background:none;border:0;color:var(--dim);font-size:18px;cursor:pointer;line-height:1}
.sc-close:hover{color:var(--txt)}

/* ---------- dock ---------- */
#dock{
  position:fixed;bottom:14px;left:50%;transform:translateX(-50%);z-index:45;
  display:flex;gap:6px;padding:6px;border-radius:12px;
  background:var(--panel);backdrop-filter:var(--blur);border:1px solid var(--line);
}
#dock button{
  display:flex;flex-direction:column;align-items:center;gap:3px;
  background:none;border:0;border-radius:8px;color:var(--muted);cursor:pointer;
  font-family:var(--din);font-size:9.5px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  padding:8px 14px;transition:background .15s,color .15s;
}
#dock button svg{width:17px;height:17px;fill:currentColor}
#dock button:hover{color:var(--txt);background:rgba(255,255,255,.06)}
#dock button.on{color:#000;background:#fff}

/* ---------- panels ---------- */
#backdrop{position:fixed;inset:0;z-index:48;background:rgba(0,0,0,.45);display:none}
#backdrop.show{display:block}
.panel{
  position:fixed;top:0;right:0;bottom:0;z-index:50;width:min(440px,100vw);
  background:var(--panel);backdrop-filter:var(--blur);border-left:1px solid var(--line);
  transform:translateX(102%);transition:transform .28s cubic-bezier(.2,.8,.2,1);
  display:flex;flex-direction:column;
}
.panel.open{transform:none}
.panel-head{
  display:flex;align-items:baseline;justify-content:space-between;gap:10px;
  padding:18px 22px 12px;border-bottom:1px solid var(--line-soft);
}
.panel-head h2{margin:0;font-size:15px;font-weight:800;letter-spacing:.22em;text-transform:uppercase}
.panel-head .num{color:var(--dim);font-size:11px;letter-spacing:.3em;margin-right:8px}
.panel-close{background:none;border:0;color:var(--dim);font-size:20px;cursor:pointer;line-height:1}
.panel-close:hover{color:var(--txt)}
.panel-body{overflow-y:auto;padding:18px 22px 90px;flex:1;overscroll-behavior:contain}
.panel-body::-webkit-scrollbar{width:8px}
.panel-body::-webkit-scrollbar-thumb{background:#262b34;border-radius:4px}
.panel h3{font-size:11.5px;color:var(--muted);letter-spacing:.24em;margin:26px 0 10px;font-weight:700;text-transform:uppercase}
.panel h3:first-child{margin-top:0}
.panel p{color:#cdd3da;font-size:14px}
.section-note{color:var(--muted);font-size:13px}
.microcopy{color:var(--dim);font-size:12.5px}
.src{font-size:11px;color:var(--dim);white-space:nowrap}
.src:hover{color:var(--accent)}

/* daily brief */
.brief{border:1px solid var(--line);border-left:3px solid var(--accent);border-radius:6px;background:rgba(15,18,26,.6);padding:14px 16px;margin-bottom:6px}
.brief .b-date{font-size:10px;letter-spacing:.26em;color:var(--accent);font-weight:700;text-transform:uppercase}
.brief .b-fact{margin:8px 0 6px;font-size:14.5px;color:#e7ebf0}
.brief .b-src{font-size:11.5px;color:var(--dim)}
.brief-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin:12px 0 0}
.bstat{display:flex;flex-direction:column;gap:1px;border:1px solid var(--line-soft);border-radius:5px;padding:8px 10px}
.bstat s{text-decoration:none;font-size:9px;letter-spacing:.18em;color:var(--dim);text-transform:uppercase}
.bstat b{font-size:16px;font-variant-numeric:tabular-nums}

/* constellation controls */
.shell-row{display:flex;align-items:center;gap:10px;padding:7px 0;border-bottom:1px solid var(--line-soft);font-size:13.5px}
.shell-row:last-child{border-bottom:0}
.shell-dot{width:9px;height:9px;border-radius:2px;flex:none}
.shell-row b{font-variant-numeric:tabular-nums;margin-left:auto;color:var(--muted);font-weight:600}
.shell-row input{accent-color:var(--accent)}
.searchbar{display:flex;gap:8px;margin:4px 0 2px}
.searchbar input{
  flex:1;background:#05070a;border:1px solid #39404d;border-radius:4px;color:var(--txt);
  font-family:var(--din);font-size:14px;padding:9px 12px;min-width:0;
}
.searchbar input:focus{outline:2px solid var(--accent);outline-offset:1px}
.row-btns{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}

/* buttons */
.btn{
  display:inline-block;padding:10px 18px;border:1px solid #3a4150;border-radius:5px;
  color:var(--txt);font-family:var(--din);font-size:11.5px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;
  background:rgba(255,255,255,.03);cursor:pointer;transition:background .15s,border-color .15s;
}
.btn:hover{background:#161a22;text-decoration:none;border-color:#4d5564}
.btn-primary{background:#fff;color:#000;border-color:#fff}
.btn-primary:hover{background:#dfe3e8;border-color:#dfe3e8}
.btn-sm{padding:7px 12px;font-size:10.5px}
.linklike{background:none;border:0;padding:0;color:var(--accent);cursor:pointer;font:inherit;font-size:12.5px}
.linklike:hover{text-decoration:underline}

/* data tables (ported) */
.datatable{width:100%;border-collapse:collapse;border:1px solid var(--line);background:rgba(8,10,14,.5);font-size:13px}
.datatable th,.datatable td{padding:8px 10px;border-bottom:1px solid var(--line-soft);text-align:left;vertical-align:top}
.datatable thead th{font-size:9.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--dim);background:rgba(20,24,32,.6)}
.datatable tbody th{width:38%;color:var(--muted);font-weight:600;font-size:12px;letter-spacing:.04em}
.datatable tr:last-child td,.datatable tr:last-child th{border-bottom:0}

/* lockup counters (ported) */
.lockup-counters{display:grid;grid-template-columns:1fr;gap:8px;margin:0 0 14px}
.counter{border:1px solid var(--line);background:rgba(8,10,14,.5);border-radius:6px;padding:12px 14px;display:flex;flex-direction:column;gap:2px}
.counter-label{font-size:9.5px;letter-spacing:.2em;color:var(--dim);text-transform:uppercase}
.counter-value{font-size:22px;font-weight:800;font-variant-numeric:tabular-nums}
.counter-foot{font-size:11.5px;color:var(--muted)}

/* launches (ported) */
.next-launch{
  display:flex;flex-direction:column;gap:4px;border:1px solid var(--line);border-left:3px solid var(--accent);
  background:rgba(8,10,14,.5);border-radius:6px;padding:14px 16px;margin-bottom:16px;
}
.next-launch-clock{font-size:26px;font-weight:800;letter-spacing:.05em;font-variant-numeric:tabular-nums}
.next-launch-name{color:var(--muted);font-size:12.5px;letter-spacing:.05em}
.launch-list{list-style:none;margin:0 0 8px;padding:0;border:1px solid var(--line);background:rgba(8,10,14,.5)}
.launch-list li{display:grid;grid-template-columns:1fr auto;gap:2px 10px;padding:10px 12px;border-bottom:1px solid var(--line-soft)}
.launch-list li:last-child{border-bottom:0}
.launch-empty{color:var(--dim)}
.l-mission{font-weight:700;letter-spacing:.02em;font-size:13.5px}
.l-vehicle{color:var(--muted);font-size:10.5px;letter-spacing:.06em;text-transform:uppercase}
.l-time{grid-column:1;color:var(--dim);font-size:11.5px;font-variant-numeric:tabular-nums}
.l-status{grid-column:2;grid-row:1 / span 3;align-self:center;font-size:9px;font-weight:800;letter-spacing:.12em;padding:3px 7px;border-radius:3px;border:1px solid var(--line);color:var(--muted);white-space:nowrap}
.l-status.ok{color:#062;background:var(--ok);border-color:var(--ok)}
.l-status.go{color:var(--ok);border-color:var(--ok)}
.l-status.bad{color:#400;background:var(--bad);border-color:var(--bad)}
.l-status.tbd{color:var(--warn);border-color:var(--warn)}

/* roadmap cards (ported, single column) */
.road-card{border:1px solid var(--line);background:rgba(8,10,14,.5);border-radius:6px;padding:14px 16px 12px;display:flex;flex-direction:column;gap:7px;margin-bottom:10px}
.road-card h4{font-size:14px;letter-spacing:.04em;margin:0;text-transform:uppercase;font-weight:800}
.road-card p{margin:0;font-size:13px}
.road-when{font-size:9.5px;letter-spacing:.24em;color:var(--accent);font-weight:700}
.subchart{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;align-items:end;height:110px;margin:8px 0 2px;padding:0 2px}
.subbar{display:flex;flex-direction:column;justify-content:flex-end;align-items:center;gap:3px;height:100%;font-variant-numeric:tabular-nums}
.subbar i{display:block;width:100%;height:var(--h);background:linear-gradient(180deg,var(--accent),#27407e);border-radius:2px 2px 0 0}
.subbar b{font-size:11px}
.subbar s{text-decoration:none;font-size:9px;color:var(--dim);letter-spacing:.08em}

/* TV slots */
.consent-gate{border:1px dashed #39404d;border-radius:6px;background:rgba(8,10,14,.5);padding:20px 16px;text-align:center}
.consent-gate p{margin:0 0 12px}
.gate-foot{color:var(--dim);font-size:11.5px;margin-top:10px!important}
.tv-slot{border:1px solid var(--line);border-radius:6px;background:var(--panel-solid);overflow:hidden;margin-bottom:12px}
.tv-chart{height:340px}
#tv-timeline{height:420px}
#tv-financials{height:380px}
.tv-credit{color:var(--dim);font-size:11.5px}

/* links + FAQ (ported) */
.linkcol ul{list-style:none;margin:0 0 6px;padding:0;display:grid;gap:7px}
.linkcol a{color:#cdd3da;font-size:13.5px}
.linkcol a:hover{color:var(--accent)}
.faq dt{font-weight:800;letter-spacing:.03em;text-transform:uppercase;font-size:12.5px;margin:18px 0 6px}
.faq dd{margin:0;color:#cdd3da;font-size:13.5px}
.faq{margin:0}

/* alerts (ported) */
#sub-form{display:flex;gap:8px;flex-wrap:wrap;margin:12px 0 6px}
#sub-form input[type=email]{
  flex:1;min-width:180px;background:#05070a;border:1px solid #39404d;border-radius:4px;
  color:var(--txt);font-family:var(--din);font-size:14px;padding:10px 12px;
}
#sub-form input[type=email]:focus{outline:2px solid var(--accent);outline-offset:1px}
.hp-field{position:absolute;left:-5000px;width:1px;height:1px;opacity:0}
#sub-msg:empty{display:none}
#sub-msg.ok{color:var(--ok)}
#sub-msg.err{color:var(--bad)}

/* overhead result */
#overhead-result{border:1px solid var(--line);border-radius:6px;background:rgba(8,10,14,.5);padding:12px 14px;margin-top:10px;display:none}
#overhead-result.show{display:block}
#overhead-result b{font-variant-numeric:tabular-nums}
#overhead-result ol{margin:8px 0 0;padding-left:18px;color:var(--muted);font-size:12.5px}

/* legal line */
#legal-line{
  position:fixed;right:14px;bottom:14px;z-index:38;color:var(--dim);font-size:10px;letter-spacing:.14em;
  text-transform:uppercase;text-align:right;pointer-events:auto;text-shadow:0 1px 8px #000;
}
#legal-line a{color:var(--muted)}

/* toast */
#toast{
  position:fixed;left:50%;bottom:84px;transform:translateX(-50%);z-index:60;
  background:var(--panel-solid);border:1px solid var(--line);border-radius:6px;
  padding:8px 14px;font-size:12px;letter-spacing:.08em;display:none;
}
#toast.show{display:block;animation:cardIn .2s ease}

/* fallback (no WebGL) */
#fallback{position:fixed;inset:0;z-index:20;display:none;align-items:center;justify-content:center;text-align:center;padding:30px;background:radial-gradient(circle at 50% 120%, #0a1430 0%, #000 60%)}
#fallback.show{display:flex}
#fallback .fb-inner{max-width:520px}

/* ---------- mobile ---------- */
@media (max-width:760px){
  .topbar{padding:10px 12px}
  .clock{display:none}
  #hud{top:50px;left:12px;font-size:10px}
  #hero-copy{left:12px;right:12px;bottom:108px;max-width:none}
  #hero-copy h1{font-size:24px}
  #hero-copy p{font-size:13.5px}
  #sat-card{top:auto;bottom:78px;right:8px;left:8px;width:auto}
  #dock{bottom:8px;width:calc(100vw - 16px);justify-content:space-between;padding:5px}
  #dock button{padding:7px 8px;flex:1}
  .panel{top:auto;left:0;right:0;bottom:0;width:100%;max-height:78vh;border-left:0;border-top:1px solid var(--line);border-radius:14px 14px 0 0;transform:translateY(105%)}
  .panel.open{transform:none}
  .panel-body{padding:14px 16px 80px}
  #legal-line{display:none}
  .brief-stats{grid-template-columns:repeat(3,1fr)}
}
@media (prefers-reduced-motion:reduce){
  .panel{transition:none}
  #loader{transition:none}
}

/* ================= v3.0 FRONTIER — sci-fi layer ================= */
:root{--cyan:#67e8f9;--glow:0 0 12px rgba(103,232,249,.25)}

/* corner frame */
#frame{position:fixed;inset:10px;z-index:25;pointer-events:none}
#frame i{position:absolute;width:26px;height:26px;border:1px solid rgba(103,232,249,.4)}
#frame i:nth-child(1){top:0;left:0;border-right:0;border-bottom:0}
#frame i:nth-child(2){top:0;right:0;border-left:0;border-bottom:0}
#frame i:nth-child(3){bottom:0;left:0;border-right:0;border-top:0}
#frame i:nth-child(4){bottom:0;right:0;border-left:0;border-top:0}

/* loader transfer diagram */
#transfer{width:min(360px,76vw);height:auto;margin:6px 0 2px}
.loader-pct{font-size:12px;letter-spacing:.3em;color:var(--cyan);font-variant-numeric:tabular-nums}
#tship{filter:drop-shadow(0 0 4px #fff)}

/* destination bar */
#destbar{
  position:fixed;top:54px;left:50%;transform:translateX(-50%);z-index:42;
  display:flex;gap:2px;border:1px solid var(--line);border-radius:6px;overflow:hidden;
  background:var(--panel);backdrop-filter:var(--blur);box-shadow:var(--glow);
}
#destbar button{
  background:none;border:0;border-right:1px solid var(--line);color:var(--muted);cursor:pointer;
  font-family:var(--din);font-size:11px;font-weight:800;letter-spacing:.26em;padding:9px 18px;
  transition:color .15s,background .15s;
}
#destbar button:last-of-type{border-right:0}
#destbar button:hover:not(:disabled){color:var(--txt)}
#destbar button.on{background:rgba(103,232,249,.14);color:var(--cyan);text-shadow:0 0 8px rgba(103,232,249,.6)}
#destbar button:disabled{opacity:.35;cursor:wait}
#scale-chip{
  position:fixed;top:96px;left:50%;transform:translateX(-50%);z-index:41;
  font-size:9px;letter-spacing:.22em;color:var(--dim);background:rgba(0,0,0,.55);
  border:1px solid var(--line);border-radius:3px;padding:3px 9px;white-space:nowrap;
}

/* warp flash */
#warpfx{position:fixed;inset:0;z-index:90;pointer-events:none;opacity:0;background:
  radial-gradient(circle at 50% 50%, rgba(160,220,255,.55) 0%, rgba(60,110,255,.22) 35%, transparent 70%)}
#warpfx.go{animation:warp .85s ease-out}
@keyframes warp{0%{opacity:0}28%{opacity:1}100%{opacity:0}}

/* cinema button */
.cin-btn{
  background:var(--panel);border:1px solid var(--line);border-radius:5px;color:var(--muted);
  font-family:var(--din);font-size:10px;font-weight:800;letter-spacing:.2em;padding:7px 12px;cursor:pointer;
}
.cin-btn:hover{color:var(--txt);border-color:#4d5564}
.cin-btn.on{color:#000;background:var(--cyan);border-color:var(--cyan);box-shadow:var(--glow)}

/* MY SKY */
#btn-mysky{
  pointer-events:auto;margin-top:8px;align-self:flex-start;
  background:rgba(103,232,249,.08);border:1px solid rgba(103,232,249,.45);border-radius:4px;
  color:var(--cyan);font-family:var(--din);font-size:10px;font-weight:800;letter-spacing:.18em;
  padding:7px 11px;cursor:pointer;box-shadow:var(--glow);
}
#btn-mysky:hover{background:rgba(103,232,249,.16)}

/* time engine */
#time-engine{
  position:fixed;left:16px;bottom:16px;z-index:44;display:flex;flex-direction:column;gap:5px;
  background:var(--panel);backdrop-filter:var(--blur);border:1px solid var(--line);border-radius:8px;
  padding:10px 12px;min-width:178px;
  clip-path:polygon(0 0,calc(100% - 12px) 0,100% 12px,100% 100%,12px 100%,0 calc(100% - 12px));
}
.te-label{font-size:9px;letter-spacing:.3em;color:var(--dim)}
.te-btns{display:flex;gap:4px}
.te-btns button{
  flex:1;display:flex;flex-direction:column;align-items:center;gap:1px;
  background:rgba(255,255,255,.03);border:1px solid var(--line);border-radius:4px;color:var(--muted);
  font-family:var(--din);font-size:11px;padding:6px 4px;cursor:pointer;
}
.te-btns button s{text-decoration:none;font-size:8px;letter-spacing:.16em;color:var(--dim)}
.te-btns button.on{background:rgba(103,232,249,.15);border-color:rgba(103,232,249,.6);color:var(--cyan);box-shadow:var(--glow)}
.te-btns button.on s{color:var(--cyan)}
.te-note{font-size:9.5px;letter-spacing:.14em;color:var(--dim)}
.te-sim{font-size:9.5px;letter-spacing:.18em;color:var(--warn);font-weight:800}

/* market chip */
#market-chip{
  position:fixed;right:16px;bottom:46px;z-index:44;display:flex;flex-direction:column;gap:2px;align-items:flex-end;
  background:var(--panel);backdrop-filter:var(--blur);border:1px solid var(--line);border-radius:8px;
  padding:10px 14px;cursor:pointer;text-align:right;font-family:var(--din);
  clip-path:polygon(12px 0,100% 0,100% calc(100% - 12px),calc(100% - 12px) 100%,0 100%,0 12px);
}
#market-chip:hover{border-color:rgba(103,232,249,.5);box-shadow:var(--glow)}
#market-chip s{text-decoration:none;font-size:9px;letter-spacing:.26em;color:var(--dim)}
#market-chip b{font-size:13.5px;color:var(--txt);letter-spacing:.06em}
#market-chip i{font-style:normal;font-size:10px;letter-spacing:.12em;color:var(--cyan)}

/* POI card */
#poi-card{
  position:fixed;top:64px;right:16px;z-index:36;width:min(340px,calc(100vw - 32px));
  background:var(--panel);backdrop-filter:var(--blur);
  border:1px solid var(--line);border-left:3px solid var(--cyan);border-radius:8px;
  padding:16px 18px 14px;display:none;
}
#poi-card.show{display:block;animation:cardIn .25s ease}
.pc-type{
  display:inline-block;font-size:9px;font-weight:800;letter-spacing:.22em;color:#000;
  background:var(--cyan);border-radius:3px;padding:2px 8px;margin-bottom:8px;
}
.pc-type[data-t="PLANNED"]{background:var(--ok)}
.pc-type[data-t="CANDIDATE"]{background:var(--warn)}
.pc-type[data-t="HISTORIC"]{background:#d9a0ff}
.pc-type[data-t="ACTIVE"]{background:var(--accent);color:#fff}
.pc-type[data-t="LANDMARK"]{background:#9aa3ad}
.pc-blurb{margin:6px 0 12px;color:#dde3ea;font-size:14px}

/* sci-fi polish on existing chrome */
.panel{border-left:1px solid rgba(103,232,249,.35);box-shadow:-18px 0 50px rgba(0,0,0,.5)}
.panel::after{
  content:"";position:absolute;inset:0;pointer-events:none;opacity:.05;
  background:repeating-linear-gradient(0deg,transparent 0 2px,#9fdcff 2px 3px);
}
.panel-head h2{color:var(--cyan);text-shadow:0 0 10px rgba(103,232,249,.35)}
.panel-head .num::before{content:"// "}
#dock{box-shadow:var(--glow);clip-path:polygon(10px 0,calc(100% - 10px) 0,100% 10px,100% 100%,0 100%,0 10px)}
#dock button.on{background:var(--cyan)}
#sat-card{border-left-color:var(--cyan)}
#hud .hud-live{animation:blink 2.2s infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.35}}
.next-launch{border-left-color:var(--cyan)}
.brief{border-left-color:var(--cyan)}

/* ================= v4.0 GAME HUD ================= */
#crt{
  position:fixed;inset:0;z-index:24;pointer-events:none;
  background:
    radial-gradient(ellipse at center, transparent 58%, rgba(0,0,0,.42) 100%),
    repeating-linear-gradient(0deg, transparent 0 3px, rgba(120,180,255,.012) 3px 4px);
}
#scene{cursor:crosshair}
#scene:active{cursor:grabbing}

#telemetry{
  position:fixed;bottom:76px;left:50%;transform:translateX(-50%);z-index:43;
  display:flex;gap:22px;padding:7px 18px;border:1px solid var(--line);border-radius:5px;
  background:rgba(5,8,12,.72);backdrop-filter:var(--blur);
  font-variant-numeric:tabular-nums;white-space:nowrap;
}
#telemetry span{display:flex;flex-direction:column;align-items:center;gap:0}
#telemetry s{text-decoration:none;font-size:8px;letter-spacing:.24em;color:var(--dim)}
#telemetry b{font-size:11.5px;letter-spacing:.08em;color:var(--cyan);font-weight:700}

/* HUD boot-in */
#hud.boot > *{opacity:0;animation:bootline .5s ease forwards}
#hud.boot > :nth-child(1){animation-delay:.1s}
#hud.boot > :nth-child(2){animation-delay:.35s}
#hud.boot > :nth-child(3){animation-delay:.6s}
#hud.boot > :nth-child(4){animation-delay:.85s}
@keyframes bootline{from{opacity:0;transform:translateX(-8px);clip-path:inset(0 100% 0 0)}to{opacity:1;transform:none;clip-path:inset(0 0 0 0)}}

/* panel title decode */
.panel.open .panel-head h2{animation:decode .45s ease}
@keyframes decode{0%{letter-spacing:.6em;opacity:0;filter:blur(2px)}100%{letter-spacing:.22em;opacity:1;filter:none}}

/* sat card extras */
.sc-track{margin:0 0 10px;color:var(--dim);font-size:10px;letter-spacing:.1em}
.seo-line{margin-top:8px;color:#3c434d;font-size:10.5px;letter-spacing:.12em;text-transform:uppercase}

/* trading deck width on desktop */
@media (min-width:761px){
  #panel-markets{width:min(560px,100vw)}
}

/* v4 mobile */
@media (max-width:760px){
  #telemetry{bottom:auto;top:130px;gap:12px;padding:5px 10px}
  #telemetry s{font-size:7px}
  #telemetry b{font-size:10px}
  #crt{display:none}
}

/* v3 mobile */
@media (max-width:760px){
  #destbar{top:50px}
  #destbar button{padding:8px 12px;font-size:10px}
  #scale-chip{top:88px;font-size:8px;max-width:92vw;overflow:hidden;text-overflow:ellipsis}
  #time-engine{left:8px;bottom:74px;min-width:0;padding:8px 9px}
  .te-note{display:none}
  #market-chip{display:none}
  #poi-card{top:auto;bottom:78px;right:8px;left:8px;width:auto}
  #frame{display:none}
  #hero-copy{bottom:150px}
}
