/* ═══ Manja desk · maahaa.dev · Cosmic Engineering ═══ */
:root{
  color-scheme:dark;
  --ink:#0a0612;--ink-2:#15102a;--ink-3:#1c1635;
  --paper:#f5ede0;--paper-2:#d6cdba;--muted:#8a7f99;
  --gold:#f4a93b;--gold-2:#d97a1f;--terra:#c54a2c;--violet:#7a5ec7;--green:#5fae6b;
  --rule:rgba(245,237,224,.08);--rule-2:rgba(245,237,224,.18);--rule-3:rgba(245,237,224,.32);
  --bar:rgba(10,6,18,.9);
  --font-display:'Fraunces','Times New Roman',serif;
  --font-body:'Outfit',system-ui,-apple-system,sans-serif;
  --font-mono:'JetBrains Mono',ui-monospace,Menlo,monospace;
  --h1:clamp(2rem,8vw,3rem);--h3:clamp(1.1rem,3.6vw,1.4rem);
  --body:clamp(1.02rem,3.6vw,1.12rem);--small:clamp(.9rem,3vw,.98rem);--micro:clamp(.74rem,2.6vw,.82rem);
  --r1:2px;--r2:4px;--r3:8px;--ease:cubic-bezier(.16,1,.3,1);
}
:root[data-theme="light"]{
  color-scheme:light;
  --ink:#f3ece0;--ink-2:#fbf7ee;--ink-3:#ece3d4;
  --paper:#241c33;--paper-2:#4d4463;--muted:#7c7290;
  --gold:#b3700f;--gold-2:#925b0a;--terra:#b0421f;--violet:#5d44a8;--green:#3f7d4a;
  --rule:rgba(36,28,51,.10);--rule-2:rgba(36,28,51,.20);--rule-3:rgba(36,28,51,.34);
  --bar:rgba(243,236,224,.92);
}
:root[data-theme="light"] .surface::after{opacity:.22}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
body{margin:0;background:var(--ink);color:var(--paper);font-family:var(--font-body);font-weight:400;font-size:var(--body);line-height:1.5;-webkit-font-smoothing:antialiased;padding-bottom:40px}
h1,h3{font-family:var(--font-display);font-weight:300;letter-spacing:-.025em;line-height:1.06;margin:0}
h1{font-size:var(--h1);font-weight:200}h3{font-size:var(--h3);font-weight:400}
.it{font-style:italic;color:var(--gold)}
.mono{font-family:var(--font-mono)}
/* atmosphere — never a flat ground */
.surface{position:relative;isolation:isolate}
.surface::before{content:'';position:fixed;inset:0;z-index:0;pointer-events:none;background:radial-gradient(ellipse 80% 50% at 78% 10%,rgba(122,94,199,.11) 0%,transparent 55%),radial-gradient(ellipse 60% 40% at 10% 90%,rgba(244,169,59,.06) 0%,transparent 55%)}
.surface::after{content:'';position:fixed;inset:0;z-index:0;pointer-events:none;opacity:.5;mix-blend-mode:overlay;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/><feColorMatrix values='0 0 0 0 0.96 0 0 0 0 0.93 0 0 0 0 0.88 0 0 0 0.04 0'/></filter><rect width='200' height='200' filter='url(%23n)'/></svg>")}
#root{position:relative;z-index:1;max-width:680px;margin:0 auto;padding:0 20px}
header{position:sticky;top:0;z-index:10;background:var(--bar);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid var(--rule);padding:max(28px,env(safe-area-inset-top)) 24px 16px;margin:0}
.hrow{display:flex;align-items:center;justify-content:space-between;gap:12px;max-width:680px;margin:0 auto}
.brand{display:flex;align-items:center;gap:10px}
.mark{width:26px;height:26px;color:var(--paper)}
.ttl{font-family:var(--font-display);font-size:var(--h3);font-weight:300}
.sub{font-family:var(--font-mono);font-size:var(--micro);color:var(--muted);letter-spacing:.12em;text-transform:uppercase;margin-top:2px}
.themebtn{background:transparent;border:1px solid var(--rule-2);border-radius:var(--r1);color:var(--gold);padding:7px;display:flex;cursor:pointer;line-height:0}.themebtn:active{border-color:var(--gold)}
.eyebrow{font-family:var(--font-mono);font-size:var(--micro);letter-spacing:.22em;text-transform:uppercase;color:var(--gold);font-weight:400;margin:22px 0 8px}
.eyebrow .num{color:var(--paper-2);margin-right:.6em}
/* desk summary strip */
.strip{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--rule);border:1px solid var(--rule);border-radius:var(--r2);overflow:hidden;margin-top:14px}
.cell{background:var(--ink-2);padding:12px 12px 11px}
.cell .k{font-family:var(--font-mono);font-size:var(--micro);letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.cell .v{font-family:var(--font-mono);font-size:1.28rem;font-weight:500;margin-top:3px;letter-spacing:-.01em}
.cell .vsub{font-family:var(--font-mono);font-size:var(--micro);margin-top:2px}
/* market context bar */
.mkt{display:flex;flex-wrap:wrap;gap:6px 20px;align-items:center;margin-top:14px;padding:11px 13px;background:var(--ink-2);border:1px solid var(--rule);border-radius:var(--r2);font-family:var(--font-mono);font-size:var(--small)}
.mkt .mk{color:var(--muted);font-size:var(--micro);letter-spacing:.08em;text-transform:uppercase;margin-right:6px}
.mkt b{font-weight:500;color:var(--paper-2)}
.bd{display:inline-flex;height:7px;width:84px;border-radius:99px;overflow:hidden;background:var(--terra);vertical-align:middle;margin-left:2px}
.bd i{display:block;height:100%;background:var(--green)}
/* movers strip */
.movers{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:14px}
.mov{background:var(--ink-2);border:1px solid var(--rule);border-radius:var(--r2);padding:11px 12px}
.mov .mh{font-family:var(--font-mono);font-size:var(--micro);letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:7px}
.mov .mr{display:flex;justify-content:space-between;gap:8px;font-family:var(--font-mono);font-size:var(--small);padding:3px 0}
.mov .ms{color:var(--paper);font-family:var(--font-body)}
.mov .mb{font-family:var(--font-mono);font-size:var(--micro);color:var(--muted)}
/* book cards */
.book{background:var(--ink-2);border:1px solid var(--rule);border-radius:var(--r3);padding:15px 15px 6px;margin:12px 0;animation:fade .3s var(--ease)}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.book.killed{border-color:var(--terra)}
.bhead{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;cursor:pointer}
.bname{font-family:var(--font-display);font-size:1.18rem;font-weight:400}
.bsharpe{font-family:var(--font-mono);font-size:var(--micro);color:var(--gold);letter-spacing:.08em;margin-top:2px}
.bpnl{font-family:var(--font-mono);font-size:1.46rem;font-weight:500;letter-spacing:-.02em;line-height:1}
.bday{font-family:var(--font-mono);font-size:var(--micro);margin-top:3px}
.bplabel{font-family:var(--font-mono);font-size:var(--micro);color:var(--muted);letter-spacing:.06em;text-transform:uppercase}
.pos{color:var(--green)}.neg{color:var(--terra)}.flat{color:var(--paper-2)}
.spark{margin:10px 0 2px;height:30px;width:100%;display:block}
.bmeta{display:flex;flex-wrap:wrap;gap:4px 16px;margin-top:9px;font-family:var(--font-mono);font-size:var(--micro);color:var(--muted)}
.bmeta b{color:var(--paper-2);font-weight:500}
.bmeta-row{display:flex;justify-content:space-between;width:100%}
.bmeta-row span{flex:1}
.bmeta-row span:last-child{text-align:right}
.kill{display:inline-block;font-family:var(--font-mono);font-size:var(--micro);color:var(--terra);border:1px solid var(--terra);border-radius:var(--r1);padding:1px 6px;letter-spacing:.1em;text-transform:uppercase}
/* positions table (collapsed by default) */
.postbl{margin-top:11px;border-top:1px solid var(--rule);padding:0 4px;display:none}
.book.open .postbl{display:block}
.prow{display:grid;grid-template-columns:1fr auto auto auto auto;gap:10px;padding:8px 4px;border-bottom:1px solid var(--rule);font-family:var(--font-mono);font-size:var(--small);align-items:center;white-space:nowrap}
.prow:last-child{border-bottom:none}
.phead{background:var(--ink-3);font-weight:500;border-bottom:1px solid var(--rule-2);margin-bottom:2px}
.phead .psym{color:var(--muted);font-size:var(--micro);text-transform:uppercase;letter-spacing:.08em}
.phead .pnum,.phead .pday{text-align:right;color:var(--muted);font-size:var(--micro);text-transform:uppercase;letter-spacing:.08em}
.psym{color:var(--paper);font-weight:500;font-family:var(--font-body)}
.pnum{text-align:right;color:var(--paper-2);font-size:var(--micro)}
.pday{text-align:right;font-size:var(--micro)}
/* positions table - proper alignment */
.postbl table { width:100%; border-collapse:collapse; table-layout:fixed; font-family:var(--font-mono); font-size:var(--small); }
.postbl th, .postbl td { padding:6px 4px; text-align:left; border-bottom:1px solid var(--rule); }
.postbl th { color:var(--muted); font-size:var(--micro); text-transform:uppercase; letter-spacing:.08em; font-weight:500; text-align:left; }
.postbl th.num, .postbl td.num { text-align:right; color:var(--paper-2); }
.postbl th.day, .postbl td.day { text-align:right; }
.postbl tr:last-child td { border-bottom:none; }
.caret{color:var(--muted);font-family:var(--font-mono);font-size:var(--small);transition:transform .2s}
.book.open .caret{transform:rotate(90deg)}
.book.open .rebal{display:block !important}
/* box health footer */
.box{margin:26px 0 0;padding:14px;border:1px solid var(--rule);border-radius:var(--r3);background:var(--ink-2)}
.box .row{display:flex;flex-wrap:wrap;gap:6px 18px;font-family:var(--font-mono);font-size:var(--micro);color:var(--muted)}
.box b{color:var(--paper-2);font-weight:500}
.warn{color:var(--gold)}
.foot{margin:20px 0 8px;font-family:var(--font-mono);font-size:var(--micro);color:var(--muted);text-align:center;letter-spacing:.06em}
.err{padding:30px 16px;text-align:center;color:var(--muted);font-family:var(--font-mono);font-size:var(--small)}

/* ── Tab strip ─────────────────────────────────────────────────────────────── */
.tabnav{display:flex;overflow-x:auto;gap:0;margin:10px 0 0;padding:0 24px;scrollbar-width:none;-webkit-overflow-scrolling:touch;max-width:100%;border-bottom:1px solid var(--rule);position:relative}
.tabnav::-webkit-scrollbar{display:none}
.hrow{display:flex;align-items:center;justify-content:space-between;gap:12px;max-width:680px;margin:0 auto}
/* Tab underline: the active underline slides via CSS transform so it eases rather than jumps */
.tab{background:transparent;border:none;border-bottom:2px solid transparent;padding:8px 14px 9px;font-family:var(--font-mono);font-size:var(--micro);letter-spacing:.16em;text-transform:uppercase;color:var(--muted);cursor:pointer;white-space:nowrap;transition:color .2s var(--ease),border-color .2s var(--ease);flex-shrink:0;border-radius:0;margin-bottom:-1px}
.tab:hover{color:var(--paper-2)}
.tab:focus-visible{outline:1px solid var(--gold);outline-offset:-3px;border-radius:2px}
.tab.active{color:var(--gold);border-bottom-color:var(--gold)}

/* ── Market tab ─────────────────────────────────────────────────────────────── */
.mkt-tab{animation:fade .3s var(--ease)}

/* — States: loading / empty / stale — */
.mkt-state{display:flex;flex-direction:column;align-items:center;gap:10px;padding:48px 20px;text-align:center}
.mkt-state-icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px}
.mkt-state-icon--flat svg{opacity:.38}
.mkt-state-text{font-size:var(--small);color:var(--paper-2);letter-spacing:.06em}
.mkt-state-sub{font-size:var(--micro);color:var(--muted);letter-spacing:.06em;margin-top:2px}

