/* Tweakable design tokens */
:root {
  --accent-h: 152;
  --accent-c: 0.16;
  --accent-l: 0.55;
  --accent: oklch(var(--accent-l) var(--accent-c) var(--accent-h));
  --accent-soft: oklch(0.94 0.04 var(--accent-h));
  --accent-text: white;

  --up: oklch(0.62 0.16 152);
  --down: oklch(0.62 0.18 25);
  --warn: oklch(0.72 0.16 65);

  --bg: #fafaf7;
  --bg-2: #ffffff;
  --bg-3: #f1f0eb;
  --line: oklch(0.92 0.005 90);
  --line-2: oklch(0.88 0.005 90);
  --fg: oklch(0.20 0.01 90);
  --fg-2: oklch(0.42 0.01 90);
  --fg-3: oklch(0.58 0.01 90);

  --shadow-card: 0 1px 0 rgba(0,0,0,0.02), 0 1px 2px rgba(15,15,15,0.04), 0 8px 24px -12px rgba(15,15,15,0.06);
  --shadow-hover: 0 1px 0 rgba(0,0,0,0.03), 0 2px 6px rgba(15,15,15,0.06), 0 18px 40px -18px rgba(15,15,15,0.14);
  --sheen: rgba(255,255,255,0);
  --radius: 12px;
  --radius-lg: 16px;

  --font-display: "Inter", "Helvetica Neue", system-ui, sans-serif;
  --font-body: "Inter", "Helvetica Neue", system-ui, sans-serif;
  --font-mono: "JetBrains Mono", ui-monospace, "SF Mono", Menlo, monospace;

  --pad-card-y: 18px;
  --pad-card-x: 20px;
  --gap-grid: 16px;
  --row-gap: 16px;

  --sidebar-w: 304px;
}

[data-theme="dark"] {
  --bg: #0e1014;
  --bg-2: #161922;
  --bg-3: #1c2030;
  --line: oklch(0.28 0.01 250);
  --line-2: oklch(0.34 0.01 250);
  --fg: oklch(0.96 0.005 250);
  --fg-2: oklch(0.78 0.01 250);
  --fg-3: oklch(0.62 0.01 250);
  --accent-soft: oklch(0.28 0.06 var(--accent-h));
  --shadow-card: 0 1px 0 rgba(0,0,0,0.4), 0 1px 2px rgba(0,0,0,0.3), 0 12px 32px -16px rgba(0,0,0,0.6);
  --shadow-hover: 0 1px 0 rgba(0,0,0,0.5), 0 4px 10px rgba(0,0,0,0.4), 0 22px 48px -20px rgba(0,0,0,0.8);
  --sheen: rgba(255,255,255,0.045);
}

[data-density="compact"] {
  --pad-card-y: 12px;
  --pad-card-x: 14px;
  --gap-grid: 10px;
  --row-gap: 10px;
}

[data-typeface="serif"] {
  --font-display: "Source Serif 4", "Iowan Old Style", Georgia, serif;
  --font-body: "Inter", system-ui, sans-serif;
}
[data-typeface="grotesk"] {
  --font-display: "Space Grotesk", "Inter", system-ui, sans-serif;
  --font-body: "Space Grotesk", "Inter", system-ui, sans-serif;
}
[data-typeface="mono-display"] {
  --font-display: "JetBrains Mono", ui-monospace, monospace;
  --font-body: "Inter", system-ui, sans-serif;
}

* { box-sizing: border-box; }
/* Don't constrain html/body/root height — let the page grow with
 * content. Constraining causes sticky positioning to fail because
 * .sidebar's nearest scrolling ancestor becomes #root rather than the
 * viewport, so the sidebar scrolls with the inner overflow instead of
 * sticking to the top of the screen.
 */
html, body, #root { min-height: 100%; }
body {
  margin: 0;
  font-family: var(--font-body);
  background: var(--bg);
  color: var(--fg);
  font-size: 14px;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

/* ─── Shell layout: sidebar + main ─────────────────────────────────────── */
.shell {
  display: grid;
  grid-template-columns: var(--sidebar-w) 1fr;
  column-gap: 24px;
  row-gap: 0;
  max-width: 1600px;
  margin: 0 auto;
  padding: 20px 24px 60px;
  align-items: start;
}
@media (max-width: 1080px) {
  .shell { grid-template-columns: 1fr; }
  .sidebar { position: relative !important; max-height: none !important; }
}

.sidebar {
  position: sticky;
  top: 66px;
  max-height: calc(100vh - 82px);
  overflow-y: auto;
  background: var(--bg-2);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-card);
  padding: 18px 16px;
  display: flex;
  flex-direction: column;
  gap: 18px;
  scrollbar-width: thin;
  scrollbar-color: var(--line-2) transparent;
}
.sidebar::-webkit-scrollbar { width: 8px; }
.sidebar::-webkit-scrollbar-track { background: transparent; }
.sidebar::-webkit-scrollbar-thumb {
  background: var(--line-2); border-radius: 4px;
  border: 2px solid transparent; background-clip: content-box;
}

.main { min-width: 0; display: flex; flex-direction: column; gap: var(--row-gap); position: relative; }

/* sidebar sections */
.sb-section { display: flex; flex-direction: column; gap: 8px; }
.sb-section + .sb-section { border-top: 1px dashed var(--line); padding-top: 14px; }
.sb-label {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--fg-3);
  font-weight: 700;
}
.sb-row { display: flex; flex-direction: column; gap: 6px; }
.sb-row.h { flex-direction: row; align-items: center; justify-content: space-between; gap: 10px; }
.sb-val {
  font-family: var(--font-mono);
  font-size: 12px;
  font-weight: 600;
  color: var(--fg);
}

/* sidebar brand */
.sb-brand {
  display: flex; align-items: center; gap: 10px;
  font-family: var(--font-display);
  font-weight: 700;
  letter-spacing: -0.02em;
  font-size: 15px;
}
.sb-brand .mark {
  width: 28px; height: 28px; border-radius: 8px;
  background: linear-gradient(135deg, var(--accent), color-mix(in oklch, var(--accent), black 18%));
  display: grid; place-items: center; color: var(--accent-text);
  font-weight: 700; font-size: 13px;
}
.sb-brand .sub {
  font-size: 11px;
  color: var(--fg-3);
  font-weight: 400;
  margin-top: 2px;
}

/* sidebar ticker box */
.sb-ticker-wrap {
  position: relative;
  width: 100%;
}
.sb-ticker-input {
  width: 100%;
  display: block;
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 8px 12px;
  font-family: var(--font-mono);
  font-size: 14px;
  font-weight: 700;
  color: var(--fg);
  letter-spacing: 0.04em;
  outline: none;
  box-sizing: border-box;
  caret-color: var(--accent);
}
.sb-ticker-input:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 2px color-mix(in oklch, var(--accent), transparent 80%);
}
.sb-ticker-input::placeholder { color: var(--fg-3); }
.sb-ticker-name { color: var(--fg-3); font-size: 11px; flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.sb-price { color: var(--fg); font-weight: 700; font-size: 13px; }

/* autocomplete dropdown — explicitly wider than the compact ticker
   input so company names render in full. left:0 anchors to input left. */
.sb-search-dropdown {
  position: absolute; top: calc(100% + 4px); left: 0;
  width: 280px; max-width: calc(100vw - 32px);
  background: var(--bg-2);
  border: 1px solid var(--line-2);
  border-radius: 10px;
  box-shadow: 0 8px 28px rgba(0,0,0,0.18), 0 2px 6px rgba(0,0,0,0.08);
  max-height: 280px; overflow-y: auto;
  z-index: 200;
  padding: 4px;
}
.sb-search-item {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: baseline;
  gap: 8px;
  padding: 6px 8px;
  border-radius: 6px;
  cursor: pointer;
  font-size: 12px;
}
.sb-search-item.active, .sb-search-item:hover { background: var(--bg-3); }
.sb-search-sym { font-family: var(--font-mono); font-weight: 700; color: var(--fg); font-size: 12px; letter-spacing: 0.04em; }
.sb-search-name { color: var(--fg-2); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; min-width: 0; }
.sb-search-ex { color: var(--fg-3); font-size: 10px; font-family: var(--font-mono); }
.sb-status { font-size: 11px; color: var(--fg-3); }
.sb-status.err { color: oklch(0.62 0.20 28); }
.brand-mark {
  width: 71px; height: 71px;
  object-fit: contain;
  flex-shrink: 0;
  transform: translateY(-2px);
  border-radius: 8px;
}
.sb-brand-text {
  display: flex; flex-direction: column; gap: 2px;
}
/* Source badges (Schwab + UW) sit on one row to save vertical space.
   They wrap to a second row only when the sidebar gets very narrow. */
.sb-source-badges {
  display: flex;
  flex-wrap: wrap;
  gap: 4px 6px;
  align-items: center;
  margin-top: 2px;
}

/* preset pills inside sidebar */
.sb-preset-row, .preset-row { display: flex; gap: 6px; flex-wrap: wrap; }
.preset-pill {
  font-family: var(--font-mono);
  font-size: 11px; font-weight: 600;
  padding: 4px 9px;
  border-radius: 999px;
  background: var(--bg-3);
  color: var(--fg-2);
  border: 1px solid transparent;
  cursor: pointer;
  transition: 120ms ease;
  letter-spacing: 0.04em;
}
.preset-pill:hover { color: var(--fg); border-color: var(--line-2); }
.preset-pill.active { background: var(--accent); color: var(--accent-text); }

/* sidebar slider */
.sb-slider {
  width: 100%;
  accent-color: var(--accent);
}
.sb-select {
  font-family: var(--font-body);
  font-size: 13px;
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 6px 8px;
  color: var(--fg);
  width: 100%;
}

/* sidebar theme toggle */
.theme-toggle button.active { background: var(--bg-2); color: var(--fg); box-shadow: 0 1px 2px rgba(0,0,0,0.06); }

/* expiration card in sidebar */
.sb-expiry {
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 8px 10px;
}

/* ─── Cards (used in main column) ─────────────────────────────────────── */
.card {
  background: var(--bg-2);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  padding: var(--pad-card-y) var(--pad-card-x);
  box-shadow: var(--shadow-card);
}
.card .card-head {
  display: flex; align-items: flex-start; justify-content: space-between;
  gap: 12px; flex-wrap: wrap;
  margin-bottom: 14px;
}
.card-title {
  font-family: var(--font-display);
  font-weight: 600;
  letter-spacing: -0.01em;
  font-size: 15px;
}
.card-sub { font-size: 12px; color: var(--fg-3); font-weight: 400; }

.kicker {
  text-transform: uppercase;
  font-size: 11px;
  letter-spacing: 0.12em;
  color: var(--fg-3);
  font-weight: 600;
  display: block;
  margin-bottom: 6px;
  line-height: 1;
}
.card-head > div { display: flex; flex-direction: column; gap: 4px; }
.card-head > .toolbar, .card-head > .legend, .card-head > .card-sub { flex-direction: row; }

/* ─── Hero ──────────────────────────────────────────────────────────────── */
.hero {
  display: grid;
  grid-template-columns: 1.7fr 1fr;
  gap: var(--gap-grid);
}
@media (max-width: 1280px) { .hero { grid-template-columns: 1fr; } }

/* ─── Strike pair ──────────────────────────────────────────────────────── */
.strike-pair { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.strike-card {
  position: relative;
  border-radius: 14px; padding: 18px;
  display: flex; flex-direction: column; gap: 8px;
  border: 1px solid var(--line);
  overflow: hidden;
}
.strike-card.call { background: color-mix(in oklch, var(--up), transparent 92%); border-color: color-mix(in oklch, var(--up), transparent 70%); }
.strike-card.put { background: color-mix(in oklch, var(--down), transparent 92%); border-color: color-mix(in oklch, var(--down), transparent 70%); }
.strike-card .label { display: flex; align-items: center; gap: 8px; font-size: 12px; font-weight: 600; }
.strike-card .label .dot { width: 8px; height: 8px; border-radius: 50%; }
.strike-card.call .label .dot { background: var(--up); }
.strike-card.put .label .dot { background: var(--down); }
.strike-card .price-big {
  font-family: var(--font-display);
  font-size: 30px;
  font-weight: 700;
  letter-spacing: -0.02em;
}
.strike-card .price-big small { font-size: 16px; color: var(--fg-2); margin-right: 2px; }
.strike-card .meta { display: flex; justify-content: space-between; gap: 8px; margin-top: 4px; font-size: 12px; color: var(--fg-2); }
.strike-card .meta b { color: var(--fg); font-family: var(--font-mono); font-weight: 600; }

/* metric grid */
.metric-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px; }
.metric-grid.five { grid-template-columns: repeat(5, 1fr); gap: 8px; }
@media (max-width: 1100px) { .metric-grid.five { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 720px) { .metric-grid, .metric-grid.five { grid-template-columns: repeat(2, 1fr); } }
.metric {
  border: 1px solid var(--line); border-radius: 10px; padding: 10px 12px;
  background: var(--bg);
}
.metric-grid.five .metric { padding: 8px 10px; }
.metric .lbl { font-size: 10px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--fg-3); font-weight: 600; }
.metric .val { font-family: var(--font-display); font-weight: 600; font-size: 18px; letter-spacing: -0.02em; margin-top: 2px; }
.metric-grid.five .metric .val { font-size: 17px; }
.metric .delta-tiny { font-family: var(--font-mono); font-size: 12px; margin-left: 6px; }
.metric.compact .val { font-size: 16px; }
.metric .muted, .metric div.muted { font-size: 11px; }

/* sb-expiry: keep date + DTE chip from running together */
.sb-expiry .sb-expiry-dte {
  margin-left: 8px;
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 700;
  padding: 2px 6px;
  border-radius: 5px;
  background: var(--bg-3);
  color: var(--fg-2);
  letter-spacing: 0.04em;
}

/* ─── Recommendation ───────────────────────────────────────────────────── */
.rec {
  border-radius: 14px;
  padding: 16px 18px;
  display: flex; gap: 14px; align-items: flex-start;
  border: 1px solid;
}
.rec.success { background: color-mix(in oklch, var(--up), transparent 92%); border-color: color-mix(in oklch, var(--up), transparent 70%); color: var(--fg); }
.rec.warn { background: color-mix(in oklch, var(--warn), transparent 90%); border-color: color-mix(in oklch, var(--warn), transparent 70%); }
.rec.info { background: color-mix(in oklch, var(--accent), transparent 92%); border-color: color-mix(in oklch, var(--accent), transparent 70%); }
.rec.danger { background: color-mix(in oklch, var(--down), transparent 92%); border-color: color-mix(in oklch, var(--down), transparent 70%); }
.rec .icon {
  width: 32px; height: 32px; border-radius: 8px; display: grid; place-items: center;
  font-size: 18px; flex-shrink: 0;
}
.rec.success .icon { background: var(--up); color: white; }
.rec.warn .icon { background: var(--warn); color: white; }
.rec.info .icon { background: var(--accent); color: var(--accent-text); }
.rec.danger .icon { background: var(--down); color: white; }
.rec .title { font-weight: 700; font-family: var(--font-display); margin-bottom: 2px; font-size: 14px; }
.rec .body { font-size: 13px; color: var(--fg-2); line-height: 1.45; }

/* RecommendationPair (Phase B, v1.11) — two stacked banners, one for
   covered calls and one for cash-secured puts, each with a kicker
   label. Wraps the existing .rec styling so each banner keeps the same
   colored background, border, and icon treatment. */
.rec-pair { display: flex; flex-direction: column; gap: 10px; }
.rec.rec-with-kicker {
  flex-direction: column;
  gap: 8px;
  align-items: stretch;
}
.rec-with-kicker .rec-kicker {
  font-family: var(--font-mono);
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--fg-3);
  cursor: help;
}
.rec-with-kicker .rec-row {
  display: flex;
  gap: 14px;
  align-items: flex-start;
}

/* Strategy mode toggle (Phase C, v1.12).
   Sits in the right column header next to the "Suggested strikes" title.
   Three pills: Both (default), CC, CSP. Hides irrelevant content across
   the recommendation banners, strike cards, and analyst warning columns. */
.strikes-head-row {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
}
/* Right cluster: stacks the EARN badge above the Both/CC/CSP toggle in
   normal flow. Replaces the old absolutely positioned earn-badge that
   overlapped the toggle in the top right corner at every width (v1.20). */
.strikes-head-right {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 8px;
}
/* Phone: title block stacks on top, then the EARN badge and toggle sit
   in a single left aligned row that wraps. No corner collision. */
@media (max-width: 520px) {
  .strikes-head-row { flex-direction: column; align-items: stretch; gap: 10px; }
  .strikes-head-right { flex-direction: row; flex-wrap: wrap; align-items: center; justify-content: flex-start; gap: 10px; }
  .strategy-mode-toggle { align-items: flex-start; }
}
.strategy-mode-toggle {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 4px;
  cursor: help;
}
.strategy-mode-kicker {
  font-family: var(--font-mono);
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--fg-3);
}
.strategy-mode-pills {
  display: inline-flex;
  background: var(--bg-3);
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 2px;
  gap: 2px;
}
.strategy-mode-pill {
  background: transparent;
  border: none;
  padding: 5px 10px;
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.04em;
  color: var(--fg-3);
  cursor: pointer;
  border-radius: 6px;
  transition: background 80ms, color 80ms;
}
.strategy-mode-pill:hover { color: var(--fg-2); }
.strategy-mode-pill.active {
  background: var(--accent);
  color: var(--accent-text);
}

/* When only one strike card is visible (CC or CSP mode), the .strike-pair
   2-col grid would leave a blank slot. The .single class set by app.jsx
   collapses to a single column so the visible card spans full width. */
.strike-pair.single {
  grid-template-columns: 1fr;
}

/* ─── Charts ───────────────────────────────────────────────────────────── */
.chart-wrap { position: relative; width: 100%; }
.chart-svg { width: 100%; height: auto; display: block; color: var(--fg-2); }
.chart-svg .grid { stroke: currentColor; stroke-opacity: 0.08; stroke-width: 1; }
.chart-svg .axis-text { font-size: 13px; font-family: var(--font-mono); fill: var(--fg-3); }
.chart-svg .strike-label { font-size: 11px; font-family: var(--font-mono); font-weight: 600; }

