:root{
  --bg:#101418; --panel:#171d23; --panel2:#1c242c; --line:#2a333d;
  --ink:#e9edf1; --muted:#8b97a4; --faint:#5b6773;
  --tsla:#f5b942; --spacex:#7fb4ff;
  --kept:#3ecf8e; --late:#d8c14a; --partial:#e8954d; --missed:#e05656;
  --abandoned:#76828e; --open:#5aa9e6; --false:#ff4d6d;
  --mono:'IBM Plex Mono',ui-monospace,SFMono-Regular,Menlo,monospace;
  --disp:'Space Grotesk',system-ui,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}*{transition:none!important;animation:none!important}}
body{background:var(--bg);color:var(--ink);font-family:var(--mono);font-size:13px;line-height:1.55}
.loading,.error{max-width:1240px;margin:80px auto;padding:0 20px;text-align:center;color:var(--muted)}
.loading{font-size:14px;letter-spacing:.08em}
.error p{margin-bottom:12px}
.error b{color:var(--ink)}
a{color:var(--open)}
.wrap{max-width:1240px;margin:0 auto;padding:0 20px 80px}

/* ---------- header ---------- */
header{padding:34px 0 18px;border-bottom:1px solid var(--line)}
header.compact{padding:20px 0 12px}
.headtop{display:flex;flex-wrap:wrap;align-items:flex-end;justify-content:space-between;gap:16px}
header.compact h1{font-family:var(--disp);font-weight:700;font-size:clamp(22px,3.2vw,36px);line-height:1.05;margin:4px 0 0;letter-spacing:-.01em}
.eyebrow{color:var(--tsla);letter-spacing:.22em;font-size:10px;text-transform:uppercase}
h1 .vs{color:var(--missed)}
.sub{color:var(--muted);max-width:100%;font-size:12px;margin-top:8px}
.statbar{display:flex;flex-wrap:wrap;gap:18px}
header.compact .statbar{margin:0;gap:14px}
.stat b{display:block;font-family:var(--disp);font-size:20px;font-weight:700}
header.compact .stat b{font-size:17px}
.stat span{color:var(--faint);font-size:10px;text-transform:uppercase;letter-spacing:.1em}

/* ---------- toolbar (search + scope) ---------- */
.toolbar{display:flex;flex-wrap:wrap;gap:8px;align-items:center;padding:10px 0 8px;
  position:sticky;top:0;z-index:30;background:linear-gradient(var(--bg) 90%,transparent)}
.search{flex:1;min-width:140px;max-width:280px;font-family:var(--mono);font-size:11.5px;
  color:var(--ink);background:var(--panel);border:1px solid var(--line);border-radius:3px;padding:5px 10px}
.search::placeholder{color:var(--faint)}
.search:focus{outline:2px solid var(--tsla);outline-offset:2px;border-color:var(--tsla)}
.scope-chips{display:flex;flex-wrap:wrap;gap:6px}

/* year range slider */
.yearslider{display:flex;align-items:center;gap:10px}
.yearslider .rowlabel{min-width:0}
.rng{position:relative;width:170px;height:20px}
.rng .track{position:absolute;top:50%;left:0;right:0;height:3px;transform:translateY(-50%);
  background:var(--line);border-radius:2px}
.rng .fill{position:absolute;top:0;bottom:0;background:var(--tsla);border-radius:2px}
.rng input[type=range]{position:absolute;top:0;left:0;width:100%;height:20px;margin:0;
  background:none;pointer-events:none;-webkit-appearance:none;appearance:none}
.rng input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;pointer-events:auto;
  width:13px;height:13px;border-radius:50%;background:var(--ink);border:2px solid var(--tsla);cursor:pointer}
.rng input[type=range]::-moz-range-thumb{pointer-events:auto;
  width:13px;height:13px;border-radius:50%;background:var(--ink);border:2px solid var(--tsla);cursor:pointer}
.rng input[type=range]:focus-visible::-webkit-slider-thumb{outline:2px solid var(--tsla);outline-offset:2px}
.yearvals{font-size:11px;color:var(--muted);min-width:74px;white-space:nowrap}
.chip{font-family:var(--mono);font-size:11px;color:var(--muted);background:var(--panel);
  border:1px solid var(--line);border-radius:3px;padding:4px 9px;cursor:pointer;transition:all .12s;white-space:nowrap}