/* Loading spinner */
.mkt-spinner{animation:mkt-spin 1.2s linear infinite}
@keyframes mkt-spin{to{transform:rotate(360deg)}}

/* Stale banner — terracotta, tight, honest */
.mkt-stale{font-family:var(--font-mono);font-size:var(--micro);letter-spacing:.08em;color:var(--terra);background:rgba(197,74,44,.08);border:1px solid rgba(197,74,44,.22);border-radius:var(--r2);padding:6px 12px;margin-top:14px;text-align:center}

/* — Breadth hero panel — */
.mkt-section-label{margin:20px 0 10px}

.mkt-breadth{display:flex;flex-wrap:wrap;align-items:center;gap:16px;padding:18px;background:var(--ink-2);border:1px solid var(--rule);border-radius:var(--r3)}
/* Entrance: visible by default; class adds the slide-up animation */
.mkt-breadth--entrance{opacity:1;transform:none}
.mkt-breadth--visible{animation:mkt-breadth-in .4s var(--ease) both}
@keyframes mkt-breadth-in{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}

/* Gauge hero: enlarged for focal point */
.mkt-breadth-gauge{flex-shrink:0;width:120px;height:72px}
.gauge{width:100%;height:100%;overflow:visible}

/* Needle ease-in animation (applied after inject via initMarketMotion) */
.gauge-needle{transform-origin:center;transition:none}
.gauge-needle--animated{transition:opacity .25s var(--ease)}

