/* Daily Summary hero card */
/* ─── Daily Summary hero card ────────────────────────────────────────────── */
.daily-summary{margin:0 0 14px;padding:18px 20px;border-radius:var(--radius-lg);
  background:var(--bg);border:1px solid var(--border);color:var(--text);
  box-shadow:var(--shadow-sm)}
.daily-summary .ds-top{display:flex;gap:14px;align-items:flex-start;justify-content:space-between;flex-wrap:wrap}
.daily-summary .ds-text{flex:1;min-width:240px}
.daily-summary .ds-headline{font-size:17px;font-weight:600;color:var(--text);line-height:1.4;margin-bottom:8px;letter-spacing:-0.2px}
.daily-summary .ds-drivers{margin:0;padding:0;list-style:none;color:var(--text2);font-size:13px;line-height:1.65}
.daily-summary .ds-drivers li{padding:0 0 0 16px;margin:2px 0;position:relative}
.daily-summary .ds-drivers li::before{content:"";position:absolute;left:0;top:9px;width:4px;height:4px;border-radius:50%;background:var(--text3)}
.daily-summary .ds-tomorrow{margin-top:10px;padding-top:10px;border-top:1px solid var(--border);
  font-size:12px;color:var(--text2);font-weight:500}
.daily-summary .ds-badges{display:flex;gap:5px;flex-wrap:wrap;align-items:flex-start}
.daily-summary .ds-badge{display:inline-flex;align-items:center;padding:3px 9px;border-radius:6px;
  font-size:11px;font-weight:600;letter-spacing:.1px;border:1px solid var(--border);white-space:nowrap;
  background:var(--bg);color:var(--text2)}