.chip:hover{color:var(--ink);border-color:var(--faint)}
.chip.on{color:#0d1115;background:var(--ink);border-color:var(--ink);font-weight:600}
.chip.scope.on{background:var(--tsla);border-color:var(--tsla)}
.chip:focus-visible,.dot:focus-visible,.tog:focus-visible,button:focus-visible{outline:2px solid var(--tsla);outline-offset:2px}
.chip .n{opacity:.55;margin-left:4px;font-size:10px}
.chip.action{color:var(--ink);background:var(--panel2)}

/* ---------- chart layout ---------- */
.chartcard{background:var(--panel);border:1px solid var(--line);border-radius:6px;padding:10px;margin-top:4px}
.chart-layout{display:grid;grid-template-columns:132px minmax(0,1fr);gap:10px;align-items:start}
.catbar{display:flex;flex-direction:column;gap:4px;padding:4px 0}
.catbar .chip{width:100%;text-align:left;white-space:normal;line-height:1.35;padding:5px 8px;font-size:10px}
.catbar .chip.cat-all{font-weight:600;margin-bottom:2px}
.catbar .chip.cat-all.on{background:var(--tsla);border-color:var(--tsla);color:#0d1115}
@media(max-width:720px){.chart-layout{grid-template-columns:1fr}.catbar{display:none}}
.chart-main{min-width:0}
.charthead{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:8px;
  padding:0 2px 8px;border-bottom:1px solid var(--line);margin-bottom:6px}
.catselect{display:none;font-family:var(--mono);font-size:13px;color:var(--ink);background:var(--panel);
  border:1px solid var(--line);border-radius:3px;padding:6px 10px;cursor:pointer;max-width:220px}
.catselect:focus{outline:2px solid var(--tsla);outline-offset:2px;border-color:var(--tsla)}
@media(max-width:720px){.catselect{display:block;flex-shrink:0}}
.typebar{display:flex;flex-wrap:wrap;gap:6px;flex:1}
.typebar .chip{font-size:10.5px;padding:4px 8px}

/* market line toggle */
.layer-toggle{display:inline-flex;flex-shrink:0;border:1px solid var(--line);border-radius:4px;overflow:hidden}
.tog{font-family:var(--mono);font-size:10px;font-weight:600;letter-spacing:.04em;
  padding:5px 11px;border:none;background:var(--panel2);color:var(--faint);cursor:pointer;transition:all .12s}
.tog:hover{color:var(--muted)}
.tog.on{background:var(--bg);color:var(--tsla)}
.tog.on.t-spacex{color:var(--spacex)}

/* ---------- tooltip ---------- */
.tooltip{position:fixed;z-index:50;pointer-events:none;
  background:var(--panel2);border:1px solid var(--line);border-radius:5px;
  padding:10px 13px;max-width:320px;font-size:11.5px;line-height:1.5;
  box-shadow:0 6px 24px rgba(0,0,0,.45);color:var(--ink)}
.tooltip[hidden]{display:none}
.tooltip .tt-title{font-family:var(--disp);font-weight:700;font-size:13px;margin-bottom:5px}
.tooltip .tt-pill{display:inline-block;font-size:9.5px;font-weight:600;text-transform:uppercase;
  letter-spacing:.06em;padding:2px 7px;border-radius:3px;margin-bottom:6px}
.tooltip .tt-row{display:flex;justify-content:space-between;gap:10px;color:var(--muted)}
.tooltip .tt-row span:last-child{color:var(--ink);text-align:right}
.tooltip .tt-cat{color:var(--faint);font-size:10px;margin-top:4px}

/* ---------- chart ---------- */
.chartscroll{overflow-x:auto}
.chartscroll svg{display:block;width:100%;min-width:880px}
@media(max-width:720px){.chartscroll svg{min-width:0}}
svg{display:block}
.gridline{stroke:#222b34;stroke-width:1}
.axis{fill:var(--faint);font-size:10px;font-family:var(--mono)}
.pricelabel{font-size:10px;font-weight:600}
.stack-stem{stroke:var(--faint);stroke-width:1;opacity:.4}
.dot{cursor:pointer;transition:r .1s}
.dot:hover{stroke:#fff;stroke-width:1.5}
.dot.sel{stroke:#fff;stroke-width:2}
.dot.dim{opacity:.14;pointer-events:none}
.arc{fill:none;stroke-width:1.6;stroke-dasharray:5 4;opacity:.95}
.arcsolid{fill:none;stroke-width:1.6}
.evt{font-size:9.5px;fill:var(--faint)}
.legend{display:flex;flex-wrap:wrap;gap:12px;padding:8px 2px 4px;color:var(--muted);font-size:10.5px}
.legend i{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:5px;vertical-align:-1px}
.chartnote{color:var(--faint);font-size:10px;padding:2px 2px 4px}

/* ---------- list + detail ---------- */
.main{display:grid;grid-template-columns:2fr 1fr;gap:18px;margin-top:18px}
@media(max-width:920px){.main{grid-template-columns:1fr}.detail{position:static!important;max-height:none!important}}
.claimrow{display:grid;grid-template-columns:84px 1fr auto;gap:12px;align-items:baseline;
  padding:11px 12px;border:1px solid transparent;border-bottom:1px solid var(--line);cursor:pointer}
.claimrow:hover{background:var(--panel)}
.claimrow.sel{background:var(--panel2);border:1px solid var(--faint);border-radius:4px}
.claimrow .d{color:var(--faint);font-size:11px}
.claimrow .t{font-size:12.5px}
.claimrow .t small{display:block;color:var(--muted);font-size:11px;margin-top:2px}
.pill{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;padding:3px 8px;border-radius:3px;white-space:nowrap}
.stat .red{color:var(--missed)} .stat .amber{color:var(--tsla)} .stat .blue{color:var(--open)} .stat .green{color:var(--kept)}
.yeardiv{color:var(--tsla);font-family:var(--disp);font-weight:700;font-size:15px;padding:20px 12px 6px;border-bottom:1px solid var(--line)}
.empty{color:var(--muted);padding:30px 12px}

.detail{position:sticky;top:88px;align-self:start;max-height:calc(100vh - 100px);overflow-y:auto;
  background:var(--panel);border:1px solid var(--line);border-radius:6px;padding:18px}
.detail .cat{color:var(--faint);font-size:10px;text-transform:uppercase;letter-spacing:.16em}
.detail h3{font-family:var(--disp);font-size:18px;line-height:1.25;margin:7px 0 12px}
.detail blockquote{border-left:3px solid var(--tsla);padding:8px 0 8px 12px;color:var(--ink);
  font-size:12.5px;margin:12px 0;background:var(--panel2);border-radius:0 4px 4px 0}
.kv{display:grid;grid-template-columns:118px 1fr;gap:6px 10px;font-size:12px;margin:12px 0}
.kv dt{color:var(--faint)} .kv dd{color:var(--ink)}
.qtybox{display:flex;gap:10px;margin:12px 0}
.qtybox div{flex:1;background:var(--panel2);border:1px solid var(--line);border-radius:4px;padding:9px 11px}
.qtybox b{display:block;font-family:var(--disp);font-size:17px}
.qtybox span{color:var(--faint);font-size:10px;text-transform:uppercase;letter-spacing:.1em}
.mkt{background:var(--panel2);border:1px solid var(--line);border-radius:4px;padding:10px 12px;margin:12px 0;font-size:12px}
.mkt b{color:var(--tsla)} .mkt .sx{color:var(--spacex)}
.note{color:var(--muted);font-size:12px;margin:10px 0}
.srclink{font-size:11.5px;word-break:break-all}
.placeholder{color:var(--faint);text-align:center;padding:60px 14px}
.detail .pill{display:inline-block;margin-bottom:4px}
footer{margin-top:46px;color:var(--faint);font-size:11px;border-top:1px solid var(--line);padding-top:16px;max-width:90ch}
footer p{margin-bottom:8px}
.version{margin-top:12px;font-size:10px;letter-spacing:.1em;text-transform:uppercase;opacity:.45}