.chart-tooltip {
  position: absolute;
  top: 12px; transform: translateX(12px);
  background: var(--bg-2); border: 1px solid var(--line); border-radius: 8px;
  padding: 8px 10px; box-shadow: var(--shadow-card);
  font-size: 12px; pointer-events: none; min-width: 130px;
  z-index: 20;
}
.chart-tooltip.small { min-width: 120px; }
.chart-tooltip.pl-tip { background: rgba(13, 21, 48, 0.94); border-color: rgba(58, 90, 153, 0.5); color: #e0eaff; }
.chart-tooltip.pl-tip .tt-row span { color: #9fb6e0; }
.chart-tooltip .tt-date { font-weight: 600; margin-bottom: 4px; font-size: 11px; color: var(--fg-2); }
.chart-tooltip.pl-tip .tt-date { color: #9fb6e0; }
.chart-tooltip .tt-row { display: flex; justify-content: space-between; gap: 8px; font-family: var(--font-mono); }
.chart-tooltip .tt-row span { color: var(--fg-3); }

/* ─── Layout grids ─────────────────────────────────────────────────────── */
.row { display: grid; gap: var(--gap-grid); }
.row.two { grid-template-columns: 1fr 1fr; }
.row.three { grid-template-columns: repeat(3, 1fr); }
.row.split-2-1 { grid-template-columns: 2fr 1fr; }
.row.split-1-2 { grid-template-columns: 1fr 2fr; }
@media (max-width: 1100px) {
  .row.two, .row.three, .row.split-2-1, .row.split-1-2 { grid-template-columns: 1fr; }
}

/* probability rows */
.prob-row { display: flex; align-items: center; gap: 14px; padding: 10px 0; }
.prob-row + .prob-row { border-top: 1px dashed var(--line); }
.prob-row .label-col { display: flex; align-items: center; gap: 8px; font-size: 13px; min-width: 220px; }
.prob-row .dot { width: 8px; height: 8px; border-radius: 50%; }
.prob-row .bar-track { flex: 1; height: 8px; background: var(--bg-3); border-radius: 6px; overflow: hidden; position: relative; }
.prob-row .bar-fill { height: 100%; border-radius: 6px; transition: width 400ms cubic-bezier(.2,.8,.2,1); }
.prob-row .pct { font-family: var(--font-mono); font-weight: 700; font-size: 16px; min-width: 52px; text-align: right; }

/* iv vs hist */
.iv-cmp { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.iv-cmp .iv-col { padding: 12px; border-radius: 10px; border: 1px solid var(--line); background: var(--bg); }
.iv-cmp .iv-col .lbl { font-size: 11px; text-transform: uppercase; letter-spacing: 0.08em; color: var(--fg-3); font-weight: 600; }
.iv-cmp .iv-col .val { font-family: var(--font-display); font-weight: 700; font-size: 28px; letter-spacing: -0.02em; margin: 4px 0 6px; }
.iv-cmp .iv-col .sub { font-size: 12px; color: var(--fg-3); }

.iv-verdict {
  margin-top: 10px;
  padding: 10px 12px;
  border-radius: 10px;
  font-size: 13px;
}

/* legend */
.legend { display: flex; gap: 16px; flex-wrap: wrap; font-size: 12px; color: var(--fg-2); }
.legend .item { display: flex; align-items: center; gap: 6px; }
.legend .swatch { width: 12px; height: 4px; border-radius: 2px; }
.legend .swatch.dashed { width: 14px; height: 0; border-top: 1.5px dashed; }
.legend .swatch.ring { width: 10px; height: 10px; border-radius: 999px; background: var(--bg-2); border: 2px solid var(--fg); }
.legend .swatch.open-tick { width: 8px; height: 2px; background: var(--fg-2); border-radius: 1px; }

/* chart toolbar */
.toolbar { display: flex; gap: 6px; align-items: center; }
.seg {
  display: inline-flex; gap: 2px; padding: 3px;
  background: var(--bg); border: 1px solid var(--line); border-radius: 8px;
}
.seg button {
  font-family: var(--font-body); font-size: 12px; font-weight: 500;
  background: transparent; border: 0; padding: 4px 10px; border-radius: 6px;
  color: var(--fg-3); cursor: pointer;
}
.seg button.active { background: var(--bg-2); color: var(--fg); box-shadow: 0 1px 1px rgba(0,0,0,0.06); }

/* earnings warning banner */
.earnings-banner {
  display: flex; gap: 12px; align-items: center;
  background: color-mix(in oklch, var(--warn), transparent 88%);
  border: 1px solid color-mix(in oklch, var(--warn), transparent 60%);
  padding: 10px 14px;
  border-radius: 10px;
  font-size: 13px;
}
.earnings-banner .ico { font-size: 16px; }
.earnings-banner b { color: var(--fg); }

/* helpers */
.col-list { display: flex; flex-direction: column; gap: var(--row-gap); }
.muted { color: var(--fg-3); }
.mono { font-family: var(--font-mono); }

/* spec list */
.spec-list { display: grid; grid-template-columns: 1fr 1fr; gap: 6px 16px; font-size: 13px; }
.spec-list .k { color: var(--fg-3); }
.spec-list .v { font-family: var(--font-mono); font-weight: 600; }

/* ─── Strategy cards ──────────────────────────────────────────────────── */
.strat-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 12px;
}
.strat-card {
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 14px 16px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  transition: 150ms ease;
  position: relative;
}
.strat-card:hover {
  transform: translateY(-1px);
  box-shadow: var(--shadow-card);
  border-color: var(--line-2);
}
.strat-card.selected {
  border-color: var(--accent);
  box-shadow: 0 0 0 2px color-mix(in oklch, var(--accent), transparent 80%);
}
.strat-card.top-1 { box-shadow: 0 0 0 2px color-mix(in oklch, var(--accent), transparent 65%), 0 6px 18px rgba(0,0,0,0.10); }
.strat-card.top-1.selected { box-shadow: 0 0 0 2px var(--accent), 0 6px 18px rgba(0,0,0,0.10); }
.strat-head {
  display: flex; align-items: center; justify-content: flex-start;
  gap: 8px; flex-wrap: wrap;
}
.strat-rank {
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 700;
  color: var(--fg-3);
  letter-spacing: 0.04em;
  padding: 2px 6px;
  border-radius: 5px;
  background: var(--bg-3);
}
.strat-rank.top {
  color: var(--accent-text);
  background: var(--accent);
}
.strat-fit {
  display: inline-flex; align-items: center; gap: 6px;
  flex: 1; min-width: 0;
}
.strat-fit-bar {
  flex: 1; height: 4px; border-radius: 3px;
  background: var(--bg-3);
  overflow: hidden;
}
.strat-fit-bar-fill {
  display: block; height: 100%;
  border-radius: 3px;
  transition: width 200ms ease;
}
.strat-fit-num {
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 700;
  color: var(--fg-2);
  min-width: 22px;
  text-align: right;
}
.strat-why {
  font-size: 11px;
  color: var(--fg-2);
  font-weight: 500;
  letter-spacing: 0.01em;
  padding: 4px 8px;
  border-radius: 6px;
  background: color-mix(in oklch, var(--accent), transparent 92%);
  border: 1px solid color-mix(in oklch, var(--accent), transparent 80%);
  margin-top: -2px;
}
.strat-tag {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-weight: 600;
  padding: 2px 7px;
  border-radius: 999px;
  border: 1px solid;
  background: var(--bg-2);
}
.strat-name {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 17px;
  letter-spacing: -0.01em;
}
.strat-stats {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: 8px 10px;
  background: var(--bg-2);
  border-radius: 8px;
  border: 1px solid var(--line);
}
.strat-stat {
  display: flex; justify-content: space-between; gap: 8px;
  font-size: 12px;
}
.strat-stat span { color: var(--fg-3); }
.strat-stat b {
  font-family: var(--font-mono);
  font-weight: 600;
  color: var(--fg);
}
.strat-note {
  font-size: 12px;
  color: var(--fg-3);
  line-height: 1.5;
  border-top: 1px dashed var(--line);
  padding-top: 8px;
}
.strat-pl-btn {
  font-family: var(--font-body);
  font-size: 12px;
  font-weight: 600;
  background: var(--bg-2);
  color: var(--fg-2);
  border: 1px solid var(--line);
  border-radius: 7px;
  padding: 5px 10px;
  cursor: pointer;
  margin-top: auto;
  transition: 120ms ease;
}
.strat-pl-btn:hover { color: var(--fg); border-color: var(--accent); }
.strat-card.selected .strat-pl-btn {
  background: var(--accent);
  color: var(--accent-text);
  border-color: var(--accent);
}

/* ─── Theta vs gamma timing ─────────────────────────────────────────── */
.theta-scenarios {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
  margin-top: 14px;
}
@media (max-width: 900px) { .theta-scenarios { grid-template-columns: 1fr; } }
.theta-scenario {
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 10px 12px;
  background: var(--bg);
  display: flex;
  flex-direction: column;
  gap: 6px;
  position: relative;
}
.theta-scenario.winner {
  border-color: var(--accent);
  background: color-mix(in oklch, var(--accent), transparent 92%);
  box-shadow: 0 0 0 2px color-mix(in oklch, var(--accent), transparent 80%);
}
.theta-scenario-name {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 13px;
  color: var(--fg);
}
.theta-scenario-stats {
  display: flex; flex-wrap: wrap; gap: 4px 12px;
  font-size: 11px; color: var(--fg-3);
  font-family: var(--font-mono);
}
.theta-scenario-stats b {
  color: var(--fg); font-weight: 600;
}
.theta-scenario-cap {
  font-family: var(--font-mono);
  font-weight: 700;
  font-size: 14px;
  margin-top: 2px;
}
.theta-scenario-badge {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-weight: 700;
  color: var(--accent);
  padding: 2px 6px;
  border-radius: 5px;
  background: color-mix(in oklch, var(--accent), transparent 85%);
  align-self: flex-start;
  margin-top: 2px;
}
.term {
  border-bottom: 1px dotted color-mix(in oklch, var(--fg-3), transparent 30%);
  cursor: help;
  outline: none;
}
.term:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
  border-radius: 2px;
}

.tip {
  position: fixed;
  transform: translate(-50%, 8px);
  background: var(--bg-2);
  color: var(--fg);
  border: 1px solid var(--line-2);
  border-radius: 10px;
  padding: 10px 12px;
  box-shadow: 0 12px 32px -8px rgba(0,0,0,0.18), 0 1px 2px rgba(0,0,0,0.06);
  font-size: 12px;
  line-height: 1.5;
  max-width: 320px;
  min-width: 200px;
  z-index: 99999;
  pointer-events: none;
  animation: tip-in 120ms ease-out;
}
[data-theme="dark"] .tip {
  box-shadow: 0 12px 32px -8px rgba(0,0,0,0.5), 0 1px 2px rgba(0,0,0,0.3);
}
.tip .tip-arrow {
  position: absolute;
  top: -5px; left: 50%; transform: translateX(-50%) rotate(45deg);
  width: 9px; height: 9px;
  background: var(--bg-2);
  border-left: 1px solid var(--line-2);
  border-top: 1px solid var(--line-2);
}
.tip .tip-body { color: var(--fg-2); }
@keyframes tip-in {
  from { opacity: 0; transform: translate(-50%, 4px); }
  to { opacity: 1; transform: translate(-50%, 8px); }
}

/* Earnings badge in This Week's Setup panel */
.earn-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 5px 11px;
  border-radius: 999px;
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.04em;
  border: 1px solid;
}
.earn-badge .earn-dot { font-size: 9px; opacity: 0.9; }
.earn-badge .earn-cap { letter-spacing: 0.12em; }
.earn-badge .earn-when { font-weight: 600; opacity: 0.92; }
.earn-warn-strong {
  color: var(--warn);
  background: color-mix(in srgb, var(--warn) 18%, transparent);
  border-color: color-mix(in srgb, var(--warn) 60%, transparent);
}
.earn-warn {
  color: var(--warn);
  background: color-mix(in srgb, var(--warn) 10%, transparent);
  border-color: color-mix(in srgb, var(--warn) 35%, transparent);
}
.earn-soft {
  color: var(--fg-2);
  background: var(--bg-3);
  border-color: var(--line);
}

/* Open Interest / Volume concentration card */
.oi-grid { display: flex; flex-direction: column; gap: 16px; }
.oi-totals { display: flex; flex-direction: column; gap: 6px; }
.oi-total-row {
  display: flex; align-items: baseline; justify-content: space-between;
  padding: 10px 14px; background: var(--bg-3); border-radius: 8px;
  border: 1px solid var(--line);
}
.oi-label { font-size: 12px; color: var(--fg-2); font-family: var(--font-mono); letter-spacing: 0.04em; text-transform: uppercase; }
.oi-pair { display: inline-flex; align-items: baseline; gap: 6px; font-family: var(--font-mono); font-size: 14px; }
.oi-pair b { font-weight: 700; }
.oi-sep { color: var(--fg-3); font-size: 11px; margin-right: 4px; }
.oi-ratio { margin-left: 12px; padding: 2px 8px; border-radius: 6px; background: var(--bg-2); border: 1px solid var(--line); font-size: 12px; font-weight: 600; color: var(--fg-2); }
.oi-tops { display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px; }
.oi-col { background: var(--bg-3); border: 1px solid var(--line); border-radius: 8px; padding: 10px 12px; }
.oi-col-head { font-size: 11px; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase; margin-bottom: 6px; font-family: var(--font-mono); }
.oi-row { display: flex; justify-content: space-between; align-items: center; padding: 3px 0; font-family: var(--font-mono); font-size: 13px; }
.oi-row.muted { color: var(--fg-3); justify-content: center; }
.oi-strike { color: var(--fg); font-weight: 600; }
.oi-num { color: var(--fg-2); }
@media (max-width: 1200px) {
  .oi-tops { grid-template-columns: repeat(2, 1fr); }
}

/* Trade ticket legs in strategy cards */
.strat-legs {
  display: flex; flex-direction: column; gap: 5px;
  margin: 8px 0 10px;
  padding: 8px 10px;
  background: var(--bg-3);
  border-radius: 6px;
  border: 1px solid var(--line);
  min-width: 0;
}
.strat-leg {
  display: flex;
  align-items: baseline;
  gap: 6px;
  font-family: var(--font-mono);
  font-size: 10.5px;
  line-height: 1.35;
  min-width: 0;
}
.strat-leg .leg-action {
  font-weight: 700;
  letter-spacing: 0.04em;
  flex: 0 0 auto;
}
.strat-leg.sell .leg-action { color: var(--down); }
.strat-leg.buy  .leg-action { color: var(--up); }
.strat-leg .leg-qty { color: var(--fg-2); flex: 0 0 auto; }
.strat-leg .leg-side { font-weight: 700; flex: 0 0 auto; }
.strat-leg .leg-side.call  { color: var(--up); }
.strat-leg .leg-side.put   { color: var(--down); }
.strat-leg .leg-side.stock { color: var(--fg-2); }
.strat-leg .leg-strike { color: var(--fg); font-weight: 600; flex: 0 0 auto; }
.strat-leg .leg-exp {
  color: var(--fg-3); font-size: 10px;
  flex: 1 1 auto; min-width: 0;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.strat-leg .leg-prem { color: var(--fg-2); flex: 0 0 auto; }

/* Options chain table */
.oc-wrap { margin-top: 18px; padding-top: 16px; border-top: 1px solid var(--line); }
.oc-head { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 8px; }
.oc-title { font-weight: 600; font-size: 14px; color: var(--fg); }
.oc-sub { font-size: 11px; color: var(--fg-3); font-family: var(--font-mono); }
.oc-table-scroll { overflow-x: auto; }
.oc-table {
  width: 100%; border-collapse: collapse; font-family: var(--font-mono);
  font-size: 11px;
}
.oc-table th, .oc-table td {
  padding: 5px 6px; text-align: right; white-space: nowrap;
}
.oc-table thead th.oc-side {
  letter-spacing: 0.12em; font-weight: 700; padding: 6px 8px;
  font-size: 11px;
}
.oc-side-call { color: var(--up); border-bottom: 1px solid color-mix(in srgb, var(--up) 35%, transparent); }
.oc-side-put  { color: var(--down); border-bottom: 1px solid color-mix(in srgb, var(--down) 35%, transparent); }
.oc-strike-h { color: var(--fg-2); font-weight: 700; letter-spacing: 0.08em; font-size: 11px; }
.oc-table .oc-sub-head th { font-size: 10px; color: var(--fg-3); font-weight: 500; padding-bottom: 6px; border-bottom: 1px solid var(--line); }
.oc-table tbody tr { border-bottom: 1px solid color-mix(in srgb, var(--line) 50%, transparent); }
.oc-table tbody tr:hover { background: color-mix(in srgb, var(--accent) 8%, transparent); }
.oc-table td.oc-strike { color: var(--fg); font-weight: 700; text-align: center; background: var(--bg-3); }
.oc-table td.itm { background: color-mix(in srgb, var(--fg) 4%, transparent); color: var(--fg); }
.oc-table tr.oc-atm { background: color-mix(in srgb, var(--accent) 12%, transparent); }
.oc-table tr.oc-atm td { font-weight: 700; }
.oc-legend { display: flex; gap: 18px; margin-top: 8px; font-size: 11px; color: var(--fg-3); font-family: var(--font-mono); }
.oc-leg-item { display: inline-flex; align-items: center; gap: 6px; }
.oc-leg-swatch { display: inline-block; width: 14px; height: 12px; border-radius: 3px; }
.oc-leg-itm { background: color-mix(in srgb, var(--fg) 8%, transparent); }
.oc-leg-atm { background: color-mix(in srgb, var(--accent) 24%, transparent); }

/* Net Greeks panel for active strategy */
.net-greeks {
  margin-top: 18px;
  padding-top: 16px;
  border-top: 1px solid var(--line);
}
.net-greeks-head {
  display: flex; align-items: baseline; gap: 12px; margin-bottom: 10px;
}
.net-greeks-title {
  font-size: 13px; font-weight: 700; color: var(--fg);
  letter-spacing: 0.04em;
}
.net-greeks-partial {
  font-size: 10px; color: var(--warn); font-family: var(--font-mono);
  text-transform: uppercase; letter-spacing: 0.08em;
}
.net-greeks-grid {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px;
}
.ng-cell {
  background: var(--bg-3); border: 1px solid var(--line);
  border-radius: 8px; padding: 10px 12px;
}
.ng-lbl {
  font-size: 11px; color: var(--fg-3);
  letter-spacing: 0.08em; text-transform: uppercase;
  font-family: var(--font-mono); margin-bottom: 4px;
}
.ng-val {
  font-family: var(--font-mono); font-size: 18px; font-weight: 700;
  display: inline-flex; align-items: baseline; gap: 4px;
}
.ng-val.up   { color: var(--up); }
.ng-val.down { color: var(--down); }
.ng-val .ng-unit { font-size: 10px; font-weight: 500; color: var(--fg-3); margin-left: 2px; }
.ng-sub {
  font-size: 10.5px; color: var(--fg-3); margin-top: 4px;
  font-family: var(--font-mono);
}
@media (max-width: 1100px) {
  .net-greeks-grid { grid-template-columns: repeat(2, 1fr); }
}

/* Max pain pill in OI card header */
.max-pain-pill {
  display: inline-flex; align-items: baseline; gap: 8px;
  padding: 6px 12px;
  background: var(--bg-3); border: 1px solid var(--line);
  border-radius: 999px; font-family: var(--font-mono);
}
.max-pain-pill .mp-lbl {
  font-size: 10px; color: var(--fg-3);
  text-transform: uppercase; letter-spacing: 0.1em;
}
.max-pain-pill .mp-strike {
  font-size: 14px; color: var(--fg); font-weight: 700;
}
.max-pain-pill .mp-delta {
  font-size: 11px; font-weight: 600;
}
.max-pain-pill .mp-delta.up   { color: var(--up); }
.max-pain-pill .mp-delta.down { color: var(--down); }

/* Watchlist controls in sidebar */
.sb-label-row { display: flex; align-items: baseline; justify-content: space-between; margin-bottom: 6px; }
.sb-pin-btn {
  background: transparent; border: 1px solid var(--line);
  color: var(--fg-2); font-family: var(--font-mono); font-size: 10px;
  padding: 2px 8px; border-radius: 999px; cursor: pointer;
  letter-spacing: 0.04em;
}
.sb-pin-btn:hover { color: var(--accent); border-color: var(--accent); }
.sb-watchlist-empty { font-size: 11px; color: var(--fg-3); padding: 4px 0; }

/* Loading progress bar at top of main */
.load-bar {
  position: absolute; top: 0; left: 0; right: 0; z-index: 50;
  height: 3px; background: transparent;
  pointer-events: none;
  margin-bottom: 0;
  opacity: 0; transition: opacity 0.2s ease-out;
}
.load-bar.loading { opacity: 1; }
.load-bar-fill {
  height: 100%;
  background: linear-gradient(90deg, transparent 0%, var(--accent) 50%, transparent 100%);
  width: 30%;
  animation: load-bar-slide 1.1s ease-in-out infinite;
}
@keyframes load-bar-slide {
  0%   { transform: translateX(-100%); }
  100% { transform: translateX(400%); }
}

/* Error banner (replaces tiny sidebar error) */
.error-banner {
  display: flex; align-items: center; gap: 12px;
  padding: 12px 16px; margin-bottom: var(--row-gap);
  background: color-mix(in srgb, var(--down) 12%, transparent);
  border: 1px solid color-mix(in srgb, var(--down) 40%, transparent);
  border-radius: 10px;
}
.error-banner .ico {
  flex: 0 0 auto;
  width: 24px; height: 24px; border-radius: 6px;
  background: var(--down); color: white;
  display: inline-flex; align-items: center; justify-content: center;
  font-weight: 700;
}
.error-banner > div { flex: 1; font-size: 13px; }
.error-retry {
  background: var(--down); color: white; border: none;
  padding: 6px 14px; border-radius: 6px; cursor: pointer;
  font-weight: 600; font-size: 12px;
}
.error-retry:hover { filter: brightness(1.1); }

/* Sidebar sub-labels and hints */
.sb-label-sub { font-size: 11px; color: var(--fg-2); font-weight: 500; }
.sb-hint { font-size: 10.5px; color: var(--fg-3); margin-top: 4px; font-family: var(--font-mono); }

/* MA toggle buttons in chart toolbar */
.ma-toggles button {
  font-family: var(--font-mono); font-size: 11px; font-weight: 700;
  letter-spacing: 0.06em;
}
.ma-toggles button.ma50.active   { color: var(--warn); border-color: var(--warn); }
.ma-toggles button.ma200.active  { color: var(--accent); border-color: var(--accent); }
.ma-toggles button.ema21.active  { color: rgb(80, 160, 255); border-color: rgb(80, 160, 255); }
.ma-toggles button.rsi.active    { color: rgb(190, 130, 255); border-color: rgb(190, 130, 255); }

/* Vol Rank pill */
.vol-rank-pill {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 8px 14px; border-radius: 12px;
  border: 1px solid var(--line);
  background: var(--bg-3);
}
.vol-rank-pill .vr-num {
  font-family: var(--font-mono); font-size: 24px; font-weight: 800;
  line-height: 1;
}
.vol-rank-pill .vr-lbl {
  font-size: 10px; color: var(--fg-2);
  text-transform: uppercase; letter-spacing: 0.1em; font-family: var(--font-mono);
  font-weight: 700;
}
.vol-rank-pill .vr-sub {
  font-size: 10px; color: var(--fg-3); font-family: var(--font-mono);
}
.vol-rank-pill.vr-high { background: color-mix(in srgb, var(--up) 14%, transparent); border-color: color-mix(in srgb, var(--up) 40%, transparent); }
.vol-rank-pill.vr-high .vr-num { color: var(--up); }
.vol-rank-pill.vr-low  { background: color-mix(in srgb, var(--warn) 14%, transparent); border-color: color-mix(in srgb, var(--warn) 40%, transparent); }
.vol-rank-pill.vr-low  .vr-num { color: var(--warn); }
.vol-rank-pill.vr-mid  .vr-num { color: var(--fg-2); }

/* GEX card */
.gex-total {
  display: inline-flex; align-items: baseline; gap: 8px;
  padding: 6px 12px; border-radius: 999px; border: 1px solid var(--line);
  background: var(--bg-3); font-family: var(--font-mono);
}
.gex-total .gex-total-lbl { font-size: 10px; color: var(--fg-3); text-transform: uppercase; letter-spacing: 0.1em; }
.gex-total .gex-total-val { font-size: 16px; font-weight: 800; }
.gex-total .gex-total-tag { font-size: 10px; color: var(--fg-3); }
.gex-total.pos .gex-total-val { color: var(--up); }
.gex-total.neg .gex-total-val { color: var(--down); }
.gex-grid { display: grid; grid-template-columns: 1fr 1.4fr; gap: 14px; }
.gex-col { background: var(--bg-3); border: 1px solid var(--line); border-radius: 8px; padding: 12px 14px; }
.gex-col-head { font-size: 11px; color: var(--fg-3); text-transform: uppercase; letter-spacing: 0.1em; font-family: var(--font-mono); margin-bottom: 8px; }
.gex-flip-strike { font-family: var(--font-mono); font-size: 22px; font-weight: 800; color: var(--fg); }
.gex-flip-side { font-family: var(--font-mono); font-size: 12px; margin-top: 4px; }
.gex-flip-side.above { color: var(--up); }
.gex-flip-side.below { color: var(--down); }
.gex-flip-hint { margin-top: 8px; font-size: 11px; color: var(--fg-2); line-height: 1.5; }
.gex-row { display: grid; grid-template-columns: 60px 1fr 70px; gap: 10px; align-items: center; padding: 4px 0; font-family: var(--font-mono); font-size: 12px; }
.gex-strike { color: var(--fg); font-weight: 600; }
.gex-bar-wrap { background: var(--bg-2); height: 8px; border-radius: 4px; overflow: hidden; }
.gex-bar { display: block; height: 100%; border-radius: 4px; }
.gex-bar.pos { background: var(--up); }
.gex-bar.neg { background: var(--down); }
.gex-val { text-align: right; font-weight: 600; }
.gex-val.pos { color: var(--up); }
.gex-val.neg { color: var(--down); }
.gex-disclaimer { margin-top: 10px; font-size: 10.5px; color: var(--fg-3); font-family: var(--font-mono); }
@media (max-width: 1100px) { .gex-grid { grid-template-columns: 1fr; } }

/* Roll suggestions */
.roll-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.roll-side {
  background: var(--bg-3); border: 1px solid var(--line);
  border-radius: 8px; padding: 14px;
}
.roll-side-head {
  font-family: var(--font-mono); font-size: 11px;
  letter-spacing: 0.1em; text-transform: uppercase;
  margin-bottom: 4px;
}
.roll-side-head .up   { color: var(--up); }
.roll-side-head .down { color: var(--down); }
.roll-side-now {
  font-size: 11px; color: var(--fg-3); font-family: var(--font-mono);
  margin-bottom: 12px; padding-bottom: 10px;
  border-bottom: 1px solid var(--line);
}
.roll-row {
  display: grid; grid-template-columns: 1fr auto;
  gap: 4px 12px; padding: 8px 0;
  border-bottom: 1px solid color-mix(in srgb, var(--line) 50%, transparent);
}
.roll-row:last-child { border-bottom: none; }
.roll-label { font-size: 12px; color: var(--fg); font-weight: 600; }
.roll-credit { font-family: var(--font-mono); font-size: 13px; font-weight: 700; text-align: right; }
.roll-credit .up { color: var(--up); }
.roll-credit .down { color: var(--down); }
.roll-meta {
  grid-column: 1 / -1;
  display: flex; gap: 14px;
  font-family: var(--font-mono); font-size: 11px; color: var(--fg-3);
}
.roll-meta .roll-k { color: var(--fg-2); font-weight: 600; }
@media (max-width: 1100px) { .roll-grid { grid-template-columns: 1fr; } }

/* Compact ticker layout: small input on left, big symbol on right */
.sb-ticker-row { display: flex; gap: 12px; align-items: flex-start; }
.sb-ticker-left { flex: 1 1 auto; min-width: 0; }
.sb-ticker-wrap-compact { width: 110px; position: relative; }
.sb-ticker-wrap-compact .sb-ticker-input { width: 100%; }
.sb-ticker-display {
  flex: 0 0 auto;
  display: flex; flex-direction: column; align-items: flex-start; justify-content: center;
  min-width: 0;
}
.sb-ticker-symbol {
  font-family: var(--font-display); font-weight: 800;
  font-size: 22px; line-height: 1.05;
  color: var(--fg); letter-spacing: 0.02em;
}
.sb-ticker-logo {
  height: 56px; max-width: 100%; object-fit: contain;
  align-self: flex-start;
  filter: drop-shadow(0 0 0.5px var(--line));
  border-radius: 6px;
  background: rgba(255, 255, 255, 0.04);
  padding: 3px 6px;
  transform: translateY(-6px);
}
.sb-ticker-symbol-fallback {
  font-family: var(--font-display); font-weight: 800;
  font-size: 32px; line-height: 1.05;
  color: var(--fg); letter-spacing: 0.02em;
  transform: translateY(-2px);
}
.sb-ticker-price-row {
  display: flex; gap: 8px; align-items: baseline;
  font-family: var(--font-mono); margin-top: 2px;
}
.sb-ticker-price-row .sb-price { font-size: 13px; color: var(--fg-2); font-weight: 600; }
.sb-ticker-price-row .delta { font-size: 11px; font-weight: 700; }
.sb-ticker-price-row .delta.up   { color: var(--up); }
.sb-ticker-price-row .delta.down { color: var(--down); }
.sb-ticker-name-line {
  font-size: 11px; color: var(--fg-3);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  margin-top: 4px; padding: 0 2px;
}

/* MA regime summary in legend */
.legend .ma-regime { font-size: 12px; }
.legend .ma-pip { display: inline-block; width: 8px; height: 8px; border-radius: 50%; margin-right: 4px; }

/* GEX refresh controls */
.gex-controls { display: flex; flex-direction: column; gap: 6px; align-items: flex-end; }
.gex-refresh { display: inline-flex; align-items: center; gap: 6px; }
.gex-refresh-btn {
  width: 28px; height: 28px;
  background: var(--bg-3); color: var(--accent);
  border: 1px solid var(--line);
  border-radius: 6px; cursor: pointer;
  font-size: 14px; font-weight: 700;
}
.gex-refresh-btn:hover:not(:disabled) {
  background: var(--accent); color: var(--accentText);
  border-color: var(--accent);
}
.gex-refresh-btn:disabled { opacity: 0.5; cursor: wait; }
.gex-auto-sel {
  background: var(--bg-3); color: var(--fg-2);
  border: 1px solid var(--line); border-radius: 6px;
  padding: 4px 8px; font-family: var(--font-mono); font-size: 11px;
  cursor: pointer;
}
.gex-last { font-family: var(--font-mono); font-size: 10px; color: var(--fg-3); }

/* Position tracker */
.pos-toolbar { display: inline-flex; gap: 8px; align-items: center; }
.pos-add-btn {
  background: var(--bg-3); color: var(--fg);
  border: 1px solid var(--line);
  padding: 6px 14px; border-radius: 6px; cursor: pointer;
  font-size: 12px; font-weight: 600;
}
.pos-add-btn:hover { border-color: var(--accent); color: var(--accent); }
.pos-add-btn.primary {
  background: var(--accent); color: var(--accentText); border-color: var(--accent);
}
.pos-empty {
  display: flex; flex-direction: column; align-items: center; gap: 14px;
  padding: 32px 16px; color: var(--fg-3); text-align: center;
  border: 1px dashed var(--line); border-radius: 10px; margin-top: 12px;
}
.pos-list { display: flex; flex-direction: column; gap: 8px; margin-top: 12px; }
.pos-row {
  display: grid; grid-template-columns: 1fr auto auto;
  gap: 12px; align-items: center;
  padding: 12px 14px;
  background: var(--bg-3); border: 1px solid var(--line);
  border-radius: 8px;
}
.pos-row.closed { opacity: 0.6; }
.pos-row-main { min-width: 0; }
.pos-line1 {
  display: flex; gap: 8px; align-items: baseline;
  font-family: var(--font-mono); font-size: 13px;
  margin-bottom: 4px;
}
.pos-tk { font-weight: 800; color: var(--fg); font-size: 14px; }
.pos-side {
  font-size: 10px; font-weight: 700; letter-spacing: 0.08em;
  padding: 2px 6px; border-radius: 3px;
}
.pos-side.short { background: color-mix(in srgb, var(--down) 18%, transparent); color: var(--down); }
.pos-side.long  { background: color-mix(in srgb, var(--up) 18%, transparent); color: var(--up); }
.pos-type { font-weight: 700; font-size: 11px; }
.pos-type.call  { color: var(--up); }
.pos-type.put   { color: var(--down); }
.pos-type.stock { color: var(--fg-2); }
.pos-k { color: var(--fg); font-weight: 600; }
.pos-exp { color: var(--fg-2); font-size: 11px; }
.pos-dte {
  font-size: 10px; padding: 1px 6px; border-radius: 3px;
  background: var(--bg-2); color: var(--fg-2);
}
.pos-qty { color: var(--fg-3); font-size: 11px; margin-left: auto; }
.pos-line2 {
  display: flex; gap: 14px; align-items: baseline;
  font-family: var(--font-mono); font-size: 11px; color: var(--fg-3);
}
.pos-line2 b { color: var(--fg-2); }
.pos-status { color: var(--fg-3); font-size: 10px; margin-left: auto; }
.pos-row-pnl { text-align: right; font-family: var(--font-mono); }
.pos-pnl { font-size: 17px; font-weight: 800; line-height: 1.05; }
.pos-pnl.up   { color: var(--up); }
.pos-pnl.down { color: var(--down); }
.pos-pnl-pct { font-size: 11px; font-weight: 600; }
.pos-pnl-pct.up   { color: var(--up); }
.pos-pnl-pct.down { color: var(--down); }
.pos-pnl-na { font-size: 18px; color: var(--fg-3); }
.pos-row-actions { display: flex; gap: 4px; }
.pos-action {
  background: transparent; border: 1px solid var(--line);
  color: var(--fg-2); padding: 4px 10px; border-radius: 4px;
  font-size: 11px; cursor: pointer;
}
.pos-action:hover { border-color: var(--accent); color: var(--accent); }
.pos-action.danger:hover { border-color: var(--down); color: var(--down); }

/* Add position form */
.pos-add-form {
  background: var(--bg-3); border: 1px solid var(--line);
  border-radius: 8px; padding: 14px; margin-top: 12px;
}
.pos-form-quick {
  display: flex; gap: 8px; align-items: center;
  font-size: 11px; color: var(--fg-3); margin-bottom: 12px;
  padding-bottom: 12px; border-bottom: 1px solid var(--line);
  flex-wrap: wrap;
}
.pos-quick-btn {
  background: var(--bg-2); border: 1px solid var(--line);
  color: var(--fg-2); font-family: var(--font-mono); font-size: 11px;
  padding: 4px 10px; border-radius: 4px; cursor: pointer;
}
.pos-quick-btn:hover { color: var(--accent); border-color: var(--accent); }
.pos-form-grid {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px;
}
.pos-form-grid label {
  display: flex; flex-direction: column; gap: 4px;
  font-size: 11px; color: var(--fg-3);
}
.pos-form-grid input, .pos-form-grid select {
  background: var(--bg-2); border: 1px solid var(--line);
  color: var(--fg); padding: 6px 10px; border-radius: 4px;
  font-family: var(--font-mono); font-size: 12px;
}
.pos-form-grid input:focus, .pos-form-grid select:focus {
  outline: none; border-color: var(--accent);
}
.pos-form-actions { display: flex; gap: 8px; margin-top: 12px; }
@media (max-width: 1100px) {
  .pos-form-grid { grid-template-columns: repeat(2, 1fr); }
  .pos-row { grid-template-columns: 1fr auto; }
  .pos-row-actions { grid-column: 1 / -1; justify-content: flex-end; }
}

/* ── v15 additions ────────────────────────────────────────────── */

/* Sidebar brand row needs to fit the new help button on the right */
.sb-brand { display: flex; align-items: center; gap: 10px; }
.sb-brand-text { flex: 1; min-width: 0; }
.sb-brand-actions {
  display: flex; gap: 7px; flex-shrink: 0;
}
.sb-icon-btn {
  background: var(--bg-3); border: 1px solid var(--line);
  color: var(--fg-2); width: 28px; height: 28px;
  border-radius: 7px; cursor: pointer;
  display: inline-flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  transition: color 0.12s ease, border-color 0.12s ease, background 0.12s ease;
  padding: 0;
}
.sb-icon-btn svg { width: 18px; height: 18px; display: block; }
.sb-icon-btn:hover { color: var(--accent); border-color: var(--accent); }
.sb-theme-btn:hover { color: var(--accent); }

/* Hot keys overlay */
.hk-overlay {
  position: fixed; inset: 0;
  background: rgba(0, 0, 0, 0.65);
  display: flex; align-items: center; justify-content: center;
  z-index: 9000; backdrop-filter: blur(4px);
}
.hk-card {
  background: var(--bg); border: 1px solid var(--line);
  border-radius: 14px; padding: 24px 28px;
  min-width: 420px; max-width: 560px;
  box-shadow: 0 24px 64px rgba(0, 0, 0, 0.5);
}
.hk-head {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 18px;
  padding-bottom: 12px; border-bottom: 1px solid var(--line);
}
.hk-title {
  font-family: var(--font-display); font-weight: 800;
  font-size: 17px; color: var(--fg);
}
.hk-close {
  background: transparent; color: var(--fg-3);
  border: 1px solid var(--line);
  width: 28px; height: 28px; border-radius: 6px;
  cursor: pointer; font-size: 16px; line-height: 1;
}
.hk-close:hover { color: var(--fg); border-color: var(--fg-3); }
.hk-grid { display: flex; flex-direction: column; gap: 10px; }
.hk-row {
  display: flex; align-items: center; gap: 8px;
  font-size: 13px; color: var(--fg-2);
}
.hk-row span { flex: 1; }
.hk-row kbd {
  background: var(--bg-3); border: 1px solid var(--line);
  border-bottom-width: 2px; border-radius: 4px;
  padding: 2px 8px; font-family: var(--font-mono); font-size: 12px;
  color: var(--fg); font-weight: 600;
  min-width: 22px; text-align: center;
  display: inline-block;
}
.hk-foot {
  margin-top: 18px; padding-top: 12px;
  border-top: 1px solid var(--line);
  font-size: 11px; color: var(--fg-3);
}

/* CONE toggle in chart toolbar */
.ma-toggles button.cone.active { color: var(--accent); border-color: var(--accent); }

/* Options chain — clickable cells + selection styling */
.oc-table tbody td.oc-cell {
  cursor: pointer;
  transition: background-color 0.08s ease, box-shadow 0.08s ease;
}
.oc-table tbody td.oc-call-cell:hover {
  background: color-mix(in srgb, var(--up) 18%, transparent) !important;
}
.oc-table tbody td.oc-put-cell:hover {
  background: color-mix(in srgb, var(--down) 18%, transparent) !important;
}
.oc-table tbody td.oc-sel-call {
  background: color-mix(in srgb, var(--up) 32%, transparent) !important;
  box-shadow: inset 0 1px 0 var(--up), inset 0 -1px 0 var(--up);
  color: var(--fg) !important;
}
.oc-table tbody td.oc-sel-put {
  background: color-mix(in srgb, var(--down) 32%, transparent) !important;
  box-shadow: inset 0 1px 0 var(--down), inset 0 -1px 0 var(--down);
  color: var(--fg) !important;
}
.oc-table tbody td.oc-wing-call {
  background: color-mix(in srgb, var(--up) 14%, transparent) !important;
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--up) 60%, transparent);
}
.oc-table tbody td.oc-wing-put {
  background: color-mix(in srgb, var(--down) 14%, transparent) !important;
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--down) 60%, transparent);
}
.oc-reset-btn {
  background: var(--accent); color: var(--accentText);
  border: 1px solid var(--accent);
  padding: 4px 12px; border-radius: 4px;
  font-size: 11px; font-weight: 600; cursor: pointer;
  margin-left: auto;
}
.oc-reset-btn:hover { opacity: 0.85; }