.daily-summary .ds-strong-up,.daily-summary .ds-up{color:var(--green);border-color:#d1fae5;background:var(--green-bg)}
.daily-summary .ds-strong-down,.daily-summary .ds-down{color:var(--red);border-color:#fecaca;background:var(--red-bg)}
.daily-summary .ds-flat{color:var(--text2);background:var(--bg2)}
.daily-summary .ds-calm{color:var(--blue);border-color:#bfdbfe;background:var(--blue-bg)}
.daily-summary .ds-neutral{color:var(--text2);background:var(--bg2)}
.daily-summary .ds-fear{color:var(--yellow);border-color:#fde68a;background:var(--yellow-bg)}
.daily-summary .ds-right-col{display:flex;flex-direction:column;align-items:flex-end;gap:8px}
.daily-summary .ds-share{display:inline-flex;align-items:center;gap:5px;
  padding:5px 11px;border-radius:6px;background:var(--bg);border:1px solid var(--border);
  color:var(--text2);font-size:11.5px;font-weight:500;cursor:pointer;
  transition:all .12s;letter-spacing:0}
.daily-summary .ds-share:hover{background:var(--text);color:#fff;border-color:var(--text)}
.daily-summary .ds-share-icon{font-size:12px;font-weight:600}

.ds-share-modal{position:fixed;inset:0;z-index:9998;display:flex;align-items:center;justify-content:center}
.ds-share-backdrop{position:absolute;inset:0;background:rgba(15,23,42,0.7);cursor:pointer}
.ds-share-dialog{position:relative;background:#fff;border-radius:14px;padding:20px 22px;
  max-width:420px;width:90vw;max-height:90vh;overflow-y:auto;box-shadow:0 24px 64px rgba(0,0,0,0.4);
  animation:ds-modal-in .25s cubic-bezier(.18,1.04,.55,1.16)}
@keyframes ds-modal-in{from{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}
.ds-share-title{font-size:15px;font-weight:700;color:var(--text);margin-bottom:12px}
.ds-share-preview{width:100%;border-radius:10px;border:1px solid #e2e8f0;display:block;margin-bottom:14px}
.ds-share-actions{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px}
.ds-share-act{padding:9px 8px;border-radius:8px;text-align:center;font-size:12px;font-weight:600;
  text-decoration:none;color:#fff;transition:transform .1s,opacity .15s}
.ds-share-act:hover{transform:translateY(-1px);opacity:.92}
.ds-act-wa{background:#25d366}
.ds-act-tw{background:#1da1f2}
.ds-act-dl{background:#0f172a}
.ds-share-close{position:absolute;top:8px;right:10px;width:30px;height:30px;border-radius:50%;
  background:transparent;border:0;font-size:22px;cursor:pointer;color:var(--text2);line-height:1}
.ds-share-close:hover{background:#f1f5f9;color:var(--text)}


/* ─── Earnings Ahead card ────────────────────────────────────────────────── */
.earnings-card{margin:0 0 14px;padding:14px 16px;border-radius:var(--radius-lg);
  background:var(--bg);border:1px solid var(--border);box-shadow:var(--shadow-sm)}
.earnings-card .er-head{display:flex;align-items:baseline;gap:10px;margin-bottom:10px;flex-wrap:wrap}
.earnings-card .er-title{font-size:11px;font-weight:600;color:var(--text);letter-spacing:.6px;text-transform:uppercase}
.earnings-card .er-sub{font-size:11.5px;color:var(--text3)}
.earnings-card .er-body{display:flex;flex-direction:column;gap:10px}
.earnings-card .er-bucket{display:flex;align-items:flex-start;gap:10px;flex-wrap:wrap}
.earnings-card .er-bucket-label{font-size:10.5px;font-weight:600;letter-spacing:.3px;
  padding:3px 8px;border-radius:6px;flex-shrink:0;min-width:78px;text-align:center;
  background:var(--bg2);color:var(--text2);border:1px solid var(--border)}
.earnings-card .er-tone-hot{color:var(--red)}
.earnings-card .er-tone-soon{color:var(--text)}
.earnings-card .er-tone-later{color:var(--text2)}
.earnings-card .er-count{display:inline-block;margin-left:4px;font-weight:600;color:var(--text)}
.earnings-card .er-chips{display:flex;gap:6px;flex-wrap:wrap;flex:1;min-width:200px}
.earnings-card .er-chip{display:inline-flex;align-items:center;gap:7px;padding:4px 9px;
  border-radius:var(--radius-sm);background:var(--bg);border:1px solid var(--border);color:var(--text);
  text-decoration:none;font-size:12px;line-height:1.4;max-width:260px;
  transition:border-color .12s,background .12s}
.earnings-card .er-chip:hover{border-color:var(--text3);background:var(--bg2)}
.earnings-card .er-ex{font-size:9.5px;font-weight:700;letter-spacing:.5px;
  padding:1.5px 5px;border-radius:3px;flex-shrink:0;line-height:1.3;
  background:var(--bg3);color:var(--text2)}
.earnings-card .er-ex-nse .er-ex{color:var(--blue)}
.earnings-card .er-ex-bse .er-ex{color:var(--text2)}
.earnings-card .er-name{font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:180px}
.earnings-card .er-date{color:var(--text3);font-size:11px;font-variant-numeric:tabular-nums;flex-shrink:0}
.earnings-card .er-more{font-size:11px;color:var(--text3);align-self:center}
@media (max-width:560px){
  .earnings-card .er-bucket{flex-direction:column;gap:4px}
  .earnings-card .er-bucket-label{min-width:0;align-self:flex-start}
}

/* ─── Market Status Banner ──────────────────────────────────────────────── */
/* Subtle, neutral surface. Status comes from the dot only — no coloured
   background since the rest of the dashboard already conveys urgency. */
.market-banner{display:flex;align-items:center;gap:10px;padding:9px 14px;border-radius:var(--radius-md);
  margin-bottom:14px;font-size:13px;font-weight:500;background:var(--bg2);
  border:1px solid var(--border);color:var(--text2)}
.market-banner .status-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0;background:var(--text3)}
.market-banner.closed .status-dot{background:var(--text3)}
.market-banner.open .status-dot{background:var(--green);animation:pulse-green 1.5s infinite}
.market-banner .status-label{font-weight:600;font-size:12px;letter-spacing:.1px;color:var(--text)}
.market-banner.open .status-label{color:var(--green)}
.market-banner .status-detail{color:var(--text3);font-size:12px;margin-left:auto}
@keyframes pulse-green{0%,100%{opacity:1}50%{opacity:0.55}}

/* ─── Homepage Market Ticker Strip ──────────────────────────────────────── */
.ticker-strip{display:grid;grid-template-columns:repeat(auto-fit,minmax(155px,1fr));gap:10px;margin-bottom:14px}
.ticker-card{border:1px solid var(--border);border-radius:10px;padding:10px 12px;
  cursor:pointer;transition:transform .12s ease,border-color .15s,box-shadow .15s;background:var(--bg);position:relative;overflow:hidden;min-height:78px}
.ticker-card:hover{transform:translateY(-1px);box-shadow:0 2px 12px rgba(0,0,0,.08);border-color:var(--blue)}
.ticker-card.active{border-color:var(--blue);box-shadow:0 0 0 2px rgba(37,99,235,.15)}
.ticker-card .tk-name{font-size:10px;font-weight:700;color:var(--text2);letter-spacing:.6px;
  text-transform:uppercase;margin-bottom:4px}
.ticker-card .tk-price{font-size:18px;font-weight:700;letter-spacing:-0.5px;line-height:1.15;font-variant-numeric:tabular-nums}
.ticker-card .tk-change{font-size:11px;font-weight:600;margin-top:2px;font-variant-numeric:tabular-nums}
.ticker-card .tk-sparkline{position:absolute;bottom:0;right:0;width:60%;height:30px;opacity:0.45;pointer-events:none}
.ticker-card .tk-sparkline canvas{width:100%;height:100%}

/* ─── Sector Rotation Strip ─────────────────────────────────────────────── */
.sector-strip{display:grid;grid-template-columns:repeat(auto-fit,minmax(128px,1fr));gap:8px;margin:0 0 14px}
.sector-card{border:1px solid var(--border);border-radius:8px;padding:8px 10px;background:var(--bg);
  cursor:pointer;transition:transform .12s ease,border-color .15s,box-shadow .15s;position:relative;overflow:hidden;min-height:68px}
.sector-card:hover{transform:translateY(-1px);box-shadow:0 2px 10px rgba(0,0,0,.06);border-color:var(--text3)}
.sector-card .sec-top{display:flex;align-items:baseline;justify-content:space-between;gap:6px;margin-bottom:2px}
.sector-card .sec-label{font-size:10px;font-weight:700;color:var(--text2);letter-spacing:.4px;text-transform:uppercase}
.sector-card .sec-pct{font-size:11px;font-weight:700;font-variant-numeric:tabular-nums}
.sector-card .sec-ltp{font-size:13px;font-weight:700;line-height:1.1;font-variant-numeric:tabular-nums;color:var(--text)}
.sector-card .sec-spark{height:24px;margin-top:4px;opacity:.85}
.sector-card .sec-spark canvas{width:100%;height:100%;display:block}

/* Heat tiers: tinted left border + background blend */
.sector-card.heat-up-0{border-left:3px solid #86efac}
.sector-card.heat-up-1{border-left:3px solid #4ade80;background:linear-gradient(180deg,rgba(22,163,74,.04),transparent 40%)}
.sector-card.heat-up-2{border-left:3px solid #16a34a;background:linear-gradient(180deg,rgba(22,163,74,.08),transparent 50%)}
.sector-card.heat-up-3{border-left:3px solid #15803d;background:linear-gradient(180deg,rgba(22,163,74,.13),transparent 55%)}
.sector-card.heat-down-0{border-left:3px solid #fca5a5}
.sector-card.heat-down-1{border-left:3px solid #f87171;background:linear-gradient(180deg,rgba(220,38,38,.04),transparent 40%)}
.sector-card.heat-down-2{border-left:3px solid #dc2626;background:linear-gradient(180deg,rgba(220,38,38,.08),transparent 50%)}
.sector-card.heat-down-3{border-left:3px solid #b91c1c;background:linear-gradient(180deg,rgba(220,38,38,.13),transparent 55%)}
.sector-card.heat-flat-0,.sector-card.heat-flat-1,.sector-card.heat-flat-2,.sector-card.heat-flat-3{border-left:3px solid var(--border)}
.sector-card.heat-up-0 .sec-pct,.sector-card.heat-up-1 .sec-pct,.sector-card.heat-up-2 .sec-pct,.sector-card.heat-up-3 .sec-pct{color:#15803d}
.sector-card.heat-down-0 .sec-pct,.sector-card.heat-down-1 .sec-pct,.sector-card.heat-down-2 .sec-pct,.sector-card.heat-down-3 .sec-pct{color:#b91c1c}

/* Top Movers */
.movers-scope-bar{display:flex;gap:6px;margin:14px 0 10px;flex-wrap:wrap}
.scope-btn{border:1px solid var(--border);background:var(--bg);color:var(--text2);font-size:11px;
  padding:4px 12px;border-radius:14px;cursor:pointer;font-weight:600;transition:all .15s;white-space:nowrap}
.scope-btn:hover{background:var(--bg2);color:var(--text);border-color:var(--text3)}
.scope-btn.active{background:var(--text);color:var(--bg);border-color:var(--text)}
.movers-wrap{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.movers-card{border:1px solid var(--border);border-radius:10px;background:var(--bg);overflow:hidden}
.movers-head{display:flex;align-items:center;gap:6px;padding:8px 12px;border-bottom:1px solid var(--border)}
.movers-head .movers-icon{font-size:10px;font-weight:700}
.movers-head.gain .movers-icon{color:var(--green)}
.movers-head.loss .movers-icon{color:var(--red)}
.movers-head .movers-label{font-size:11px;font-weight:700;color:var(--text2);text-transform:uppercase;letter-spacing:.4px}
.movers-row{display:flex;align-items:center;padding:5px 12px;font-size:12px;line-height:1}
.movers-row:hover{background:var(--bg2)}
.movers-sym{font-weight:600;color:var(--text)}
.movers-price{color:var(--text2);margin-left:auto;font-variant-numeric:tabular-nums}
.movers-pct{width:58px;text-align:right;font-weight:600;font-variant-numeric:tabular-nums;margin-left:10px}

/* Homepage sections grid */
.home-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:16px}
.home-section{border:1px solid var(--border);border-radius:12px;padding:16px;background:var(--bg)}
.home-section-title{font-size:13px;font-weight:700;color:var(--text2);text-transform:uppercase;
  letter-spacing:.5px;margin-bottom:12px;display:flex;align-items:center;gap:8px}
.home-section-title .icon{width:20px;height:20px;border-radius:6px;display:flex;
  align-items:center;justify-content:center;font-size:11px}

/* Mover rows */
.mover-row{display:flex;align-items:center;gap:10px;padding:6px 0;
  border-bottom:1px solid var(--border);font-size:13px}
.mover-row:last-child{border-bottom:none}
.mover-rank{width:20px;font-size:11px;font-weight:700;color:var(--text2);text-align:center;flex-shrink:0}
.mover-name{font-weight:600;flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mover-pnl{font-weight:700;flex-shrink:0;text-align:right}
.mover-meta{font-size:10px;color:var(--text2);flex-shrink:0;text-align:right;min-width:60px}

/* News Timeline */
.timeline{position:relative;padding-left:18px}
.timeline::before{content:'';position:absolute;left:4px;top:6px;bottom:6px;width:2px;background:var(--border)}
.tl-day{position:relative}
.tl-day .tl-dot{position:absolute;left:-17px;top:9px;width:8px;height:8px;
  border-radius:50%;border:2px solid var(--border);background:var(--bg);z-index:1}
.tl-day.tl-up .tl-dot{border-color:var(--green);background:var(--green-bg)}
.tl-day.tl-down .tl-dot{border-color:var(--red);background:var(--red-bg)}
.tl-day.tl-big .tl-dot{width:10px;height:10px;left:-18px;top:8px}
.tl-day.tl-big.tl-up .tl-dot{background:var(--green);border-color:var(--green)}
.tl-day.tl-big.tl-down .tl-dot{background:var(--red);border-color:var(--red)}
.tl-day.tl-closed .tl-dot{border-color:var(--text3);background:var(--bg2);border-style:dashed;width:6px;height:6px;left:-16px;top:10px}
.tl-day.tl-closed .tl-header{opacity:0.55}
.tl-header{display:flex;align-items:center;gap:6px;padding:3px 6px;border-radius:4px;
  cursor:pointer;transition:background .1s;font-size:11px}
.tl-header:hover{background:var(--bg2)}
.tl-date{font-weight:600;color:var(--text2);min-width:62px;font-size:11px}
.tl-market{display:flex;gap:8px;flex:1}
.tl-idx{display:flex;align-items:center;gap:3px;font-size:11px}
.tl-idx .idx-label{font-weight:600;color:var(--text3);font-size:9px}
.tl-idx .idx-val{font-weight:700;font-size:11px}
.tl-news-count{font-size:9px;color:var(--text3);flex-shrink:0}
.tl-chevron{font-size:8px;color:var(--text3);transition:transform .15s;margin-left:2px}
.tl-day.expanded .tl-chevron{transform:rotate(90deg)}
.tl-news{padding:2px 0 4px 4px;display:none}
.tl-day.expanded .tl-news{display:block}
.tl-headline{display:flex;gap:5px;padding:2px 0;align-items:flex-start;font-size:11px}
.tl-score{flex-shrink:0;min-width:24px;text-align:center;padding:0 4px;
  border-radius:3px;font-size:9px;font-weight:700;line-height:18px}
.tl-headline-text{flex:1;line-height:1.35;color:var(--text2)}
.tl-headline-link{color:var(--text2);text-decoration:none;transition:color .1s}
.tl-headline-link:hover{color:var(--blue)}
.tl-ctx{display:inline-block;font-size:8px;padding:0 3px;border-radius:2px;
  background:var(--blue-bg);color:var(--blue);font-weight:600;margin-left:3px;
  text-transform:uppercase;vertical-align:middle}
.tl-day.tl-big .tl-header{background:var(--bg2);border-radius:4px}
.tl-day.tl-big .tl-date{color:var(--text)}
.tl-event{font-size:10px;font-weight:600;padding:1px 6px;border-radius:3px;margin-left:4px;white-space:nowrap}
.tl-event.up{background:var(--green-bg);color:var(--green)}
.tl-event.down{background:var(--red-bg);color:var(--red)}
.tl-ohlc{display:flex;gap:8px;font-size:10px;color:var(--text2);padding:2px 0 3px;border-bottom:1px solid var(--bg2);flex-wrap:wrap}
.tl-ohlc b{font-weight:600;color:var(--text)}

/* Timeline v2 */
.tl-status-chip{display:inline-flex;align-items:center;gap:3px;font-size:9px;font-weight:700;padding:1px 6px;border-radius:3px;text-transform:uppercase;letter-spacing:.3px}
.tl-status-chip.live{background:#16a34a20;color:#16a34a}
.tl-status-chip.live::before{content:'';width:5px;height:5px;border-radius:50%;background:#16a34a;animation:pulse 1.5s infinite}
.tl-status-chip.pre-open{background:#f59e0b20;color:#d97706}
.tl-status-chip.holiday{background:#ec489920;color:#be185d}
.tl-status-chip.weekend{background:var(--bg2);color:var(--text3)}
.tl-status-chip.forecast{background:linear-gradient(135deg,#6366f1 0%,#8b5cf6 100%);color:#fff}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}

.tl-nextday{display:inline-flex;align-items:center;gap:3px;font-size:9.5px;padding:1px 5px;border-radius:3px;margin-left:6px;white-space:nowrap}
.tl-nextday.up{background:#16a34a15;color:#16a34a}
.tl-nextday.down{background:#dc262615;color:#dc2626}
.tl-nextday.flat{background:var(--bg2);color:var(--text2)}
.tl-nextday-arr{font-size:8px}

/* Forecast / Predicted-vs-Actual */
.tl-forecast-row{border:1px solid #c7d2fe !important;background:linear-gradient(135deg,#eef2ff 0%,#faf5ff 100%);border-radius:8px;padding:12px 14px;margin-bottom:14px;position:relative}
.tl-forecast-row .tl-dot{background:#8b5cf6 !important}
.tl-forecast-header{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:6px}
.tl-forecast-title{font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:#6d28d9}
.tl-forecast-date{font-weight:700;font-size:13.5px;color:#1e1b4b}
.tl-forecast-bias{display:inline-flex;align-items:center;gap:4px;font-size:12.5px;font-weight:700;padding:3px 9px;border-radius:5px;font-variant-numeric:tabular-nums}
.tl-forecast-bias.up{background:#dcfce7;color:#166534}
.tl-forecast-bias.down{background:#fee2e2;color:#991b1b}
.tl-forecast-bias.flat{background:#f1f5f9;color:#475569}
.tl-forecast-bias.unknown{background:var(--bg2);color:var(--text3)}
.tl-forecast-conf{font-size:9.5px;font-weight:600;text-transform:uppercase;letter-spacing:.3px;padding:2px 7px;border-radius:3px;margin-left:auto}
.tl-forecast-conf.high{background:#16a34a20;color:#166534}
.tl-forecast-conf.med{background:#f59e0b20;color:#92400e}
.tl-forecast-conf.low{background:var(--bg2);color:var(--text3)}
.tl-forecast-reasons{font-size:10.5px;color:var(--text2);margin-top:4px;line-height:1.5}
.tl-forecast-reasons b{color:#1e1b4b}
.tl-forecast-breakdown{display:flex;gap:8px;flex-wrap:wrap;font-size:10px;margin-top:6px;padding-top:6px;border-top:1px dashed #c7d2fe}
.tl-forecast-breakdown span{display:inline-flex;align-items:center;gap:3px;padding:2px 6px;border-radius:3px;background:#fff;border:1px solid #e0e7ff;color:var(--text2)}
.tl-forecast-breakdown b{font-variant-numeric:tabular-nums}
.tl-forecast-breakdown .pos{color:#16a34a}
.tl-forecast-breakdown .neg{color:#dc2626}

.tl-forecast-gn{display:inline-flex;align-items:center;gap:8px;padding:5px 10px;background:#fff;border:1px solid #e0e7ff;border-radius:6px;font-size:11px;margin:6px 0;box-shadow:0 1px 2px rgba(0,0,0,.04)}
.tl-forecast-gn-tag{font-weight:700;color:#6d28d9;font-size:9.5px;text-transform:uppercase;letter-spacing:.3px}
.tl-forecast-gn-val{font-weight:700;font-variant-numeric:tabular-nums;font-size:13px}
.tl-forecast-gn-val.pos{color:#16a34a}
.tl-forecast-gn-val.neg{color:#dc2626}
.tl-forecast-gn-src{color:var(--text3);font-size:9.5px;font-style:italic;margin-left:auto}
.tl-forecast-gn.stale{background:#fafafa;border-color:#e5e7eb;opacity:.65}
.tl-forecast-gn-val.stale{color:#9ca3af;text-decoration:line-through}
.tl-forecast-override{background:#fef2f2;border:1px solid #fecaca;color:#991b1b;font-size:11px;padding:5px 10px;border-radius:6px;margin:4px 0 6px;line-height:1.4}

/* Realized next-day outcome strip (replaces the old "Next +X%" badge) */
.tl-outcome{display:inline-flex;align-items:center;gap:4px;font-size:9.5px;margin-left:6px;white-space:nowrap;color:var(--text3);cursor:help}
.tl-outcome-label{font-weight:600;text-transform:uppercase;font-size:8.5px;letter-spacing:.3px;opacity:.7}
.tl-outcome-pill{padding:1px 5px;border-radius:3px;font-weight:600;font-variant-numeric:tabular-nums}
.tl-outcome-pill.up{background:#16a34a15;color:#16a34a}
.tl-outcome-pill.down{background:#dc262615;color:#dc2626}
.tl-outcome-pill.flat{background:var(--bg2);color:var(--text2)}

/* Forecast-vs-Actual mini strip (appears on past rows that had a stored model call) */
.tl-pva{display:flex;gap:6px;align-items:center;flex-wrap:wrap;font-size:9.5px;padding:3px 0;color:var(--text3)}
.tl-pva-tag{font-weight:700;text-transform:uppercase;letter-spacing:.3px;font-size:8.5px;color:#6d28d9}
.tl-pva-item{padding:1px 5px;border-radius:3px;background:#fff;border:1px solid var(--bg2);font-variant-numeric:tabular-nums}
.tl-pva-item b{font-weight:700}
.tl-pva-hit{font-weight:700}
.tl-pva-hit.yes{color:#16a34a}
.tl-pva-hit.no{color:#dc2626}

.tl-similar{font-size:9px;color:var(--text3);margin-left:4px;font-weight:500}

.tl-compressed{position:relative;padding:5px 6px 6px;border-radius:4px;font-size:11px;color:var(--text3);
  display:flex;align-items:center;gap:8px;background:var(--bg2);margin:2px 0}
.tl-compressed .tl-dot{position:absolute;left:-15px;top:11px;width:4px;height:4px;border-radius:50%;background:var(--text3)}
.tl-compressed-news{color:var(--blue);cursor:pointer;font-size:10px}
.tl-compressed-news:hover{text-decoration:underline}

.tl-fiidii{display:flex;gap:10px;font-size:10px;padding:3px 0;border-bottom:1px solid var(--bg2);color:var(--text2);flex-wrap:wrap}
.tl-fiidii b{font-variant-numeric:tabular-nums}
.tl-fiidii .pos{color:#16a34a}
.tl-fiidii .neg{color:#dc2626}

.tl-sectors{display:flex;gap:6px;flex-wrap:wrap;font-size:9.5px;padding:4px 0;border-bottom:1px solid var(--bg2)}
.tl-sector-pill{padding:1px 5px;border-radius:3px;background:var(--bg2);font-variant-numeric:tabular-nums}
.tl-sector-pill b{font-weight:600;color:var(--text)}
.tl-sector-pill.pos{color:#16a34a}
.tl-sector-pill.neg{color:#dc2626}

.tl-global{display:flex;gap:10px;font-size:9.5px;padding:3px 0;color:var(--text3);border-bottom:1px solid var(--bg2);flex-wrap:wrap}
.tl-global b{color:var(--text2)}
.tl-global .pos{color:#16a34a}
.tl-global .neg{color:#dc2626}

.tl-banner{background:linear-gradient(135deg,#eff6ff,#f0fdf4);border:1px solid #dbeafe;border-radius:6px;padding:8px 10px;margin-bottom:10px;font-size:11px;color:var(--text);line-height:1.5}
.tl-banner b{color:#0f172a}
.tl-banner .tl-banner-title{font-weight:700;font-size:10px;text-transform:uppercase;letter-spacing:.5px;color:#2563eb;margin-bottom:2px}

.tl-accuracy{display:inline-flex;align-items:center;gap:4px;font-size:10px;color:var(--text3);margin-left:8px}
.tl-accuracy b{color:var(--green);font-weight:700}

.tl-theme-chips{display:flex;gap:4px;flex-wrap:wrap;margin:8px 0 10px}
.tl-theme-chip{font-size:10px;padding:3px 8px;border-radius:10px;background:var(--bg2);color:var(--text2);cursor:pointer;border:1px solid transparent;transition:all .1s}
.tl-theme-chip:hover{background:var(--bg);border-color:var(--border)}
.tl-theme-chip.active{background:#2563eb;color:#fff}
.tl-theme-chip .tl-theme-count{opacity:.7;margin-left:3px;font-size:9px}

.pred-card .pred-detail{font-size:11px;color:var(--text2);flex:1;text-align:right}

/* ─── Intraday play-by-play (collapsible card on dashboard) ───────────── */
/* Lifted from the retired Today tab. Kept compact: closed by default outside
   market hours, open when live so traders see the tape immediately. */
.dash-playbook{background:#fff;border:1px solid var(--border);border-radius:12px;
  box-shadow:0 1px 2px rgba(0,0,0,0.03);margin-bottom:12px;overflow:hidden}
.dash-playbook>summary{list-style:none;cursor:pointer;padding:12px 16px;display:flex;
  align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;
  background:#fff;transition:background .12s}
.dash-playbook>summary::-webkit-details-marker{display:none}
.dash-playbook>summary:hover{background:#f8fafc}
.dash-playbook>summary::after{content:"▾";color:var(--text2);font-size:11px;margin-left:auto;transition:transform .15s}
.dash-playbook[open]>summary::after{transform:rotate(180deg)}
.dash-playbook-title{font-size:12px;font-weight:700;color:var(--text);text-transform:uppercase;letter-spacing:.4px}
.dash-playbook-sub{font-weight:500;color:var(--text2);text-transform:none;letter-spacing:0;font-size:11px}
.dash-playbook-headline{display:inline-flex;align-items:baseline;gap:8px;font-variant-numeric:tabular-nums}
.dash-playbook-num{font-size:14px;font-weight:700;color:var(--text)}
.dash-playbook-pct{font-size:13px;font-weight:700}
.dash-playbook-pct.up{color:#16a34a}
.dash-playbook-pct.down{color:#dc2626}
.dash-playbook-pct.flat{color:var(--text2)}
.dash-playbook-vsopen{font-size:10.5px;color:var(--text2);font-weight:500}
.dash-playbook-body{padding:0 16px 14px}
.dash-playbook-spark{margin:6px 0;background:#f8fafc;border-radius:8px;padding:6px;display:block}
.dash-playbook-bins{margin-top:6px;font-size:12px}
.dash-playbook-bins>summary{cursor:pointer;color:var(--text2);font-weight:600;padding:4px 0}
/* Re-declared from the retired today.css so the bins table works without it */
.t-bins-table-wrap{max-height:280px;overflow-y:auto;margin-top:6px;border:1px solid var(--border);border-radius:8px}
.t-bins-table{width:100%;border-collapse:collapse;font-size:12px}
.t-bins-table th{background:#f8fafc;padding:6px 10px;text-align:left;font-weight:600;color:var(--text2);position:sticky;top:0;font-size:11px;text-transform:uppercase;letter-spacing:.3px}
.t-bins-table td{padding:5px 10px;border-top:1px solid var(--border);font-variant-numeric:tabular-nums}
.t-bins-table .t-time{color:var(--text2);font-weight:500}
.t-bins-table .t-pct.up{color:#16a34a;font-weight:600}
.t-bins-table .t-pct.down{color:#dc2626;font-weight:600}
.t-bins-table .t-pct.flat{color:var(--text2)}


