/* ═══════════════════════════════════════════════════════════════
   VOO Buy Opportunity Dashboard — Styles
   Adapted from Claude Design mockup (L1 Hero + Grid layout)
   ═══════════════════════════════════════════════════════════════ */

/* ---------- CSS VARIABLES ---------- */
:root {
  --bg:         #ffffff;
  --panel:      #ffffff;
  --panel-2:    #fafafa;
  --ink:        #0a0a0a;
  --ink-2:      #18181b;
  --muted:      #71717a;
  --muted-2:    #a1a1aa;
  --line:       #e7e7e9;
  --line-2:     #efeff1;
  --grid:       #f3f3f5;

  --accent:     #15803d;
  --accent-ink: #14532d;
  --accent-soft:#dcfce7;
  --red:        #b91c1c;
  --red-soft:   #fee2e2;
  --amber:      #a16207;
  --amber-soft: #fef3c7;
  --green:      #15803d;
  --green-soft: #dcfce7;
  --greenDark:  #14532d;

  --ff-sans: 'Geist','Inter',ui-sans-serif,system-ui,sans-serif;
  --ff-mono: 'Geist Mono','IBM Plex Mono',ui-monospace,monospace;

  --r-sm: 4px;
  --r-md: 6px;
  --r-lg: 10px;
}

/* ---------- PALETTES ---------- */
:root[data-palette="classic"] {
  --accent:#2f855a; --accent-ink:#1f5138; --accent-soft:#d1fae5;
  --red:#c53030; --red-soft:#fee2e2; --amber:#d69e2e; --amber-soft:#fef3c7;
  --green:#2f855a; --green-soft:#d1fae5; --greenDark:#1f5138;
}
:root[data-palette="muted"] {
  --accent:#0f766e; --accent-ink:#134e4a; --accent-soft:#ccfbf1;
  --red:#9f1239; --red-soft:#ffe4e6; --amber:#ca8a04; --amber-soft:#fef3c7;
  --green:#0f766e; --green-soft:#ccfbf1; --greenDark:#134e4a;
}
:root[data-palette="cool"] {
  --accent:#1e3a8a; --accent-ink:#172554; --accent-soft:#dbeafe;
  --red:#9f1239; --red-soft:#ffe4e6; --amber:#0891b2; --amber-soft:#cffafe;
  --green:#1e3a8a; --green-soft:#dbeafe; --greenDark:#172554;
}

