/* ticker_v2.css — Phase 2.7 design tokens + responsive layout. */

/* Default tokens = dark theme (html.dark is default in base.html). Light-mode
   override below kicks in when the user toggles the theme and <html> loses
   the .dark class. We also re-express common hardcoded rgba() values as
   tokens so light mode has one place to override them. */
:root {
  --bg:#020617; --card:#0f172a; --secondary:#1e293b;
  --border:rgba(30,41,59,0.6);
  --border-soft:rgba(30,41,59,0.3);
  --border-strong:rgba(30,41,59,0.8);
  --header-bg:rgba(2,6,23,0.4);
  /* Deeper-than-card surface — sticky cells, scrollbar track, emphasized panels. */
  --surface-solid:#0b1220;
  /* Alt surface — lighter than page bg, used for inset cards (pt-up-card, legend). */
  --surface-alt:rgba(2,6,23,0.3);
  /* Hover tint over a card surface. */
  --surface-hover:rgba(30,41,59,0.5);
  /* Row hover / subtle accent band. */
  --accent-soft:rgba(56,189,248,0.06);
  --accent-hover:rgba(56,189,248,0.08);
  /* Solid overlay for sticky nav / tooltips — must remain high-contrast on
     both themes for readability. Intentionally NOT a generic alpha on --bg. */
  --nav-bg:rgba(2,6,23,0.95);
  --tooltip-bg:#0b1220;
  --scrollbar-track:#0b1220;
  --scrollbar-thumb:#1e293b;
  /* Full Fundamentals table shades — zebra, hover, total rows. */
  --table-row-even:#0c1526;
  --table-row-hover:#15243f;
  --table-total-bg:#102039;
  --table-total-label:#122543;
  --table-total-hover:#16284a;
  --table-total-label-hover:#182e55;
  --card-shadow: 0 1px 2px rgba(0,0,0,0.4);
  --radius:14px; --radius-sm:10px;
  --green:#34d399; --blue:#38bdf8; --red:#f87171;
  --amber:#fbbf24; --purple:#a78bfa;
  /* --text-dim bumped from #64748b → #7a8a9e to clear WCAG AA 4.5:1 on --card. */
  --text:#e2e8f0; --text-muted:#94a3b8; --text-dim:#7a8a9e;
  --font:'DM Sans', -apple-system, BlinkMacSystemFont, sans-serif;
  --content-pad-x:24px;
}

/* Light theme — activates when the user toggles away from dark. Accent colors
   (green/blue/red/amber/purple) stay identical — only chrome changes. Contrast
   checked: --text #0f172a on --card #ffffff = 19:1 (AAA). */
html:not(.dark) {
  --bg:#f8fafc;          /* slate-50, matches body bg in base.html */
  --card:#ffffff;
  --secondary:#f1f5f9;   /* slate-100 */
  --border:#e2e8f0;      /* slate-200 */
  --border-soft:rgba(148,163,184,0.25);  /* slate-400 @ 25% */
  --border-strong:rgba(100,116,139,0.45);
  --header-bg:rgba(255,255,255,0.85);
  --surface-solid:#f1f5f9;               /* slate-100 — bg for sticky/header cells */
  --surface-alt:rgba(241,245,249,0.6);   /* slate-100 @ 60% — inset cards */
  --surface-hover:rgba(148,163,184,0.12); /* slate-400 tint on hover */
  --accent-soft:rgba(56,189,248,0.08);
  --accent-hover:rgba(56,189,248,0.14);
  --nav-bg:rgba(255,255,255,0.92);
  --tooltip-bg:#0f172a;                  /* stay dark for contrast pop */
  --scrollbar-track:#f1f5f9;
  --scrollbar-thumb:#cbd5e1;             /* slate-300 */
  /* Full Fundamentals table shades (light). Zebra on slate, hover in sky blue,
     totals in a slight blue tint to distinguish them from regular rows. */
  --table-row-even:#f8fafc;              /* slate-50 */
  --table-row-hover:#e0f2fe;             /* sky-100 */
  --table-total-bg:#dbeafe;              /* blue-100 */
  --table-total-label:#bfdbfe;           /* blue-200 */
  --table-total-hover:#bfdbfe;           /* blue-200 */
  --table-total-label-hover:#93c5fd;     /* blue-300 */
  --card-shadow: 0 1px 3px rgba(15,23,42,0.08);
  --text:#0f172a;        /* slate-900 */
  --text-muted:#475569;  /* slate-600 */
  --text-dim:#64748b;    /* slate-500 — 4.6:1 on white = AA pass */
}

@media (max-width: 640px) {
  :root { --content-pad-x:12px; }  /* was 5px — gave card edges zero breathing room */
}

/* Global focus ring — keyboard users need to see where they are. Overrides the
   browser default outline so it's consistent across interactive elements. */
.ticker-page :focus-visible {
  outline: 2px solid var(--blue);
  outline-offset: 2px;
  border-radius: 4px;
}
/* Screen-reader-only utility — exposed to AT without taking visual space. */
.ticker-page .sr-only {
  position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0;
}

/* Section heading layout: title on the left, optional controls on the right. */
.section-head {
  display: flex; align-items: baseline; justify-content: space-between;
  gap: 12px; flex-wrap: wrap; margin-bottom: 12px;
}
.section-head .s-title { margin: 0; }