/* Manual override tag on suggested strike cards */
.strike-card.manual {
  border-color: color-mix(in srgb, var(--accent) 50%, var(--line)) !important;
}
.manual-tag {
  display: inline-block; margin-left: 8px;
  font-size: 9px; font-weight: 700; letter-spacing: 0.08em;
  padding: 1px 6px; border-radius: 3px;
  background: color-mix(in srgb, var(--accent) 22%, transparent);
  color: var(--accent);
}

/* ── v16 additions ───────────────────────────────────────────── */

/* Net Greeks card */
.ng-credit { display: inline-flex; flex-direction: column; align-items: flex-end; gap: 2px; }
.ng-credit-lbl { font-size: 10px; color: var(--fg-3); text-transform: uppercase; letter-spacing: 0.1em; font-family: var(--font-mono); }
.ng-credit-val { font-family: var(--font-mono); font-size: 22px; font-weight: 800; }
.ng-credit-tag { font-size: 10px; color: var(--fg-3); font-family: var(--font-mono); }
.ng-grid {
  display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 12px;
}
.ng-leg, .ng-totals {
  background: var(--bg-3); border: 1px solid var(--line);
  border-radius: 8px; padding: 12px 14px;
}
.ng-leg-head { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; margin-bottom: 4px; }
.ng-leg-head .up { color: var(--up); } .ng-leg-head .down { color: var(--down); }
.ng-leg-line { font-family: var(--font-mono); font-size: 12px; color: var(--fg-2); margin-bottom: 8px; }
.ng-leg-line:last-child { margin-bottom: 0; }
.ng-totals-head { font-family: var(--font-mono); font-size: 11px; color: var(--fg-3); text-transform: uppercase; letter-spacing: 0.1em; margin-bottom: 8px; }
.ng-tot-row { display: flex; justify-content: space-between; align-items: center; padding: 4px 0; font-family: var(--font-mono); font-size: 13px; }
.ng-tot-lbl { color: var(--fg-2); font-weight: 500; }
.ng-tot-val { font-weight: 700; }
.ng-tot-val.up   { color: var(--up); }
.ng-tot-val.down { color: var(--down); }
.ng-disclaimer { margin-top: 10px; font-size: 10.5px; color: var(--fg-3); font-family: var(--font-mono); }
@media (max-width: 1100px) { .ng-grid { grid-template-columns: 1fr; } }

/* Volatility skew card */
.vs-svg { width: 100%; height: auto; display: block; }

.vs-stats { display: inline-flex; gap: 18px; align-items: center; }
.vs-stat { font-family: var(--font-mono); display: flex; flex-direction: column; align-items: flex-end; gap: 2px; }
.vs-stat-lbl { font-size: 10px; color: var(--fg-3); text-transform: uppercase; letter-spacing: 0.08em; }
.vs-stat-val { font-size: 18px; font-weight: 800; color: var(--fg); }
.vs-stat-val.up { color: var(--up); }
.vs-stat-val.down { color: var(--down); }

/* Error boundary styling */
.card-error { border-color: var(--down); }
.card-error-msg { color: var(--down); font-family: var(--font-mono); font-size: 12px; margin: 8px 0; padding: 10px; background: var(--bg-3); border-radius: 6px; }
.card-error-btn { background: var(--accent); color: var(--accentText); border: none; padding: 6px 14px; border-radius: 6px; font-size: 12px; cursor: pointer; }

/* Drag-range hover styling — strikes inside an active drag range */
.oc-table tbody td.oc-drag-call {
  background: color-mix(in srgb, var(--up) 22%, transparent) !important;
}
.oc-table tbody td.oc-drag-put {
  background: color-mix(in srgb, var(--down) 22%, transparent) !important;
}

/* Chart pan/zoom interaction */
.chart-svg { cursor: crosshair; }
.chart-svg.is-panning { cursor: grabbing; }
.zoom-reset {
  font-family: var(--font-mono);
  font-size: 11px; font-weight: 600;
  letter-spacing: 0.05em;
  color: var(--accent);
  background: transparent;
  border: 1px solid var(--accent);
  border-radius: 4px;
  padding: 4px 8px;
  cursor: pointer;
  margin-left: 6px;
}
.zoom-reset:hover { background: color-mix(in srgb, var(--accent) 12%, transparent); }

/* Earnings pill in chart title */
.earn-pill {
  display: inline-block;
  margin-left: 10px;
  font-family: var(--font-mono);
  font-size: 11px; font-weight: 700;
  letter-spacing: 0.04em;
  padding: 3px 8px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--warn) 15%, transparent);
  color: var(--warn);
  border: 1px solid color-mix(in srgb, var(--warn) 35%, transparent);
  vertical-align: middle;
}
.earn-pill.close {
  background: color-mix(in srgb, var(--warn) 22%, transparent);
  border-color: color-mix(in srgb, var(--warn) 55%, transparent);
}
.earn-pill.urgent {
  background: var(--warn);
  color: white;
  border-color: var(--warn);
  animation: earnPulse 2s ease-in-out infinite;
}
@keyframes earnPulse {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.65; }
}

/* Add earnings legend */
.legend .item.earn-next-legend { color: var(--warn); }

/* Watchlist scanner */
.scan-toolbar { display: flex; align-items: center; gap: 12px; }
.scan-stale { font-size: 11px; color: var(--fg-3); font-family: var(--font-mono); }
.scan-run-btn {
  background: var(--accent); color: var(--accentText);
  border: 1px solid var(--accent);
  padding: 6px 14px; border-radius: 6px;
  font-size: 12px; font-weight: 600;
  font-family: var(--font-mono);
  letter-spacing: 0.04em;
  cursor: pointer;
}
.scan-run-btn:disabled { opacity: 0.55; cursor: not-allowed; }
.scan-run-btn:hover:not(:disabled) { opacity: 0.92; }
.scan-empty {
  padding: 18px 4px; color: var(--fg-3);
  font-family: var(--font-mono); font-size: 12px;
  text-align: center;
}
.scan-table-wrap { overflow-x: auto; }
.scan-table {
  width: 100%; border-collapse: collapse;
  font-family: var(--font-mono); font-size: 12px;
}
.scan-table th {
  text-align: left; padding: 8px 10px;
  color: var(--fg-3);
  font-size: 10.5px; letter-spacing: 0.06em; text-transform: uppercase;
  border-bottom: 1px solid var(--line);
  font-weight: 600;
}
.scan-table .scan-th-num { text-align: right; }
.scan-table .scan-th-strat { text-align: left; }
.scan-row {
  border-bottom: 1px solid color-mix(in srgb, var(--line) 50%, transparent);
  cursor: pointer;
  transition: background 0.1s ease;
}
.scan-row:hover { background: var(--bg-3); }
.scan-row-active { background: color-mix(in srgb, var(--accent) 10%, transparent); }
.scan-row-active .scan-sym { color: var(--accent); }
.scan-row td { padding: 8px 10px; }
.scan-sym { font-weight: 700; color: var(--fg); }
.scan-num { text-align: right; }
.scan-num.up { color: var(--up); }
.scan-num.down { color: var(--down); }
.scan-num.rich { color: var(--accent); font-weight: 700; }
.scan-num.cheap { color: var(--warn); font-weight: 700; }
.scan-num.earn-close { color: var(--warn); font-weight: 700; }
.scan-num.earn-urgent { color: white; background: var(--warn); border-radius: 4px; padding: 4px 6px !important; }
.scan-num.score-hi { color: var(--up); font-weight: 800; font-size: 14px; }
.scan-num.score-mid { color: var(--accent); font-weight: 700; }
.scan-num.score-lo { color: var(--fg-3); }
.scan-strat { color: var(--fg); }
.scan-pending { color: var(--fg-3); font-style: italic; }
.scan-err { color: var(--down); font-size: 11px; }
.scan-disclaimer {
  margin-top: 8px; font-size: 10.5px; color: var(--fg-3);
  font-family: var(--font-mono);
}

/* Vol skew hover tooltip */
.vs-svg-wrap .vs-svg { cursor: crosshair; }
.vs-tooltip {
  position: absolute;
  background: var(--bg-2);
  border: 1px solid var(--line-2);
  border-radius: 8px;
  padding: 8px 12px;
  font-family: var(--font-mono);
  font-size: 12px;
  box-shadow: 0 6px 18px rgba(0,0,0,0.25);
  pointer-events: none;
  transform: translateX(-50%);
  min-width: 130px;
  z-index: 5;
}
.vs-tt-head { font-weight: 700; font-size: 13px; color: var(--fg); margin-bottom: 6px; padding-bottom: 4px; border-bottom: 1px solid var(--line); }
.vs-tt-row { display: flex; justify-content: space-between; gap: 16px; padding: 2px 0; }
.vs-tt-lbl { color: var(--fg-3); font-size: 11px; }
.vs-tt-lbl.up { color: var(--up); }
.vs-tt-lbl.down { color: var(--down); }
.vs-tt-val { color: var(--fg); font-weight: 600; }
.vs-tt-val.up { color: var(--up); }
.vs-tt-val.down { color: var(--down); }
.vs-tt-spread { margin-top: 4px; padding-top: 4px; border-top: 1px solid var(--line); }

/* Strategy reference cheatsheet */
.sref-toolbar {
  display: flex; gap: 12px; align-items: center;
  flex-wrap: wrap;
}
.sref-search {
  font-family: var(--font-mono); font-size: 12px;
  background: var(--bg-3); color: var(--fg);
  border: 1px solid var(--line); border-radius: 6px;
  padding: 6px 10px; min-width: 220px;
  outline: none;
}
.sref-search:focus { border-color: var(--accent); }
.sref-filter { display: inline-flex; gap: 4px; background: var(--bg-3); border-radius: 6px; padding: 3px; border: 1px solid var(--line); }
.sref-filter button {
  font-family: var(--font-mono); font-size: 11px; font-weight: 600;
  background: transparent; color: var(--fg-2); border: none;
  padding: 4px 10px; border-radius: 4px; cursor: pointer;
}
.sref-filter button.active { background: var(--accent); color: var(--accentText); }
.sref-empty {
  text-align: center; padding: 30px; color: var(--fg-3);
  font-family: var(--font-mono); font-size: 12px;
}
.sref-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 10px;
  margin-top: 4px;
}
.sref-tile {
  background: var(--bg-3); border: 1px solid var(--line);
  border-radius: 8px; padding: 12px 14px;
  cursor: pointer;
  transition: border-color 0.15s ease, transform 0.1s ease;
}
.sref-tile:hover { border-color: color-mix(in srgb, var(--accent) 60%, transparent); }
.sref-tile.open {
  grid-column: 1 / -1;
  border-color: var(--accent);
  background: color-mix(in srgb, var(--accent) 4%, var(--bg-3));
}
.sref-tile-head {
  display: flex; justify-content: space-between; align-items: baseline;
  gap: 12px; margin-bottom: 4px;
}
.sref-tile-name {
  font-family: var(--font-display); font-weight: 700;
  font-size: 14px; color: var(--fg);
}
.sref-tile-fam {
  font-family: var(--font-mono); font-size: 10px;
  letter-spacing: 0.05em; color: var(--fg-3);
  text-transform: uppercase;
  white-space: nowrap;
}
.sref-tile-summary {
  font-size: 12px; color: var(--fg-2); line-height: 1.45;
}
.sref-tile-foot {
  font-family: var(--font-mono); font-size: 10px;
  color: var(--fg-3); margin-top: 8px;
  letter-spacing: 0.04em;
}
.sref-tile-detail {
  margin-top: 12px; padding-top: 12px;
  border-top: 1px solid var(--line);
  display: grid; grid-template-columns: 140px 1fr; gap: 8px 18px;
  cursor: default;
}
.sref-row { display: contents; }
.sref-lbl {
  font-family: var(--font-mono); font-size: 11px;
  color: var(--fg-3); text-transform: uppercase;
  letter-spacing: 0.05em;
  font-weight: 600;
  padding-top: 1px;
}
.sref-val {
  font-size: 12.5px; color: var(--fg-2); line-height: 1.5;
}
.sref-row-risk .sref-val { color: var(--down); }
@media (max-width: 700px) {
  .sref-tile-detail { grid-template-columns: 1fr; gap: 4px; }
  .sref-lbl { margin-top: 8px; }
}

/* Strategy builder tray */
.builder-tray {
  margin: 12px 0;
  padding: 12px 14px;
  background: var(--bg-3);
  border: 1px solid var(--line);
  border-radius: 8px;
}
.builder-tray.has-legs { border-color: color-mix(in srgb, var(--accent) 50%, transparent); }
.builder-head {
  display: flex; align-items: baseline; gap: 12px;
  flex-wrap: wrap;
}
.builder-title {
  font-family: var(--font-mono);
  font-size: 11px; font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--accent);
}
.builder-sub { font-size: 11px; color: var(--fg-3); }
.builder-legs {
  display: flex; flex-direction: column; gap: 4px;
  margin-top: 10px;
}
.builder-leg {
  display: grid;
  grid-template-columns: 50px 50px 70px 36px 78px 1fr 30px 30px;
  gap: 8px;
  align-items: center;
  padding: 6px 8px;
  background: var(--bg-2);
  border: 1px solid var(--line);
  border-left-width: 3px;
  border-radius: 6px;
  font-family: var(--font-mono);
  font-size: 12px;
}
.builder-leg.long { border-left-color: var(--up); }
.builder-leg.short { border-left-color: var(--down); }
.builder-leg-tag {
  font-size: 10px; font-weight: 700;
  letter-spacing: 0.04em;
}
.builder-leg.long .builder-leg-tag { color: var(--up); }
.builder-leg.short .builder-leg-tag { color: var(--down); }
.builder-leg-side { font-weight: 700; color: var(--fg); }
.builder-leg-strike { font-weight: 700; color: var(--fg); }
.builder-leg-qty { color: var(--fg-3); }
.builder-leg-prem { color: var(--fg-2); }
.builder-leg-cost { font-weight: 700; text-align: right; }
.builder-leg-cost.credit { color: var(--up); }
.builder-leg-cost.debit { color: var(--down); }
.builder-leg-flip, .builder-leg-rm {
  background: transparent;
  color: var(--fg-3);
  border: 1px solid var(--line);
  width: 24px; height: 24px;
  border-radius: 4px;
  cursor: pointer;
  font-size: 13px;
  display: inline-flex; align-items: center; justify-content: center;
}
.builder-leg-flip:hover { color: var(--accent); border-color: var(--accent); }
.builder-leg-rm:hover { color: var(--down); border-color: var(--down); }
.builder-actions {
  display: flex; align-items: center; justify-content: space-between;
  gap: 12px; margin-top: 10px;
  flex-wrap: wrap;
}
.builder-total {
  font-family: var(--font-mono);
  font-size: 14px; font-weight: 700;
}
.builder-total.credit { color: var(--up); }
.builder-total.debit { color: var(--down); }
.builder-btn-row { display: flex; gap: 8px; }
.builder-btn {
  font-family: var(--font-mono); font-size: 12px;
  padding: 7px 14px; border-radius: 6px;
  cursor: pointer; font-weight: 600;
  border: 1px solid var(--line);
  background: var(--bg-3);
  color: var(--fg);
}
.builder-btn-viz {
  background: var(--accent);
  color: var(--accentText);
  border-color: var(--accent);
}
.builder-btn-viz:hover { opacity: 0.9; }
.builder-btn-clear:hover { color: var(--down); border-color: var(--down); }

/* +/− buttons inline in chain */
.oc-build-cell {
  padding: 2px 4px !important;
  white-space: nowrap;
}
.oc-build-btn {
  font-family: var(--font-mono);
  font-size: 10px; font-weight: 700;
  padding: 3px 6px; margin: 0 1px;
  border-radius: 3px; cursor: pointer;
  border: 1px solid var(--line);
  background: var(--bg-3);
  color: var(--fg-2);
}
.oc-build-btn.oc-build-long { color: var(--up); }
.oc-build-btn.oc-build-long:hover { background: color-mix(in srgb, var(--up) 22%, transparent); border-color: var(--up); }
.oc-build-btn.oc-build-short { color: var(--down); }
.oc-build-btn.oc-build-short:hover { background: color-mix(in srgb, var(--down) 22%, transparent); border-color: var(--down); }
tr.oc-has-leg .oc-strike { background: color-mix(in srgb, var(--accent) 20%, transparent); }

/* Payoff card */
.payoff-stat-val.up { color: var(--up); }
.payoff-stat-val.down { color: var(--down); }
.payoff-hover b.up { color: var(--up); }
.payoff-hover b.down { color: var(--down); }

/* Strategy reference modal */
.ref-card {
  background: var(--bg-2);
  border: 1px solid var(--line);
  border-radius: 12px;
  width: min(1100px, 92vw);
  max-height: 88vh;
  overflow: hidden;
  display: flex; flex-direction: column;
  box-shadow: 0 24px 60px rgba(0,0,0,0.55);
}
.ref-card .hk-head {
  padding: 16px 20px;
  border-bottom: 1px solid var(--line);
  flex-shrink: 0;
}
.sref-modal-body {
  padding: 16px 20px;
  overflow-y: auto;
  flex: 1;
}
.sref-modal-body .sref-toolbar { margin-bottom: 12px; }

/* ═══════════════════════════════════════════════════════════════════════════
   MOBILE LAYOUT (≤720px)
   Optimized for iPhone Pro Max portrait (~430px logical px) but flexible
   down to ~360px and up through small tablets. Strategy:
   - Sidebar collapses to a top bar
   - Hero stacks vertically; charts shrink with viewBox auto-scale
   - Cards reduce padding
   - Touch targets bumped to 44px
   - Options chain horizontally scrolls
   - Modal takes full screen
   - Hide UI that doesn't translate well to mobile
   ═══════════════════════════════════════════════════════════════════════════ */
@media (max-width: 720px) {
  /* Honor iPhone safe-area insets so brand content isn't under the notch */
  body {
    padding: env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left);
  }

  /* Shell: single column, tighter padding */
  .shell {
    grid-template-columns: 1fr !important;
    gap: 12px !important;
    padding: 8px 10px 40px !important;
  }

  /* Sidebar: was sticky 304px. Becomes a normal section at the top.
     position:relative (not static) so the version + weather corner
     pills anchor to the sidebar on phones (v1.21). */
  .sidebar {
    position: relative !important;
    max-height: none !important;
    overflow: visible !important;
    padding: 14px !important;
  }
  .sb-section { margin-bottom: 14px; }

  /* Brand row: shrink logo a bit on mobile, keep buttons touch-sized */
  .brand-mark { width: 48px !important; height: 48px !important; }
  .sb-icon-btn {
    width: 38px !important; height: 38px !important;
    border-radius: 9px !important;
  }
  .sb-icon-btn svg { width: 20px !important; height: 20px !important; }
  .sb-brand-actions { gap: 8px !important; }

  /* Ticker section: input + logo + price stack vertically on tiny widths */
  .sb-ticker-row { flex-wrap: wrap; gap: 14px; }
  .sb-ticker-wrap-compact { width: 130px !important; }
  .sb-ticker-input {
    font-size: 16px !important;  /* iOS zooms inputs <16px on focus */
  }
  .sb-ticker-logo {
    height: 52px !important;
    transform: translateY(-2px) !important;
  }
  .sb-ticker-symbol-fallback {
    font-size: 28px !important;
    transform: translateY(-2px) !important;
  }
  .sb-price { font-size: 22px !important; }

  /* Watchlist + presets: keep pills but allow wrap */
  .sb-preset-row, .preset-row { gap: 8px; }
  .preset-pill {
    padding: 7px 12px !important;
    font-size: 12px !important;
    min-height: 36px;
  }

  /* Search dropdown: full-width + scrollable */
  .sb-search-dropdown {
    width: 100% !important;
    max-width: 100% !important;
    max-height: 50vh !important;
  }
  .sb-search-item { padding: 10px 12px !important; min-height: 44px; }

  /* Card padding tightens up to claw back horizontal space */
  .card { padding: 14px !important; }
  .card-head { gap: 8px !important; flex-wrap: wrap; }
  .kicker { font-size: 10px !important; }
  .card-title { font-size: 16px !important; line-height: 1.25; }
  .card-sub { font-size: 11.5px !important; }

  /* Hero stacks unconditionally */
  .hero {
    grid-template-columns: 1fr !important;
    gap: 12px !important;
  }

  /* Charts: viewBox preserves aspect ratio. We let them shrink naturally
     but cap minimum height so nothing collapses to nothing. */
  .chart-wrap, .chart-svg, .vs-svg, .payoff-svg {
    width: 100% !important;
    height: auto !important;
    min-height: 220px;
  }
  /* Disable crosshair cursor on touch devices — won't read anyway */
  .chart-svg { cursor: default !important; }
  /* Bigger axis text so it's legible on a phone */
  .chart-svg .axis-text { font-size: 14px !important; }
  .chart-svg .strike-label { font-size: 12px !important; }
  /* Hover tooltip would be cramped on phones; let it flow inline */
  .chart-tooltip {
    position: static !important; transform: none !important;
    margin: 8px 0 0 !important;
    width: 100% !important; max-width: 100% !important;
  }

  /* Toolbar above chart: wrap + space the segment buttons out */
  .toolbar {
    flex-wrap: wrap !important;
    gap: 6px !important;
    width: 100%;
    margin-top: 6px;
  }
  .seg button {
    min-height: 36px !important; min-width: 44px;
    padding: 6px 10px !important; font-size: 12px !important;
  }
  .zoom-reset { min-height: 36px; }

  /* Strike pair (suggested call/put) becomes single column */
  .strike-pair { grid-template-columns: 1fr !important; gap: 10px; }

  /* Metric grids: 2 columns max on mobile, regardless of count */
  .metric-grid, .metric-grid.five {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 8px !important;
  }

  /* Net Greeks card: stack the three columns */
  .ng-grid { grid-template-columns: 1fr !important; }
  .ng-credit-val { font-size: 18px !important; }

  /* Watchlist scanner: cards instead of table on phones — table doesn't fit
     17 narrow columns. We keep the table markup but let it horizontally
     scroll, and wrap each row's strategy info underneath. */
  .scan-table-wrap {
    -webkit-overflow-scrolling: touch;
  }
  .scan-table { font-size: 11.5px !important; }
  .scan-table th, .scan-table td { padding: 6px 8px !important; }
  .scan-toolbar { flex-wrap: wrap; }
  .scan-stale { font-size: 10px !important; }

  /* Options chain: lots of columns, must scroll horizontally. We keep the
     +/− buttons on the edges so they're reachable while scrolling. */
  .oc-table-scroll {
    -webkit-overflow-scrolling: touch;
    overflow-x: auto;
  }
  .oc-table { font-size: 11px !important; min-width: 760px; }
  .oc-table th, .oc-table td { padding: 6px 6px !important; }
  .oc-build-cell { padding: 4px 4px !important; }
  .oc-build-btn {
    padding: 6px 8px !important;
    font-size: 11px !important;
    min-width: 32px;
    min-height: 32px;
  }
  .oc-strike { font-size: 12px !important; }

  /* Builder tray: legs grid was 8 columns, that won't fit. Convert to
     two-line layout per leg on phones. */
  .builder-leg {
    grid-template-columns: auto 1fr auto auto !important;
    grid-template-rows: auto auto;
    gap: 6px !important;
    padding: 8px 10px !important;
  }
  .builder-leg-tag { grid-column: 1; grid-row: 1; }
  .builder-leg-side { grid-column: 2; grid-row: 1; }
  .builder-leg-strike { grid-column: 1; grid-row: 2; font-size: 13px; }
  .builder-leg-qty { grid-column: 2; grid-row: 2; }
  .builder-leg-prem { grid-column: 1 / span 2; grid-row: 3; }
  .builder-leg-cost { grid-column: 3; grid-row: 1 / span 2; align-self: center; }
  .builder-leg-flip, .builder-leg-rm {
    grid-row: 1 / span 2; align-self: center;
    width: 32px !important; height: 32px !important;
  }
  .builder-leg-flip { grid-column: 4; }
  .builder-leg-rm { grid-column: 5; }
  .builder-actions { flex-direction: column; align-items: stretch; }
  .builder-btn { min-height: 44px; font-size: 13px !important; }

  /* Strategy reference modal: full screen on mobile */
  .ref-card {
    width: 100% !important;
    max-height: 100vh !important;
    height: 100vh;
    border-radius: 0 !important;
    border: none !important;
  }
  .sref-grid {
    grid-template-columns: 1fr !important;
    gap: 8px !important;
  }
  .sref-tile { padding: 12px !important; }
  .sref-tile-detail {
    grid-template-columns: 1fr !important;
    gap: 4px !important;
  }
  .sref-lbl { margin-top: 8px; font-size: 10px !important; }
  .sref-search { font-size: 16px !important; min-width: 0 !important; flex: 1; }
  .sref-filter { flex-wrap: wrap; }
  .sref-filter button { min-height: 36px; }

  /* Help overlay: full screen */
  .hk-card {
    width: 100% !important;
    max-height: 100vh;
    border-radius: 0 !important;
  }

  /* Tweaks panel: drawer style — already responsive but force narrow */
  .tweaks-panel { width: 100vw !important; }

  /* Strategy menu: cards stack to single column */
  .strat-grid { grid-template-columns: 1fr !important; }

  /* Spec list (P/L stats) in two columns max */
  .spec-list { grid-template-columns: max-content 1fr !important; }
  .row.two { grid-template-columns: 1fr !important; }

  /* Theta scenarios stack */
  .theta-scenarios { grid-template-columns: 1fr !important; }

  /* GEX + Roll grids stack */
  .gex-grid, .roll-grid { grid-template-columns: 1fr !important; }

  /* Vol skew tooltip stays anchored but smaller */
  .vs-tooltip { font-size: 11px !important; padding: 6px 10px !important; min-width: 110px !important; }
  .vs-stats { gap: 12px !important; flex-wrap: wrap; }
  .vs-stat-val { font-size: 14px !important; }

  /* Earnings pill smaller */
  .earn-pill { font-size: 10px !important; padding: 2px 6px !important; margin-left: 6px !important; }

  /* All buttons: ensure min touch target 44px on key actions */
  .scan-run-btn, .builder-btn-viz, .builder-btn-clear, .oc-reset-btn {
    min-height: 40px;
    font-size: 13px !important;
  }

  /* Focus rings + tap highlights */
  * { -webkit-tap-highlight-color: rgba(0, 0, 0, 0); }
  button:focus-visible { outline: 2px solid var(--accent); outline-offset: 1px; }

  /* Hide elements that don't translate well to mobile */  /* keyboard shortcut hint at bottom */

  /* Tab bar (v1.25): horizontal scroll on phones so the tabs never wrap
     into a tall block. Stays sticky and thumb-reachable at the top. */
  .tab-bar {
    flex-wrap: nowrap;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    top: 4px;
  }
  .tab-bar::-webkit-scrollbar { display: none; }
  .tab-btn { min-height: 40px; flex-shrink: 0; }
}