/* ---------- DARK MODE ---------- */
:root[data-dark="true"] {
  --bg:#0b0b0c; --panel:#111113; --panel-2:#0e0e10; --ink:#f4f4f5;
  --ink-2:#e4e4e7; --muted:#a1a1aa; --muted-2:#71717a;
  --line:#26262a; --line-2:#1c1c1f; --grid:#1a1a1d;
  --accent-soft: color-mix(in oklab, var(--accent) 22%, #0b0b0c);
  --red-soft:    color-mix(in oklab, var(--red) 22%, #0b0b0c);
  --amber-soft:  color-mix(in oklab, var(--amber) 22%, #0b0b0c);
  --green-soft:  color-mix(in oklab, var(--green) 22%, #0b0b0c);
}

/* ---------- FONT OVERRIDES ---------- */
:root[data-font="geist"] { --ff-sans:'Geist','Inter',system-ui,sans-serif; --ff-mono:'Geist Mono',ui-monospace,monospace; }
:root[data-font="inter"] { --ff-sans:'Inter',system-ui,sans-serif; --ff-mono:'IBM Plex Mono',ui-monospace,monospace; }
:root[data-font="plex"]  { --ff-sans:'IBM Plex Sans',system-ui,sans-serif; --ff-mono:'IBM Plex Mono',ui-monospace,monospace; }
:root[data-font="mono"]  { --ff-sans:'IBM Plex Mono',ui-monospace,monospace; --ff-mono:'IBM Plex Mono',ui-monospace,monospace; }

/* ---------- DENSITY ---------- */
:root[data-density="airy"]     .page { --gap:20px; --pad:22px; }
:root[data-density="balanced"] .page { --gap:14px; --pad:16px; }
:root[data-density="dense"]    .page { --gap:10px; --pad:12px; }

/* ---------- RESET ---------- */
*, *::before, *::after { box-sizing: border-box; }
html, body { margin:0; padding:0; background:var(--bg); color:var(--ink); font-family:var(--ff-sans); }
body { -webkit-font-smoothing:antialiased; font-feature-settings:"ss01","cv11","tnum"; }

/* ---------- TOP NAV ---------- */
.topbar {
  position:sticky; top:0; z-index:30;
  display:grid; grid-template-columns:auto 1fr auto; align-items:center; gap:20px;
  padding:10px 24px; border-bottom:1px solid var(--line);
  background:color-mix(in oklab, var(--bg) 92%, transparent);
  backdrop-filter:blur(8px);
}
.brand { display:flex; align-items:center; gap:10px; font-weight:600; letter-spacing:-0.01em; }
.brand .mark {
  width:22px; height:22px; border-radius:4px; background:var(--ink);
  display:grid; place-items:center; color:var(--bg);
  font-family:var(--ff-mono); font-size:11px; font-weight:700;
}
.brand small { color:var(--muted); font-weight:500; }
.tabs { display:flex; gap:2px; justify-self:center; }
.tab {
  font:500 12px/1 var(--ff-mono); color:var(--muted);
  padding:8px 12px; border-radius:var(--r-sm); cursor:pointer;
  border:0; background:transparent; letter-spacing:.02em;
  transition:color .15s, background .15s;
}
.tab[aria-selected="true"] { background:var(--panel-2); color:var(--ink); box-shadow:inset 0 0 0 1px var(--line); }
.tab:hover { color:var(--ink); }
.top-meta { display:flex; align-items:center; gap:14px; font:500 12px/1 var(--ff-mono); color:var(--muted); }
.dot {
  display:inline-block; width:6px; height:6px; border-radius:50%;
  background:var(--green); margin-right:6px; animation:pulse 2.4s infinite;
}
@keyframes pulse { 0%,100%{opacity:1} 50%{opacity:.35} }

.btn {
  display:inline-flex; align-items:center; gap:6px;
  font:500 12px/1 var(--ff-sans); padding:7px 10px; border-radius:var(--r-sm);
  border:1px solid var(--line); background:var(--panel); color:var(--ink); cursor:pointer;
}
.btn:hover { background:var(--panel-2); }

/* ---------- LAYOUT ---------- */
.view { display:none; }
.view[data-active="true"] { display:block; }
.page { padding:var(--gap,10px) 24px 40px; max-width:1440px; margin:0 auto; }

/* ---------- PANEL ---------- */
.panel {
  background:var(--panel); border:1px solid var(--line); border-radius:var(--r-md);
  overflow:hidden;
}
.panel.flat { background:var(--panel-2); }
.ph {
  display:flex; align-items:center; justify-content:space-between; gap:8px;
  padding:10px var(--pad,12px); border-bottom:1px solid var(--line-2);
  font:500 11px/1 var(--ff-mono); letter-spacing:.06em; text-transform:uppercase; color:var(--muted);
}
.ph .ph-r { color:var(--muted-2); }
.pb { padding:var(--pad,12px); }

/* ---------- TYPOGRAPHY ---------- */
.mono   { font-family:var(--ff-mono); font-feature-settings:"tnum"; }
.muted  { color:var(--muted); }
.muted-2{ color:var(--muted-2); }
.eyebrow{ font:500 11px/1 var(--ff-mono); letter-spacing:.08em; text-transform:uppercase; color:var(--muted); }
.num    { font-family:var(--ff-mono); font-feature-settings:"tnum","zero"; font-variant-numeric:tabular-nums; }

/* ---------- HERO ---------- */
.hero {
  display:grid; grid-template-columns:minmax(480px,2fr) 1fr; gap:var(--gap,10px);
}
.hero-main { padding:18px var(--pad,16px); }
.hero-title { font:600 22px/1.1 var(--ff-sans); letter-spacing:-0.02em; margin:0 0 2px; }
.hero-sub {
  font:500 12px/1 var(--ff-mono); color:var(--muted);
  display:flex; gap:10px; align-items:center; flex-wrap:wrap;
}
.hero-sub .pill {
  border:1px solid var(--line); padding:3px 7px; border-radius:999px; color:var(--muted);
}

.score-row {
  display:grid; grid-template-columns:auto 1fr auto; align-items:end; gap:18px;
  margin-top:14px;
}
.score-big {
  font:600 86px/0.9 var(--ff-sans); letter-spacing:-0.04em;
  font-feature-settings:"tnum"; font-variant-numeric:tabular-nums;
}
.score-big small { font-size:28px; color:var(--muted); letter-spacing:0; font-weight:500; }
.score-label { font:600 16px/1.15 var(--ff-sans); color:var(--accent-ink); margin-bottom:2px; }
.score-delta {
  display:inline-flex; align-items:center; gap:4px;
  font:500 12px/1 var(--ff-mono);
  padding:3px 6px; border-radius:var(--r-sm);
}
.score-delta.pos { color:var(--green); background:var(--green-soft); }
.score-delta.neg { color:var(--red); background:var(--red-soft); }
.score-delta.flat { color:var(--muted); background:var(--panel-2); }
.blurb { margin-top:10px; color:var(--ink-2); font-size:13px; max-width:62ch; line-height:1.5; }

/* ---------- BANDS RULER ---------- */
.bands {
  position:relative; height:34px; margin-top:16px;
  border-radius:var(--r-sm); overflow:visible; border:1px solid var(--line-2);
  display:grid; grid-template-columns:20fr 20fr 20fr 15fr 15fr 10fr;
}
.bands .seg { position:relative; overflow:hidden; }
.bands .seg[data-b="a"] { background:color-mix(in oklab, var(--red) 16%, transparent); }
.bands .seg[data-b="b"] { background:color-mix(in oklab, var(--red) 8%, transparent); }
.bands .seg[data-b="c"] { background:color-mix(in oklab, var(--amber) 12%, transparent); }
.bands .seg[data-b="d"] { background:color-mix(in oklab, var(--green) 14%, transparent); }
.bands .seg[data-b="e"] { background:color-mix(in oklab, var(--green) 26%, transparent); }
.bands .seg[data-b="f"] { background:color-mix(in oklab, var(--green) 40%, transparent); }
.bands .seg span {
  position:absolute; bottom:4px; left:6px;
  font:500 10px/1 var(--ff-mono); color:var(--ink-2); opacity:.7;
}
.bands .marker {
  position:absolute; top:-6px; bottom:-6px; width:2px; background:var(--ink);
  box-shadow:0 0 0 3px var(--bg); z-index:2;
}
.bands .marker::after {
  content:attr(data-score);
  position:absolute; top:-16px; left:50%; transform:translateX(-50%);
  font:600 10px/1 var(--ff-mono); color:var(--ink);
  background:var(--bg); padding:2px 4px; border:1px solid var(--line); border-radius:3px;
}
.bands-legend {
  display:grid; grid-template-columns:repeat(6,1fr); gap:6px; margin-top:20px;
  font:500 10.5px/1.3 var(--ff-mono); color:var(--muted);
}
.bands-legend div b { display:block; color:var(--ink); font-weight:600; }

/* ---------- HERO SIDE: CONFIDENCE ---------- */
.hero-side { padding:14px var(--pad,16px); display:flex; flex-direction:column; gap:12px; }
.conf-ring { display:flex; align-items:center; gap:12px; }
.conf-ring svg { width:64px; height:64px; }
.conf-ring .ring-bg { stroke:var(--line); }
.conf-ring .ring-fg { stroke:var(--accent); }
.conf-ring h4 { margin:0 0 2px; font:600 13px/1 var(--ff-sans); }
.conf-ring small { color:var(--muted); font-family:var(--ff-mono); font-size:11px; }
.conf-breakdown { display:grid; gap:6px; font:500 11px/1.2 var(--ff-mono); }
.conf-row {
  display:grid; grid-template-columns:14px 1fr auto; gap:8px; align-items:center; color:var(--muted);
}
.conf-row b { color:var(--ink); font-weight:500; }
.conf-row .tick { width:10px; height:10px; border-radius:50%; background:var(--green); }
.conf-row[data-s="stale"] .tick { background:var(--amber); }
.conf-row[data-s="unavailable"] .tick { background:var(--muted-2); }

/* ---------- GRID ---------- */
.row { display:grid; gap:var(--gap,10px); margin-top:var(--gap,10px); }
.row.c-3  { grid-template-columns:repeat(3,1fr); }
.row.c-2  { grid-template-columns:2fr 1fr; }
.row.c-2e { grid-template-columns:1fr 1fr; }

/* ---------- COMPONENT CARD ---------- */
.cc { padding:var(--pad,12px); display:flex; flex-direction:column; gap:8px; min-height:170px; }
.cc-top { display:flex; justify-content:space-between; align-items:flex-start; gap:8px; }
.cc-name { font:600 13px/1.1 var(--ff-sans); }
.cc-name small {
  display:block; font:500 10.5px/1 var(--ff-mono); color:var(--muted);
  margin-top:3px; letter-spacing:.04em; text-transform:uppercase;
}
.cc-score { font:600 28px/1 var(--ff-sans); font-variant-numeric:tabular-nums; letter-spacing:-0.02em; }
.cc-score small { color:var(--muted); font-size:13px; font-weight:500; }
.cc-bar { height:4px; border-radius:2px; background:var(--line-2); overflow:hidden; position:relative; }
.cc-bar > i { position:absolute; inset:0 auto 0 0; background:var(--accent); border-radius:2px; }
.cc-meta {
  display:flex; justify-content:space-between; gap:8px;
  font:500 10.5px/1 var(--ff-mono); color:var(--muted);
}
.cc-meta .chg.pos { color:var(--green); }
.cc-meta .chg.neg { color:var(--red); }
.cc-metrics { display:grid; grid-template-columns:1fr 1fr; gap:4px 12px; font:500 11px/1.3 var(--ff-mono); }
.cc-metrics .k { color:var(--muted); }
.cc-metrics .v { color:var(--ink); text-align:right; }
.cc-note {
  font:400 11.5px/1.45 var(--ff-sans); color:var(--ink-2);
  border-top:1px dashed var(--line-2); padding-top:8px;
}
.cc-wc {
  display:flex; align-items:center; gap:6px;
  font:500 10.5px/1 var(--ff-mono); color:var(--muted); padding-top:4px;
}
.cc-wc .chg { font-weight:600; }
.cc-wc .chg.pos { color:var(--green); }
.cc-wc .chg.neg { color:var(--red); }
.cc-wc .chg.flat { color:var(--muted); }

/* ---------- CHART ---------- */
.chartwrap { padding:var(--pad,12px); }
.chart svg { width:100%; height:220px; display:block; }
.chart .grid-line { stroke:var(--grid); stroke-width:1; }
.chart .axis { fill:var(--muted); font:500 10px/1 var(--ff-mono); }
.chart .price-line { fill:none; stroke:var(--ink); stroke-width:1.25; }
.chart .score-line { fill:none; stroke:var(--accent); stroke-width:1.5; }
.chart .score-fill { fill:var(--accent); opacity:.08; }
.chart .dot { r:3; }

/* ---------- WHAT CHANGED STRIP ---------- */
.changestrip { display:flex; gap:0; align-items:stretch; overflow:hidden; }
.changestrip .ci {
  flex:1; padding:10px var(--pad,12px); border-right:1px solid var(--line-2);
  display:flex; flex-direction:column; gap:4px;
}
.changestrip .ci:last-child { border-right:0; }
.changestrip .ci h6 {
  margin:0; font:500 10.5px/1 var(--ff-mono); color:var(--muted);
  text-transform:uppercase; letter-spacing:.06em;
}
.changestrip .ci .d { font:600 16px/1 var(--ff-sans); font-variant-numeric:tabular-nums; }
.changestrip .ci .d.pos { color:var(--green); }
.changestrip .ci .d.neg { color:var(--red); }
.changestrip .ci small { color:var(--muted); font:500 11px/1.35 var(--ff-mono); }

/* ---------- BANDS CARD ---------- */
.bandcard .row-b {
  display:grid; grid-template-columns:72px 1fr auto; align-items:center;
  gap:10px; padding:8px var(--pad,12px); border-top:1px solid var(--line-2);
  font:500 12px/1.2 var(--ff-sans);
}
.bandcard .row-b:first-of-type { border-top:0; }
.bandcard .bar { height:6px; border-radius:3px; }
.bandcard .range { font:500 11px/1 var(--ff-mono); color:var(--muted); }
.bandcard .row-b[data-hit="true"] { background:var(--panel-2); }
.bandcard .row-b[data-hit="true"] .label::after {
  content:" \25C0 today"; font:500 10px/1 var(--ff-mono); color:var(--accent); letter-spacing:.04em;
}

/* ---------- STRATEGY LAB ---------- */
.val-grid {
  display:grid; grid-template-columns:repeat(4,1fr); gap:16px;
  font:500 12px/1.4 var(--ff-mono);
}
.val-item .val-label { color:var(--muted); font-size:10.5px; text-transform:uppercase; letter-spacing:.06em; }
.val-item .val-value { font-size:20px; font-weight:600; color:var(--ink); margin-top:2px; }
.val-item .val-sub { color:var(--muted); font-size:11px; margin-top:2px; }

.compare-bars { display:grid; gap:12px; }
.compare-row {
  display:grid; grid-template-columns:140px auto 50px; gap:12px; align-items:center;
  font:500 12px/1 var(--ff-mono);
}
.compare-row .bar-track { height:8px; background:var(--line-2); border-radius:4px; position:relative; overflow:hidden; }
.compare-row .bar-fill { position:absolute; inset:0 auto 0 0; background:var(--accent); border-radius:4px; }

/* ---------- FOOTER ---------- */
.foot {
  margin-top:16px; padding:12px 24px; color:var(--muted);
  font:500 11px/1.4 var(--ff-mono);
  display:flex; justify-content:space-between; gap:20px;
  border-top:1px solid var(--line-2); flex-wrap:wrap;
}

/* ---------- TWEAKS PANEL ---------- */
.tweaks-panel {
  position:fixed; right:16px; bottom:16px; z-index:50;
  width:280px; background:var(--panel); border:1px solid var(--line);
  border-radius:var(--r-md); box-shadow:0 10px 30px rgba(0,0,0,.08);
  padding:10px; display:none; font-family:var(--ff-sans);
}
.tweaks-panel[data-open="true"] { display:block; }
.tweaks-panel h4 {
  margin:0 0 8px; font:500 10.5px/1 var(--ff-mono);
  color:var(--muted); text-transform:uppercase; letter-spacing:.08em;
  display:flex; justify-content:space-between; align-items:center;
}
.tweaks-panel .tw-row {
  display:grid; grid-template-columns:80px 1fr; align-items:center;
  gap:8px; margin:8px 0; font-size:11.5px;
}
.tweaks-panel .tw-row label { color:var(--muted); font:500 11px/1 var(--ff-mono); }
.tweaks-panel select {
  font-family:var(--ff-mono); font-size:11px;
  width:100%; padding:5px 6px; border-radius:var(--r-sm);
  border:1px solid var(--line); background:var(--panel); color:var(--ink);
}
.tw-swatches { display:flex; gap:4px; }
.tw-swatches button {
  width:22px; height:22px; border-radius:4px; border:1px solid var(--line);
  cursor:pointer; padding:0;
}
.tw-swatches button[aria-selected="true"] { outline:2px solid var(--ink); outline-offset:1px; }

/* ---------- LOADING ---------- */
.loading-overlay {
  position:fixed; inset:0; z-index:100;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  background:var(--bg);
}
.loading-overlay.hidden { display:none; }
.loading-spinner {
  width:28px; height:28px; border:3px solid var(--line);
  border-top-color:var(--accent); border-radius:50%;
  animation:spin .7s linear infinite;
}
@keyframes spin { to { transform:rotate(360deg); } }

/* ---------- HIDE HELPERS ---------- */
.hide-elem { display:none !important; }

/* ---------- RESPONSIVE ---------- */
@media (max-width:1100px) {
  .hero { grid-template-columns:1fr; }
  .row.c-3 { grid-template-columns:repeat(2,1fr); }
}
@media (max-width:700px) {
  .topbar { grid-template-columns:1fr; gap:8px; justify-items:start; }
  .tabs { justify-self:start; }
  .top-meta { justify-self:start; flex-wrap:wrap; }
  .hero { grid-template-columns:1fr; }
  .row.c-3, .row.c-2, .row.c-2e { grid-template-columns:1fr; }
  .score-row { grid-template-columns:auto 1fr; }
  .score-big { font-size:56px; }
  .bands-legend { grid-template-columns:repeat(3,1fr); }
  .changestrip { flex-direction:column; }
  .val-grid { grid-template-columns:repeat(2,1fr); }
}