.ticker-page {
  background: var(--bg); color: var(--text);
  font-family: var(--font); font-size: 14px; line-height: 1.5;
  max-width: 1600px; margin: 0 auto;
  border-left: 1px solid var(--border); border-right: 1px solid var(--border);
  min-height: 100vh;
}
.ticker-page * { box-sizing: border-box; }
.ticker-page .th {
  padding: 18px var(--content-pad-x); border-bottom: 1px solid var(--border);
  background: var(--header-bg);
}
.th-inner {
  max-width: 1600px; margin: 0 auto;
  display: flex; align-items: center; gap: 14px;
}
.th-ico {
  width: 42px; height: 42px; border-radius: 10px;
  background: linear-gradient(135deg,#76b900,#5a8a00);
  display: flex; align-items: center; justify-content: center;
  font-size: 20px; font-weight: 700; color: #000;
  flex-shrink: 0;
}
.th-body { flex: 1; min-width: 0; }
.ticker-page .th h1 {
  font-size: 22px; font-weight: 700; margin: 0;
}
.ticker-page .th h1 small {
  font-size: 13px; font-weight: 400; color: var(--text-dim); margin-left: 10px;
}
.th-meta { font-size: 11px; color: var(--text-dim); margin-top: 2px; }
.th-right { display: flex; flex-direction: column; align-items: flex-end; gap: 2px; }
.th-asof {
  font-size: 10px; color: var(--text-dim); line-height: 1.35;
  text-align: right; font-variant-numeric: tabular-nums;
}
@media (max-width: 640px) {
  /* Mobile: wrap the header — ticker name takes full row, price+dates flow
     on a second row as a single line with a visual separator. */
  .th-inner { flex-wrap: wrap; }
  .th-right {
    width: 100%; flex-direction: row; align-items: baseline;
    justify-content: space-between; gap: 8px;
    padding-top: 8px; margin-top: 4px;
    border-top: 1px solid var(--border);
  }
  .th-asof { font-size: 10px; line-height: 1.3; text-align: right; }
  .th-asof div + div { margin-top: 1px; }
}
.ticker-main section {
  margin: 24px 0; padding: 0 var(--content-pad-x);
}
/* content-visibility: auto removed — it implies paint/layout containment, which
   makes sections the containing block for position:fixed descendants. That
   broke the global fixed-bottom tooltip (clipped inside section bounds) and
   misplaced absolute markers in the price-target gauge and 52-week range bar.
   See docs/tasks/tech-debt.md Initiative 6 for the LCP workaround we want
   instead (Redis cache + streamed HTML rather than content-visibility). */
.s-title {
  font-size: 15px; font-weight: 600;
  display: flex; align-items: baseline; gap: 10px; margin-bottom: 14px;
}
.s-sub { font-size: 11px; color: var(--text-dim); font-weight: 400; }
@media (max-width: 640px) {
  .s-title { font-size: 13px; }
  .s-sub   { font-size: 10px; }
}

/* Snapshot */
.snap-strip {
  display: grid; grid-template-columns: repeat(5, 1fr); gap: 10px;
  background: var(--card); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 16px;
}
@media (max-width: 960px) { .snap-strip { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 640px) { .snap-strip { grid-template-columns: 1fr 1fr; padding: 12px; } }
.snap-item { padding-right: 10px; border-right: 1px solid var(--border); }
.snap-item:last-child { border-right: none; }
.snap-l { font-size: 9px; color: var(--text-dim); text-transform: uppercase; letter-spacing: .3px; }
.snap-v { font-size: 16px; font-weight: 700; font-variant-numeric: tabular-nums; line-height: 1.2; margin-top: 3px; }
.snap-range { font-size: 13px; }
.range-bar {
  height: 6px; background: linear-gradient(to right,#f87171,#fbbf24,#34d399);
  border-radius: 3px; position: relative; margin-top: 4px;
}
.range-dot {
  position: absolute; top: -2px; width: 10px; height: 10px; border-radius: 50%;
  background: var(--text); border: 2px solid var(--bg); transform: translateX(-50%);
}

/* Performance grid */
.perf-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
@media (max-width: 640px) { .perf-grid { grid-template-columns: 1fr; } }
.perf-card {
  background: var(--card); border: 1px solid var(--border);
  border-radius: var(--radius-sm); padding: 14px;
}
.perf-head { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 10px; }
.perf-title { font-size: 12px; font-weight: 600; color: var(--text-muted); }
.perf-val { font-size: 16px; font-weight: 700; font-variant-numeric: tabular-nums; }
.perf-chart { height: 80px; }
.perf-chart svg { width: 100%; height: 80px; display: block; }
.perf-range { display: flex; justify-content: space-between; font-size: 9px; color: var(--text-dim); margin-top: 4px; }

/* Dense ratio tables */
.ratio-table {
  background: var(--card); border: 1px solid var(--border);
  border-radius: var(--radius-sm); overflow: hidden;
}
.rt-head, .rt-row {
  display: grid;
  grid-template-columns: minmax(160px, 2fr) 100px 1fr 1fr 80px;
  gap: 10px; padding: 10px 14px; align-items: center;
}
@media (max-width: 640px) {
  .rt-head, .rt-row {
    /* Drop the sparkline column on mobile — it repeats below in Full Fundamentals
       anyway. Frees up space for company/industry numbers which otherwise clip. */
    grid-template-columns: minmax(120px, 1.5fr) 1fr 1fr 44px;
    padding: 8px 10px; gap: 6px; font-size: 11px;
  }
  .rt-head .rt-spark-col, .rt-row .rt-spark { display: none; }
}
.rt-head {
  border-bottom: 1px solid var(--border);
  font-size: 10px; color: var(--text-dim); text-transform: uppercase; letter-spacing: .3px;
}
.rt-row { border-bottom: 1px solid var(--border-soft); }
.rt-row:last-child { border-bottom: none; }
.rt-row:hover { background: var(--accent-soft); }
.rt-metric { display: flex; align-items: center; gap: 6px; }
.rt-info {
  background: none; border: none; color: var(--text-dim); font-size: 11px;
  cursor: help; padding: 0 4px;
}
.rt-company { font-weight: 700; font-variant-numeric: tabular-nums; }
.rt-company.vd-overvalued { color: var(--red); }
.rt-company.vd-fair_value { color: var(--text); }
.rt-company.vd-undervalued { color: var(--green); }
.rt-company.vd-top_tier { color: var(--green); }
.rt-company.vd-weak { color: var(--red); }
.rt-company.vd-low_yield { color: var(--amber); }
.rt-industry { color: var(--text-muted); font-variant-numeric: tabular-nums; }
.rt-actions { display: flex; gap: 4px; justify-content: flex-end; }
.rt-actions button {
  background: transparent; border: none; font-size: 13px; padding: 4px;
  color: var(--text-dim); cursor: pointer;
  min-width: 28px; min-height: 28px; border-radius: 6px;
}
@media (max-width: 640px) {
  .rt-actions button { min-width: 34px; min-height: 34px; }
}
.rt-actions button:hover { background: var(--accent-hover); color: var(--blue); }
.pin-btn.pinned, .mm-btn.selected { color: var(--blue); background: var(--accent-hover); }

.empty { color: var(--text-muted); padding: 40px var(--content-pad-x); font-style: italic; }

/* Hero price badge */
.th-price { color: var(--green); font-weight: 700; font-variant-numeric: tabular-nums; font-size: 18px; }

/* Sparkline SVG fits its column, never overflows into the next one.
   Applies to both ratio-table .rt-spark and Full Fundamentals .ff-trend. */
.rt-spark, .ff-trend { overflow: hidden; }
.rt-spark svg, .ff-trend svg { display: block; max-width: 100%; height: auto; }

/* Badges strip */
.badges-strip {
  display: flex; gap: 8px; padding: 8px var(--content-pad-x);
  overflow-x: auto; scrollbar-width: none;
  border-bottom: 1px solid var(--border);
  background: var(--surface-solid);
}
.badges-strip::-webkit-scrollbar { display: none; }
.badges-strip.empty { display: none; }
.sb {
  flex-shrink: 0; min-width: 120px;
  background: var(--card); border: 1px solid var(--border);
  border-radius: var(--radius-sm); padding: 8px 28px 8px 12px;
  text-decoration: none; color: var(--text); position: relative;
}
.sb-l { font-size: 9px; color: var(--text-dim); text-transform: uppercase; letter-spacing: .3px; }
.sb-v { font-size: 15px; font-weight: 700; font-variant-numeric: tabular-nums; margin-top: 2px; }
.sb-c { font-size: 9px; color: var(--text-dim); margin-top: 1px; }
.sb-x {
  position: absolute; top: 4px; right: 6px; width: 18px; height: 18px;
  background: var(--secondary); color: var(--text-dim); border: none;
  border-radius: 50%; font-size: 10px; cursor: pointer; opacity: 0.5;
}
.sb-x:hover { opacity: 1; color: var(--red); }

/* Metric cards (dividends/earnings summary) */
.mg { display: grid; gap: 10px; margin-bottom: 10px; }
.mg-3 { grid-template-columns: repeat(3, 1fr); }
.mg-4 { grid-template-columns: repeat(4, 1fr); }
@media (max-width: 640px) { .mg-3, .mg-4 { grid-template-columns: 1fr 1fr; } }
.mc { background: var(--card); border: 1px solid var(--border); border-radius: var(--radius-sm); padding: 14px; }
.mc-l { font-size: 10px; color: var(--text-dim); text-transform: uppercase; letter-spacing: .3px; }
.mc-v { font-size: 20px; font-weight: 700; font-variant-numeric: tabular-nums; line-height: 1.1; margin-top: 3px; }

/* Generic tables */
.tbl { width: 100%; border-collapse: collapse; margin-top: 10px;
       background: var(--card); border: 1px solid var(--border); border-radius: var(--radius-sm); overflow: hidden; }
.tbl th { font-size: 10px; color: var(--text-dim); text-transform: uppercase;
          padding: 10px; text-align: left; border-bottom: 1px solid var(--border); }
.tbl td { padding: 9px 10px; font-size: 12px; border-bottom: 1px solid var(--border-soft);
          font-variant-numeric: tabular-nums; }
.tbl tr:last-child td { border-bottom: none; }
.tbl .beat { color: var(--green); }
.tbl .miss { color: var(--red); }
.subject-row { background: var(--accent-soft); }
@media (max-width: 640px) {
  .tbl-peers, .tbl-stmt { display: block; overflow-x: auto; white-space: nowrap; }
}

/* Consensus */
/* ── Analyst Consensus — verdict + bar + price gauge ─────────────────── */
.cns-verdict { background: var(--card); border: 1px solid var(--border);
               border-radius: var(--radius); padding: 18px 20px; margin-bottom: 16px; }
.cns-verdict-head { display: flex; align-items: baseline; justify-content: space-between;
                    gap: 12px; margin-bottom: 14px; flex-wrap: wrap; }
.cns-verdict-label { font-size: 22px; font-weight: 700; letter-spacing: .5px; }
.cns-verdict-label.cv-strong_buy { color: #10b981; }
.cns-verdict-label.cv-buy        { color: #34d399; }
.cns-verdict-label.cv-hold       { color: #fbbf24; }
.cns-verdict-label.cv-sell       { color: #fb923c; }
.cns-verdict-label.cv-strong_sell { color: #f87171; }
.cns-verdict-count { font-size: 12px; color: var(--text-muted); }
.cns-verdict-count b { color: var(--text); font-weight: 700; font-size: 14px; }

.cns-bar { display: flex; height: 12px; border-radius: 6px; overflow: hidden;
           background: var(--surface-hover); margin-bottom: 14px; }
.cns-seg { height: 100%; min-width: 2px; transition: flex .2s ease; }

.cns-legend { list-style: none; padding: 0; margin: 0;
              display: grid; grid-template-columns: repeat(5, 1fr); gap: 8px;
              font-size: 11px; color: var(--text-muted); }
.cns-legend li { display: flex; flex-direction: column; align-items: flex-start;
                 gap: 2px; padding: 8px 10px; background: var(--surface-alt);
                 border-radius: var(--radius-sm); border: 1px solid transparent; }
.cns-legend .dot { display: inline-block; width: 10px; height: 10px; border-radius: 2px; }
.cns-legend b { color: var(--text); font-size: 13px; font-weight: 700;
                font-variant-numeric: tabular-nums; }
.cns-pct { color: var(--text-dim); font-size: 10px; font-variant-numeric: tabular-nums; }
@media (max-width: 640px) {
  .cns-legend { grid-template-columns: 1fr 1fr; }
  .cns-verdict-label { font-size: 18px; }
  .cns-verdict { padding: 14px; }
}

/* ── Price target gauge ──────────────────────────────────────────────── */
.cns-target { background: var(--card); border: 1px solid var(--border);
              border-radius: var(--radius); padding: 18px 20px; }
.cns-target-head { display: flex; align-items: baseline; justify-content: space-between;
                   gap: 12px; margin-bottom: 24px; flex-wrap: wrap; }
.cns-target-title { font-size: 14px; font-weight: 600; margin: 0; color: var(--text); }
.cns-target-sub { font-size: 11px; color: var(--text-dim);
                  font-variant-numeric: tabular-nums; }

.pt-gauge { position: relative; padding: 40px 0 60px; margin: 0 12px; }
.pt-track {
  position: relative; height: 6px; border-radius: 3px;
  background: linear-gradient(to right, #f87171 0%, #fb923c 25%,
                              #fbbf24 50%, #34d399 75%, #10b981 100%);
}
.pt-mark {
  position: absolute; top: -38px; transform: translateX(-50%);
  display: flex; flex-direction: column; align-items: center; gap: 2px;
  font-size: 10px; color: var(--text-muted); white-space: nowrap; pointer-events: none;
}
.pt-mark::after {
  content: ''; position: absolute; top: 36px; width: 2px; height: 14px;
  background: var(--text-muted); border-radius: 1px;
}
.pt-mark-lbl { font-size: 9px; text-transform: uppercase; color: var(--text-dim);
               letter-spacing: .3px; }
.pt-mark-val { font-weight: 700; color: var(--text);
               font-variant-numeric: tabular-nums; }
.pt-mark-median::after { background: var(--blue); }
.pt-mark-median .pt-mark-val { color: var(--blue); }

.pt-current {
  position: absolute; top: 36px; transform: translateX(-50%);
  display: flex; flex-direction: column; align-items: center; gap: 2px;
  font-size: 10px; white-space: nowrap; pointer-events: none;
}
.pt-current::before {
  content: ''; position: absolute; top: -14px; width: 3px; height: 22px;
  background: var(--text); border-radius: 1px;
  box-shadow: 0 0 0 2px var(--card);
}
.pt-current-lbl { font-size: 9px; color: var(--text-muted);
                  text-transform: uppercase; letter-spacing: .3px; margin-top: 16px; }
.pt-current-val { font-weight: 700; color: var(--text);
                  font-variant-numeric: tabular-nums; }

.pt-ends { display: flex; justify-content: space-between;
           margin-top: 10px; padding: 0 2px; }
.pt-end { display: flex; flex-direction: column; gap: 2px;
          font-variant-numeric: tabular-nums; }
.pt-end-low { align-items: flex-start; }
.pt-end-high { align-items: flex-end; }
.pt-end-lbl { font-size: 9px; text-transform: uppercase; color: var(--text-dim);
              letter-spacing: .3px; }
.pt-end-val { font-weight: 700; font-size: 12px; color: var(--text-muted); }

.pt-upside { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-top: 20px; }
.pt-up-card { background: var(--surface-alt); padding: 12px 14px;
              border-radius: var(--radius-sm); display: flex; flex-direction: column;
              gap: 4px; }
.pt-up-lbl { font-size: 10px; color: var(--text-dim); text-transform: uppercase;
             letter-spacing: .3px; }
.pt-up-val { font-size: 20px; font-weight: 700; color: var(--text);
             font-variant-numeric: tabular-nums; }
.pt-up-upside { font-size: 12px; font-weight: 600;
                font-variant-numeric: tabular-nums; }
.pt-up-upside.up { color: var(--green); }
.pt-up-upside.down { color: var(--red); }

@media (max-width: 640px) {
  .cns-target { padding: 14px; }
  .pt-gauge { padding: 56px 0 48px; margin: 0 8px; }
  .pt-mark { top: -54px; }
  .pt-mark::after { top: 52px; height: 18px; }
  .pt-upside { grid-template-columns: 1fr; }
  .pt-up-val { font-size: 18px; }
}

/* Consensus rating dots — still used by new .cns-verdict and .cns-legend blocks. */
.cs-sb { background: #10b981; } .cs-b { background: #34d399; }
.cs-h { background: #fbbf24; } .cs-s { background: #fb923c; } .cs-ss { background: #f87171; }

/* ── AI Talk Show ─────────────────────────────────────────────────────── */
.ai-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-bottom: 16px; }
@media (max-width: 860px) { .ai-grid { grid-template-columns: 1fr; } }
.ai-card {
  background: var(--card); border: 1px solid var(--border);
  border-left: 3px solid var(--border);
  border-radius: var(--radius-sm); padding: 14px 16px;
}
.ai-card-grok    { border-left-color: #a78bfa; }
.ai-card-claude  { border-left-color: #f0a869; }
.ai-card-gemini  { border-left-color: #38bdf8; }
.ai-card-chatgpt { border-left-color: #34d399; }

.ai-head {
  display: flex; align-items: center; gap: 10px; margin-bottom: 12px;
  padding-bottom: 10px; border-bottom: 1px solid var(--border);
}
.ai-name { font-weight: 700; text-transform: capitalize; color: var(--text); font-size: 13px; }
.ai-verdict {
  font-size: 9px; font-weight: 700; padding: 3px 7px; border-radius: 4px;
  text-transform: uppercase; letter-spacing: .5px;
}
.ai-v-buy  { background: rgba(52,211,153,0.15); color: var(--green); }
.ai-v-hold { background: rgba(251,191,36,0.15); color: var(--amber); }
.ai-v-sell { background: rgba(248,113,113,0.15); color: var(--red); }
.ai-conf { font-size: 10px; color: var(--text-dim); margin-left: auto; font-variant-numeric: tabular-nums; }
.ai-mind-change {
  font-size: 10px; color: var(--blue); margin-left: auto;
  background: rgba(56,189,248,0.1); padding: 2px 7px; border-radius: 4px;
}

/* Round labels */
.ai-round-title {
  font-size: 12px; font-weight: 600; color: var(--text-muted);
  text-transform: uppercase; letter-spacing: 0.5px;
  margin: 20px 0 10px; padding-bottom: 6px;
  border-bottom: 1px solid var(--border);
}

/* Opening takes — bullish/bearish blocks */
.ai-side { padding: 8px 0; }
.ai-side + .ai-side { margin-top: 6px; border-top: 1px solid var(--border-soft); padding-top: 12px; }
.ai-side-lbl {
  font-size: 10px; font-weight: 700; letter-spacing: .3px;
  text-transform: uppercase; margin-bottom: 4px;
}
.ai-side-bull .ai-side-lbl { color: var(--green); }
.ai-side-bear .ai-side-lbl { color: var(--red); }
.ai-text {
  font-size: 12px; line-height: 1.6; color: var(--text-muted);
  margin: 0;
}

/* ── Chat dialog (rounds 2 & 3) ───────────────────────────────────────── */
.ai-chat {
  display: flex; flex-direction: column; gap: 14px;
  padding: 8px 0;
  margin-bottom: 18px;
}
.chat-msg {
  display: flex; gap: 10px; align-items: flex-start;
  max-width: 80%;
}
@media (max-width: 640px) { .chat-msg { max-width: 94%; } }
.chat-msg.chat-left { align-self: flex-start; }
.chat-msg.chat-right { align-self: flex-end; flex-direction: row-reverse; }

.chat-avatar {
  flex-shrink: 0;
  width: 32px; height: 32px; border-radius: 50%;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 13px; font-weight: 700; color: #000;
  font-family: var(--font);
}
.chat-ava-grok    { background: linear-gradient(135deg, #c4b5fd, #a78bfa); }
.chat-ava-claude  { background: linear-gradient(135deg, #fbbf9f, #f0a869); }
.chat-ava-gemini  { background: linear-gradient(135deg, #7dd3fc, #38bdf8); }
.chat-ava-chatgpt { background: linear-gradient(135deg, #6ee7b7, #34d399); }

.chat-bubble {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 10px 14px;
  min-width: 0;
  position: relative;
}
.chat-msg.chat-left .chat-bubble  { border-top-left-radius: 4px; }
.chat-msg.chat-right .chat-bubble { border-top-right-radius: 4px; }
.chat-grok    .chat-bubble { border-color: rgba(167,139,250,0.35); }
.chat-claude  .chat-bubble { border-color: rgba(240,168,105,0.35); }
.chat-gemini  .chat-bubble { border-color: rgba(56,189,248,0.35); }
.chat-chatgpt .chat-bubble { border-color: rgba(52,211,153,0.35); }

.chat-head {
  display: flex; align-items: center; gap: 8px; margin-bottom: 6px;
}
.chat-name {
  font-size: 11px; font-weight: 700; color: var(--text);
  text-transform: capitalize;
}
.chat-grok    .chat-name { color: #c4b5fd; }
.chat-claude  .chat-name { color: #fbbf9f; }
.chat-gemini  .chat-name { color: #7dd3fc; }
.chat-chatgpt .chat-name { color: #6ee7b7; }

.chat-text {
  font-size: 12.5px; line-height: 1.6; color: var(--text-muted);
  margin: 0;
}

/* ── Forecast table ───────────────────────────────────────────────────── */
.fc-wrap {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow: hidden;
}
.fc-table {
  width: 100%; border-collapse: collapse;
  font-size: 12px;
}
.fc-table thead th {
  text-align: left;
  padding: 10px 14px;
  font-size: 10px; font-weight: 600; color: var(--text-dim);
  text-transform: uppercase; letter-spacing: .4px;
  border-bottom: 1px solid var(--border);
  background: var(--surface-solid);
}
.fc-table thead th.fc-num { text-align: right; width: 110px; }
.fc-row td {
  padding: 12px 14px;
  border-bottom: 1px solid var(--border-soft);
  vertical-align: top;
}
.fc-row:last-child td { border-bottom: none; }
.fc-row:hover td { background: var(--accent-soft); }
.fc-model {
  width: 140px; white-space: nowrap;
  display: flex !important; align-items: center; gap: 10px;
  font-weight: 600; color: var(--text);
}
.fc-model .chat-avatar { width: 24px; height: 24px; font-size: 11px; }
.fc-num {
  text-align: right;
  font-family: ui-monospace, 'SF Mono', 'Menlo', monospace;
  font-weight: 700; font-size: 14px;
  color: var(--text);
  font-variant-numeric: tabular-nums;
}
.fc-reasoning {
  color: var(--text-muted);
  font-size: 12px; line-height: 1.55;
}
.fc-row.fc-grok    .fc-model { color: #c4b5fd; }
.fc-row.fc-claude  .fc-model { color: #fbbf9f; }
.fc-row.fc-gemini  .fc-model { color: #7dd3fc; }
.fc-row.fc-chatgpt .fc-model { color: #6ee7b7; }

/* ── Forecast mobile cards (Task D, Phase 2.7) ───────────────────────── */
/* Plan: docs/tasks/phase-2.7-mobile-forecast-cards-plan.md
 * On <=640px viewport 4-col table fails (Reasoning gets ~15px, vertical text).
 * Solution: flex stacked card per row, inline span labels (cross-platform a11y),
 * RTL-aware via logical properties.
 */

/* Inline label hidden on desktop — thead provides column headers */
.fc-num-label { display: none; }

@media (max-width: 640px) {
  /* Defensive fallback: якщо CSS partial-load, table/tbody як block дають
     vertical stack без flex (replaces native table-layout). Real-money
     platform: краще degrade graceful ніж broken table-row inside flex. */
  .fc-table, .fc-table tbody { display: block; }

  /* Hide thead — labels rendered inline через .fc-num-label span */
  .fc-table thead { display: none; }

  /* Row → flex card. flex-wrap дозволяє model + 2 nums + reasoning stack */
  .fc-row {
    display: flex;
    flex-wrap: wrap;
    padding: 14px 16px;
    border-bottom: 1px solid var(--border-soft);
  }
  .fc-row:last-child { border-bottom: none; }
  /* Override desktop hover: на touch :hover stick'аеться після tap */
  .fc-row:hover td { background: transparent; }
  .fc-row td {
    flex: 0 0 100%;
    padding: 0;
    border: none;
  }

  /* Model name + avatar — повний рядок зверху. flex збережений з !important */
  .fc-row .fc-model {
    width: auto;
    margin: 0 0 10px 0;
    font-size: 13px;
  }

  /* 3M / 6M Target — 50/50 layout via flex-basis (avoid inline-block whitespace) */
  .fc-row .fc-num {
    flex: 0 0 50%;
    box-sizing: border-box;
    text-align: start;          /* RTL-aware */
    padding-inline-end: 8px;
    padding-inline-start: 0;
    margin-bottom: 10px;
    font-size: 14px;
    /* Defensive — BRK.A-tier prices не horizontal-overflow */
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  /* Inline label виглядає як thead column header */
  .fc-num-label {
    display: block;
    font-family: ui-sans-serif, system-ui, sans-serif;
    font-size: 10px; font-weight: 600;
    color: var(--text-dim);
    text-transform: uppercase;
    letter-spacing: .4px;
    margin-bottom: 2px;
  }

  /* Reasoning — full row, plain block з overflow-wrap для довгих text */
  .fc-row .fc-reasoning {
    margin-top: 4px;
    font-size: 12px;
    line-height: 1.55;
    overflow-wrap: break-word;
  }
}

/* Panel Summary — prominent consensus block */
.ai-summary {
  margin-bottom: 18px;
  padding: 16px 20px;
  background: linear-gradient(135deg, var(--accent-soft), rgba(167,139,250,0.04));
  border: 1px solid rgba(56,189,248,0.2);
  border-radius: var(--radius);
}
.ai-summary-head {
  display: flex; align-items: center; gap: 12px; margin-bottom: 10px;
}
.ai-summary-lbl {
  font-size: 10px; font-weight: 700; color: var(--blue);
  text-transform: uppercase; letter-spacing: .6px;
}
.ai-conf-big {
  font-size: 11px; color: var(--text-dim); margin-left: auto;
  font-variant-numeric: tabular-nums;
}
.ai-summary-text {
  font-size: 13px; line-height: 1.7; color: var(--text); margin: 0;
}

/* Expandable */
details.exp { margin-top: 8px; }
details.exp > summary {
  list-style: none; cursor: pointer; padding: 10px 14px;
  background: var(--header-bg); border: 1px solid var(--border);
  border-radius: var(--radius-sm); font-weight: 500;
}
details.exp[open] > summary { background: var(--accent-soft); border-color: rgba(56,189,248,0.2); }

/* News + Signals */
.news-list, .sig-list { list-style: none; padding: 0; margin-top: 8px;
                        background: var(--card); border: 1px solid var(--border);
                        border-radius: var(--radius-sm); }
.news-item, .sig-item { padding: 10px 14px; border-bottom: 1px solid var(--border-soft); }
.news-item:last-child, .sig-item:last-child { border: none; }
.news-item a, .sig-item a { color: var(--text); text-decoration: none; font-size: 13px; display: block; }
.news-item a:hover, .sig-item a:hover { color: var(--blue); }
.news-meta { font-size: 10px; color: var(--text-dim); margin-top: 3px; display: block; }
.sig-item a { display: flex; gap: 12px; align-items: center; font-size: 12px; }
.sig-type { font-weight: 700; }
.sig-date { margin-left: auto; color: var(--text-dim); }

/* My Metrics — reuses .ff-section / .ff-table layout; only empty state is unique. */
.mm-empty {
  text-align: center; padding: 48px 20px;
  background: var(--card); border: 1px dashed var(--border); border-radius: var(--radius);
}
.mm-empty-ico { font-size: 44px; margin-bottom: 14px; }
.mm-empty-msg { color: var(--text-muted); max-width: 420px; margin: 0 auto 10px; line-height: 1.5; }
.mm-empty-hint { color: var(--text-dim); font-size: 11px; max-width: 420px; margin: 0 auto; line-height: 1.5; }

/* Toast */
.toast {
  position: fixed; bottom: 80px; left: 50%;
  transform: translateX(-50%) translateY(20px);
  opacity: 0; transition: all .3s;
  background: var(--card); border: 1px solid var(--blue);
  padding: 10px 20px; border-radius: 24px;
  font-size: 13px; font-weight: 500; z-index: 300; pointer-events: none;
}
.toast.show { opacity: 1; transform: translateX(-50%) translateY(0); }

/* Sections anchor scroll */
.ticker-main section { scroll-margin-top: 80px; }

/* ── Price chart ───────────────────────────────────────────────────────── */
/* Phase 2.7 Stage 3: investing.com-style layout — top toolbar (chart type +
   indicators dropdown), central canvas, bottom toolbar (timeframes +
   granularity). KLineChart generates 10+ <canvas> elements inside
   #priceChart — no CSS rules target them directly (KLC internal layout).
   Секція-рівень візуальні атрибути (background/border) навмисно НЕ
   застосовуємо на .pc-section — хай chart-блок виглядає як усі інші
   секції (title + padding-x від .ticker-main section). */
.pc-section .s-title { margin-bottom: 10px; }

.pc-toolbar {
  display: flex; flex-wrap: wrap; gap: 10px 14px;
  padding: 8px 0; align-items: center;
  border-bottom: 1px solid var(--border-soft);
}
/* Indicators dropdown притискається вправо — TradingView-style (головні
   controls зліва, dropdown з advanced настройками справа). */
.pc-toolbar .pc-dropdown { margin-left: auto; }
.pc-group {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 2px; border-radius: 8px;
  background: var(--bg-2, rgba(30,41,59,0.35));
  border: 1px solid var(--border-soft);
}
.pc-sep {
  width: 1px; align-self: stretch; margin: 4px 6px;
  background: var(--border-soft);
}
.pc-btn {
  background: transparent; border: 0; color: var(--text-muted);
  font: 500 12px/1 var(--font-ui, inherit); letter-spacing: .01em;
  padding: 6px 10px; border-radius: 6px; cursor: pointer;
  transition: color .12s, background .12s;
  min-height: 28px; display: inline-flex; align-items: center; gap: 4px;
}
/* [hidden] attribute override — `.pc-btn` display:inline-flex має вищу
   специфіку за UA-rule `[hidden]{display:none}`, тому без explicit override
   приховані кнопки (gran filter на MAX+Y) залишалися видимими → юзер міг
   їх клікнути і передати KLC indicator що не підтримується на цьому gran. */
.pc-btn[hidden] { display: none !important; }
.pc-btn:hover { color: var(--text); background: rgba(56,189,248,.08); }
.pc-btn:focus-visible { outline: 2px solid var(--blue, #38bdf8); outline-offset: 2px; }
.pc-btn.active {
  background: var(--blue, #38bdf8); color: #0b1220;
  font-weight: 600;
}
.pc-btn.active:hover { background: var(--blue, #38bdf8); }
/* Busy state — R3 race guard via aria-busy на section. JS additionally
   has _chartBusy flag у handlers as belt-and-suspenders. */
.pc-section[aria-busy="true"] .pc-btn { pointer-events: none; opacity: .55; }
.pc-tf-btn, .pc-gr-btn { min-width: 36px; justify-content: center; font-variant-numeric: tabular-nums; }
.pc-gr-btn { min-width: 28px; padding: 6px 8px; }
.pc-gr-btn[hidden] { display: none; }

/* Indicators dropdown — show active count + caret; panel розкривається
   абсолютно позиційована під кнопкою. */
.pc-dropdown { position: relative; display: inline-flex; }
.pc-dropdown-btn { gap: 6px; padding: 6px 10px; background: var(--bg-2, rgba(30,41,59,.35));
                   border: 1px solid var(--border-soft); }
.pc-badge {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 18px; height: 16px; padding: 0 5px;
  background: var(--blue, #38bdf8); color: #0b1220;
  border-radius: 8px; font-size: 10px; font-weight: 700;
}
.pc-caret { font-size: 9px; color: var(--text-muted); transition: transform .18s; }
.pc-dropdown-btn[aria-expanded="true"] .pc-caret { transform: rotate(180deg); }

.pc-dropdown-panel {
  position: absolute; top: calc(100% + 6px); left: 0; z-index: 30;
  min-width: 320px; max-width: 480px;
  background: var(--card); border: 1px solid var(--border);
  border-radius: 10px; padding: 10px 12px; box-shadow: 0 10px 30px rgba(0,0,0,.35);
  display: flex; flex-direction: column; gap: 10px;
}
/* HTML `hidden` attribute ставить display:none за spec, але наш display:flex
   на .pc-dropdown-panel перекривав. Явний rule повертає expected behavior. */
.pc-dropdown-panel[hidden] { display: none; }
.pc-ind-group { display: flex; flex-wrap: wrap; gap: 4px; }
.pc-ind-heading {
  flex: 1 0 100%; margin: 0 0 2px; font-size: 10px; font-weight: 600;
  color: var(--text-muted); text-transform: uppercase; letter-spacing: .08em;
}
.pc-ind-group .pc-ind-btn {
  padding: 6px 10px; min-width: 46px; background: var(--bg-2, rgba(30,41,59,.3));
  border: 1px solid var(--border-soft);
}
.pc-ind-group .pc-ind-btn:hover { border-color: var(--blue, #38bdf8); }
.pc-ind-group .pc-ind-btn.active { background: var(--blue, #38bdf8); border-color: var(--blue, #38bdf8); }

/* Inline ⚙ cog для per-indicator configuration (Stage 8). Tap target 24×24
   на desktop, 32×32 на mobile — WCAG 2.5.5 (44 ideal, 24 мін для inline).
   Hidden у configure-unfriendly indicators через .pc-ind-btn[data-configurable="0"]. */
.pc-ind-btn { position: relative; }
.pc-ind-label { display: inline-block; }
.pc-ind-cog {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-left: 6px;
  width: 22px;
  height: 22px;
  font-size: 13px;
  line-height: 1;
  border-radius: 4px;
  background: rgba(148, 163, 184, .12);
  color: var(--text-muted);
  opacity: 0.75;
  cursor: pointer;
  transition: opacity .12s, transform .12s, background .12s;
  user-select: none;
}
.pc-ind-btn:hover .pc-ind-cog,
.pc-ind-btn:focus-within .pc-ind-cog,
.pc-ind-cog:focus-visible { opacity: 1; }
.pc-ind-cog:hover {
  background: rgba(148, 163, 184, .24);
  color: var(--text);
  transform: rotate(30deg);
}
/* Non-configurable indicators — cumulative/null gran → cog прихований */
.pc-ind-btn[data-configurable="0"] .pc-ind-cog { display: none; }
@media (max-width: 640px) {
  .pc-ind-cog {
    width: 30px;
    height: 30px;
    font-size: 15px;
    margin-left: 8px;
    opacity: 1;  /* mobile — не ховаємо; touch немає hover */
  }
}

/* Popover для configuring indicator params. Floating absolute positioned;
   JS positions near triggering cog. */
.pc-params-popover {
  position: fixed; z-index: 50;
  min-width: 300px; max-width: 400px;
  background: var(--card); border: 1px solid var(--border);
  border-radius: 10px; padding: 14px 16px;
  box-shadow: 0 12px 36px rgba(0, 0, 0, .4);
  display: flex; flex-direction: column; gap: 10px;
}
.pc-params-popover[hidden] { display: none; }
.pc-params-head {
  display: flex; align-items: center; justify-content: space-between;
  gap: 12px;
}
.pc-params-title {
  font-size: 14px; font-weight: 600; color: var(--text);
}
.pc-params-close {
  background: transparent; border: 0; color: var(--text-muted);
  font-size: 20px; line-height: 1; padding: 0 4px; cursor: pointer;
  border-radius: 4px;
}
.pc-params-close:hover { color: var(--text); }
.pc-params-body { display: flex; flex-direction: column; gap: 6px; }
.pc-params-label {
  font-size: 11px; font-weight: 600; color: var(--text-muted);
  text-transform: uppercase; letter-spacing: .05em;
}
.pc-params-input {
  background: var(--bg-2, rgba(30,41,59,.5));
  border: 1px solid var(--border);
  border-radius: 6px; padding: 8px 10px;
  color: var(--text); font-size: 13px;
  font-variant-numeric: tabular-nums;
  font-family: var(--font-mono, ui-monospace, monospace);
}
.pc-params-input:focus {
  outline: none; border-color: var(--blue, #38bdf8);
  box-shadow: 0 0 0 2px rgba(56,189,248,.2);
}
.pc-params-hint {
  font-size: 11px; color: var(--text-muted); margin: 0;
  line-height: 1.4;
  display: flex; flex-direction: column; gap: 2px;
}
.pc-params-hint-line:first-child {
  color: var(--text); font-weight: 500;
  font-family: ui-monospace, SFMono-Regular, Consolas, monospace;
}
.pc-params-hint code {
  background: var(--bg-2, rgba(30,41,59,.4));
  padding: 1px 4px; border-radius: 3px;
  font-size: 10.5px;
}
.pc-params-actions {
  display: flex; gap: 8px; justify-content: flex-end;
  margin-top: 4px;
}
.pc-params-actions .pc-btn {
  padding: 7px 14px; font-weight: 500;
  border: 1px solid var(--border);
  background: transparent;
}
.pc-params-reset { color: var(--text-muted); }
.pc-params-reset:hover { color: var(--text); border-color: var(--text-muted); }
.pc-params-save.active {
  background: var(--blue, #38bdf8); color: #0b1220;
  border-color: var(--blue, #38bdf8);
}
.pc-params-save.active:hover { background: var(--blue, #38bdf8); }

/* Body: horizontal flex — drawing sidebar ліворуч, chart canvas остачу */
.pc-body { padding: 8px 10px; display: flex; gap: 6px; align-items: stretch; }
/* .pc-main height set dynamically from JS (_updateChartHeight) щоб candles
   + N sub-panes індикаторів не сплющувалися при додаванні. Base 360px для
   candles тільки, +110px за кожен pane indicator. flex:1 бере remainder
   after pc-drawings (~44px). */
.pc-main { height: 460px; flex: 1 1 auto; min-height: 320px; min-width: 0; }

/* Drawing tools sidebar (Stage 5) */
.pc-drawings {
  display: flex; flex-direction: column; gap: 3px;
  padding: 4px 2px;
  background: var(--bg-2, rgba(30,41,59,.35));
  border: 1px solid var(--border-soft);
  border-radius: 8px;
  flex: 0 0 auto;
}
.pc-draw-btn {
  width: 34px; height: 34px;
  display: inline-flex; align-items: center; justify-content: center;
  background: transparent; border: 0; color: var(--text-muted);
  border-radius: 6px; cursor: pointer;
  transition: color .12s, background .12s, transform .1s;
}
.pc-draw-btn:hover { color: var(--text); background: rgba(56,189,248,.1); }
.pc-draw-btn:focus-visible { outline: 2px solid var(--blue, #38bdf8); outline-offset: 1px; }
.pc-draw-btn.active {
  background: var(--blue, #38bdf8); color: #0b1220;
}
.pc-draw-btn.pc-draw-erase:hover { color: var(--red, #f87171); background: rgba(248,113,113,.1); }
.pc-draw-sep { height: 1px; background: var(--border-soft); margin: 4px 4px; }

@media (max-width: 640px) {
  /* На mobile — drawing tools приховано (занадто вузький viewport щоб
     одночасно показати sidebar + readable chart). Alt: move drawings
     у bottom sheet — Stage 6 polish candidate. */
  .pc-drawings { display: none; }
}

/* Stage 7 FR15: indicator legend під chart.
   Формат: "Active on months granularity:" + list з active indicators,
   їх params, label і period interpretation. */
.pc-legend {
  padding: 10px 14px;
  font-size: 11px;
  line-height: 1.5;
  color: var(--text-muted);
  border-top: 1px solid var(--border-soft);
  background: rgba(15, 23, 42, 0.3);
}
.pc-legend[hidden] { display: none; }
.pc-legend .pc-legend-title {
  font-size: 10px; font-weight: 600;
  text-transform: uppercase; letter-spacing: .08em;
  color: var(--text);
  margin-bottom: 4px;
}
.pc-legend .pc-legend-title b {
  color: var(--blue, #38bdf8); font-weight: 600;
}
.pc-legend .pc-legend-list {
  list-style: none; margin: 0; padding: 0;
  display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 2px 14px;
}
.pc-legend .pc-leg-name {
  color: var(--text); font-weight: 600;
  font-variant-numeric: tabular-nums;
}
.pc-legend .pc-leg-label { color: var(--text-muted); }
.pc-legend .pc-leg-note { color: var(--text-muted); opacity: .8; font-size: 10.5px; }

/* Event markers sub-legend (dividends, earnings). Chips з color swatches. */
.pc-legend-subnote { font-weight: 400; color: var(--text-muted); }
.pc-legend-subnote b { color: var(--blue, #38bdf8); }
.pc-legend-divider { height: 1px; background: var(--border-soft); margin: 8px 0 6px; }
.pc-legend-events {
  list-style: none; margin: 0; padding: 0;
  display: flex; flex-wrap: wrap; gap: 4px 14px;
}
.pc-legend-events li {
  display: inline-flex; align-items: center; gap: 6px;
  color: var(--text-muted); font-size: 11px;
}
.pc-legend-events b { color: var(--text); font-weight: 600; font-variant-numeric: tabular-nums; }
.pc-ev-dot {
  display: inline-block; width: 12px; height: 2px;
  border-top: 1px dashed currentColor;
  /* background overridden inline per event type */
  border-top-color: transparent;
  box-shadow: 0 0 0 1px rgba(255,255,255,.05);
  border-radius: 0;
}
/* Actually simpler — just solid rect with alpha color matching chart markers. */
.pc-ev-dot { width: 14px; height: 2px; border: 0; box-shadow: none; }

@media (max-width: 640px) {
  .pc-toolbar { padding: 8px 8px; gap: 6px 8px; }
  .pc-btn { padding: 6px 8px; font-size: 11px; min-height: 32px; }
  .pc-tf-btn, .pc-gr-btn { min-width: 32px; }
  .pc-main { min-height: 260px; }
  .pc-body { padding: 4px 4px; }
  .pc-dropdown-panel { min-width: 260px; left: -40px; }
}

/* ── Full Fundamentals — light, spacious, tabular ──────────────────────── */
.ff-section .s-title { gap: 14px; align-items: center; }

.ff-group {
  margin-bottom: 12px;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow: hidden;
  transition: border-color .15s;
}
.ff-group[open] { border-color: rgba(56,189,248,0.25); }

.ff-summary {
  padding: 14px 18px;
  cursor: pointer;
  list-style: none;
  display: flex;
  align-items: center;
  gap: 10px;
  transition: background .12s;
  user-select: none;
}
.ff-summary:hover { background: var(--accent-soft); }
.ff-summary::-webkit-details-marker { display: none; }
.ff-summary::before {
  content: '›';
  color: var(--text-dim);
  font-size: 18px; font-weight: 700;
  transition: transform .2s;
  display: inline-block; line-height: 1;
}
.ff-group[open] > .ff-summary::before {
  transform: rotate(90deg); color: var(--blue);
}
.ff-group[open] > .ff-summary {
  border-bottom: 1px solid var(--border);
}
.ff-name {
  font-size: 14px; font-weight: 600; color: var(--text);
  letter-spacing: -0.01em;
}
.ff-count {
  margin-left: auto;
  font-size: 11px; color: var(--text-dim); font-weight: 500;
  background: var(--secondary); padding: 3px 8px; border-radius: 10px;
  min-width: 24px; text-align: center;
}

.ff-wrap {
  overflow-x: auto;
  overflow-y: visible;
  max-width: 100%;
  /* min-width:0 on parent (.ff-group) ensures this can shrink below
     content width and scroll horizontally instead of stretching the page. */
  scrollbar-width: thin;
  scrollbar-color: var(--scrollbar-thumb) var(--scrollbar-track);
}
.ff-group { min-width: 0; }

/* Custom scrollbar tuned to the dark theme */
.ff-wrap::-webkit-scrollbar {
  height: 10px;
  background: transparent;
}
.ff-wrap::-webkit-scrollbar-track {
  background: var(--surface-solid);
  border-top: 1px solid rgba(30,41,59,0.6);
  border-radius: 0;
}
.ff-wrap::-webkit-scrollbar-thumb {
  background: var(--scrollbar-thumb);
  border-radius: 10px;
  border: 2px solid var(--scrollbar-track);   /* creates inset padding effect */
  transition: background .15s;
}
.ff-wrap::-webkit-scrollbar-thumb:hover {
  background: #38bdf8;
}
.ff-wrap::-webkit-scrollbar-button { display: none; width: 0; height: 0; }
.ff-wrap::-webkit-scrollbar-corner { background: var(--surface-solid); }

.ff-table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  font-size: 12px;
  min-width: 720px;
}

/* Headers */
.ff-table thead th {
  padding: 11px 14px;
  text-align: right;
  font-size: 10px; font-weight: 600;
  color: var(--text-dim);
  text-transform: uppercase; letter-spacing: .6px;
  background: var(--surface-solid);                 /* SOLID — no alpha */
  border-bottom: 1px solid var(--border);
  position: sticky; top: 0; z-index: 2;
  white-space: nowrap;
}
.ff-table thead th:first-child,
.ff-table thead th.ff-label {
  text-align: left;
  position: sticky; left: 0; z-index: 6;  /* above row bodies */
  background: var(--surface-solid);                   /* SOLID header-left corner */
  min-width: 240px; padding-left: 14px;
  box-shadow: 2px 0 0 var(--border-strong);
}
.ff-table thead th.ff-trend { text-align: center; width: 80px; }

/* Body cells */
.ff-table tbody td {
  padding: 9px 14px;
  text-align: right;
  font-variant-numeric: tabular-nums;
  font-family: ui-monospace, 'SF Mono', 'Menlo', 'Consolas', monospace;
  font-size: 11.5px;
  color: var(--text);
  white-space: nowrap;
  border-bottom: 1px solid var(--border-soft);
  transition: background .08s;
}
.ff-table tbody tr:last-child td { border-bottom: none; }
.ff-table tbody tr:nth-child(even) td { background: var(--table-row-even); }       /* SOLID zebra */
.ff-table tbody tr:nth-child(odd) td  { background: var(--card); }       /* SOLID base (card) */
.ff-table tbody tr:hover td { background: var(--table-row-hover); color: var(--text); }    /* SOLID hover */

/* Label column — sticky left (SOLID bg so scrolling cells don't bleed through) */
.ff-table td.ff-label {
  text-align: left;
  font-family: var(--font);
  font-weight: 500;
  color: var(--text-muted);
  position: sticky; left: 0; z-index: 3;
  padding: 6px 14px 6px 8px;
  min-width: 240px;
  box-shadow: 2px 0 0 var(--border-strong);   /* visual divider + blocks bleed-through */
  display: flex; align-items: center; gap: 8px;
  line-height: 1.3;
}
/* explicit solid bg by row parity — overrides .ff-table tbody td bg above */
.ff-table tbody tr:nth-child(odd)  td.ff-label { background: var(--card); }
.ff-table tbody tr:nth-child(even) td.ff-label { background: var(--table-row-even); }
.ff-table tbody tr:hover td.ff-label { background: var(--table-row-hover); color: var(--text); }
.ff-label-text { flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; }

/* Inline mm-btn inside label cell */
.ff-table td.ff-label .mm-btn {
  flex-shrink: 0;
  width: 22px; height: 22px;
  border-radius: 5px;
  background: transparent; border: 1px solid transparent;
  color: var(--text-dim); font-size: 13px; font-weight: 600;
  cursor: pointer; opacity: 0.35;
  display: inline-flex; align-items: center; justify-content: center;
  transition: all .12s;
  line-height: 1;
}
.ff-table tr:hover td.ff-label .mm-btn { opacity: 0.7; }
.ff-table td.ff-label .mm-btn:hover {
  opacity: 1 !important; background: rgba(56,189,248,0.12);
  color: var(--blue); border-color: rgba(56,189,248,0.3);
}
.ff-table td.ff-label .mm-btn.selected {
  opacity: 1 !important; color: var(--blue);
  background: rgba(56,189,248,0.15); border-color: rgba(56,189,248,0.4);
}

/* Trend (sparkline) column */
.ff-table td.ff-trend {
  text-align: center; width: 80px;
  padding: 6px 8px;
}
.ff-table td.ff-trend svg { display: inline-block; vertical-align: middle; opacity: .7; }
.ff-table tbody tr:hover td.ff-trend svg { opacity: 1; }

/* Compact FF table on mobile — default layout steals >60% width for the label
   column and forces horizontal scroll before any data appears. Shrink label
   min-width, drop the dedicated Trend column (duplicated by ratio-table spark
   elsewhere), tighten padding and fonts. */
@media (max-width: 640px) {
  .ff-table {
    font-size: 10.5px;
    min-width: 0;  /* no forced 720px scroll — grow to fit data */
  }
  .ff-table thead th {
    padding: 7px 6px; font-size: 9px; letter-spacing: .3px;
  }
  .ff-table thead th:first-child,
  .ff-table thead th.ff-label {
    min-width: 130px; padding-left: 8px;
  }
  /* Kill the Trend column on mobile. Sparkline lives in ratio-table above;
     repeating it here eats ~20% width for marginal visual gain. */
  .ff-table thead th.ff-trend,
  .ff-table tbody td.ff-trend { display: none; }

  .ff-table tbody td {
    padding: 5px 6px; font-size: 10px;
  }
  .ff-table td.ff-label {
    min-width: 130px; max-width: 150px;
    padding: 4px 6px 4px 2px;
    gap: 4px;
    line-height: 1.2;
  }
  .ff-label-text {
    font-size: 10.5px; line-height: 1.15;
  }
  .ff-table td.ff-label .mm-btn {
    width: 18px; height: 18px; font-size: 11px; flex-shrink: 0;
  }
  .ff-table td.ff-label .rt-info {
    font-size: 10px; padding: 0 2px; flex-shrink: 0;
  }
}

/* Total / subtotal rows — bolder, top border, SOLID blue-tinted bg */
.ff-table tr.ff-total td {
  font-weight: 700; color: var(--text);
  background: var(--table-total-bg) !important;
  border-top: 1px solid rgba(56,189,248,0.25);
}
.ff-table tr.ff-total td.ff-label {
  color: var(--text); font-weight: 700;
  background: var(--table-total-label) !important;
}
.ff-table tr.ff-total:hover td { background: var(--table-total-hover) !important; }
.ff-table tr.ff-total:hover td.ff-label { background: var(--table-total-label-hover) !important; }

/* Indented sub-item rows */
.ff-table tr.ff-sub .ff-label-text {
  padding-left: 18px; color: var(--text-dim); font-weight: 400;
}
.ff-table tr.ff-sub td {
  color: var(--text-muted);
}

/* Empty cells */
.ff-table td.ff-empty {
  color: var(--text-dim); opacity: 0.35;
  font-family: var(--font);
}

/* Toggle tabs */
.ff-toggle { display: inline-flex; gap: 4px; margin-left: auto; }
.ff-tab {
  background: var(--secondary);
  border: 1px solid var(--border);
  color: var(--text-muted);
  padding: 6px 14px; border-radius: 8px;
  font-size: 12px; font-weight: 500;
  cursor: pointer; font-family: var(--font);
  display: inline-flex; align-items: center; gap: 8px;
  transition: all .12s;
}
.ff-tab:hover { color: var(--text); border-color: rgba(56,189,248,0.3); }
.ff-tab.active {
  background: rgba(56,189,248,0.12);
  color: var(--blue);
  border-color: rgba(56,189,248,0.4);
}
.ff-cnt {
  font-size: 10px; color: var(--text-dim);
  background: var(--header-bg); padding: 1px 6px; border-radius: 6px;
  min-width: 18px; text-align: center;
}
.ff-tab.active .ff-cnt { color: var(--blue); background: var(--accent-hover); }

/* Sub-nav for FF groups (desktop sidebar) */
.ni-sub {
  padding-left: 36px !important;
  font-size: 11px !important;
  color: var(--text-dim) !important;
}
.ni-sub.active { color: var(--blue) !important; }

/* ── CSS tooltip (data-tip attr on any element) ───────────────────────── */
[data-tip] { position: relative; }

/* Singleton tooltip — JS positions #ui-tip near the clicked/hovered trigger,
   clamped to the viewport. Lives on <body>, so ancestor `overflow: hidden`,
   sticky columns and table containment never clip it. Position computed as
   fixed-with-pixels so we bypass the CSS locale-decimal-comma trap that
   broke `left: 52.1%` under uk/de/es locales. */
#ui-tip {
  position: fixed;
  background: var(--surface-solid); color: var(--text);
  border: 1px solid rgba(56,189,248,0.35);
  border-radius: 8px;
  padding: 10px 14px;
  font-size: 12px; font-family: var(--font); font-weight: 400;
  line-height: 1.5; letter-spacing: 0;
  white-space: normal;
  max-width: min(340px, calc(100vw - 24px));
  z-index: 9999; pointer-events: none;
  box-shadow: 0 10px 28px rgba(0,0,0,0.5);
  opacity: 0;
  transform: translateY(4px);
  transition: opacity .12s ease-out, transform .12s ease-out;
}
#ui-tip.ui-tip--open {
  opacity: 1;
  transform: translateY(0);
}
/* Tiny arrow — JS sets data-side=top/bottom based on where the tooltip fits. */
#ui-tip::before {
  content: '';
  position: absolute; left: var(--ui-tip-arrow-x, 50%);
  width: 10px; height: 10px;
  background: var(--surface-solid);
  border: 1px solid rgba(56,189,248,0.35);
  transform: translateX(-50%) rotate(45deg);
  pointer-events: none;
}
#ui-tip[data-side="top"]::before    { bottom: -6px; border-top: 0; border-left: 0; }
#ui-tip[data-side="bottom"]::before { top:    -6px; border-bottom: 0; border-right: 0; }

@media (max-width: 640px) {
  #ui-tip {
    font-size: 13px;
    padding: 12px 14px;
    max-width: calc(100vw - 24px);
  }
}
.rt-info {
  background: none; border: none; color: var(--text-dim);
  font-size: 11px; cursor: help; padding: 0 4px;
  font-family: var(--font);
}
.rt-info:hover { color: var(--blue); }

/* (ff-action right sticky column removed — mm-btn now lives inside ff-label cell) */

/* ── Layout: sidebar (desktop) + main, anchor bar (mobile) ─────────────── */
.ticker-layout {
  display: grid;
  grid-template-columns: 180px minmax(0, 1fr);
  gap: 0;
  max-width: 1600px;
  margin: 0 auto;
}
.ticker-main { min-width: 0; }
.ticker-main section { min-width: 0; }
@media (max-width: 960px) {
  .ticker-layout { grid-template-columns: 1fr; }
}

.page-nav {
  position: sticky;
  top: 8px;
  align-self: start;
  max-height: calc(100vh - 16px);
  overflow-y: auto;
  padding: 12px 0;
  border-right: 1px solid var(--border);
  /* Modern standard (Firefox, Chromium 121+). Legacy ::-webkit-scrollbar
     rules below serve older Safari and pre-121 Chrome. Both must be kept
     in sync when the design tokens change. */
  scrollbar-width: thin;
  scrollbar-color: var(--border-strong) transparent;
}
.page-nav::-webkit-scrollbar { width: 6px; background: transparent; }
.page-nav::-webkit-scrollbar-track { background: transparent; }
.page-nav::-webkit-scrollbar-thumb {
  background: var(--border-strong);
  border-radius: 3px;
}
.page-nav::-webkit-scrollbar-thumb:hover { background: var(--text-dim); }
.nav-lbl {
  font-size: 9px; color: var(--text-dim);
  text-transform: uppercase; letter-spacing: .5px;
  padding: 14px 14px 4px;
}
.ni {
  display: flex; align-items: center; gap: 8px;
  padding: 8px 14px;
  color: var(--text-muted); font-size: 12px; font-weight: 500;
  text-decoration: none; border-left: 2px solid transparent;
  transition: all .12s;
}
.ni:hover { color: var(--text); background: var(--accent-soft); }
.ni.active {
  color: var(--blue);
  background: rgba(56,189,248,0.07);
  border-left-color: var(--blue);
}
.ni-ico { font-size: 13px; width: 18px; text-align: center; }

/* Mobile — convert sidebar to horizontal scroll anchor bar */
@media (max-width: 960px) {
  .page-nav {
    position: sticky;
    /* Clear the base.html site header (sticky, h-14 = 56px). Without this, the
       two sticky bars would stack and claim 100px of a 667px iPhone viewport. */
    top: 56px;
    display: flex;
    flex-wrap: nowrap;
    overflow-x: auto;
    overflow-y: hidden;
    max-height: none;
    height: 44px;
    padding: 0 4px;
    border-right: none;
    border-bottom: 1px solid var(--border);
    background: var(--nav-bg);
    backdrop-filter: blur(12px);
    z-index: 70;
  }
  .page-nav::-webkit-scrollbar { display: none; }
  .page-nav { scrollbar-width: none; }
  .nav-lbl { display: none; }
  .ni {
    flex-shrink: 0;
    padding: 0 12px;
    height: 44px;
    border-left: none;
    border-bottom: 2px solid transparent;
    white-space: nowrap;
  }
  .ni.active {
    background: transparent;
    border-left: none;
    border-bottom-color: var(--blue);
  }
  /* Header (56px) + anchor bar (44px) both sticky — need 100px offset so the
     active section lands below both after an anchor click. */
  .ticker-main section { scroll-margin-top: 104px; }
}

/* ── Peers / Statements — frozen first column on mobile ──────────────── */
/* Without this, horizontal scroll hides the ticker column and the user loses
   context about which row's numbers they're reading. */
.tbl-peers th:first-child, .tbl-peers td:first-child,
.tbl-stmt  th:first-child, .tbl-stmt  td:first-child {
  position: sticky; left: 0; background: var(--card);
  box-shadow: 2px 0 4px -2px rgba(0,0,0,.35);
  z-index: 1;
}

/* ── Touch target compliance (Apple HIG 44×44) ───────────────────────── */
@media (max-width: 640px) {
  .sb-x { width: 32px; height: 32px; font-size: 14px; }
}

/* ── Print styles ────────────────────────────────────────────────────── */
@media print {
  .ticker-page { background: white !important; color: black !important;
                 border: none !important; max-width: 100% !important; }
  .ticker-page * { color: black !important; background: white !important; }
  .page-nav, .badges-strip, .rt-actions, .ff-toggle, .mm-btn, .pin-btn,
  .toast, #priceChart, #rsiChart { display: none !important; }
  .ticker-layout { display: block !important; }
  .ticker-main { padding: 0 !important; }
  .ticker-main section { margin: 12px 0 !important; page-break-inside: avoid; }
  .ff-table tr, .tbl tr { page-break-inside: avoid; }
  .ff-group { border: 1px solid #ccc !important; }
  details[open] > summary { background: #eee !important; }
  .chat-bubble { border: 1px solid #ccc !important; }
  a { color: black !important; text-decoration: underline; }
}