/* Even narrower breakpoint for ~360px wide phones */
@media (max-width: 380px) {
  .shell { padding: 6px 8px 32px !important; }
  .card { padding: 12px !important; }
  .builder-leg { font-size: 11px !important; }
  .scan-table { font-size: 10.5px !important; }
}

/* Landscape phone: hide vertical-only stuff, give chart breathing room */
@media (max-width: 950px) and (orientation: landscape) and (max-height: 500px) {
  .shell { padding: 6px 12px 30px !important; }
  .sidebar { padding: 10px !important; }
  .sb-section { margin-bottom: 10px; }
}

/* Position sizing card */
.sizing-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  margin-top: 4px;
}
@media (max-width: 900px) {
  .sizing-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 520px) {
  .sizing-grid { grid-template-columns: 1fr; }
}
.sizing-input, .sizing-stat {
  background: var(--bg-3);
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 10px 12px;
}
.sizing-result {
  border-color: var(--accent);
  background: color-mix(in srgb, var(--accent) 8%, var(--bg-3));
}
.sizing-label, .sizing-stat-lbl {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--fg-3);
  display: block;
  margin-bottom: 4px;
}
.sizing-input-wrap {
  display: flex;
  align-items: center;
  gap: 4px;
}
.sizing-input-wrap input {
  flex: 1;
  background: transparent;
  border: none;
  outline: none;
  color: var(--fg);
  font-family: var(--font-mono);
  font-size: 17px;
  font-weight: 700;
  padding: 2px 0;
  width: 100%;
  min-width: 0;
}
.sizing-input-wrap input::-webkit-outer-spin-button,
.sizing-input-wrap input::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
.sizing-input-wrap input { -moz-appearance: textfield; }
.sizing-prefix, .sizing-suffix {
  font-family: var(--font-mono);
  font-size: 14px;
  color: var(--fg-3);
  font-weight: 700;
}
.sizing-stat-val {
  font-family: var(--font-mono);
  font-size: 17px;
  font-weight: 700;
  color: var(--fg);
}
.sizing-result-val { color: var(--accent); font-size: 22px; }
.sizing-undef { color: var(--down); font-size: 13px; font-weight: 600; }
.sizing-warn {
  margin-top: 10px;
  padding: 8px 12px;
  background: color-mix(in srgb, var(--down) 12%, transparent);
  border: 1px solid color-mix(in srgb, var(--down) 35%, transparent);
  border-radius: 6px;
  color: var(--down);
  font-size: 12px;
  font-family: var(--font-mono);
}

/* Conviction column styling */
.scan-conv {
  font-weight: 800;
  font-family: var(--font-mono);
}

/* Open positions */
.pos-empty {
  padding: 30px;
  text-align: center;
  color: var(--fg-3);
  font-family: var(--font-mono);
  font-size: 12px;
}
.pos-list {
  display: flex; flex-direction: column;
  gap: 10px;
  margin-top: 4px;
}
.pos-row {
  background: var(--bg-3);
  border: 1px solid var(--line);
  border-left: 3px solid var(--accent);
  border-radius: 8px;
  padding: 12px 14px;
}
.pos-row.pos-closed {
  border-left-color: var(--fg-3);
  opacity: 0.7;
}
.pos-row-head {
  display: flex; align-items: center; gap: 12px;
  flex-wrap: wrap;
  margin-bottom: 8px;
}
.pos-ticker {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 16px;
  color: var(--fg);
}
.pos-meta {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--fg-3);
}
.pos-dte {
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 700;
  padding: 2px 8px;
  border-radius: 10px;
  background: color-mix(in srgb, var(--fg-2) 12%, transparent);
  color: var(--fg-2);
}
.pos-dte.urgent { background: color-mix(in srgb, var(--down) 22%, transparent); color: var(--down); }
.pos-dte.close { background: color-mix(in srgb, var(--warn) 22%, transparent); color: var(--warn); }
.pos-flag-assign {
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 700;
  color: var(--down);
  background: color-mix(in srgb, var(--down) 12%, transparent);
  padding: 2px 8px; border-radius: 10px;
}
.pos-status-closed {
  font-family: var(--font-mono);
  font-size: 10px; font-weight: 700;
  padding: 2px 8px; border-radius: 10px;
  background: var(--bg-2); color: var(--fg-3);
  letter-spacing: 0.06em;
}
.pos-legs {
  display: flex; flex-wrap: wrap; gap: 6px;
  margin-bottom: 10px;
}
.pos-leg {
  font-family: var(--font-mono);
  font-size: 11.5px;
  padding: 3px 8px;
  border-radius: 4px;
  background: var(--bg-2);
  border: 1px solid var(--line);
}
.pos-leg.long { color: var(--up); border-color: color-mix(in srgb, var(--up) 35%, transparent); }
.pos-leg.short { color: var(--down); border-color: color-mix(in srgb, var(--down) 35%, transparent); }
.pos-stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 8px;
  margin-bottom: 10px;
}
@media (max-width: 700px) { .pos-stats { grid-template-columns: repeat(2, 1fr); } }
.pos-stat {
  background: var(--bg-2);
  border: 1px solid var(--line);
  border-radius: 6px;
  padding: 6px 10px;
}
.pos-stat-lbl {
  font-family: var(--font-mono);
  font-size: 9.5px;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--fg-3);
}
.pos-stat-val {
  font-family: var(--font-mono);
  font-size: 13px; font-weight: 700;
  color: var(--fg);
}
.pos-stat-val.up { color: var(--up); }
.pos-stat-val.down { color: var(--down); }
.pos-note {
  font-size: 10px; color: var(--fg-3); font-weight: 500;
}
.pos-actions {
  display: flex; gap: 6px; flex-wrap: wrap;
}
.pos-btn {
  font-family: var(--font-mono);
  font-size: 11px; font-weight: 600;
  padding: 6px 12px;
  border-radius: 5px;
  cursor: pointer;
  border: 1px solid var(--line);
  background: var(--bg-2);
  color: var(--fg-2);
}
.pos-btn-ghost:hover { color: var(--accent); border-color: var(--accent); }
.pos-btn-close { background: var(--accent); color: var(--accentText); border-color: var(--accent); }
.pos-btn-close:hover { opacity: 0.85; }
.pos-btn-del:hover { color: var(--down); border-color: var(--down); }

.builder-btn-track {
  background: color-mix(in srgb, var(--up) 18%, var(--bg-3));
  color: var(--up);
  border-color: color-mix(in srgb, var(--up) 50%, transparent);
}
.builder-btn-track:hover { background: color-mix(in srgb, var(--up) 28%, var(--bg-3)); }

.pos-closed-block {
  margin-top: 14px;
  padding-top: 14px;
  border-top: 1px solid var(--line);
}
.pos-closed-block summary {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--fg-3);
  cursor: pointer;
  letter-spacing: 0.05em;
  margin-bottom: 8px;
}
.pos-closed-block summary:hover { color: var(--fg-2); }

/* Assignment risk banner */
.assign-banner {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 16px;
  border-radius: 8px;
  margin-bottom: var(--row-gap);
  cursor: pointer;
  font-family: var(--font-mono);
  font-size: 12px;
  border: 1px solid;
  transition: transform 0.1s ease, box-shadow 0.1s ease;
  flex-wrap: wrap;
}
.assign-banner:hover {
  transform: translateY(-1px);
}
.assign-close {
  background: color-mix(in srgb, var(--warn) 18%, transparent);
  border-color: color-mix(in srgb, var(--warn) 50%, transparent);
  color: var(--warn);
}
.assign-very-close {
  background: color-mix(in srgb, var(--warn) 28%, transparent);
  border-color: color-mix(in srgb, var(--warn) 70%, transparent);
  color: var(--warn);
  animation: assign-pulse 2.4s ease-in-out infinite;
}
.assign-itm {
  background: color-mix(in srgb, var(--down) 25%, transparent);
  border-color: var(--down);
  color: var(--down);
  animation: assign-pulse 1.6s ease-in-out infinite;
}
@keyframes assign-pulse {
  0%, 100% { box-shadow: 0 0 0 0 currentColor; opacity: 1; }
  50% { box-shadow: 0 0 0 4px color-mix(in srgb, currentColor 25%, transparent); opacity: 0.92; }
}
.assign-icon {
  font-size: 18px;
  line-height: 1;
}
.assign-title {
  font-weight: 800;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  font-size: 12px;
}
.assign-detail {
  flex: 1;
  font-weight: 500;
  color: var(--fg);
  min-width: 0;
}
.assign-arrow {
  font-weight: 700;
  font-size: 11px;
  letter-spacing: 0.04em;
  white-space: nowrap;
  opacity: 0.8;
}
.assign-banner:hover .assign-arrow { opacity: 1; }

@media (max-width: 720px) {
  .assign-banner { padding: 10px 12px; font-size: 11px; }
  .assign-detail { width: 100%; flex-basis: 100%; }
  .assign-arrow { display: none; }
}

/* Research tools (earnings ladder + backtest) */
.research-controls {
  display: flex; gap: 8px; flex-wrap: wrap; align-items: center;
}
.research-select {
  font-family: var(--font-mono); font-size: 12px;
  background: var(--bg-3); color: var(--fg);
  border: 1px solid var(--line); border-radius: 6px;
  padding: 6px 10px; cursor: pointer;
  outline: none;
}
.research-select:focus { border-color: var(--accent); }
.research-run-btn {
  font-family: var(--font-mono); font-size: 12px; font-weight: 700;
  background: var(--accent); color: var(--accentText);
  border: 1px solid var(--accent); border-radius: 6px;
  padding: 7px 16px; cursor: pointer;
  min-height: 36px;
}
.research-run-btn:hover { opacity: 0.9; }
.research-run-btn:disabled { opacity: 0.5; cursor: wait; }
.research-empty {
  padding: 24px; text-align: center;
  color: var(--fg-3); font-size: 12px;
  font-family: var(--font-mono);
}
.research-error {
  padding: 12px 14px;
  background: color-mix(in srgb, var(--down) 12%, transparent);
  border: 1px solid color-mix(in srgb, var(--down) 35%, transparent);
  border-radius: 6px;
  color: var(--down);
  font-family: var(--font-mono); font-size: 12px;
}
.research-disclaimer {
  margin-top: 10px;
  padding: 8px 12px;
  background: var(--bg-3);
  border-radius: 6px;
  color: var(--fg-3);
  font-size: 11px;
  font-family: var(--font-mono);
  line-height: 1.5;
}

/* Earnings ladder */
.ladder-summary {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px;
  margin-bottom: 14px;
}
@media (max-width: 700px) { .ladder-summary { grid-template-columns: repeat(2, 1fr); } }
.ladder-stat {
  background: var(--bg-3); border: 1px solid var(--line);
  border-radius: 8px; padding: 10px 12px;
}
.ladder-stat-lbl {
  font-family: var(--font-mono); font-size: 10px;
  letter-spacing: 0.05em; text-transform: uppercase;
  color: var(--fg-3); margin-bottom: 3px;
}
.ladder-stat-val {
  font-family: var(--font-mono); font-size: 17px; font-weight: 700;
  color: var(--fg);
}
.ladder-stat-val.up { color: var(--up); }
.ladder-stat-val.down { color: var(--down); }
.ladder-stat-sub {
  font-size: 11px; color: var(--fg-3); font-weight: 500;
}
.ladder-table {
  width: 100%; border-collapse: collapse;
  font-family: var(--font-mono); font-size: 12px;
}
.ladder-table th, .ladder-table td {
  padding: 8px 10px;
  border-bottom: 1px solid var(--line);
  text-align: left;
}
.ladder-table th {
  font-size: 10px; letter-spacing: 0.05em;
  text-transform: uppercase; color: var(--fg-3);
  font-weight: 700;
}
.ladder-table td.num, .ladder-table th.num { text-align: right; font-variant-numeric: tabular-nums; }
.ladder-table td.up { color: var(--up); }
.ladder-table td.down { color: var(--down); }
.ladder-row-sell { background: color-mix(in srgb, var(--up) 4%, transparent); }
.ladder-row-buy { background: color-mix(in srgb, var(--down) 4%, transparent); }
.ladder-pill {
  font-size: 9.5px; font-weight: 800;
  letter-spacing: 0.07em;
  padding: 3px 8px; border-radius: 10px;
}
.ladder-pill-sellers { background: color-mix(in srgb, var(--up) 25%, transparent); color: var(--up); }
.ladder-pill-buyers { background: color-mix(in srgb, var(--down) 25%, transparent); color: var(--down); }

/* Backtest */
.bt-summary {
  display: grid; grid-template-columns: repeat(6, 1fr); gap: 8px;
  margin-bottom: 14px;
}
@media (max-width: 1100px) { .bt-summary { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 700px) { .bt-summary { grid-template-columns: repeat(2, 1fr); } }
.bt-stat {
  background: var(--bg-3); border: 1px solid var(--line);
  border-radius: 8px; padding: 9px 11px;
}
.bt-stat-lbl {
  font-family: var(--font-mono); font-size: 9.5px;
  letter-spacing: 0.05em; text-transform: uppercase;
  color: var(--fg-3); margin-bottom: 2px;
}
.bt-stat-val {
  font-family: var(--font-mono); font-size: 15px; font-weight: 700;
  color: var(--fg);
}
.bt-stat-val.up { color: var(--up); }
.bt-stat-val.down { color: var(--down); }
.bt-stat-sub { font-size: 11px; color: var(--fg-3); font-weight: 500; }
.bt-chart-wrap {
  margin: 4px 0 14px;
  background: var(--bg-3);
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 8px;
}
.bt-chart { width: 100%; height: auto; display: block; }
.bt-trades-details {
  margin-top: 8px;
  border-top: 1px solid var(--line);
  padding-top: 14px;
}
.bt-trades-details summary {
  font-family: var(--font-mono); font-size: 11px;
  color: var(--fg-3); cursor: pointer;
  letter-spacing: 0.04em;
  margin-bottom: 8px;
}
.bt-trades-details summary:hover { color: var(--fg-2); }
.bt-trades-table {
  width: 100%; border-collapse: collapse;
  font-family: var(--font-mono); font-size: 11px;
}
.bt-trades-table th, .bt-trades-table td {
  padding: 5px 8px;
  border-bottom: 1px solid var(--line);
  text-align: left;
}
.bt-trades-table th {
  font-size: 9.5px; letter-spacing: 0.05em;
  text-transform: uppercase; color: var(--fg-3);
}
.bt-trades-table td.num, .bt-trades-table th.num { text-align: right; font-variant-numeric: tabular-nums; }
.bt-trades-table td.up { color: var(--up); }
.bt-trades-table td.down { color: var(--down); }
.bt-win { background: color-mix(in srgb, var(--up) 3%, transparent); }
.bt-loss { background: color-mix(in srgb, var(--down) 3%, transparent); }

@media (max-width: 720px) {
  .ladder-table, .bt-trades-table { font-size: 10.5px; }
  .ladder-table th, .ladder-table td,
  .bt-trades-table th, .bt-trades-table td { padding: 5px 6px; }
}

/* Data source badge */
.src-badge {
  display: inline-flex; align-items: center; gap: 5px;
  margin-top: 4px;
  font-family: var(--font-mono);
  font-size: 9.5px;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  padding: 3px 8px;
  border-radius: 10px;
  width: max-content;
}
.src-dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: currentColor;
}
.src-badge-schwab {
  background: color-mix(in srgb, var(--up) 15%, transparent);
  color: var(--up);
}
.src-badge-schwab .src-dot {
  animation: src-pulse 1.8s ease-in-out infinite;
}
.src-badge-warn {
  background: color-mix(in srgb, var(--warn) 18%, transparent);
  color: var(--warn);
}
.src-badge-yf {
  background: var(--bg-3);
  color: var(--fg-3);
  border: 1px solid var(--line);
}
@keyframes src-pulse {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.45; }
}

/* Sidebar watchlist actions */
.sb-wl-actions { display: flex; gap: 4px; align-items: center; }
.sb-manage-btn {
  font-family: var(--font-mono); font-size: 9.5px;
  font-weight: 700;
  letter-spacing: 0.04em;
  background: var(--bg-3);
  color: var(--fg-2);
  border: 1px solid var(--line);
  border-radius: 4px;
  padding: 3px 7px;
  cursor: pointer;
  white-space: nowrap;
}
.sb-manage-btn:hover {
  background: var(--bg-2);
  color: var(--fg);
  border-color: var(--accent);
}