.mkt-breadth-stats{display:grid;grid-template-columns:1fr 1fr;gap:6px 22px;flex:1;min-width:120px}
.mkt-bstat{display:flex;flex-direction:column;gap:1px}
.mkt-bstat .mono.muted{font-family:var(--font-mono);font-size:var(--micro);letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.mkt-bstat-val{font-family:var(--font-mono);font-size:1.18rem;font-weight:500;letter-spacing:-.01em}
.mkt-breadth-meta{width:100%;font-family:var(--font-mono);font-size:var(--micro);color:var(--muted);letter-spacing:.06em;margin-top:4px;padding-top:10px;border-top:1px solid var(--rule)}

/* — Index cards grid — */
.mkt-indices{display:grid;grid-template-columns:repeat(auto-fill,minmax(148px,1fr));gap:8px;margin-top:0}
/* Cards are visible by default; --visible class adds staggered entrance */
.mkt-card--entrance{opacity:1;transform:none}
.mkt-card--visible{animation:mkt-card-in .36s var(--ease) calc(var(--i, 0) * 55ms) both}
@keyframes mkt-card-in{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

.mkt-card{background:var(--ink-2);border:1px solid var(--rule);border-radius:var(--r2);padding:12px 13px}
/* Positive/negative tint on card border for extra clarity */
.mkt-card[data-change="pos"]{border-color:rgba(95,174,107,.12)}
.mkt-card[data-change="neg"]{border-color:rgba(197,74,44,.12)}
.mkt-card-name{font-family:var(--font-mono);font-size:var(--micro);letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-bottom:7px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mkt-card-body{display:flex;justify-content:space-between;align-items:baseline;gap:6px}
.mkt-card-last{font-family:var(--font-mono);font-size:1.12rem;font-weight:500;color:var(--paper-2);letter-spacing:-.01em}
.mkt-card-chg{font-family:var(--font-mono);font-size:var(--micro);letter-spacing:.04em}
.mkt-card-spark{margin-top:7px;height:24px;overflow:hidden}
.mkt-card-spark .spark{height:24px;width:100%;display:block;margin:0}

/* Sparkline draw-on animation */
.spark-draw{stroke-dasharray:var(--spark-len, 200);stroke-dashoffset:var(--spark-len, 200);animation:spark-in .7s var(--ease) .1s forwards}
@keyframes spark-in{to{stroke-dashoffset:0}}

/* — VIX panel — */
.mkt-vix{margin-top:8px;padding:13px 15px;background:var(--ink-2);border:1px solid var(--rule);border-radius:var(--r2)}
.mkt-vix-label{margin:0 0 8px}
.mkt-vix-body{display:flex;align-items:baseline;gap:12px;flex-wrap:wrap}
.mkt-vix-val{font-family:var(--font-mono);font-size:1.3rem;font-weight:500;color:var(--paper-2);letter-spacing:-.01em}
.mkt-vix-chg{font-family:var(--font-mono);font-size:var(--small)}
/* Regime badge: mono, small, bordered; color inherited from .pos/.neg/.flat */
.mkt-vix-regime{font-family:var(--font-mono);font-size:var(--micro);letter-spacing:.2em;padding:2px 7px;border:1px solid currentColor;border-radius:var(--r1);opacity:.9}
.mkt-vix-spark{margin-top:8px;height:24px;overflow:hidden}
.mkt-vix-spark .spark{height:24px;width:100%;display:block;margin:0}

/* — Timestamp footer — */
.mkt-stamp{font-family:var(--font-mono);font-size:var(--micro);color:var(--muted);text-align:center;margin-top:24px;letter-spacing:.06em;padding-bottom:4px}

/* — Reduced motion: disable all market animations, keep crossfades — */
@media (prefers-reduced-motion: reduce){
  .mkt-breadth--visible{animation:fade .2s var(--ease) both}
  .mkt-card--visible{animation:fade .2s var(--ease) both}
  .spark-draw{animation:none;stroke-dasharray:none;stroke-dashoffset:0}
  .mkt-spinner{animation:none;opacity:.6}
  .gauge-needle--animated{transition:none}
}

/* mono/muted helpers used inline */
.muted{color:var(--muted)}

/* ── Tap-to-open chart ───────────────────────────────────────────────────── */
.mkt-card--tappable,.mkt-vix--tappable{cursor:pointer;transition:border-color .15s ease,transform .1s ease}
.mkt-card--tappable:hover,.mkt-vix--tappable:hover{border-color:var(--gold)}
.mkt-card--tappable:active,.mkt-vix--tappable:active{transform:translateY(1px)}
.mkt-card--tappable:focus-visible,.mkt-vix--tappable:focus-visible{outline:2px solid var(--gold);outline-offset:2px}

.chart-modal{position:fixed;inset:0;z-index:1000;display:flex;align-items:flex-end;justify-content:center}
.chart-modal[hidden]{display:none}
body.chart-open{overflow:hidden}
.chart-backdrop{position:absolute;inset:0;background:rgba(4,2,8,.62);backdrop-filter:blur(2px)}
.chart-sheet{position:relative;display:flex;flex-direction:column;width:100%;max-width:720px;height:92vh;
  background:var(--ink-2,#0d0918);border:1px solid var(--rule-3);border-radius:14px 14px 0 0;
  box-shadow:0 -12px 40px rgba(0,0,0,.5);overflow:hidden}
.chart-head{display:flex;align-items:center;justify-content:space-between;padding:14px 16px 10px;border-bottom:1px solid var(--rule-3)}
.chart-titles{display:flex;flex-direction:column;gap:2px;min-width:0}
.chart-name{font-family:var(--font-display,"Fraunces"),serif;font-size:1.15rem;color:var(--paper);line-height:1.1}
.chart-meta{font-size:.68rem;color:var(--muted);letter-spacing:.04em}
.chart-close{flex:none;width:32px;height:32px;border-radius:8px;border:1px solid var(--rule-3);
  background:var(--ink-3);color:var(--paper);font-size:.85rem;cursor:pointer}
.chart-close:hover{border-color:var(--gold)}
.chart-canvas{flex:1;min-height:0;position:relative}
.chart-state{position:absolute;top:50%;left:0;right:0;transform:translateY(-50%);text-align:center;
  color:var(--muted);font-size:.8rem;pointer-events:none}
.chart-foot{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap;
  padding:10px 14px;border-top:1px solid var(--rule-3)}
.chart-tfs,.chart-kinds{display:inline-flex;gap:2px}
.tf-btn,.kind-btn{font:600 .72rem/1 var(--font-mono),monospace;letter-spacing:.03em;padding:7px 11px;
  background:var(--ink-3);color:var(--muted);border:1px solid var(--rule-3);cursor:pointer}
.tf-btn:first-child,.kind-btn:first-child{border-radius:6px 0 0 6px}
.tf-btn:last-child,.kind-btn:last-child{border-radius:0 6px 6px 0}
.tf-btn.is-active,.kind-btn.is-active{background:var(--gold);color:var(--ink);border-color:var(--gold)}
.tf-btn:focus-visible,.kind-btn:focus-visible{outline:2px solid var(--gold);outline-offset:1px}
@media (min-width:640px){.chart-modal{align-items:center}.chart-sheet{border-radius:14px;height:78vh}}
@media (prefers-reduced-motion:reduce){.mkt-card--tappable,.mkt-vix--tappable{transition:none}}

/* ── SECTORS tab ─────────────────────────────────────────────────────────── */
.sectors{display:flex;flex-direction:column;gap:12px}
.sectors-head{display:flex;align-items:baseline;gap:12px;flex-wrap:wrap}
.sectors-title{font-family:var(--font-display),serif;font-size:1.4rem;font-weight:400;margin:0;color:var(--paper)}
.sectors-controls{display:inline-flex;gap:2px;margin-left:auto}

/* Segmented toggle — mirrors .tf-btn pattern already in codebase */
.seg-btn{
  font:500 var(--micro)/1 var(--font-mono),monospace;
  letter-spacing:.06em;text-transform:uppercase;
  padding:8px 14px;min-height:40px;
  background:var(--ink-3);color:var(--muted);
  border:1px solid var(--rule-2);cursor:pointer;
  transition:background .14s var(--ease),color .14s var(--ease),border-color .14s var(--ease)
}
.seg-btn:first-child{border-radius:var(--r1) 0 0 var(--r1)}
.seg-btn:last-child{border-radius:0 var(--r1) var(--r1) 0;border-left:none}
.seg-btn:not(:first-child):not(:last-child){border-left:none}
.seg-btn:hover:not(.is-active){color:var(--paper-2);border-color:var(--rule-3)}
.seg-btn.is-active{background:var(--gold);color:var(--ink);border-color:var(--gold);font-weight:600}
.seg-btn:focus-visible{outline:2px solid var(--gold);outline-offset:2px;z-index:1;position:relative}
.sectors-note{font:var(--micro)/1.4 var(--font-mono),monospace;color:var(--muted);letter-spacing:.04em}

/* Heatmap container */
.heatmap-wrap{
  position:relative;width:100%;aspect-ratio:16/9;min-height:280px;
  background:var(--ink-2);border:1px solid var(--rule);border-radius:var(--r3);overflow:hidden
}
.heatmap-wrap.is-empty::after{
  content:"— no live constituents —";position:absolute;inset:0;
  display:grid;place-items:center;
  font:var(--micro)/1 var(--font-mono),monospace;color:var(--muted);letter-spacing:.08em
}
.heatmap{width:100%;height:100%;display:block}

/* SVG tile group */
.hm-tile{transition:filter .12s var(--ease);cursor:default}
.hm-tile:hover{filter:brightness(1.14)}

/* Ticker labels — dark stroke keeps them legible on both pale-green and deep-red tiles */
.hm-sym{
  font:600 9px/1 var(--font-mono),monospace;
  fill:rgba(255,255,255,.94);pointer-events:none;
  paint-order:stroke;stroke:rgba(0,0,0,.35);stroke-width:2px
}
/* Sector header labels inside the SVG — slightly larger, all-caps */
.hm-sector{
  font:700 10px/1 var(--font-mono),monospace;
  fill:rgba(255,255,255,.78);text-transform:uppercase;letter-spacing:.05em;pointer-events:none;
  paint-order:stroke;stroke:rgba(0,0,0,.28);stroke-width:2px
}

/* Sector ranked list — dense terminal readout, not bootstrap cards */
.sector-rank{
  list-style:none;margin:0;padding:0;display:grid;
  grid-template-columns:repeat(auto-fill,minmax(176px,1fr));gap:1px;
  background:var(--rule);border:1px solid var(--rule);border-radius:var(--r3);overflow:hidden
}
.rank-row{
  display:flex;justify-content:space-between;align-items:center;gap:8px;
  padding:10px 12px;min-height:40px;
  font:var(--micro)/1 var(--font-mono),monospace;
  background:var(--ink-2);
  border-left:2px solid transparent;
  transition:background .1s var(--ease),border-color .1s var(--ease)
}
.rank-row:hover{background:var(--ink-3)}
.rank-row .rank-name{color:var(--paper);letter-spacing:.02em;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0;flex:1}
.rank-row .rank-pct{font-variant-numeric:tabular-nums;flex-shrink:0;letter-spacing:.03em}
.rank-row.up{border-left-color:var(--green)}
.rank-row.up .rank-pct{color:var(--green)}
.rank-row.down{border-left-color:var(--terra)}
.rank-row.down .rank-pct{color:var(--terra)}
.rank-row.flat .rank-pct{color:var(--muted)}

/* Entrance animation — mirrors existing .mkt-* pattern */
.sectors{animation:fade .3s var(--ease)}

@media (prefers-reduced-motion:reduce){
  .hm-tile{transition:none}
  .seg-btn{transition:none}
  .rank-row{transition:none}
  .sectors{animation:none}
}

/* ── SENTIMENT tab ─────────────────────────────────────────────────────── */
.sentiment { display: flex; flex-direction: column; gap: 14px; }
.sentiment-head { display: flex; align-items: baseline; gap: 12px; flex-wrap: wrap; }
.sentiment-title { font-family: var(--font-display), serif; font-size: 1.4rem; font-weight: 400; margin: 0; color: var(--paper); }
.sentiment-note { font: 0.7rem var(--font-mono), monospace; color: var(--muted); }

.meter-wrap { display: grid; place-items: center; padding: 8px 0 4px; }
.meter-wrap .meter { width: min(100%, 340px); height: auto; display: block; }
.meter-label { font: 700 9px var(--font-mono), monospace; fill: var(--paper); text-transform: uppercase; letter-spacing: .05em; }

/* .gauge-needle already has transition:none in the breadth gauge block above —
   the .meter-needle class shares that base and needs no additional override. */

.sentiment-readouts {
  list-style: none; margin: 0; padding: 0; display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); gap: 1px;
  background: var(--rule); border: 1px solid var(--rule); border-radius: 6px; overflow: hidden;
}
.readout-row {
  display: flex; justify-content: space-between; align-items: center; gap: 8px;
  padding: 9px 12px; min-height: 40px; font: 0.78rem var(--font-mono), monospace; background: var(--ink-2);
}
.readout-row .readout-name { color: var(--paper); }
.readout-row .readout-val { font-variant-numeric: tabular-nums; color: var(--paper); }
.readout-row.up .readout-val { color: var(--green); }
.readout-row.down .readout-val { color: var(--terra); }
.readout-row.flat .readout-val { color: var(--muted); }