/* Watchlist Manager modal */
.wlm-card {
  background: var(--bg-1);
  border: 1px solid var(--line);
  border-radius: 12px;
  width: min(900px, 95vw);
  max-height: 88vh;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
.wlm-body {
  padding: 14px 18px 18px;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.wlm-toolbar {
  display: flex; gap: 8px; align-items: center;
  flex-wrap: wrap;
}
.wlm-search {
  flex: 1; min-width: 180px;
  font-family: var(--font-mono); font-size: 13px;
  background: var(--bg-3); color: var(--fg);
  border: 1px solid var(--line); border-radius: 6px;
  padding: 8px 12px; outline: none;
}
.wlm-search:focus { border-color: var(--accent); }
.wlm-sort {
  font-family: var(--font-mono); font-size: 12px;
  background: var(--bg-3); color: var(--fg);
  border: 1px solid var(--line); border-radius: 6px;
  padding: 7px 10px; cursor: pointer; outline: none;
}
.wlm-bulk-toggle {
  font-family: var(--font-mono); font-size: 11.5px; font-weight: 700;
  background: var(--bg-3);
  color: var(--fg-2);
  border: 1px solid var(--line);
  border-radius: 6px;
  padding: 7px 12px; cursor: pointer;
}
.wlm-bulk-toggle.active {
  background: var(--accent);
  color: var(--accentText);
  border-color: var(--accent);
}
.wlm-tags-row {
  display: flex; flex-wrap: wrap; gap: 4px;
}
.wlm-tag-chip {
  font-family: var(--font-mono); font-size: 10.5px; font-weight: 600;
  background: var(--bg-3);
  color: var(--fg-3);
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 4px 10px; cursor: pointer;
  transition: all 100ms;
}
.wlm-tag-chip:hover { color: var(--fg); }
.wlm-tag-chip.active {
  background: var(--accent);
  color: var(--accentText);
  border-color: var(--accent);
}
.wlm-bulk-panel {
  background: var(--bg-3);
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 10px;
}
.wlm-bulk-input {
  width: 100%;
  font-family: var(--font-mono); font-size: 12px;
  background: var(--bg-1); color: var(--fg);
  border: 1px solid var(--line); border-radius: 6px;
  padding: 8px 10px;
  resize: vertical;
  outline: none;
  box-sizing: border-box;
}
.wlm-bulk-input:focus { border-color: var(--accent); }
.wlm-bulk-actions { margin-top: 8px; text-align: right; }
.wlm-bulk-add {
  font-family: var(--font-mono); font-size: 12px; font-weight: 700;
  background: var(--accent); color: var(--accentText);
  border: 1px solid var(--accent); border-radius: 6px;
  padding: 7px 18px; cursor: pointer;
}
.wlm-quick-add {
  display: flex; gap: 6px;
}
.wlm-quick-input {
  flex: 1;
  font-family: var(--font-mono); font-size: 12px;
  background: var(--bg-3); color: var(--fg);
  border: 1px solid var(--line); border-radius: 6px;
  padding: 7px 10px; outline: none;
  text-transform: uppercase;
}
.wlm-quick-input:focus { border-color: var(--accent); }
.wlm-quick-btn {
  font-family: var(--font-mono); font-size: 12px; font-weight: 700;
  background: var(--bg-3); color: var(--fg-2);
  border: 1px solid var(--line); border-radius: 6px;
  padding: 7px 16px; cursor: pointer;
}
.wlm-quick-btn:hover {
  background: var(--accent); color: var(--accentText); border-color: var(--accent);
}
.wlm-list {
  display: flex; flex-direction: column; gap: 4px;
  margin-top: 4px;
}
.wlm-empty {
  padding: 24px; text-align: center;
  color: var(--fg-3); font-size: 12px;
  font-family: var(--font-mono);
  background: var(--bg-3);
  border-radius: 8px;
}
.wlm-row {
  background: var(--bg-3);
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 8px 10px;
  transition: border-color 120ms;
}
.wlm-row.starred {
  border-color: color-mix(in srgb, var(--up) 30%, var(--line));
}
.wlm-row.editing {
  border-color: var(--accent);
}
.wlm-row-main {
  display: flex; align-items: center; gap: 8px;
}
.wlm-star-btn {
  font-size: 16px;
  background: transparent; border: none;
  color: var(--fg-3);
  cursor: pointer;
  padding: 0; width: 24px;
}
.wlm-star-btn.on { color: var(--up); }
.wlm-sym-btn {
  font-family: var(--font-mono); font-size: 13.5px; font-weight: 800;
  background: transparent;
  color: var(--fg);
  border: none; padding: 4px 8px;
  cursor: pointer;
  letter-spacing: 0.02em;
  min-width: 70px; text-align: left;
}
.wlm-sym-btn:hover { color: var(--accent); }
.wlm-row-meta {
  flex: 1;
  display: flex; flex-wrap: wrap; gap: 4px; align-items: center;
  min-width: 0;
}
.wlm-tag-pill {
  font-family: var(--font-mono); font-size: 9.5px; font-weight: 700;
  background: color-mix(in srgb, var(--accent) 12%, transparent);
  color: var(--accent);
  padding: 2px 7px;
  border-radius: 8px;
  letter-spacing: 0.02em;
}
.wlm-strategy-pill {
  font-family: var(--font-mono); font-size: 9.5px; font-weight: 700;
  background: color-mix(in srgb, var(--up) 14%, transparent);
  color: var(--up);
  padding: 2px 7px;
  border-radius: 8px;
  letter-spacing: 0.02em;
}
.wlm-note-snip {
  font-family: var(--font-mono); font-size: 10.5px;
  color: var(--fg-3);
  font-style: italic;
}
.wlm-row-actions { display: flex; gap: 4px; }
.wlm-edit-btn {
  font-family: var(--font-mono); font-size: 10.5px;
  background: transparent;
  color: var(--fg-3);
  border: 1px solid var(--line);
  border-radius: 5px;
  padding: 3px 9px;
  cursor: pointer;
}
.wlm-edit-btn:hover { color: var(--fg); border-color: var(--fg-3); }
.wlm-del-btn {
  font-size: 16px; line-height: 1;
  background: transparent;
  color: var(--fg-3);
  border: 1px solid var(--line);
  border-radius: 5px;
  padding: 0 8px;
  cursor: pointer;
  width: 26px; height: 24px;
}
.wlm-del-btn:hover { color: var(--down); border-color: var(--down); }
.wlm-edit-panel {
  margin-top: 10px;
  padding-top: 10px;
  border-top: 1px solid var(--line);
  display: flex; flex-direction: column; gap: 8px;
}
.wlm-edit-row {
  display: grid; grid-template-columns: 80px 1fr;
  gap: 10px; align-items: start;
}
.wlm-edit-row label {
  font-family: var(--font-mono); font-size: 10px;
  letter-spacing: 0.05em; text-transform: uppercase;
  color: var(--fg-3);
  padding-top: 6px;
}
.wlm-edit-row input,
.wlm-edit-row textarea,
.wlm-edit-row select {
  font-family: var(--font-mono); font-size: 12px;
  background: var(--bg-1); color: var(--fg);
  border: 1px solid var(--line); border-radius: 5px;
  padding: 6px 9px; outline: none;
  width: 100%; box-sizing: border-box;
  resize: vertical;
}
.wlm-edit-row input:focus,
.wlm-edit-row textarea:focus,
.wlm-edit-row select:focus { border-color: var(--accent); }
.wlm-edit-actions { text-align: right; }
.wlm-save-btn {
  font-family: var(--font-mono); font-size: 11.5px; font-weight: 700;
  background: var(--accent); color: var(--accentText);
  border: 1px solid var(--accent); border-radius: 5px;
  padding: 5px 16px; cursor: pointer;
}

/* Scanner filter chip + tag select */
.scan-filter-chip {
  font-family: var(--font-mono); font-size: 10.5px; font-weight: 700;
  background: color-mix(in srgb, var(--accent) 18%, transparent);
  color: var(--accent);
  border: 1px solid color-mix(in srgb, var(--accent) 35%, transparent);
  border-radius: 12px;
  padding: 3px 10px;
  cursor: pointer;
}
.scan-filter-chip:hover { background: color-mix(in srgb, var(--accent) 28%, transparent); }
.scan-tag-select {
  font-family: var(--font-mono); font-size: 11px;
  background: var(--bg-3); color: var(--fg);
  border: 1px solid var(--line); border-radius: 5px;
  padding: 4px 8px; cursor: pointer; outline: none;
}

@media (max-width: 720px) {
  .wlm-card { width: 100vw; max-height: 100vh; border-radius: 0; }
  .wlm-edit-row { grid-template-columns: 1fr; }
  .wlm-edit-row label { padding-top: 0; }
  .wlm-row-main { flex-wrap: wrap; }
  .wlm-row-meta { flex-basis: 100%; padding-left: 32px; }
}

/* Weekly range scanner */
.wr-table-wrap {
  overflow-x: auto;
  margin: 0 -2px;
}
.wr-table {
  width: 100%; border-collapse: collapse;
  font-family: var(--font-mono); font-size: 12px;
}
.wr-table th, .wr-table td {
  padding: 7px 9px;
  border-bottom: 1px solid var(--line);
  text-align: left;
  white-space: nowrap;
}
.wr-table th {
  font-size: 9.5px; letter-spacing: 0.04em;
  text-transform: uppercase; color: var(--fg-3);
  font-weight: 700;
}
.wr-table td.num, .wr-table th.num { text-align: right; font-variant-numeric: tabular-nums; }
.wr-table td.up { color: var(--up); }
.wr-table td.down { color: var(--down); }
.wr-sym-btn {
  font-family: var(--font-mono); font-size: 12.5px; font-weight: 800;
  background: transparent;
  color: var(--fg);
  border: none; padding: 0;
  cursor: pointer;
  letter-spacing: 0.02em;
}
.wr-sym-btn:hover { color: var(--accent); }
.wr-sym {
  font-family: var(--font-mono); font-size: 12.5px; font-weight: 800;
  color: var(--fg-3);
}
.wr-row-pending td.wr-pending-cell {
  color: var(--fg-3);
  font-style: italic;
  font-size: 11px;
}
.wr-row-err td.wr-err-cell {
  color: var(--down);
  font-size: 11px;
}
@media (max-width: 720px) {
  .wr-table { font-size: 10.5px; }
  .wr-table th, .wr-table td { padding: 5px 6px; }
}

/* Sortable column headers */
.sortable-th {
  cursor: pointer;
  user-select: none;
  -webkit-user-select: none;
  position: relative;
  transition: color 100ms;
}
.sortable-th:hover {
  color: var(--fg);
}
.sortable-th.active {
  color: var(--accent);
}
.sortable-th > span {
  display: inline-block;
  white-space: nowrap;
}

/* Live price flash animation */
.price-flash-up {
  animation: price-flash-up 600ms ease-out;
}
.price-flash-down {
  animation: price-flash-down 600ms ease-out;
}
@keyframes price-flash-up {
  0% { background: color-mix(in srgb, var(--up) 35%, transparent); }
  100% { background: transparent; }
}
@keyframes price-flash-down {
  0% { background: color-mix(in srgb, var(--down) 35%, transparent); }
  100% { background: transparent; }
}

/* App version pill — anchored top-left of sidebar.
 * Note: sidebar already has position:sticky which counts as a positioned
 * ancestor for the absolute pill below. Don't override sidebar to relative
 * here — that would break sticky and let the sidebar scroll with the page.
 */
.sb-version-pill {
  position: absolute;
  top: 18px;
  left: 16px;
  z-index: 5;
  font-family: var(--font-mono);
  font-size: 9.5px;
  font-weight: 700;
  letter-spacing: 0.06em;
  color: var(--fg-3);
  background: var(--bg-3);
  border: 1px solid var(--line);
  padding: 2px 7px;
  border-radius: 8px;
}

/* Weather pill (v1.21): mirrors the version pill on the right of the
   brand header. Tap to toggle Yonkers vs device geolocation. */
.sb-weather-pill {
  position: absolute;
  top: 16px;
  right: 16px;
  z-index: 5;
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.02em;
  color: var(--fg-2);
  background: var(--bg-3);
  border: 1px solid var(--line);
  padding: 3px 9px;
  border-radius: 999px;
  cursor: pointer;
  line-height: 1.4;
  transition: border-color 0.12s ease, color 0.12s ease;
}
.sb-weather-pill:hover { border-color: var(--accent); }
.sb-weather-pill.wx-err { color: var(--fg-3); }
.sb-weather-pill .wx-icon { font-size: 12px; }
.sb-weather-pill .wx-temp { font-variant-numeric: tabular-nums; }

/* ─── Jump bar (v1.22) ───────────────────────────────────────────────
   Sticky in-page nav at the top of the main column. Anchors get
   scroll-margin so the bar does not cover the card heading on jump. */
/* ─── Tab bar (v1.25) ────────────────────────────────────────────────
   Full-width section switcher spanning both shell columns. Sticky at
   the page top. Replaces the v1.22 jump bar. */
.tab-bar {
  grid-column: 1 / -1;
  position: sticky;
  top: 0;
  z-index: 40;
  display: flex;
  align-items: center;
  gap: 4px;
  flex-wrap: wrap;
  padding: 6px;
  margin: 0 0 14px;
  background: color-mix(in oklch, var(--bg) 86%, transparent);
  border: 1px solid var(--line);
  border-radius: 12px;
  box-shadow: var(--shadow-card);
  backdrop-filter: blur(8px) saturate(1.1);
}
.tab-btn {
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 600;
  color: var(--fg-3);
  background: transparent;
  border: 1px solid transparent;
  border-radius: 9px;
  padding: 8px 16px;
  cursor: pointer;
  white-space: nowrap;
  transition: color 0.12s ease, background 0.12s ease;
}
.tab-btn:hover { color: var(--fg-2); }
.tab-btn.active {
  color: var(--accent-text);
  background: var(--accent);
}
.tab-panel { display: flex; flex-direction: column; gap: var(--row-gap); }



/* Percent calculator slide-out */
.pcalc-tab {
  position: fixed;
  top: 50%;
  right: 0;
  transform: translateY(-50%);
  z-index: 100;
  background: var(--accent);
  color: var(--accentText);
  border: none;
  border-radius: 8px 0 0 8px;
  padding: 18px 8px;
  font-family: var(--font-mono);
  font-size: 14px;
  font-weight: 800;
  cursor: pointer;
  box-shadow: -2px 2px 10px rgba(0, 0, 0, 0.25);
  transition: right 250ms ease, background 150ms;
  letter-spacing: 0.04em;
}
.pcalc-tab:hover {
  background: color-mix(in srgb, var(--accent) 90%, white);
}
.pcalc-tab-open {
  right: 280px;
}
.pcalc-panel {
  position: fixed;
  top: 50%;
  right: -300px;
  transform: translateY(-50%);
  width: 280px;
  height: 60vh;
  max-height: 540px;
  min-height: 380px;
  background: var(--bg-2);
  border: 1px solid var(--line);
  border-right: none;
  border-radius: 12px 0 0 12px;
  box-shadow: -8px 0 30px rgba(0, 0, 0, 0.5);
  z-index: 99;
  display: flex;
  flex-direction: column;
  transition: right 250ms ease;
  overflow: hidden;
  /* Force opaque even if --bg-2 has any transparency */
  backdrop-filter: none;
}
.pcalc-panel-open {
  right: 0;
}
.pcalc-head {
  padding: 16px 18px 12px;
  border-bottom: 1px solid var(--line);
  background: var(--bg-1);
}
.pcalc-title {
  font-family: var(--font-mono);
  font-size: 13px;
  font-weight: 800;
  color: var(--fg);
  letter-spacing: 0.02em;
}
.pcalc-sub {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--fg-3);
  margin-top: 2px;
}
.pcalc-body {
  flex: 1;
  overflow-y: auto;
  padding: 14px 16px 18px;
}

@media (max-width: 720px) {
  .pcalc-panel { width: 260px; right: -280px; height: 70vh; }
  .pcalc-tab-open { right: 260px; }
  .pcalc-result { width: 80px; }
}
.pcalc-label {
  font-family: var(--font-mono);
  font-size: 9.5px;
  font-weight: 800;
  letter-spacing: 0.08em;
  color: var(--fg-3);
  margin-bottom: 6px;
}
.pcalc-from-row {
  margin-bottom: 8px;
}
.pcalc-from-input-wrap,
.pcalc-to-input-wrap {
  position: relative;
  display: flex;
  align-items: center;
}
.pcalc-currency {
  position: absolute;
  left: 10px;
  font-family: var(--font-mono);
  font-size: 13px;
  font-weight: 700;
  color: var(--fg-3);
  pointer-events: none;
}
.pcalc-from-input,
.pcalc-to-input {
  width: 100%;
  font-family: var(--font-mono);
  font-size: 14px;
  font-weight: 700;
  background: var(--bg-3);
  color: var(--fg);
  border: 1px solid var(--line);
  border-radius: 6px;
  padding: 9px 12px 9px 22px;
  outline: none;
  box-sizing: border-box;
}
.pcalc-from-input:focus,
.pcalc-to-input:focus {
  border-color: var(--accent);
}
.pcalc-clear-btn {
  position: absolute;
  right: 6px;
  top: 50%;
  transform: translateY(-50%);
  background: transparent;
  border: none;
  color: var(--fg-3);
  font-size: 14px;
  cursor: pointer;
  padding: 2px 6px;
  border-radius: 4px;
}
.pcalc-clear-btn:hover {
  color: var(--fg);
  background: var(--bg-2);
}
.pcalc-from-meta {
  font-family: var(--font-mono);
  font-size: 9.5px;
  color: var(--fg-3);
  margin-top: 4px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.pcalc-divider {
  height: 1px;
  background: var(--line);
  margin: 16px 0;
}
.pcalc-to-section {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.pcalc-to-row {
  display: flex;
  align-items: center;
  gap: 6px;
}
.pcalc-to-row .pcalc-to-input-wrap {
  flex: 1;
  min-width: 0;
}
.pcalc-result {
  width: 90px;
  flex-shrink: 0;
  text-align: right;
  font-family: var(--font-mono);
}
.pcalc-pct {
  font-size: 13px;
  font-weight: 800;
  letter-spacing: 0.01em;
}
.pcalc-pct.up { color: var(--up); }
.pcalc-pct.down { color: var(--down); }
.pcalc-dollar {
  font-size: 10.5px;
  margin-top: 1px;
}
.pcalc-dollar.up { color: var(--up); }
.pcalc-dollar.down { color: var(--down); }
.pcalc-empty-result {
  font-size: 12px;
  color: var(--fg-3);
}
.pcalc-remove-btn {
  background: transparent;
  border: 1px solid var(--line);
  color: var(--fg-3);
  border-radius: 4px;
  font-size: 14px;
  line-height: 1;
  width: 22px;
  height: 22px;
  cursor: pointer;
  flex-shrink: 0;
}
.pcalc-remove-btn:hover {
  color: var(--down);
  border-color: var(--down);
}
.pcalc-add-btn {
  margin-top: 6px;
  background: var(--bg-3);
  color: var(--fg-2);
  border: 1px dashed var(--line);
  border-radius: 6px;
  padding: 8px;
  font-family: var(--font-mono);
  font-size: 11.5px;
  font-weight: 700;
  cursor: pointer;
  transition: all 120ms;
}
.pcalc-add-btn:hover {
  border-color: var(--accent);
  border-style: solid;
  color: var(--accent);
}


/* Day-of-week extremes — best high / worst low per weekday */
/* ── Day-of-week section: labels, bars, extremes, footer ───────── */

/* Pill labels above each bar chart (HIGH / LOW) */
.dow-seclabel {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  margin-bottom: 6px;
  padding: 3px 11px 3px 9px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  border-radius: 999px;
  border: 1px solid transparent;
}
.dow-seclabel::before {
  content: "";
  width: 7px;
  height: 7px;
  border-radius: 50%;
}
.dow-seclabel--up {
  color: var(--up);
  background: color-mix(in srgb, var(--up) 12%, transparent);
  border-color: color-mix(in srgb, var(--up) 28%, transparent);
}
.dow-seclabel--up::before {
  background: var(--up);
  box-shadow: 0 0 7px color-mix(in srgb, var(--up) 80%, transparent);
}
.dow-seclabel--down {
  color: var(--down);
  background: color-mix(in srgb, var(--down) 12%, transparent);
  border-color: color-mix(in srgb, var(--down) 28%, transparent);
}
.dow-seclabel--down::before {
  background: var(--down);
  box-shadow: 0 0 7px color-mix(in srgb, var(--down) 80%, transparent);
}

/* Bars: crisp baseline + staggered grow-in */
.dow-chart .dow-baseline {
  stroke: currentColor;
  stroke-opacity: 0.22;
  stroke-width: 1.5;
}
.dow-bar {
  transform-box: fill-box;
  transform-origin: bottom;
  animation: dowBarRise 0.55s cubic-bezier(0.22, 0.85, 0.25, 1) both;
}
@keyframes dowBarRise {
  from { transform: scaleY(0); opacity: 0; }
  to   { transform: scaleY(1); opacity: 1; }
}
@media (prefers-reduced-motion: reduce) {
  .dow-bar { animation: none; }
}

/* Best-high / worst-low matrix */
.dow-extremes {
  margin-top: 18px;
  padding: 12px 14px;
  background:
    linear-gradient(180deg,
      color-mix(in srgb, var(--bg-3) 60%, transparent),
      var(--bg-3));
  border: 1px solid var(--line);
  border-radius: 12px;
  display: flex;
  flex-direction: column;
  gap: 7px;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.03);
}
.dow-extremes-head,
.dow-extremes-row {
  display: grid;
  grid-template-columns: 86px repeat(5, 1fr);
  align-items: center;
  font-family: var(--font-mono);
  gap: 4px;
}
.dow-extremes-corner { /* spacer above the row labels */ }
.dow-extremes-daycol {
  font-size: 10.5px;
  font-weight: 700;
  color: var(--fg-3);
  text-align: center;
  letter-spacing: 0.06em;
  padding: 2px 0;
  text-transform: uppercase;
}
.dow-extremes-label {
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}
.dow-extremes-label.up { color: var(--up); }
.dow-extremes-label.down { color: var(--down); }
.dow-extremes-cell {
  font-size: 12px;
  font-weight: 700;
  text-align: center;
  padding: 3px 0;
  border-radius: 6px;
}
.dow-extremes-cell.up   { color: var(--up); }
.dow-extremes-cell.down { color: var(--down); }

/* Footer: clustering summary as chips */
.dow-footer {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  margin-top: 16px;
  font-size: 12.5px;
}
.dow-footer-chip {
  padding: 4px 12px;
  border-radius: 999px;
  color: var(--fg-2);
  background: var(--bg-3);
  border: 1px solid var(--line);
  white-space: nowrap;
}
.dow-footer-chip b { font-weight: 800; }
.dow-footer-chip.up b   { color: var(--up); }
.dow-footer-chip.down b { color: var(--down); }
.dow-footer-dot { color: var(--fg-3); }

/* Basing tool card */
.basing-card .basing-signal {
  display: inline-block;
  margin-left: 12px;
  padding: 3px 9px;
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 800;
  background: var(--up);
  color: var(--accentText);
  border-radius: 6px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.basing-row1 {
  display: grid;
  grid-template-columns: 1fr 1.4fr 1.2fr;
  gap: 14px;
  padding: 14px 0;
  border-bottom: 1px solid var(--line);
}
.basing-stat-label {
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 700;
  color: var(--fg-3);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  margin-bottom: 4px;
}
.basing-stat-val {
  font-family: var(--font-mono);
  font-size: 18px;
  font-weight: 800;
  color: var(--fg);
}
.basing-stat-val.up { color: var(--up); }
.basing-stat-val.down { color: var(--down); }
.basing-stat-sub {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--fg-3);
  margin-top: 2px;
}

.basing-profile { padding: 14px 0; }
.basing-profile-title {
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 700;
  color: var(--fg-3);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin-bottom: 8px;
}
.basing-profile-rows {
  display: flex;
  flex-direction: column;
  gap: 1px;
  background: var(--bg-3);
  border-radius: 6px;
  padding: 4px;
  max-height: 380px;
  overflow-y: auto;
}
.basing-profile-row {
  display: grid;
  grid-template-columns: 70px 1fr 60px;
  align-items: center;
  font-family: var(--font-mono);
  font-size: 10.5px;
  padding: 1px 4px;
  position: relative;
}
.basing-profile-row.in-va { background: color-mix(in srgb, var(--accent) 10%, transparent); }
.basing-profile-row.is-poc { background: color-mix(in srgb, var(--accent) 22%, transparent); }
.basing-profile-row.is-current::before {
  content: "";
  position: absolute;
  left: 0; right: 0; top: 50%;
  border-top: 1px dashed var(--fg);
  pointer-events: none;
  z-index: 1;
}
.basing-profile-price {
  color: var(--fg-2);
  font-weight: 700;
  text-align: right;
  padding-right: 8px;
}
/* 26-cell heatmap row: each cell = 15 min of session (9:30am-4:00pm).
 * Color intensity scales with minutes spent at this price during that
 * window. Empty cells = transparent. Helps spot when price visited
 * each level chronologically.
 */
.basing-heatmap-cells {
  display: grid;
  grid-template-columns: repeat(26, 1fr);
  gap: 1px;
  height: 14px;
  background: rgba(255, 255, 255, 0.03);
  border-radius: 2px;
  overflow: hidden;
}
.basing-heatmap-cell {
  height: 100%;
  border-radius: 1px;
  transition: opacity 80ms;
}
.basing-heatmap-cell:hover {
  outline: 1px solid var(--accent);
  outline-offset: -1px;
}
/* Time-axis labels above the heatmap */
.basing-heatmap-timeaxis {
  display: grid;
  grid-template-columns: 70px 1fr 60px;
  font-family: var(--font-mono);
  font-size: 9.5px;
  color: var(--fg-3);
  margin-bottom: 4px;
  align-items: end;
}
.basing-heatmap-time-track {
  display: grid;
  grid-template-columns: repeat(26, 1fr);
  gap: 1px;
  height: 14px;
  align-items: end;
}
.basing-heatmap-time-track span {
  letter-spacing: 0.04em;
  white-space: nowrap;
  /* Labels left-align inside their grid cell so 9:30 starts flush
   * with the first cell's left edge, 4:00 with the last cell's left
   * edge, etc. No translation needed since grid placement is exact. */
}
.basing-heatmap-time-spacer,
.basing-heatmap-marker-spacer { /* alignment cells, intentionally empty */ }

.basing-profile-marker {
  display: flex;
  align-items: center;
  gap: 4px;
  padding-left: 8px;
}
.basing-tag {
  font-family: var(--font-mono);
  font-size: 9px;
  font-weight: 800;
  padding: 1px 5px;
  border-radius: 3px;
  letter-spacing: 0.04em;
}
.tag-poc { background: var(--accent); color: var(--accentText); }
.tag-tpo { background: var(--bg-1); color: var(--fg-2); border: 1px solid var(--line); }
.tag-now { color: var(--fg); font-size: 12px; padding: 0; }

.basing-legend {
  display: flex;
  gap: 16px;
  margin-top: 8px;
  font-family: var(--font-mono);
  font-size: 10.5px;
  color: var(--fg-3);
  flex-wrap: wrap;
}
.basing-legend i {
  display: inline-block;
  width: 14px;
  height: 8px;
  margin-right: 4px;
  vertical-align: middle;
  border-radius: 2px;
}
.legend-heat-light { background: rgba(29, 158, 117, 0.18); }
.legend-heat-mid   { background: rgba(29, 158, 117, 0.55); }
.legend-heat-dark  { background: rgba(29, 158, 117, 1); }
.legend-va { background: color-mix(in srgb, var(--accent) 22%, transparent); }

.basing-levels {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 8px;
  padding: 12px 0 4px;
  margin-top: 12px;
  border-top: 1px solid var(--line);
}
.basing-levels > div {
  display: flex;
  flex-direction: column;
  align-items: center;
  font-family: var(--font-mono);
}
.basing-levels-label {
  font-size: 10px;
  font-weight: 700;
  color: var(--fg-3);
  letter-spacing: 0.06em;
}
.basing-levels-val {
  font-size: 13px;
  font-weight: 700;
  color: var(--fg);
  margin-top: 2px;
}

@media (max-width: 720px) {
  .basing-row1 { grid-template-columns: 1fr; gap: 8px; }
  .basing-levels { grid-template-columns: repeat(3, 1fr); }
}

/* Basing — header row above the heatmap (OHL + Time/Volume toggle) */
.basing-profile-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 8px;
  flex-wrap: wrap;
}
.basing-ohl {
  display: flex;
  align-items: baseline;
  gap: 16px;
  font-family: var(--font-mono);
  font-size: 12px;
}
.basing-ohl-val.up { color: var(--up); }
.basing-ohl-val.down { color: var(--down); }
.basing-toggle {
  display: inline-flex;
  background: var(--bg-3);
  border: 1px solid var(--line);
  border-radius: 6px;
  padding: 2px;
}
.basing-toggle button {
  background: transparent;
  border: none;
  color: var(--fg-3);
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.04em;
  padding: 4px 10px;
  border-radius: 4px;
  cursor: pointer;
  transition: all 100ms;
}
.basing-toggle button:hover { color: var(--fg-2); }
.basing-toggle button.active {
  background: var(--accent);
  color: var(--accentText);
}

/* Basing OHLV column - vertical list of Open/High/Low/Volume.
 * Label and value sit close together; the label gets a fixed width so
 * the four values still line up vertically.
 */
.basing-ohlv {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.basing-ohlv-line {
  display: flex;
  align-items: baseline;
  font-family: var(--font-mono);
  font-size: 11.5px;
  gap: 6px;
  line-height: 1.3;
}
.basing-ohlv-key {
  color: var(--fg-3);
  font-size: 10.5px;
  font-weight: 700;
  width: 56px;
  flex-shrink: 0;
}
.basing-ohlv-val {
  color: var(--fg);
  font-weight: 700;
  font-size: 13px;
}
.basing-ohlv-val.up { color: var(--up); }
.basing-ohlv-val.down { color: var(--down); }
.basing-ohlv-pct {
  font-size: 11px;
  font-weight: 600;
  opacity: 0.85;
}

/* Toolbar wraps the Time/Volume toggle and overlay switch */
.basing-toolbar {
  display: inline-flex;
  align-items: center;
  gap: 12px;
}
/* Overlay switch — looks like a labeled toggle, similar to the theme switch */
.basing-overlay-switch {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: transparent;
  border: none;
  padding: 0;
  cursor: pointer;
}
.basing-overlay-switch-label {
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.04em;
  color: var(--fg-3);
  transition: color 100ms;
}
.basing-overlay-switch.on .basing-overlay-switch-label {
  color: var(--fg);
}
.basing-overlay-switch-track {
  position: relative;
  width: 30px;
  height: 16px;
  background: var(--bg-3);
  border: 1px solid var(--line);
  border-radius: 999px;
  transition: background 120ms, border-color 120ms;
}
.basing-overlay-switch.on .basing-overlay-switch-track {
  background: rgba(255, 200, 60, 0.45);
  border-color: rgba(255, 200, 60, 0.7);
}
.basing-overlay-switch-knob {
  position: absolute;
  top: 1px;
  left: 1px;
  width: 12px;
  height: 12px;
  background: var(--fg-3);
  border-radius: 50%;
  transition: transform 120ms, background 120ms;
}
.basing-overlay-switch.on .basing-overlay-switch-knob {
  transform: translateX(14px);
  background: rgb(255, 200, 60);
}

/* Per-row overlay bar: a horizontal amber bar laid behind the heatmap
 * cells whose width scales with the row's TOTAL overlay metric. Lets
 * users scan the price column quickly to see where total volume (or
 * total time) clustered, similar to a traditional volume profile.
 */
.basing-heatmap-cells { position: relative; }
.basing-row-overlay {
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  background: rgba(255, 200, 60, 0.18);
  border-left: 1px solid rgba(255, 200, 60, 0.6);
  pointer-events: none;
  z-index: 0;
}
.basing-heatmap-cell {
  position: relative;
  z-index: 1;
}
.legend-overlay { background: rgba(255, 200, 60, 0.45); }

/* Row1 needs to allow 4 columns now */
.basing-row1 {
  grid-template-columns: 1fr 1.4fr 1.2fr 1.3fr;
}
@media (max-width: 720px) {
  .basing-row1 { grid-template-columns: 1fr; }
}

/* Day-of-week extremes — today's column highlighted so it pops */
.dow-extremes-daycol.today {
  color: var(--fg);
  font-weight: 800;
  background: color-mix(in srgb, var(--accent, #6ea8ff) 18%, transparent);
  border-radius: 999px;
}
.dow-extremes-cell.today {
  font-weight: 800;
  background: color-mix(in srgb, var(--accent, #6ea8ff) 10%, transparent);
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--accent, #6ea8ff) 22%, transparent);
}

/* ── Decision Engine on the Suggested Strike card ────────────── */
.basing-verdict {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: 10px 12px;
  margin-bottom: 14px;
  border-radius: 8px;
  border: 1px solid var(--line);
  background: var(--bg-3);
}
.basing-verdict.verdict-sell {
  border-color: rgba(29, 158, 117, 0.55);
  background: rgba(29, 158, 117, 0.12);
}
.basing-verdict.verdict-partial {
  border-color: rgba(255, 200, 60, 0.5);
  background: rgba(255, 200, 60, 0.10);
}
.basing-verdict.verdict-avoid {
  border-color: rgba(220, 80, 80, 0.55);
  background: rgba(220, 80, 80, 0.12);
}
.basing-verdict.verdict-wait {
  border-color: var(--line);
  background: var(--bg-3);
}
.basing-verdict-label {
  font-family: var(--font-mono);
  font-size: 14px;
  font-weight: 800;
  letter-spacing: 0.04em;
  color: var(--fg);
}
.basing-verdict.verdict-sell .basing-verdict-label { color: var(--up); }
.basing-verdict.verdict-partial .basing-verdict-label { color: rgb(255, 200, 60); }
.basing-verdict.verdict-avoid .basing-verdict-label { color: var(--down); }
.basing-verdict-reason {
  font-size: 12.5px;
  color: var(--fg-2);
  line-height: 1.4;
}

.decision-engine {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-top: 12px;
  padding-top: 12px;
  border-top: 1px solid var(--line);
}
.decision-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 12px;
}
.catalyst-badge {
  font-family: var(--font-mono);
  font-size: 11.5px;
  font-weight: 700;
  letter-spacing: 0.03em;
  padding: 5px 10px;
  border-radius: 6px;
  border: 1px solid var(--line);
}
.catalyst-badge.cat-clean {
  background: rgba(29, 158, 117, 0.1);
  border-color: rgba(29, 158, 117, 0.4);
  color: var(--up);
}
.catalyst-badge.cat-caution {
  background: rgba(255, 200, 60, 0.12);
  border-color: rgba(255, 200, 60, 0.5);
  color: rgb(255, 200, 60);
}
.pop-pot {
  display: inline-flex;
  gap: 14px;
}
.pp-pair {
  display: inline-flex;
  align-items: baseline;
  gap: 5px;
  font-family: var(--font-mono);
  font-size: 12px;
}
.pp-key {
  color: var(--fg-3);
  font-size: 10.5px;
  font-weight: 700;
  letter-spacing: 0.04em;
}
.pp-val {
  color: var(--fg);
  font-weight: 800;
  font-size: 13px;
}
.picks-row {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
}
@media (max-width: 720px) { .picks-row { grid-template-columns: 1fr; } }
.pick-card {
  background: var(--bg-3);
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 10px;
  display: flex;
  flex-direction: column;
  gap: 3px;
}
.pick-label {
  font-family: var(--font-mono);
  font-size: 9.5px;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--fg-3);
}
.pick-strike {
  font-family: var(--font-mono);
  font-size: 18px;
  font-weight: 800;
  color: var(--fg);
  margin-bottom: 4px;
}
.pick-row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  font-family: var(--font-mono);
  font-size: 11px;
}
.pick-row span { color: var(--fg-3); }
.pick-row b { color: var(--fg); font-size: 12px; }

/* ── Roll Manager card ───────────────────────────────────────── */
.roll-manager .roll-list {
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.roll-item {
  background: var(--bg-3);
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 12px;
}
.roll-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  margin-bottom: 8px;
}
.roll-strike {
  font-family: var(--font-mono);
  font-size: 14px;
  font-weight: 700;
  color: var(--fg);
  display: inline-flex;
  align-items: baseline;
  gap: 4px;
}
.roll-qty {
  color: var(--fg-3);
  font-weight: 700;
  font-size: 12px;
  margin-right: 4px;
}
.roll-strike-itm { color: var(--down); }
.roll-dte {
  background: var(--bg-1);
  color: var(--fg-2);
  font-size: 10.5px;
  font-weight: 700;
  padding: 1px 6px;
  border-radius: 3px;
  margin-left: 6px;
}
.roll-itm-badge {
  background: rgba(220, 80, 80, 0.18);
  color: var(--down);
  font-size: 9.5px;
  font-weight: 800;
  padding: 1px 5px;
  border-radius: 3px;
  margin-left: 4px;
  letter-spacing: 0.05em;
}
.roll-pl {
  font-family: var(--font-mono);
  font-size: 14px;
  font-weight: 800;
}
.roll-pl .up { color: var(--up); }
.roll-pl .down { color: var(--down); }
.roll-stats {
  display: flex;
  gap: 14px;
  font-family: var(--font-mono);
  font-size: 11.5px;
  margin-bottom: 10px;
  flex-wrap: wrap;
}
.roll-stats > span {
  display: inline-flex;
  align-items: baseline;
  gap: 4px;
}
.roll-stats b { color: var(--fg); font-weight: 700; }
.roll-choices {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 6px;
}
@media (max-width: 720px) { .roll-choices { grid-template-columns: repeat(2, 1fr); } }
.roll-choice {
  background: var(--bg-1);
  border: 1px solid var(--line);
  border-radius: 6px;
  padding: 8px;
  display: flex;
  flex-direction: column;
  gap: 3px;
}
.roll-choice.unavailable { opacity: 0.55; }
.roll-choice-label {
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.04em;
  color: var(--fg-3);
  text-transform: uppercase;
}
.roll-choice-strike {
  font-family: var(--font-mono);
  font-size: 14px;
  font-weight: 800;
  color: var(--fg);
}
.roll-choice-credit {
  font-family: var(--font-mono);
  font-size: 13px;
  font-weight: 800;
}
.roll-choice-credit.up { color: var(--up); }
.roll-choice-credit.down { color: var(--down); }

/* ─── Pullback profile card (single-ticker) ───────────────── */
.pullback-card .pullback-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
  margin-bottom: 14px;
}
@media (max-width: 720px) {
  .pullback-card .pullback-grid { grid-template-columns: repeat(2, 1fr); }
}
.pullback-stat {
  background: var(--bg-3);
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 10px 12px;
}
.pullback-stat-label {
  font-family: var(--font-mono);
  font-size: 9.5px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--fg-3);
  margin-bottom: 4px;
}
.pullback-stat-val {
  font-family: var(--font-mono);
  font-size: 18px;
  font-weight: 800;
  color: var(--fg);
}

.pullback-thresholds {
  margin-bottom: 14px;
}
.pullback-thresholds-title {
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--fg-3);
  margin-bottom: 6px;
}
.pullback-thresholds-grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 6px;
}
@media (max-width: 720px) {
  .pullback-thresholds-grid { grid-template-columns: repeat(3, 1fr); }
}
.pullback-thresh {
  background: var(--bg-3);
  border: 1px solid var(--line);
  border-radius: 6px;
  padding: 8px;
  text-align: center;
}
.pullback-thresh-label {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--fg-3);
  margin-bottom: 2px;
}
.pullback-thresh-val {
  font-family: var(--font-mono);
  font-size: 14px;
  font-weight: 800;
  color: var(--fg);
}

.pullback-today, .pullback-levels, .pullback-conditions, .pullback-split {
  margin-bottom: 14px;
  padding-top: 12px;
  border-top: 1px solid var(--line);
}
.pullback-today-title, .pullback-levels-title, .pullback-split-title {
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--fg-3);
  margin-bottom: 6px;
}
.pullback-today-grid, .pullback-levels-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 8px;
}
@media (max-width: 720px) {
  .pullback-today-grid, .pullback-levels-grid { grid-template-columns: repeat(2, 1fr); }
}
.pullback-today-stat, .pullback-level {
  background: var(--bg-3);
  border: 1px solid var(--line);
  border-radius: 6px;
  padding: 8px 10px;
}
.pullback-today-label, .pullback-level-label {
  font-family: var(--font-mono);
  font-size: 9.5px;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--fg-3);
  margin-bottom: 2px;
}
.pullback-today-val, .pullback-level-val {
  font-family: var(--font-mono);
  font-size: 15px;
  font-weight: 800;
  color: var(--fg);
}
.pullback-today-val.up, .pullback-level-val.up { color: var(--up); }
.pullback-today-val.down, .pullback-level-val.down { color: var(--down); }
.pullback-level-sub {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--fg-3);
  margin-top: 1px;
}
.pullback-rr {
  margin-top: 8px;
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--fg-2);
}
.pullback-rr b { color: var(--fg); }
.pullback-rr .rr-good { color: var(--up); }
.pullback-rr .rr-bad { color: var(--down); }

.pullback-conditions {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.pullback-cond {
  background: var(--bg-3);
  border: 1px solid var(--line);
  border-radius: 6px;
  padding: 8px 10px;
}
.pullback-cond-label {
  font-family: var(--font-mono);
  font-size: 10.5px;
  font-weight: 700;
  color: var(--fg-2);
  margin-bottom: 4px;
}
.pullback-cond-vals {
  display: flex;
  gap: 14px;
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--fg-3);
  flex-wrap: wrap;
}
.pullback-cond-vals b { color: var(--fg); font-weight: 700; }

.pullback-split-bar {
  display: flex;
  height: 24px;
  border-radius: 4px;
  overflow: hidden;
  background: var(--bg-3);
}
.pullback-split-seg {
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 800;
  color: white;
  transition: width 200ms;
  min-width: 0;
  overflow: hidden;
}
.pullback-split-seg.seg-gandgo { background: rgba(220, 80, 80, 0.7); }
.pullback-split-seg.seg-normal { background: rgba(29, 158, 117, 0.7); }
.pullback-split-seg.seg-fade { background: rgba(255, 200, 60, 0.7); }
.pullback-split-legend {
  display: flex;
  gap: 14px;
  margin-top: 6px;
  font-family: var(--font-mono);
  font-size: 10.5px;
  color: var(--fg-3);
  flex-wrap: wrap;
}
.pullback-split-legend i {
  display: inline-block;
  width: 12px;
  height: 8px;
  border-radius: 2px;
  margin-right: 4px;
  vertical-align: middle;
}
.pullback-split-legend .seg-gandgo { background: rgba(220, 80, 80, 0.7); }
.pullback-split-legend .seg-normal { background: rgba(29, 158, 117, 0.7); }
.pullback-split-legend .seg-fade { background: rgba(255, 200, 60, 0.7); }

/* ─── Pullback scanner table ───────────────────────── */
.pullback-scan-table {
  display: flex;
  flex-direction: column;
  font-family: var(--font-mono);
  font-size: 12px;
}
.pullback-scan-head {
  display: grid;
  grid-template-columns: 60px 1fr 1fr 1fr 1fr 1fr 50px 130px;
  gap: 8px;
  padding: 8px 10px;
  border-bottom: 1px solid var(--line);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--fg-3);
}
.pullback-scan-row {
  display: grid;
  grid-template-columns: 60px 1fr 1fr 1fr 1fr 1fr 50px 130px;
  gap: 8px;
  padding: 8px 10px;
  border-bottom: 1px solid var(--line);
  cursor: pointer;
  transition: background 80ms;
  align-items: center;
}
.pullback-scan-row:hover { background: var(--bg-3); }
.pullback-scan-row .ticker-cell {
  font-weight: 800;
  color: var(--fg);
}
.pullback-scan-verdict {
  font-size: 10.5px;
  font-weight: 800;
  letter-spacing: 0.04em;
  padding: 3px 8px;
  border-radius: 4px;
  text-align: center;
  border: 1px solid var(--line);
}
.pullback-scan-verdict.verdict-sell {
  background: rgba(29, 158, 117, 0.15);
  border-color: rgba(29, 158, 117, 0.5);
  color: var(--up);
}
.pullback-scan-verdict.verdict-partial {
  background: rgba(255, 200, 60, 0.12);
  border-color: rgba(255, 200, 60, 0.45);
  color: rgb(255, 200, 60);
}
.pullback-scan-verdict.verdict-avoid {
  background: rgba(220, 80, 80, 0.15);
  border-color: rgba(220, 80, 80, 0.5);
  color: var(--down);
}
.pullback-scan-verdict.verdict-wait {
  background: var(--bg-3);
  color: var(--fg-3);
}

/* Pullback scanner — clickable column headers */
.pullback-scan-head .pb-th {
  cursor: pointer;
  user-select: none;
  transition: color 80ms;
}
.pullback-scan-head .pb-th:hover { color: var(--fg); }
.pullback-scan-head .pb-th.active { color: var(--fg); font-weight: 800; }

/* Active ticker row — highlighted so the user can find it without scrolling */
.pullback-scan-row.is-active {
  background: rgba(29, 158, 117, 0.10);
  border-left: 3px solid var(--up);
  padding-left: 7px;
}
.pullback-scan-row.is-active .ticker-cell {
  color: var(--up);
}

/* Pullback card tools — kicker (sample label) + direction toggle in card-head */
.pullback-card-tools {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}

/* ── Pullback custom backtest ───────────────────────── */
.pullback-backtest {
  margin-bottom: 14px;
  padding-top: 12px;
  border-top: 1px solid var(--line);
}
.pullback-backtest-title {
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--fg-3);
  margin-bottom: 8px;
}
.pullback-backtest-controls {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr auto;
  gap: 8px;
  align-items: end;
}
@media (max-width: 720px) {
  .pullback-backtest-controls { grid-template-columns: 1fr 1fr; }
}
.pbb-field {
  display: flex;
  flex-direction: column;
  gap: 3px;
}
.pbb-label {
  font-family: var(--font-mono);
  font-size: 9.5px;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--fg-3);
}
.pbb-input {
  background: var(--bg-3);
  border: 1px solid var(--line);
  border-radius: 6px;
  padding: 6px 8px;
  color: var(--fg);
  font-family: var(--font-mono);
  font-size: 13px;
  font-weight: 700;
}
.pbb-input:focus {
  outline: none;
  border-color: var(--accent);
}
.pbb-run {
  background: var(--accent);
  color: var(--accentText);
  border: none;
  border-radius: 6px;
  padding: 8px 16px;
  font-family: var(--font-mono);
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.04em;
  cursor: pointer;
  transition: opacity 100ms;
}
.pbb-run:disabled { opacity: 0.5; cursor: not-allowed; }
.pbb-run:hover:not(:disabled) { opacity: 0.85; }

.pullback-backtest-result {
  margin-top: 12px;
}
.pbb-headline {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 8px;
  margin-bottom: 10px;
}
@media (max-width: 720px) {
  .pbb-headline { grid-template-columns: repeat(2, 1fr); }
}
.pbb-stat {
  background: var(--bg-3);
  border: 1px solid var(--line);
  border-radius: 6px;
  padding: 8px 10px;
}
.pbb-stat-label {
  font-family: var(--font-mono);
  font-size: 9.5px;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--fg-3);
  margin-bottom: 2px;
}
.pbb-stat-val {
  font-family: var(--font-mono);
  font-size: 18px;
  font-weight: 800;
  color: var(--fg);
}
.pbb-stat-val.up { color: var(--up); }
.pbb-stat-val.down { color: var(--down); }

.pbb-secondary {
  margin-bottom: 10px;
}
.pbb-sec-row {
  display: flex;
  gap: 16px;
  font-family: var(--font-mono);
  font-size: 12px;
  flex-wrap: wrap;
}
.pbb-sec-row b { color: var(--fg); font-weight: 700; }

.pbb-timeline-label {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--fg-3);
  margin-bottom: 4px;
}
.pbb-timeline-bar {
  display: flex;
  gap: 2px;
  height: 18px;
}
.pbb-day {
  flex: 1;
  border-radius: 2px;
  min-width: 4px;
  transition: opacity 80ms;
}
.pbb-day.hit { background: rgba(29, 158, 117, 0.7); }
.pbb-day.miss { background: rgba(220, 80, 80, 0.55); }
.pbb-day:hover { opacity: 0.7; cursor: help; }

.pbb-meta {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--fg-3);
  margin-bottom: 8px;
  padding: 6px 8px;
  background: var(--bg-3);
  border: 1px solid var(--line);
  border-radius: 6px;
  flex-wrap: wrap;
}
.pbb-meta b { color: var(--fg); font-weight: 700; }
.pbb-warning {
  color: rgb(255, 200, 60);
  font-weight: 700;
}

/* Backtest day-of-week breakdown */
.pbb-weekday {
  margin-top: 14px;
  padding-top: 12px;
  border-top: 1px solid var(--line);
}
.pbb-weekday-title {
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--fg-3);
  margin-bottom: 8px;
}
.pbb-weekday-callout {
  text-transform: none;
  letter-spacing: 0;
  color: var(--up);
  font-weight: 600;
}
.pbb-weekday-callout b { color: var(--fg); font-weight: 800; }
.pbb-weekday-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 6px;
}
@media (max-width: 720px) {
  .pbb-weekday-grid { grid-template-columns: repeat(5, 1fr); gap: 4px; }
}
.pbb-wd {
  background: var(--bg-3);
  border: 1px solid var(--line);
  border-radius: 6px;
  padding: 8px 6px;
  text-align: center;
  cursor: help;
  transition: transform 80ms;
}
.pbb-wd:hover { transform: translateY(-1px); }
.pbb-wd.empty { opacity: 0.4; }
.pbb-wd.good {
  background: rgba(29, 158, 117, 0.12);
  border-color: rgba(29, 158, 117, 0.45);
}
.pbb-wd.ok { /* default styling */ }
.pbb-wd.weak {
  background: rgba(220, 80, 80, 0.10);
  border-color: rgba(220, 80, 80, 0.35);
}
.pbb-wd.is-best {
  border-color: var(--up);
  border-width: 2px;
  padding: 7px 5px;
}
.pbb-wd-day {
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.05em;
  color: var(--fg-3);
  text-transform: uppercase;
  margin-bottom: 3px;
}
.pbb-wd-rate {
  font-family: var(--font-mono);
  font-size: 17px;
  font-weight: 800;
  color: var(--fg);
}
.pbb-wd.good .pbb-wd-rate { color: var(--up); }
.pbb-wd.weak .pbb-wd-rate { color: var(--down); }
.pbb-wd-sub {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--fg-3);
  margin-top: 2px;
}

/* Chart card-head right column — stacks perf pills + toolbar */

/* Performance pills (WTD / MTD / QTD / YTD) above toolbar */
.chart-perf {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  justify-content: flex-end;
}
.chart-perf-pill {
  background: var(--bg-3);
  border: 1px solid var(--line);
  border-radius: 6px;
  padding: 4px 8px;
  text-align: center;
  min-width: 56px;
  cursor: help;
}
.chart-perf-lbl {
  font-family: var(--font-mono);
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.06em;
  color: var(--fg-3);
  text-transform: uppercase;
}
.chart-perf-val {
  font-family: var(--font-mono);
  font-size: 12px;
  font-weight: 800;
  color: var(--fg);
  margin-top: 1px;
}
.chart-perf-val.up { color: var(--up); }
.chart-perf-val.down { color: var(--down); }

/* Chart stats grid — fills empty space below the chart legend */
.chart-stats-grid {
  display: grid;
  grid-template-columns: repeat(8, 1fr);
  gap: 8px;
  margin-top: 16px;
  padding-top: 14px;
  border-top: 1px solid var(--line);
}
@media (max-width: 1100px) {
  .chart-stats-grid { grid-template-columns: repeat(4, 1fr); }
}
@media (max-width: 600px) {
  .chart-stats-grid { grid-template-columns: repeat(2, 1fr); }
}
.chart-stat {
  background: var(--bg-3);
  border: 1px solid var(--line);
  border-radius: 6px;
  padding: 8px 10px;
  cursor: help;
  transition: transform 80ms;
}
.chart-stat:hover { transform: translateY(-1px); }
.chart-stat-lbl {
  font-family: var(--font-mono);
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.06em;
  color: var(--fg-3);
  text-transform: uppercase;
  margin-bottom: 3px;
}
.chart-stat-val {
  font-family: var(--font-mono);
  font-size: 14px;
  font-weight: 800;
  color: var(--fg);
}
.chart-stat-val.up { color: var(--up); }
.chart-stat-val.down { color: var(--down); }
.chart-stat-sub {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--fg-3);
  margin-top: 2px;
}
.chart-stat-sub.up { color: var(--up); }
.chart-stat-sub.down { color: var(--down); }

/* Chart card needs relative positioning for absolute perf strip */
.chart-card { position: relative; }

/* Push the toolbar down on chart card so it sits BELOW the floating
   perf strip. Title block (left) keeps its natural top alignment. */
.chart-card .card-head .toolbar {
  margin-top: 42px;
}
@media (max-width: 900px) {
  .chart-card .card-head .toolbar { margin-top: 0; }
}

/* Perf pills floating in card top-right corner */
.chart-perf-floating {
  position: absolute;
  top: 14px;
  right: 14px;
  display: flex;
  gap: 6px;
  z-index: 2;
}
@media (max-width: 900px) {
  .chart-perf-floating {
    position: static;
    margin-bottom: 8px;
    flex-wrap: wrap;
  }
}

/* Unusual Whales status badge — sits alongside Schwab/yf badges */
.src-badge-uw {
  background: rgba(80, 160, 255, 0.10);
  border-color: rgba(80, 160, 255, 0.45);
  color: rgb(80, 160, 255);
}
.src-badge-uw .src-dot { background: rgb(80, 160, 255); }
.src-badge-uw-warn .src-dot { background: rgb(255, 180, 60); }
.src-badge-uw-off {
  background: rgba(120, 120, 120, 0.10);
  border-color: rgba(120, 120, 120, 0.40);
  color: rgb(150, 150, 150);
}
.src-badge-uw-off .src-dot { background: rgb(150, 150, 150); }
.src-badge-uw-err {
  background: rgba(220, 80, 80, 0.10);
  border-color: rgba(220, 80, 80, 0.50);
  color: rgb(220, 80, 80);
}
.src-badge-uw-err .src-dot { background: rgb(220, 80, 80); }

/* ── Flow Score Card (Unusual Whales) ───────────────────── */
.flow-score-card {
  margin-bottom: var(--row-gap);
  border: 1px solid rgba(80, 160, 255, 0.30);
  background: linear-gradient(180deg, var(--bg-2) 0%, rgba(80, 160, 255, 0.02) 100%);
}

.flow-verdict {
  margin-top: 14px;
  padding: 12px 14px;
  border-radius: 8px;
  border: 1px solid var(--line);
  background: var(--bg-3);
}
.flow-verdict.verdict-avoid {
  border-color: rgba(220, 80, 80, 0.55);
  background: rgba(220, 80, 80, 0.08);
}
.flow-verdict.verdict-partial {
  border-color: rgba(255, 180, 60, 0.55);
  background: rgba(255, 180, 60, 0.06);
}
.flow-verdict.verdict-sell {
  border-color: rgba(29, 158, 117, 0.55);
  background: rgba(29, 158, 117, 0.06);
}
.flow-verdict.verdict-wait {
  border-color: var(--line);
}
.flow-verdict-label {
  font-family: var(--font-mono);
  font-size: 9.5px;
  font-weight: 800;
  letter-spacing: 0.10em;
  color: var(--fg-3);
  margin-bottom: 4px;
}
.flow-verdict-text {
  font-family: var(--font-mono);
  font-size: 16px;
  font-weight: 800;
  color: var(--fg);
  margin-bottom: 4px;
}
.flow-verdict.verdict-avoid .flow-verdict-text { color: var(--down); }
.flow-verdict.verdict-sell .flow-verdict-text { color: var(--up); }
.flow-verdict.verdict-partial .flow-verdict-text { color: rgb(255, 180, 60); }
.flow-verdict-reason {
  font-size: 12px;
  color: var(--fg-2);
  line-height: 1.4;
}

.flow-overall {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 16px;
  align-items: center;
  margin-top: 14px;
  padding: 12px 0;
}
.flow-overall-circle {
  width: 92px; height: 92px;
  border-radius: 50%;
  border: 3px solid rgba(80, 160, 255, 0.5);
  background: var(--bg-3);
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  cursor: help;
}
.flow-overall-num {
  font-family: var(--font-mono);
  font-size: 32px;
  font-weight: 800;
  color: var(--fg);
  line-height: 1;
}
.flow-overall-num.up { color: var(--up); }
.flow-overall-num.down { color: var(--down); }
.flow-overall-cap {
  font-family: var(--font-mono);
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.10em;
  color: var(--fg-3);
  margin-top: 4px;
}
.flow-overall-stats {
  display: flex; flex-direction: column;
  gap: 4px;
}
.flow-stat-row {
  display: flex; justify-content: space-between;
  font-family: var(--font-mono);
  font-size: 12px;
  cursor: help;
}
.flow-stat-lbl { color: var(--fg-3); }
.flow-stat-val { color: var(--fg); font-weight: 700; }
.flow-stat-val.up { color: var(--up); }
.flow-stat-val.down { color: var(--down); }

.flow-subs {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 10px 16px;
  margin-top: 10px;
  padding-top: 12px;
  border-top: 1px solid var(--line);
}
@media (max-width: 600px) {
  .flow-subs { grid-template-columns: 1fr; }
}
.flow-sub { cursor: help; }
.flow-sub-head {
  display: flex; justify-content: space-between;
  margin-bottom: 4px;
}
.flow-sub-lbl {
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.06em;
  color: var(--fg-3);
  text-transform: uppercase;
}
.flow-sub-val {
  font-family: var(--font-mono);
  font-size: 12px;
  font-weight: 800;
  color: var(--fg);
}
.flow-sub-bar {
  height: 6px;
  background: var(--bg-3);
  border-radius: 3px;
  overflow: hidden;
  border: 1px solid var(--line);
}
.flow-sub-fill {
  height: 100%;
  border-radius: 3px;
  transition: width 200ms ease-out;
}
.flow-sub-fill.sub-default { background: rgb(120, 120, 130); }
.flow-sub-fill.sub-neutral { background: rgb(200, 200, 60); }
.flow-sub-fill.sub-good { background: var(--up); }
.flow-sub-fill.sub-bad { background: var(--down); }

/* ── Flow trades collapsible (inside FlowScoreCard) ───────── */
.flow-trades-section {
  margin-top: 12px;
  padding-top: 10px;
  border-top: 1px solid var(--line);
}
.flow-trades-toggle {
  background: transparent;
  border: 1px solid var(--line);
  border-radius: 6px;
  padding: 6px 12px;
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 700;
  color: var(--fg-2);
  cursor: pointer;
  transition: background 80ms;
}
.flow-trades-toggle:hover { background: var(--bg-3); color: var(--fg); }
.flow-trades-list {
  margin-top: 10px;
  max-height: 360px;
  overflow-y: auto;
  border: 1px solid var(--line);
  border-radius: 6px;
}
.flow-trades-head, .flow-trade-row {
  display: grid;
  grid-template-columns: 70px 50px 60px 70px 50px 70px 50px 50px 70px 30px;
  gap: 6px;
  padding: 6px 10px;
  font-family: var(--font-mono);
  font-size: 11px;
  align-items: center;
}
.flow-trades-head {
  font-weight: 700;
  color: var(--fg-3);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  background: var(--bg-3);
  border-bottom: 1px solid var(--line);
  position: sticky;
  top: 0;
  z-index: 1;
}
.flow-trade-row {
  border-bottom: 1px solid var(--line);
}
.flow-trade-row:last-child { border-bottom: none; }
.flow-trade-row:hover { background: var(--bg-3); }
.flow-trade-row .num-strong { font-weight: 700; color: var(--fg); }
.flow-trade-row .side-call { color: var(--up); font-weight: 700; }
.flow-trade-row .side-put { color: var(--down); font-weight: 700; }
.flow-trade-row .fill-ask { color: var(--up); }
.flow-trade-row .fill-bid { color: var(--down); }
.flow-trade-row .fill-mid { color: var(--fg-3); }
.flow-trade-row .bias-bull { color: var(--up); font-weight: 700; }
.flow-trade-row .bias-bear { color: var(--down); font-weight: 700; }
.flow-trade-row .bias-neutral { color: var(--fg-3); }
.flow-trade-row .sweep-flag {
  background: rgb(255, 180, 60);
  color: black;
  padding: 1px 4px;
  border-radius: 3px;
  font-weight: 800;
  font-size: 10px;
}
@media (max-width: 720px) {
  .flow-trades-head, .flow-trade-row {
    grid-template-columns: repeat(5, 1fr);
    font-size: 10px;
  }
  .flow-trades-head span:nth-child(n+6),
  .flow-trade-row span:nth-child(n+6) { display: none; }
}

/* ── Per-strike flow overlay row ─────────────────────────── */
.strike-flow-row {
  display: flex;
  flex-wrap: wrap;
  gap: 6px 10px;
  align-items: center;
  margin-top: 8px;
  padding-top: 8px;
  border-top: 1px dashed var(--line);
  font-family: var(--font-mono);
  font-size: 11px;
  cursor: help;
}
.strike-flow-lbl {
  color: var(--fg-3);
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  font-size: 9px;
}
.strike-flow-row b { color: var(--fg); font-weight: 700; }
.strike-flow-row b.warn { color: rgb(255, 180, 60); }
.strike-flow-sweep {
  background: rgb(255, 180, 60);
  color: black;
  padding: 1px 4px;
  border-radius: 3px;
  font-weight: 800;
  font-size: 10px;
}
.strike-flow-vol-oi {
  background: rgba(80, 160, 255, 0.18);
  color: rgb(80, 160, 255);
  padding: 1px 4px;
  border-radius: 3px;
  font-weight: 800;
  font-size: 10px;
  border: 1px solid rgba(80, 160, 255, 0.5);
}

/* ── Premium Richness Scanner table ──────────────────────── */
.richness-table {
  margin-top: 12px;
}
.richness-head, .richness-row {
  display: grid;
  grid-template-columns: 60px 60px 1fr 60px 70px 60px 50px;
  gap: 8px;
  padding: 8px 10px;
  font-family: var(--font-mono);
  font-size: 12px;
  align-items: center;
}
.richness-head {
  font-weight: 700;
  color: var(--fg-3);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  font-size: 10px;
  border-bottom: 1px solid var(--line);
}
.richness-row {
  border-bottom: 1px solid var(--line);
  cursor: pointer;
  transition: background 80ms;
}
.richness-row:hover { background: var(--bg-3); }
.richness-row.is-active {
  background: rgba(29, 158, 117, 0.10);
  border-left: 3px solid var(--up);
  padding-left: 7px;
}
.richness-row.is-active .ticker-cell { color: var(--up); }
.richness-score {
  font-weight: 800;
  text-align: center;
  padding: 2px 6px;
  border-radius: 4px;
}
.richness-score.rich {
  background: rgba(29, 158, 117, 0.15);
  color: var(--up);
}
.richness-score.moderate {
  background: rgba(255, 180, 60, 0.12);
  color: rgb(255, 180, 60);
}
.richness-score.fair {
  color: var(--fg-2);
}
.richness-score.thin {
  background: rgba(220, 80, 80, 0.10);
  color: var(--down);
}
.richness-verdict.verdict-sell { color: var(--up); }
.richness-verdict.verdict-partial { color: rgb(255, 180, 60); }
.richness-verdict.verdict-avoid { color: var(--down); }
.richness-row .warn { color: rgb(255, 180, 60); font-weight: 700; }

/* ── Roll Manager flow context ─────────────────────────── */
.roll-flow-context {
  margin: 12px 0;
}

/* ── Momentum scanner ──────────────────────────────────── */
.momentum-table {
  margin-top: 12px;
}
.momentum-head, .momentum-row {
  display: grid;
  grid-template-columns: 60px 60px 1fr 70px 80px 60px 50px;
  gap: 8px;
  padding: 8px 10px;
  font-family: var(--font-mono);
  font-size: 12px;
  align-items: center;
}
.momentum-head {
  font-weight: 700;
  color: var(--fg-3);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  font-size: 10px;
  border-bottom: 1px solid var(--line);
}
.momentum-row {
  border-bottom: 1px solid var(--line);
  cursor: pointer;
  transition: background 80ms;
}
.momentum-row:hover { background: var(--bg-3); }
.momentum-row.is-active {
  background: rgba(29, 158, 117, 0.10);
  border-left: 3px solid var(--up);
  padding-left: 7px;
}
.momentum-row.is-active .ticker-cell { color: var(--up); }
.momentum-row .up { color: var(--up); }
.momentum-row .down { color: var(--down); }
.momentum-row .warn { color: rgb(255, 180, 60); }
/* Momentum-specific score colors that extend the richness color palette */
.richness-score.bear-mod {
  background: rgba(220, 80, 80, 0.05);
  color: rgb(220, 80, 80);
}

/* ── Market dashboard ──────────────────────────────────── */
.market-dashboard-card .card-head { user-select: none; }
.market-tide-summary {
  display: flex;
  gap: 6px;
  align-items: center;
  font-family: var(--font-mono);
  font-size: 13px;
}
.market-tide-summary b.up { color: var(--up); }
.market-tide-summary b.down { color: var(--down); }
.market-dashboard-body {
  margin-top: 12px;
  padding-top: 12px;
  border-top: 1px solid var(--line);
}
.market-section {
  margin-bottom: 16px;
}
.market-section-title {
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.06em;
  color: var(--fg-3);
  text-transform: uppercase;
  margin-bottom: 8px;
  cursor: help;
}
.sector-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 8px;
}
@media (max-width: 800px) {
  .sector-grid { grid-template-columns: repeat(2, 1fr); }
}
.sector-cell {
  background: var(--bg-3);
  border: 1px solid var(--line);
  border-radius: 6px;
  padding: 8px 10px;
  text-align: center;
  cursor: help;
}
.sector-cell.bull { border-color: rgba(29, 158, 117, 0.45); }
.sector-cell.bear { border-color: rgba(220, 80, 80, 0.45); }
.sector-name {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--fg-3);
  text-transform: uppercase;
  font-weight: 700;
  letter-spacing: 0.04em;
}
.sector-net {
  font-family: var(--font-mono);
  font-size: 14px;
  font-weight: 800;
  margin-top: 2px;
}
.sector-net.up { color: var(--up); }
.sector-net.down { color: var(--down); }

.spike-list {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.spike-row {
  display: flex;
  gap: 6px;
  align-items: center;
  background: var(--bg-3);
  border: 1px solid var(--line);
  border-radius: 4px;
  padding: 4px 8px;
  font-family: var(--font-mono);
  font-size: 11px;
  cursor: pointer;
  transition: background 80ms;
}
.spike-row:hover { background: var(--bg); }

/* Calculator mode toggle (% → $ vs $ → %) */
.pcalc-mode-toggle {
  display: flex;
  gap: 4px;
  margin-top: 10px;
  padding: 3px;
  background: var(--bg-3);
  border: 1px solid var(--line);
  border-radius: 6px;
}
.pcalc-mode-toggle button {
  flex: 1;
  background: transparent;
  border: none;
  padding: 5px 8px;
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 700;
  color: var(--fg-3);
  border-radius: 4px;
  cursor: pointer;
  transition: background 80ms;
}
.pcalc-mode-toggle button:hover { background: var(--bg-2); color: var(--fg-2); }
.pcalc-mode-toggle button.active {
  background: var(--accent);
  color: var(--accentText);
}
.pcalc-pct-suffix {
  left: auto !important;
  right: 8px;
}

/* ── Market scanner (UW market-wide) ───────────────────── */
.market-scan-table {
  margin-top: 12px;
}
.market-scan-head, .market-scan-row {
  display: grid;
  /* 13 columns: Ticker · Score · Dir · Verdict · Total$ · Unus$ · Unus% · Net$ · Vol · Price · Chg% · Analyst · Earnings */
  grid-template-columns: 60px 50px 50px 1fr 70px 70px 60px 70px 60px 70px 60px 50px 80px;
  gap: 8px;
  padding: 8px 10px;
  font-family: var(--font-mono);
  font-size: 12px;
  align-items: center;
}
.market-scan-head {
  font-weight: 700;
  color: var(--fg-3);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  font-size: 10px;
  border-bottom: 1px solid var(--line);
}
.market-scan-row {
  border-bottom: 1px solid var(--line);
  cursor: pointer;
  transition: background 80ms;
}
.market-scan-row:hover { background: var(--bg-3); }
.market-scan-row.is-active {
  background: rgba(29, 158, 117, 0.10);
  border-left: 3px solid var(--up);
  padding-left: 7px;
}
.market-scan-row.is-active .ticker-cell { color: var(--up); }
.market-scan-row .up { color: var(--up); }
.market-scan-row .down { color: var(--down); }
.market-scan-row .num-strong { font-weight: 700; color: var(--fg); }

/* Unusual concentration % — color-coded so high concentration jumps out.
   High = today's options flow is heavily weighted toward UW-flagged
   unusual trades. Mid = significant flagged share. Low = mostly normal flow. */
.unus-pct { font-weight: 700; }
.unus-pct.unus-high { color: rgb(255, 180, 60); }
.unus-pct.unus-mid { color: var(--fg); }
.unus-pct.unus-low { color: var(--fg-3); }

/* Bullish/bearish/neutral direction pill */
.scan-dir-pill {
  display: inline-block;
  padding: 1px 6px;
  border-radius: 4px;
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 800;
  text-align: center;
  cursor: help;
}
.scan-dir-pill.dir-bull {
  background: rgba(29, 158, 117, 0.18);
  color: var(--up);
  border: 1px solid rgba(29, 158, 117, 0.45);
}
.scan-dir-pill.dir-bear {
  background: rgba(220, 80, 80, 0.15);
  color: var(--down);
  border: 1px solid rgba(220, 80, 80, 0.45);
}
.scan-dir-pill.dir-neutral {
  background: var(--bg-3);
  color: var(--fg-3);
  border: 1px solid var(--line);
}

/* Earnings pills */
.earn-pill {
  display: inline-block;
  padding: 1px 6px;
  border-radius: 4px;
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 700;
  background: var(--bg-3);
  color: var(--fg-2);
  border: 1px solid var(--line);
  cursor: help;
}
.earn-pill.earn-imminent {
  background: rgba(220, 80, 80, 0.15);
  color: rgb(220, 80, 80);
  border-color: rgba(220, 80, 80, 0.5);
}
.earn-pill.earn-soon {
  background: rgba(255, 180, 60, 0.12);
  color: rgb(255, 180, 60);
  border-color: rgba(255, 180, 60, 0.45);
}

@media (max-width: 800px) {
  .market-scan-head, .market-scan-row {
    /* On narrow screens: Ticker · Score · Dir · Total$ · Unus% · Price · Analyst · Earnings */
    grid-template-columns: 50px 40px 50px 70px 60px 70px 40px 80px;
    font-size: 11px;
  }
  /* Hide Verdict (4th), Unus$ (6th), Net$ (8th), Vol (9th), Chg% (11th) */
  .market-scan-head span:nth-child(4),
  .market-scan-row span:nth-child(4),
  .market-scan-head span:nth-child(6),
  .market-scan-row span:nth-child(6),
  .market-scan-head span:nth-child(8),
  .market-scan-row span:nth-child(8),
  .market-scan-head span:nth-child(9),
  .market-scan-row span:nth-child(9),
  .market-scan-head span:nth-child(11),
  .market-scan-row span:nth-child(11) { display: none; }
}

/* ── EMA Pullback Strategy Card ───────────────────────── */
.ema-dir-toggle {
  display: flex;
  gap: 4px;
  padding: 3px;
  background: var(--bg-3);
  border: 1px solid var(--line);
  border-radius: 6px;
}
.ema-dir-toggle button {
  background: transparent;
  border: none;
  padding: 5px 10px;
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 800;
  color: var(--fg-3);
  border-radius: 4px;
  cursor: pointer;
  letter-spacing: 0.04em;
  transition: background 80ms;
}
.ema-dir-toggle button:hover { background: var(--bg-2); color: var(--fg-2); }
.ema-dir-toggle button.active.up {
  background: rgba(29, 158, 117, 0.18);
  color: var(--up);
}
.ema-dir-toggle button.active.down {
  background: rgba(220, 80, 80, 0.18);
  color: var(--down);
}

.ema-section { margin-top: 12px; }
.ema-section-title {
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 700;
  color: var(--fg-3);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  margin-bottom: 10px;
  display: flex;
  align-items: center;
  flex-wrap: wrap;
}

.ema-stats-grid {
  display: grid;
  grid-template-columns: repeat(8, 1fr);
  gap: 8px;
  margin-bottom: 14px;
}
@media (max-width: 800px) {
  .ema-stats-grid { grid-template-columns: repeat(4, 1fr); }
}
.ema-stat {
  background: var(--bg-3);
  border: 1px solid var(--line);
  border-radius: 6px;
  padding: 8px 10px;
  cursor: help;
  text-align: center;
}
.ema-stat-lbl {
  font-family: var(--font-mono);
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.06em;
  color: var(--fg-3);
  text-transform: uppercase;
  margin-bottom: 4px;
}
.ema-stat-val {
  font-family: var(--font-mono);
  font-size: 16px;
  font-weight: 800;
  color: var(--fg);
}
.ema-stat-val.up { color: var(--up); }
.ema-stat-val.down { color: var(--down); }

.ema-trades-title {
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.06em;
  color: var(--fg-3);
  text-transform: uppercase;
  margin-bottom: 6px;
}
.ema-trades-table {
  border: 1px solid var(--line);
  border-radius: 6px;
  max-height: 320px;
  overflow-y: auto;
}
.ema-trades-head, .ema-trades-row {
  display: grid;
  grid-template-columns: 80px 80px 80px 80px 70px 60px 50px 1fr;
  gap: 8px;
  padding: 6px 10px;
  font-family: var(--font-mono);
  font-size: 11px;
  align-items: center;
}
.ema-trades-head {
  font-weight: 700;
  color: var(--fg-3);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  font-size: 9px;
  background: var(--bg-3);
  border-bottom: 1px solid var(--line);
  position: sticky;
  top: 0;
}
.ema-trades-row { border-bottom: 1px solid var(--line); }
.ema-trades-row:last-child { border-bottom: none; }
.ema-trades-row .up { color: var(--up); font-weight: 700; }
.ema-trades-row .down { color: var(--down); font-weight: 700; }

.ema-state-summary {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-bottom: 12px;
}
.ema-state-pill {
  padding: 3px 8px;
  border-radius: 4px;
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  border: 1px solid var(--line);
  background: var(--bg-3);
  cursor: help;
}
.ema-state-pill.ema-state-confirmed {
  background: rgba(29, 158, 117, 0.20);
  color: var(--up);
  border-color: rgba(29, 158, 117, 0.55);
}
.ema-state-pill.ema-state-pulled {
  background: rgba(255, 180, 60, 0.15);
  color: rgb(255, 180, 60);
  border-color: rgba(255, 180, 60, 0.45);
}
.ema-state-pill.ema-state-trending {
  color: var(--fg-2);
}
.ema-state-pill.ema-state-notrend {
  color: var(--fg-3);
}

.ema-scan-table { margin-top: 8px; }
.ema-scan-head, .ema-scan-row {
  display: grid;
  grid-template-columns: 60px 110px 70px 70px 70px 70px 50px 1fr;
  gap: 8px;
  padding: 6px 10px;
  font-family: var(--font-mono);
  font-size: 11px;
  align-items: center;
}
.ema-scan-head {
  font-weight: 700;
  color: var(--fg-3);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  font-size: 9px;
  border-bottom: 1px solid var(--line);
}
.ema-scan-row {
  border-bottom: 1px solid var(--line);
  cursor: pointer;
  transition: background 80ms;
}
.ema-scan-row:hover { background: var(--bg-3); }
.ema-scan-row.is-active {
  background: rgba(29, 158, 117, 0.10);
  border-left: 3px solid var(--up);
  padding-left: 7px;
}
.ema-scan-row.ema-state-confirmed .ema-state-text {
  color: var(--up); font-weight: 800;
}
.ema-scan-row.ema-state-pulled .ema-state-text {
  color: rgb(255, 180, 60); font-weight: 700;
}
.ema-scan-row.ema-state-trending .ema-state-text {
  color: var(--fg-2);
}
.ema-scan-row .num-strong { font-weight: 700; color: var(--fg); }

/* ── EMA strategy params row ───────────────────────────── */
.ema-params-row {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: center;
  margin-top: 10px;
  padding: 10px 12px;
  background: var(--bg-3);
  border: 1px solid var(--line);
  border-radius: 6px;
}
.ema-param {
  display: flex;
  flex-direction: column;
  gap: 4px;
  cursor: help;
}
.ema-param-lbl {
  font-family: var(--font-mono);
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.06em;
  color: var(--fg-3);
  text-transform: uppercase;
}
.ema-param input {
  width: 70px;
  padding: 4px 8px;
  background: var(--bg-2);
  border: 1px solid var(--line);
  border-radius: 4px;
  color: var(--fg);
  font-family: var(--font-mono);
  font-size: 13px;
  font-weight: 700;
  text-align: center;
}
.ema-param input:focus {
  outline: none;
  border-color: var(--accent, var(--up));
}

/* Stale-quote indicator. Subtle warning color so user knows the price
   isn't really live, without making it look like an error. Hover for
   details on how old the last trade is. */
.sb-price-stale { opacity: 0.75; }
.sb-stale-marker {
  font-size: 10px;
  font-weight: 600;
  color: rgb(255, 180, 60);
  letter-spacing: 0.04em;
  margin-left: 2px;
  cursor: help;
}

/* ── Analyst Price Targets Card ─────────────────────────────────────── */
.analyst-card { margin-bottom: var(--row-gap); }

.analyst-stats-grid {
  display: grid;
  grid-template-columns: repeat(8, 1fr);
  gap: 8px;
  margin-top: 12px;
  margin-bottom: 12px;
}
@media (max-width: 1100px) {
  .analyst-stats-grid { grid-template-columns: repeat(4, 1fr); }
}
.analyst-stat {
  background: var(--bg-3);
  border: 1px solid var(--line);
  border-radius: 6px;
  padding: 8px 10px;
  cursor: help;
  text-align: center;
}
.analyst-stat-lbl {
  font-family: var(--font-mono);
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.06em;
  color: var(--fg-3);
  text-transform: uppercase;
  margin-bottom: 4px;
}
.analyst-stat-val {
  font-family: var(--font-mono);
  font-size: 15px;
  font-weight: 800;
  color: var(--fg);
}
.analyst-stat-val.up { color: var(--up); }
.analyst-stat-val.down { color: var(--down); }
.analyst-consensus { font-size: 13px; }
.analyst-score-num {
  font-size: 11px;
  color: var(--fg-3);
  font-weight: 600;
  margin-left: 4px;
}
.analyst-trend-more_bullish { color: var(--up); font-size: 13px; }
.analyst-trend-more_bearish { color: var(--down); font-size: 13px; }
.analyst-trend-stable { color: var(--fg-2); font-size: 13px; }
.analyst-trend-none { color: var(--fg-3); }

/* Consensus breakdown bar — horizontal stacked bar showing % of analysts at each rating */
.analyst-consensus-bar {
  display: flex;
  height: 6px;
  border-radius: 3px;
  overflow: hidden;
  margin-bottom: 12px;
  background: var(--bg-3);
  cursor: help;
}
.analyst-bar-segment { transition: opacity 100ms; }
.analyst-bar-segment:hover { opacity: 0.85; }
.analyst-bar-strong-buy { background: var(--up); }
.analyst-bar-buy { background: rgba(29, 158, 117, 0.65); }
.analyst-bar-hold { background: rgba(180, 180, 180, 0.55); }
.analyst-bar-sell { background: rgba(220, 80, 80, 0.65); }
.analyst-bar-strong-sell { background: var(--down); }

/* Verdict tag pills */
.analyst-verdict-row {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-bottom: 12px;
}
.verdict-pill {
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  padding: 3px 8px;
  border-radius: 4px;
  border: 1px solid var(--line);
}
.verdict-pill-bull {
  background: rgba(29, 158, 117, 0.15);
  color: var(--up);
  border-color: rgba(29, 158, 117, 0.45);
}
.verdict-pill-bear {
  background: rgba(220, 80, 80, 0.15);
  color: var(--down);
  border-color: rgba(220, 80, 80, 0.45);
}
.verdict-pill-info {
  background: var(--bg-3);
  color: var(--fg-2);
}
.verdict-pill-neutral {
  background: var(--bg-3);
  color: var(--fg-3);
}

/* Trading warnings */
.analyst-warnings {
  background: rgba(220, 80, 80, 0.06);
  border: 1px solid rgba(220, 80, 80, 0.25);
  border-radius: 6px;
  padding: 10px 12px;
  margin-bottom: 12px;
}
.analyst-warnings-intraday {
  background: rgba(255, 180, 60, 0.06);
  border-color: rgba(255, 180, 60, 0.30);
}
.analyst-warnings-title {
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.04em;
  color: var(--fg-2);
  text-transform: uppercase;
  margin-bottom: 6px;
}
.analyst-warnings ul {
  margin: 0;
  padding-left: 18px;
  font-size: 12px;
  color: var(--fg);
  line-height: 1.45;
}
.analyst-warnings li { margin-bottom: 4px; }

/* History table */
.analyst-history { margin-top: 16px; }
.analyst-history-title {
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.04em;
  color: var(--fg-3);
  text-transform: uppercase;
  margin-bottom: 8px;
}
.analyst-source-tag { color: var(--fg-3); font-weight: 500; }
.analyst-history-table {
  border: 1px solid var(--line);
  border-radius: 6px;
  max-height: 360px;
  overflow-y: auto;
}
.analyst-history-head, .analyst-history-row {
  display: grid;
  grid-template-columns: 90px 1fr 90px 1fr 130px 60px;
  gap: 10px;
  padding: 7px 12px;
  font-family: var(--font-mono);
  font-size: 11px;
  align-items: center;
}
.analyst-history-head {
  font-weight: 700;
  color: var(--fg-3);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  font-size: 9px;
  background: var(--bg-3);
  border-bottom: 1px solid var(--line);
  position: sticky;
  top: 0;
  z-index: 1;
}
.analyst-history-row { border-bottom: 1px solid var(--line); }
.analyst-history-row:last-child { border-bottom: none; }
.analyst-firm { font-weight: 600; color: var(--fg); }

.analyst-action-pill {
  display: inline-block;
  padding: 2px 8px;
  border-radius: 3px;
  font-size: 10px;
  font-weight: 700;
  text-align: center;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.analyst-action-upgrade {
  background: rgba(29, 158, 117, 0.20);
  color: var(--up);
}
.analyst-action-downgrade {
  background: rgba(220, 80, 80, 0.20);
  color: var(--down);
}
.analyst-action-initiate {
  background: rgba(100, 160, 255, 0.18);
  color: rgb(120, 175, 255);
}
.analyst-action-target {
  background: rgba(255, 180, 60, 0.15);
  color: rgb(255, 180, 60);
}
.analyst-action-reiterate {
  background: var(--bg-3);
  color: var(--fg-3);
}
.analyst-action-unknown {
  background: var(--bg-3);
  color: var(--fg-3);
}

.grade-pill {
  display: inline-block;
  padding: 1px 6px;
  border-radius: 3px;
  font-size: 10px;
  font-weight: 700;
}
.grade-pill.grade-bull { background: rgba(29, 158, 117, 0.15); color: var(--up); }
.grade-pill.grade-bear { background: rgba(220, 80, 80, 0.15); color: var(--down); }
.grade-pill.grade-neutral { background: var(--bg-3); color: var(--fg-2); }
.grade-arrow { color: var(--fg-3); font-size: 9px; margin: 0 2px; }
.analyst-target-cell { font-weight: 600; }
.analyst-target-change { font-weight: 700; text-align: right; }
.analyst-target-change.up { color: var(--up); }
.analyst-target-change.down { color: var(--down); }

/* Finnhub hint — shown on Consensus/Analysts/Trend cells when only
   yfinance data is available */
.analyst-needs-finnhub {
  display: inline-block;
  font-size: 9px;
  font-weight: 600;
  color: var(--fg-3);
  font-family: var(--font-mono);
  margin-left: 4px;
  letter-spacing: 0.04em;
  cursor: help;
  font-style: italic;
}
.analyst-finnhub-hint {
  display: flex;
  align-items: baseline;
  gap: 2px;
  justify-content: center;
}

/* Market scanner analyst catalyst cell — compact icon for fast scanning */
.analyst-cell {
  font-weight: 800;
  font-size: 14px;
  text-align: center;
  cursor: help;
}
.analyst-cell-upgrade { color: var(--up); }
.analyst-cell-downgrade { color: var(--down); }
.analyst-cell-stretched { color: rgb(255, 180, 60); }
.analyst-cell-none { color: var(--fg-3); opacity: 0.5; }

/* ── Expected Move quick-glance card ─────────────────────── */
.expected-move-card .em-stats-grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 8px;
  margin-top: 10px;
}
@media (max-width: 900px) {
  .expected-move-card .em-stats-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}
.em-stat {
  background: var(--bg-3);
  border: 1px solid var(--line);
  border-radius: 6px;
  padding: 10px 12px;
  cursor: help;
  text-align: center;
  transition: border-color 80ms;
}
.em-stat:hover {
  border-color: var(--fg-3);
}
.em-stat-lbl {
  font-family: var(--font-mono);
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.06em;
  color: var(--fg-3);
  text-transform: uppercase;
  margin-bottom: 5px;
}
.em-stat-val {
  font-family: var(--font-mono);
  font-size: 17px;
  font-weight: 800;
  color: var(--fg);
  letter-spacing: -0.01em;
}
.em-stat-val.up { color: var(--up); }
.em-stat-val.down { color: var(--down); }

/* Expected Move when nested inside the chart card (v110+).
   Sits below the 8-stat price grid, separated by a thin divider so
   it reads as a related section without competing for visual weight. */
.chart-card .chart-em-section {
  margin-top: 14px;
  padding-top: 14px;
  border-top: 1px solid var(--line);
}
.chart-card .chart-em-section .card-head {
  margin-bottom: 0;
}
.chart-card .chart-em-section .em-stats-grid {
  margin-top: 12px;
}

/* Analyst warnings — two-column layout for the dual strategies (selling
   covered calls on the left, selling cash-secured puts on the right).
   Each side renders only if its warnings list has items, so a name with
   strong CC concerns but no CSP concerns just shows the CC column. */
.analyst-warnings-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin-bottom: 12px;
}
@media (max-width: 900px) {
  .analyst-warnings-row { grid-template-columns: 1fr; }
}
.analyst-warnings-row .analyst-warnings { margin-bottom: 0; }
.analyst-warnings-cc {
  background: rgba(220, 80, 80, 0.06);
  border: 1px solid rgba(220, 80, 80, 0.25);
}
.analyst-warnings-csp {
  background: rgba(29, 158, 117, 0.06);
  border: 1px solid rgba(29, 158, 117, 0.25);
}

/* ── Trade Builder Card ─────────────────────────────────────── */
.trade-builder-card { margin-bottom: var(--row-gap); }

/* Front-runner banner — the most visually-loud element on the card */
.trade-front-runner {
  margin-top: 12px;
  margin-bottom: 14px;
  padding: 12px 14px;
  border-radius: 6px;
  border: 1.5px solid;
}
.trade-front-runner-call {
  background: rgba(220, 80, 80, 0.08);
  border-color: rgba(220, 80, 80, 0.55);
}
.trade-front-runner-put {
  background: rgba(29, 158, 117, 0.08);
  border-color: rgba(29, 158, 117, 0.55);
}
.tfr-header {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin-bottom: 4px;
}
.tfr-label {
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--fg-3);
}
.tfr-score {
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 700;
  color: var(--fg-2);
}
.tfr-action {
  font-size: 16px;
  font-weight: 800;
  color: var(--fg);
  margin-bottom: 4px;
}
.tfr-detail {
  font-size: 13px;
  color: var(--fg-2);
  line-height: 1.45;
  margin-bottom: 8px;
}
.tfr-reasons {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
}
.tfr-reason-pill {
  font-family: var(--font-mono);
  font-size: 9px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  padding: 2px 7px;
  border-radius: 3px;
  background: var(--bg-3);
  color: var(--fg-2);
  border: 1px solid var(--line);
}

/* No-trade fallback */
.trade-no-trade {
  margin-top: 12px;
  margin-bottom: 14px;
  padding: 12px 14px;
  border-radius: 6px;
  border: 1px dashed var(--line);
  background: var(--bg-3);
}
.tnt-label {
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--fg-3);
  margin-bottom: 4px;
}
.tnt-detail {
  font-size: 12px;
  color: var(--fg-2);
  line-height: 1.5;
  margin-bottom: 8px;
}
.tnt-scores {
  display: flex;
  gap: 14px;
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--fg-3);
}
.tnt-scores span { cursor: help; }

/* Side-by-side comparison grid */
.trade-builder-compare {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin-bottom: 10px;
}
@media (max-width: 900px) {
  .trade-builder-compare { grid-template-columns: 1fr; }
}
/* Phase C follow-up (v1.13): single-side layout when strategyMode is
   "cc" or "csp". Visible side spans full width instead of leaving a
   blank slot in the 2-col grid. */
.trade-builder-compare.single { grid-template-columns: 1fr; }
.trade-side {
  background: var(--bg-3);
  border: 1px solid var(--line);
  border-radius: 6px;
  padding: 12px 14px;
  transition: border-color 80ms;
}
.trade-side.is-front {
  border-color: var(--fg-3);
  box-shadow: 0 0 0 1px var(--fg-3);
}
.trade-side-head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin-bottom: 8px;
}
.trade-side-title {
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--fg-3);
}
.trade-side-score {
  font-family: var(--font-mono);
  font-size: 12px;
  font-weight: 800;
  color: var(--fg);
  cursor: help;
}
.trade-side-strike {
  font-family: var(--font-mono);
  font-size: 18px;
  font-weight: 800;
  color: var(--fg);
  margin-bottom: 10px;
  cursor: help;
}
.trade-side-strike-meta {
  font-size: 11px;
  font-weight: 600;
  color: var(--fg-3);
  margin-left: 4px;
}
.trade-side-rows {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.trade-row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  padding: 3px 0;
  font-family: var(--font-mono);
  font-size: 11px;
  cursor: help;
  border-bottom: 1px dashed transparent;
}
.trade-row:hover { border-bottom-color: var(--line); }
.trade-lbl {
  color: var(--fg-3);
  text-transform: uppercase;
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.04em;
}
.trade-val {
  color: var(--fg);
  font-weight: 700;
}
.trade-val.up { color: var(--up); }
.trade-val.down { color: var(--down); }

.trade-builder-disclaimer {
  font-family: var(--font-mono);
  font-size: 9px;
  font-weight: 600;
  letter-spacing: 0.04em;
  color: var(--fg-3);
  text-align: center;
  text-transform: uppercase;
  cursor: help;
  margin-top: 4px;
  opacity: 0.7;
}

/* Cross-expiration comparison section in Trade Builder */
.trade-multi-exp-section {
  margin-top: 14px;
  padding-top: 14px;
  border-top: 1px dashed var(--line);
}
.trade-multi-exp-toggle {
  background: var(--bg-3);
  border: 1px solid var(--line);
  color: var(--fg);
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  padding: 8px 14px;
  border-radius: 5px;
  cursor: pointer;
  width: 100%;
  transition: background 80ms, border-color 80ms;
}
.trade-multi-exp-toggle:hover {
  background: var(--bg-2);
  border-color: var(--fg-3);
}
.trade-multi-exp-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  margin-bottom: 10px;
}
.trade-multi-exp-title {
  font-size: 14px;
  font-weight: 800;
  color: var(--fg);
}
.trade-multi-exp-refresh {
  background: var(--accent);
  color: var(--accent-text);
  border: none;
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 700;
  padding: 6px 12px;
  border-radius: 4px;
  cursor: pointer;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.trade-multi-exp-refresh:disabled {
  opacity: 0.5;
  cursor: wait;
}
.trade-multi-exp-error {
  padding: 10px 12px;
  background: color-mix(in oklch, var(--down), transparent 90%);
  border: 1px solid color-mix(in oklch, var(--down), transparent 70%);
  border-radius: 5px;
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--down);
}
.trade-multi-exp-loading, .trade-multi-exp-empty {
  padding: 16px;
  text-align: center;
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--fg-3);
}
.trade-multi-exp-table {
  border: 1px solid var(--line);
  border-radius: 5px;
  overflow: hidden;
}
.trade-multi-head, .trade-multi-row {
  display: grid;
  grid-template-columns: 60px 40px 60px 60px 70px 50px 60px 60px 70px 50px;
  gap: 6px;
  padding: 7px 10px;
  font-family: var(--font-mono);
  font-size: 11px;
  align-items: center;
}
/* Phase C follow-up (v1.13): single-mode column layouts. Both modes
   collapse to 6 columns (Exp, DTE, $, Prem, Ann%, PoP) with wider
   widths since there is more horizontal room available. */
.trade-multi-head.trade-multi-mode-cc,
.trade-multi-row.trade-multi-mode-cc,
.trade-multi-head.trade-multi-mode-csp,
.trade-multi-row.trade-multi-mode-csp {
  grid-template-columns: 80px 50px 90px 90px 110px 80px;
}
.trade-multi-head {
  background: var(--bg-3);
  border-bottom: 1px solid var(--line);
  font-size: 9px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--fg-3);
}
.trade-multi-head span { cursor: help; }
.trade-multi-row { border-bottom: 1px solid var(--line); }
.trade-multi-row:last-child { border-bottom: none; }
.trade-multi-row:hover { background: var(--bg-3); }
.trade-multi-exp { font-weight: 700; color: var(--fg); }
.trade-multi-best {
  color: var(--up);
  font-weight: 800;
  cursor: help;
}
@media (max-width: 900px) {
  .trade-multi-head, .trade-multi-row {
    grid-template-columns: 50px 35px 55px 55px 60px 60px 55px;
    font-size: 10px;
  }
  /* Hide PoP cols and one strike col on narrow */
  .trade-multi-head span:nth-child(6),
  .trade-multi-row span:nth-child(6),
  .trade-multi-head span:nth-child(8),
  .trade-multi-row span:nth-child(8),
  .trade-multi-head span:nth-child(10),
  .trade-multi-row span:nth-child(10) { display: none; }
}

/* Position tracker roll-trigger flag — shown when DTE < 7 and |delta| > 0.40 */
.pos-roll-flag {
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 600;
  color: rgb(255, 180, 60);
  background: rgba(255, 180, 60, 0.08);
  border: 1px solid rgba(255, 180, 60, 0.30);
  border-radius: 4px;
  padding: 4px 8px;
  margin-top: 6px;
  cursor: help;
  line-height: 1.4;
}

/* ─── Watchlist alerts card (v1.15) ─────────────────────────────── */
.watchlist-alerts-card .wa-collapse-btn {
  background: var(--bg-3);
  border: 1px solid var(--line);
  color: var(--fg-2);
  padding: 4px 10px;
  border-radius: 6px;
  font-size: 11px;
  font-family: var(--font-mono);
  cursor: pointer;
}
.watchlist-alerts-card .wa-collapse-btn:hover { color: var(--fg); }
.wa-list { display: flex; flex-direction: column; gap: 6px; margin-top: 10px; }
.wa-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  background: var(--bg-3);
  border: 1px solid var(--line);
  border-left-width: 3px;
  border-radius: 6px;
  padding: 8px 12px;
}
.wa-row.wa-up { border-left-color: var(--up); }
.wa-row.wa-down { border-left-color: var(--down); }
.wa-row-left { display: flex; gap: 12px; align-items: center; flex-wrap: wrap; }
.wa-row-right { display: flex; gap: 6px; }
.wa-symbol {
  font-family: var(--font-mono);
  font-weight: 700;
  font-size: 13px;
  color: var(--fg);
  cursor: help;
}
.wa-kind {
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  padding: 2px 6px;
  border-radius: 3px;
  cursor: help;
}
.wa-kind.wa-up { background: color-mix(in oklch, var(--up), transparent 80%); color: var(--up); }
.wa-kind.wa-down { background: color-mix(in oklch, var(--down), transparent 80%); color: var(--down); }
.wa-firm { font-size: 12px; color: var(--fg-2); cursor: help; }
.wa-grades { font-size: 11px; color: var(--fg-3); font-family: var(--font-mono); cursor: help; }
.wa-date { font-size: 11px; color: var(--fg-3); font-family: var(--font-mono); cursor: help; }
.wa-switch {
  background: var(--accent);
  color: var(--accent-text);
  border: none;
  padding: 4px 10px;
  border-radius: 4px;
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 700;
  cursor: pointer;
}
.wa-dismiss {
  background: transparent;
  color: var(--fg-3);
  border: 1px solid var(--line);
  width: 24px;
  height: 24px;
  border-radius: 4px;
  cursor: pointer;
  font-size: 12px;
}
.wa-dismiss:hover { color: var(--fg); border-color: var(--fg-3); }
.wa-error {
  color: var(--down);
  font-size: 12px;
  padding: 8px 12px;
  background: color-mix(in oklch, var(--down), transparent 92%);
  border-radius: 4px;
  margin-top: 8px;
}

/* ─── Win rate card (v1.15) ─────────────────────────────────────── */
.wr-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
  margin-top: 10px;
}
@media (max-width: 900px) { .wr-grid { grid-template-columns: repeat(2, 1fr); } }
.wr-tile {
  background: var(--bg-3);
  border: 1px solid var(--line);
  border-radius: 6px;
  padding: 12px 14px;
  cursor: help;
}
.wr-tile-lbl {
  font-family: var(--font-mono);
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--fg-3);
  margin-bottom: 4px;
}
.wr-tile-val {
  font-family: var(--font-display);
  font-size: 22px;
  font-weight: 700;
  color: var(--fg);
}
.wr-tile-val.up { color: var(--up); }
.wr-tile-val.down { color: var(--down); }
.wr-tile-val.warn { color: var(--warn); }
.wr-tile-sub { font-size: 11px; color: var(--fg-3); margin-top: 2px; }
.wr-extremes {
  display: flex;
  gap: 12px;
  margin-top: 12px;
  flex-wrap: wrap;
}
.wr-extreme {
  display: inline-flex;
  gap: 8px;
  align-items: center;
  background: var(--bg-3);
  border: 1px solid var(--line);
  border-radius: 4px;
  padding: 6px 10px;
  cursor: help;
}
.wr-extreme-lbl {
  font-family: var(--font-mono);
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--fg-3);
}
.wr-extreme-sym {
  font-family: var(--font-mono);
  font-weight: 700;
  font-size: 12px;
  color: var(--fg);
}
.wr-extreme-val { font-family: var(--font-mono); font-weight: 700; font-size: 13px; }
.wr-extreme-val.up { color: var(--up); }
.wr-extreme-val.down { color: var(--down); }

/* CSV export button (v1.21), sits at the right of the Win rate head. */
.wr-export-btn {
  align-self: flex-start;
  background: var(--bg-3);
  border: 1px solid var(--line);
  color: var(--fg-2);
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.04em;
  padding: 6px 11px;
  border-radius: 8px;
  cursor: pointer;
  white-space: nowrap;
  transition: color 0.12s ease, border-color 0.12s ease;
}
.wr-export-btn:hover { color: var(--accent); border-color: var(--accent); }

/* Cumulative realized P/L sparkline (v1.21). */
.wr-chart { margin-top: 12px; }
.wr-chart-head {
  display: flex; align-items: baseline; justify-content: space-between;
  margin-bottom: 4px;
}
.wr-chart-lbl {
  font-family: var(--font-mono); font-size: 10px; font-weight: 700;
  letter-spacing: 0.06em; text-transform: uppercase; color: var(--fg-3);
}
.wr-chart-now { font-family: var(--font-mono); font-size: 13px; font-weight: 700; }
.wr-chart-now.up { color: var(--up); }
.wr-chart-now.down { color: var(--down); }
.wr-chart-svg { width: 100%; height: 90px; display: block; }
.wr-line { fill: none; stroke-width: 2; vector-effect: non-scaling-stroke; }
.wr-line.up { stroke: var(--up); }
.wr-line.down { stroke: var(--down); }
.wr-area { stroke: none; opacity: 0.14; }
.wr-area.up { fill: var(--up); }
.wr-area.down { fill: var(--down); }
.wr-zero { stroke: var(--line-2); stroke-width: 1; stroke-dasharray: 3 3; vector-effect: non-scaling-stroke; }
.wr-dot.up { fill: var(--up); }
.wr-dot.down { fill: var(--down); }

/* ─── Earnings crush card (v1.15) ───────────────────────────────── */
.earnings-crush-card .ec-refresh-btn {
  background: var(--bg-3);
  border: 1px solid var(--line);
  color: var(--fg-2);
  padding: 4px 10px;
  border-radius: 6px;
  font-size: 11px;
  font-family: var(--font-mono);
  cursor: pointer;
}
.earnings-crush-card .ec-refresh-btn:disabled { opacity: 0.5; cursor: wait; }
.ec-error {
  color: var(--down);
  font-size: 12px;
  padding: 8px 12px;
  background: color-mix(in oklch, var(--down), transparent 92%);
  border-radius: 4px;
  margin-top: 8px;
}
.ec-table {
  border: 1px solid var(--line);
  border-radius: 5px;
  overflow: hidden;
  margin-top: 10px;
}
.ec-head, .ec-row {
  display: grid;
  grid-template-columns: 80px 100px 60px 100px 90px 70px;
  gap: 8px;
  padding: 8px 12px;
  font-family: var(--font-mono);
  font-size: 11px;
  align-items: center;
}
.ec-head {
  background: var(--bg-3);
  border-bottom: 1px solid var(--line);
  font-size: 9px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--fg-3);
}
.ec-head span { cursor: help; }
.ec-row { border-bottom: 1px solid var(--line); cursor: pointer; }
.ec-row:last-child { border-bottom: none; }
.ec-row:hover { background: var(--bg-3); }
.ec-sym { font-weight: 700; color: var(--fg); }
.ec-row .up { color: var(--up); font-weight: 700; }
.ec-row .down { color: var(--down); font-weight: 700; }
.ec-row .warn { color: var(--warn); font-weight: 700; }
@media (max-width: 900px) {
  .ec-head, .ec-row { grid-template-columns: 60px 80px 40px 80px 70px 50px; font-size: 10px; }
}

/* ─── Roll P/L modeling section (v1.16) ───────────────────────────── */
.roll-pl-section {
  margin-top: 12px;
  padding-top: 12px;
  border-top: 1px solid var(--line);
  cursor: help;
}
.roll-pl-head { margin-bottom: 8px; }
.roll-pl-kicker {
  font-family: var(--font-mono);
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--fg-3);
}
.roll-pl-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 8px;
}
@media (max-width: 900px) { .roll-pl-grid { grid-template-columns: repeat(2, 1fr); } }
.roll-pl-card {
  background: var(--bg-3);
  border: 1px solid var(--line);
  border-radius: 6px;
  padding: 10px 12px;
  cursor: help;
}
.roll-pl-card.unavailable { opacity: 0.5; }
.roll-pl-label {
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--fg-3);
  margin-bottom: 4px;
}
.roll-pl-pnl {
  font-family: var(--font-display);
  font-size: 18px;
  font-weight: 700;
  margin-bottom: 4px;
}
.roll-pl-pnl.up { color: var(--up); }
.roll-pl-pnl.down { color: var(--down); }
.roll-pl-detail {
  font-size: 10.5px;
  color: var(--fg-2);
  line-height: 1.4;
}

/* ─── Push settings card (v1.16) ──────────────────────────────────── */
.push-settings-card .ps-collapse-btn {
  background: var(--bg-3);
  border: 1px solid var(--line);
  color: var(--fg-2);
  padding: 4px 10px;
  border-radius: 6px;
  font-size: 11px;
  font-family: var(--font-mono);
  cursor: pointer;
}
.ps-body { display: flex; flex-direction: column; gap: 8px; margin-top: 10px; }
.ps-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  background: var(--bg-3);
  border: 1px solid var(--line);
  border-radius: 4px;
  padding: 6px 10px;
}
.ps-row-lbl {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--fg-2);
  cursor: help;
}
.ps-row-val { font-family: var(--font-mono); font-size: 11px; font-weight: 700; }
.ps-ok { color: var(--up); }
.ps-err { color: var(--down); }
.ps-actions { display: flex; gap: 10px; align-items: center; margin-top: 4px; }
.ps-test-btn {
  background: var(--accent);
  color: var(--accent-text);
  border: none;
  padding: 6px 12px;
  border-radius: 4px;
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 700;
  cursor: pointer;
}
.ps-test-btn:disabled { opacity: 0.5; cursor: wait; }
.ps-test-result { font-family: var(--font-mono); font-size: 11px; }
.ps-help { font-size: 12px; color: var(--fg-2); line-height: 1.5; }
.ps-code {
  background: var(--bg-3);
  border: 1px solid var(--line);
  border-radius: 4px;
  padding: 10px 12px;
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--fg-2);
  overflow-x: auto;
  white-space: pre;
  margin: 0;
}

/* ─── Broker import card (v1.17) ──────────────────────────────────── */
.broker-import-card .bi-collapse-btn {
  background: var(--bg-3);
  border: 1px solid var(--line);
  color: var(--fg-2);
  padding: 4px 10px;
  border-radius: 6px;
  font-size: 11px;
  font-family: var(--font-mono);
  cursor: pointer;
}
.bi-body { display: flex; flex-direction: column; gap: 10px; margin-top: 10px; }
.bi-help {
  font-size: 12px;
  color: var(--fg-2);
  line-height: 1.5;
  padding: 8px 12px;
  background: var(--bg-3);
  border-radius: 4px;
}
.bi-help code {
  background: var(--bg-2);
  padding: 1px 5px;
  border-radius: 3px;
  font-family: var(--font-mono);
  font-size: 11px;
}
.bi-account-picker {
  display: flex;
  align-items: center;
  gap: 10px;
}
.bi-row-lbl {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--fg-2);
  cursor: help;
}
.bi-account-select {
  background: var(--bg-3);
  border: 1px solid var(--line);
  color: var(--fg);
  padding: 5px 10px;
  border-radius: 4px;
  font-family: var(--font-mono);
  font-size: 12px;
}
.bi-actions { display: flex; gap: 10px; align-items: center; }
.bi-refresh-btn {
  background: var(--bg-3);
  border: 1px solid var(--line);
  color: var(--fg-2);
  padding: 6px 12px;
  border-radius: 4px;
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 700;
  cursor: pointer;
}
.bi-refresh-btn:disabled { opacity: 0.5; cursor: wait; }
.bi-import-all-btn {
  background: var(--accent);
  color: var(--accent-text);
  border: none;
  padding: 6px 12px;
  border-radius: 4px;
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 700;
  cursor: pointer;
}
.bi-error {
  color: var(--down);
  font-size: 12px;
  padding: 8px 12px;
  background: color-mix(in oklch, var(--down), transparent 92%);
  border-radius: 4px;
}
.bi-table {
  border: 1px solid var(--line);
  border-radius: 5px;
  overflow: hidden;
}
.bi-head, .bi-row {
  display: grid;
  grid-template-columns: 70px 50px 80px 100px 60px 90px 90px;
  gap: 8px;
  padding: 8px 12px;
  font-family: var(--font-mono);
  font-size: 11px;
  align-items: center;
}
.bi-head {
  background: var(--bg-3);
  border-bottom: 1px solid var(--line);
  font-size: 9px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--fg-3);
}
.bi-head span { cursor: help; }
.bi-row { border-bottom: 1px solid var(--line); }
.bi-row:last-child { border-bottom: none; }
.bi-row.bi-row-tracked { opacity: 0.55; }
.bi-sym { font-weight: 700; color: var(--fg); }
.bi-row .up { color: var(--up); }
.bi-row .down { color: var(--down); }
.bi-status-tracked {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--fg-3);
  font-style: italic;
}
.bi-add-btn {
  background: var(--accent);
  color: var(--accent-text);
  border: none;
  padding: 3px 10px;
  border-radius: 3px;
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 700;
  cursor: pointer;
}
@media (max-width: 900px) {
  .bi-head, .bi-row { grid-template-columns: 60px 40px 70px 80px 50px 70px 70px; font-size: 10px; }
}

/* ─── By-strike options activity chart (v1.19) ────────────────────── */
.oi-chart-wrap { margin: 12px 0 16px; }
.oi-chart-controls {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 10px;
  flex-wrap: wrap;
  gap: 8px;
}
.oi-chart-legend {
  display: flex;
  gap: 14px;
  align-items: center;
  font-size: 11px;
  color: var(--fg-2);
}
.oi-leg-item { display: inline-flex; align-items: center; gap: 5px; }
.oi-leg-dot { width: 9px; height: 9px; border-radius: 2px; display: inline-block; }
.oi-leg-note { color: var(--fg-3); font-family: var(--font-mono); }
.oi-metric-toggle {
  display: inline-flex;
  background: var(--bg-3);
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 2px;
  gap: 2px;
}
.oi-metric-pill {
  background: transparent;
  border: none;
  padding: 4px 12px;
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 700;
  color: var(--fg-3);
  cursor: pointer;
  border-radius: 6px;
}
.oi-metric-pill:hover { color: var(--fg-2); }
.oi-metric-pill.active { background: var(--accent); color: var(--accent-text); }
.oi-chart { display: flex; flex-direction: column; gap: 2px; }
.oi-chart-row {
  display: grid;
  grid-template-columns: 1fr 64px 1fr;
  align-items: center;
  gap: 6px;
  padding: 1px 0;
}
.oi-chart-row.near { background: color-mix(in oklch, var(--accent), transparent 88%); border-radius: 4px; }
.oi-bar-side { display: flex; align-items: center; gap: 5px; height: 16px; }
.oi-bar-side.put { justify-content: flex-end; }
.oi-bar-side.call { justify-content: flex-start; }
.oi-bar { height: 13px; border-radius: 2px; min-width: 0; }
.oi-bar.put-bar { background: var(--down); }
.oi-bar.call-bar { background: var(--up); }
.oi-bar-num { font-family: var(--font-mono); font-size: 10px; color: var(--fg-3); white-space: nowrap; }
.oi-bar-strike {
  text-align: center;
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 700;
  color: var(--fg);
}
.oi-chart-row.near .oi-bar-strike { color: var(--accent); }
.oi-chart-empty { padding: 16px 0; font-size: 13px; text-align: center; }

/* ─── Level Reprice card (v1.28) ─────────────────────────────────────
   Intraday fade staging. Matches existing dark card density. Numbers
   are right aligned tabular monospace with fixed feel, no wrapping. */
.lr-status {
  align-self: flex-start;
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.04em;
  padding: 4px 10px;
  border-radius: 999px;
  border: 1px solid var(--line);
}
.lr-status.lr-wait { color: var(--fg-3); }
.lr-status.lr-approach { color: var(--accent); border-color: var(--accent); }
.lr-status.lr-tagged { color: var(--up); border-color: var(--up); }
.lr-stage {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
  gap: 10px;
  margin-bottom: 12px;
}
.lr-field { display: flex; flex-direction: column; gap: 4px; }
.lr-field label {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--fg-3);
}
.lr-field input {
  background: var(--bg-3);
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 7px 9px;
  color: var(--fg);
  font-family: var(--font-mono);
  font-size: 13px;
  font-variant-numeric: tabular-nums;
}
.lr-field input:focus { outline: none; border-color: var(--accent); }
.lr-seg { display: inline-flex; gap: 2px; background: var(--bg-3); border: 1px solid var(--line); border-radius: 8px; padding: 2px; }
.lr-seg button {
  flex: 1;
  background: transparent;
  border: none;
  color: var(--fg-3);
  font-size: 12px;
  font-weight: 600;
  padding: 6px 10px;
  border-radius: 6px;
  cursor: pointer;
}
.lr-seg button.active { background: var(--accent); color: var(--accent-text); }
.lr-seg-sm button { padding: 4px 9px; font-size: 11px; }
.lr-levels { border-top: 1px solid var(--line); padding-top: 12px; margin-top: 4px; }
.lr-levels-head {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 10px;
  font-size: 12px; font-weight: 700; letter-spacing: 0.04em;
  text-transform: uppercase; color: var(--fg-3);
}
.lr-run, .lr-save {
  margin-top: 10px;
  background: var(--accent);
  color: var(--accent-text);
  border: none;
  border-radius: 9px;
  padding: 9px 16px;
  font-size: 13px;
  font-weight: 700;
  cursor: pointer;
}
.lr-run:disabled { opacity: 0.6; cursor: default; }
.lr-save { background: var(--bg-3); color: var(--fg-2); border: 1px solid var(--line); }
.lr-err {
  margin-top: 12px;
  padding: 10px 12px;
  border-radius: 8px;
  background: color-mix(in oklch, var(--down) 12%, transparent);
  border: 1px solid var(--down);
  color: var(--down);
  font-size: 13px;
}
.lr-results { margin-top: 14px; }
.lr-iv { font-family: var(--font-mono); font-size: 11px; color: var(--fg-3); margin-bottom: 8px; }
.lr-table { width: 100%; border-collapse: collapse; font-size: 13px; }
.lr-table th {
  text-align: left;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--fg-3);
  padding: 6px 10px;
  border-bottom: 1px solid var(--line);
  white-space: nowrap;
}
.lr-table td {
  padding: 7px 10px;
  border-bottom: 1px solid var(--line);
  white-space: nowrap;
}
.lr-table td.num, .lr-table th { font-variant-numeric: tabular-nums; }
.lr-table td.num {
  text-align: right;
  font-family: var(--font-mono);
}
.lr-table th:not(:first-child) { text-align: right; }
.lr-row-hot { background: color-mix(in oklch, var(--up) 10%, transparent); }
.lr-fade { margin-top: 16px; border-top: 1px solid var(--line); padding-top: 14px; }
.lr-fade-cap { display: flex; flex-direction: column; gap: 2px; margin-bottom: 12px; }
.lr-fade-cap-num { font-family: var(--font-mono); font-size: 30px; font-weight: 700; color: var(--up); font-variant-numeric: tabular-nums; }
.lr-fade-cap-lbl { font-size: 12px; color: var(--fg-3); }
.lr-fade-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(110px, 1fr)); gap: 10px; margin-bottom: 12px; }
.lr-fade-grid div { display: flex; flex-direction: column; gap: 3px; }
.lr-fade-grid span { font-size: 10px; font-weight: 700; letter-spacing: 0.05em; text-transform: uppercase; color: var(--fg-3); }
.lr-fade-grid b { font-family: var(--font-mono); font-size: 16px; font-variant-numeric: tabular-nums; }
.lr-fade-grid b.down { color: var(--down); }
.num.down { color: var(--down); }
.lr-trigger {
  margin: 10px 0;
  padding: 9px 12px;
  border-radius: 8px;
  background: color-mix(in oklch, var(--up) 12%, transparent);
  border: 1px solid var(--up);
  color: var(--up);
  font-size: 12px;
  font-family: var(--font-mono);
}
.lr-sweep { margin-top: 10px; }
@media (max-width: 720px) {
  .lr-stage { grid-template-columns: repeat(2, 1fr); }
  .lr-table { font-size: 12px; }
  .lr-table th, .lr-table td { padding: 6px 7px; }
}

/* Level Reprice v1.29: mode bar + gap comparison block */
.lr-modebar { display: inline-flex; gap: 2px; background: var(--bg-3); border: 1px solid var(--line); border-radius: 9px; padding: 2px; margin-bottom: 14px; }
.lr-modebar button {
  background: transparent; border: none; color: var(--fg-3);
  font-size: 13px; font-weight: 600; padding: 7px 16px; border-radius: 7px; cursor: pointer;
}
.lr-modebar button.active { background: var(--accent); color: var(--accent-text); }
.lr-compare { display: flex; align-items: stretch; gap: 10px; margin: 12px 0; }
.lr-cmp { flex: 1; display: flex; flex-direction: column; gap: 4px; padding: 12px 14px; border-radius: 10px; border: 1px solid var(--line); background: var(--bg-3); }
.lr-cmp span { font-size: 10px; font-weight: 700; letter-spacing: 0.05em; text-transform: uppercase; color: var(--fg-3); }
.lr-cmp b { font-family: var(--font-mono); font-size: 24px; font-variant-numeric: tabular-nums; }
.lr-cmp-old b { color: var(--down); }
.lr-cmp-true { border-color: var(--up); }
.lr-cmp-true b { color: var(--up); }
.lr-cmp-arrow { align-self: center; color: var(--fg-3); font-size: 18px; }
@media (max-width: 520px) { .lr-compare { flex-direction: column; } .lr-cmp-arrow { transform: rotate(90deg); } }

/* Level Reprice v1.30: chain-driven readouts + select */
.lr-field select {
  background: var(--bg-3); border: 1px solid var(--line); border-radius: 8px;
  padding: 7px 9px; color: var(--fg); font-family: var(--font-mono);
  font-size: 13px; font-variant-numeric: tabular-nums; cursor: pointer;
}
.lr-field select:focus { outline: none; border-color: var(--accent); }
.lr-readout {
  display: flex; align-items: center; min-height: 34px;
  padding: 7px 9px; border-radius: 8px;
  background: color-mix(in oklch, var(--bg-3) 60%, transparent);
  border: 1px dashed var(--line); color: var(--fg-2);
  font-size: 13px;
}
.lr-readout.num { font-family: var(--font-mono); font-variant-numeric: tabular-nums; }

/* Dividend yield line (v1.30): compact, under the company name */
.sb-divyield {
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 600;
  color: var(--up);
  letter-spacing: 0.02em;
  margin-top: 2px;
}

/* Level Reprice v1.35: pre-fill source hints under fields */
.lr-hint {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--fg-3);
  margin-top: 3px;
  letter-spacing: 0.02em;
}

/* ════════════════════════════════════════════════════════════════════
   POLISH LAYER (v1.41)
   App-wide visual refinement, layered on top of the base component
   styles above (so nothing is rewritten). All token-driven, so it
   adapts to light/dark and the density/typeface settings.
   ════════════════════════════════════════════════════════════════════ */

/* — Consistent, springy micro-interactions on interactive surfaces — */
.card, .metric, .strike-card, .strat-card,
.tab-btn, .seg button {
  transition:
    background-color 0.18s ease,
    border-color 0.18s ease,
    box-shadow 0.2s ease,
    color 0.16s ease,
    transform 0.2s cubic-bezier(0.2, 0.8, 0.2, 1);
}

/* — Cards: a faint top sheen for depth + a refined hover state — */
.card {
  background: linear-gradient(180deg, var(--sheen), transparent 160px), var(--bg-2);
}
.card:hover {
  border-color: var(--line-2);
  box-shadow: var(--shadow-hover);
}

/* — Metric tiles: glassy top, lift + accent edge on hover — */
.metric {
  background: linear-gradient(180deg, var(--sheen), transparent), var(--bg);
}
.metric:hover {
  transform: translateY(-2px);
  border-color: color-mix(in oklch, var(--accent) 45%, var(--line));
  box-shadow: var(--shadow-hover);
}

/* — Strike & strategy cards: gentle lift — */
.strike-card:hover { transform: translateY(-2px); box-shadow: var(--shadow-hover); }
.strat-card:hover {
  transform: translateY(-2px);
  border-color: var(--line-2);
  box-shadow: var(--shadow-hover);
}

/* — Nav tabs: hover wash + a soft glow under the active pill — */
.tab-btn:hover:not(.active) {
  background: color-mix(in oklch, var(--fg) 7%, transparent);
  color: var(--fg);
}
.tab-btn.active {
  box-shadow:
    0 2px 12px -2px color-mix(in oklch, var(--accent) 55%, transparent),
    inset 0 1px 0 rgba(255, 255, 255, 0.18);
}

/* — Segmented controls: crisper active chip — */
.seg button:hover:not(.active) { color: var(--fg-2); }
.seg button.active {
  box-shadow:
    0 1px 2px rgba(0, 0, 0, 0.18),
    inset 0 1px 0 rgba(255, 255, 255, 0.07);
}

/* — App-wide finishing touches — */
::selection {
  background: color-mix(in oklch, var(--accent) 32%, transparent);
}
:where(a, button, input, select, textarea, [tabindex]):focus-visible {
  outline: 2px solid color-mix(in oklch, var(--accent) 70%, transparent);
  outline-offset: 2px;
}

/* Quieter, consistent scrollbars everywhere (matches the sidebar) */
* { scrollbar-width: thin; scrollbar-color: var(--line-2) transparent; }
::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb {
  background: var(--line-2);
  border-radius: 6px;
  border: 2px solid transparent;
  background-clip: content-box;
}
::-webkit-scrollbar-thumb:hover { background: var(--fg-3); }

@media (prefers-reduced-motion: reduce) {
  .card, .metric, .strike-card, .strat-card, .tab-btn, .seg button {
    transition: none;
  }
  .metric:hover, .strike-card:hover, .strat-card:hover { transform: none; }
}
