:root {
  --font-display: "Barlow Condensed", sans-serif;
  --font-ui: "Inter", sans-serif;
  --font-mono: "IBM Plex Mono", monospace;
}
.page-header { margin-bottom: 28px; }
.page-title { font-family: var(--font-display); font-size: 28px; font-weight: 700; color: #f1f5f9; margin-bottom: 4px; }
.page-subtitle { font-size: 12px; color: var(--text-3); }
.page-subtitle span { color: var(--indigo-lt); font-weight: 500; }

/* Value-prop hero — concise positioning above the daily status strip */
/* ── Landing band (hero) ─────────────────────────────────────── */
.hero {
  position: relative;
  margin: 0 0 22px;
  padding: 30px 30px 32px;
  border-radius: 16px;
  background:
    radial-gradient(120% 150% at 88% 0%, rgba(99,102,241,0.16), transparent 58%),
    linear-gradient(180deg, rgba(32,37,56,0.55), rgba(16,19,30,0.30));
  border: 1px solid rgba(255,255,255,0.07);
  overflow: hidden;
}
.hero::after {
  content: ""; position: absolute; left: 0; right: 0; bottom: 0; height: 2px;
  background: linear-gradient(90deg, transparent, rgba(99,102,241,0.55), rgba(34,197,94,0.55), transparent);
}
.hero-grid {
  display: grid;
  grid-template-columns: 1.12fr 0.88fr;
  gap: 40px;
  align-items: center;
}
.hero-copy { min-width: 0; }
.hero-eyebrow {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--indigo-lt);
  margin-bottom: 14px;
}
.hero-title {
  font-family: var(--font-display);
  font-size: 42px;
  font-weight: 800;
  line-height: 1.03;
  letter-spacing: -0.02em;
  color: #f8fafc;
  margin: 0 0 12px;
}
.hero-sub {
  font-size: 15px;
  line-height: 1.55;
  color: var(--text-2);
  max-width: 520px;
  margin: 0 0 16px;
}
.hero-proof {
  font-size: 14.5px;
  line-height: 1.5;
  color: var(--text-2);
  margin: 0 0 20px;
  padding-left: 14px;
  border-left: 3px solid var(--green);
}
.hero-proof .hp-stat { font-family: var(--font-mono); font-weight: 700; color: var(--green); }
.hero-proof .hp-stat.idx { color: var(--indigo-lt); }
.hero-cta { display: flex; flex-wrap: wrap; gap: 12px; align-items: center; }
.hero-btn {
  display: inline-flex; align-items: center; gap: 7px;
  font-family: var(--font-ui);
  font-size: 14px; font-weight: 600;
  padding: 11px 20px;
  border-radius: 10px;
  text-decoration: none;
  transition: transform .12s ease, background .15s ease, border-color .15s ease;
}
.hero-btn-primary { background: var(--indigo-lt, #818cf8); color: #0b0e16; }
.hero-btn-primary:hover { transform: translateY(-1px); }
.hero-btn-secondary { color: var(--text-2); border: 1px solid rgba(255,255,255,0.14); }
.hero-btn-secondary:hover { border-color: rgba(255,255,255,0.30); color: #f1f5f9; }
.hero-arrow { font-weight: 700; }

/* Yesterday recap chip — recency proof under the hero */
.yest-recap { display: inline-flex; align-items: center; gap: 9px; margin: 0 0 18px; padding: 6px 13px;
  border: 1px solid rgba(255,255,255,0.10); border-radius: 999px; font-size: 13px; color: var(--text-2);
  text-decoration: none; transition: border-color 0.15s ease; }
.yest-recap:hover { border-color: rgba(255,255,255,0.24); }
.yest-recap .yr-lbl { text-transform: uppercase; letter-spacing: 0.08em; font-size: 10.5px; font-weight: 700; color: var(--text-3); }
.yest-recap .yr-rec { font-family: var(--font-mono); font-weight: 700; color: #f1f5f9; }
.yest-recap .yr-u { font-family: var(--font-mono); font-weight: 700; }
.yest-recap .yr-u.yr-pos { color: var(--green); }
.yest-recap .yr-u.yr-neg { color: var(--red); }
.yest-recap .yr-u.yr-neu { color: var(--text-2); }
.yest-recap .yr-link { color: var(--text-3); font-size: 12px; }

/* edge-bar motif */
.hero-visual { display: flex; justify-content: center; }
.hero-demo {
  width: 100%; max-width: 320px;
  background: rgba(12,15,24,0.60);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 14px;
  padding: 18px 18px 16px;
  box-shadow: 0 12px 40px rgba(0,0,0,0.30);
}
.hero-demo-top { display: flex; justify-content: space-between; align-items: baseline; gap: 12px; margin-bottom: 14px; }
.hero-demo-label { font-family: var(--font-mono); font-size: 9.5px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--text-4); margin-bottom: 3px; }
.hero-demo-team { font-family: var(--font-display); font-size: 20px; font-weight: 800; color: #f1f5f9; letter-spacing: -0.01em; }
.hero-demo-odds { font-family: var(--font-mono); font-size: 20px; font-weight: 700; color: #f1f5f9; }
.hero-demo .pc-v8-bar { margin: 0; }
.hero-demo-cap { font-size: 11.5px; line-height: 1.5; color: var(--text-4); margin-top: 14px; }

@media (max-width: 820px) {
  .hero-grid { grid-template-columns: 1fr; gap: 26px; }
  .hero-title { font-size: 38px; }
}
@media (max-width: 640px) {
  .hero { padding: 28px 18px 30px; border-radius: 14px; }
  .hero-title { font-size: 31px; }
  .hero-sub { font-size: 13.5px; }
  .hero-proof { font-size: 13px; }
  .hero-btn { font-size: 13px; padding: 10px 16px; }
}

/* ── Slim hero — one-line positioning so today's picks lead ─────── */
.hero-slim { padding: 22px 26px; }
.hero-slim .hero-title { font-size: 30px; margin-bottom: 10px; }
.hero-slim .hero-sub { font-size: 14px; color: var(--text-3); max-width: 660px; margin: 0; }
.hero-slim .hero-sub a { color: var(--indigo-lt); text-decoration: none; white-space: nowrap; }
.hero-slim .hero-sub a:hover { text-decoration: underline; }
@media (max-width: 640px) {
  .hero-slim { padding: 18px 18px; }
  .hero-slim .hero-title { font-size: 25px; }
}

/* ── Section note (fine print under a sec-lbl) ──────────────────── */
.sec-note { font-size: 11px; color: var(--text-4); line-height: 1.6; margin: -2px 0 12px; }

/* ── Slim email bar (list growth demoted below the picks) ───────── */
.email-bar {
  display: flex; align-items: center; gap: 12px 18px; flex-wrap: wrap;
  padding: 14px 18px; margin: 8px 0 18px;
  background: rgba(99,102,241,0.06); border: 1px solid rgba(99,102,241,0.20);
  border-radius: 12px;
}
.email-bar .eb-copy { flex: 1 1 280px; min-width: 0; font-size: 12.5px; color: var(--text-3); line-height: 1.55; }
.email-bar .eb-copy strong { color: var(--text); font-weight: 700; }
.email-bar .eb-form { flex: 0 1 360px; margin: 0; }
.email-bar .ec-success { flex-basis: 100%; }
@media (max-width: 560px) { .email-bar .eb-form { flex-basis: 100%; } }

/* ── How-to (collapsed; shares the About-model look) ────────────── */
.disc-block {
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: 10px; margin-bottom: 16px; overflow: hidden;
}
.disc-block > summary {
  display: flex; align-items: center; gap: 8px;
  padding: 12px 16px; cursor: pointer; list-style: none;
  color: var(--text-4); font-size: 12px; font-weight: 600;
  letter-spacing: 0.04em; user-select: none;
}
.disc-block > summary::-webkit-details-marker { display: none; }
.disc-block > summary:hover { color: var(--text-3); background: rgba(255,255,255,0.02); }
.disc-block[open] > summary { border-bottom: 1px solid var(--border); color: var(--text-3); }
.disc-block[open] .am-chevron { transform: rotate(180deg); }
.howto-grid { display: grid; grid-template-columns: repeat(auto-fit,minmax(210px,1fr)); gap: 12px; padding: 16px; }
.howto-card { padding: 14px 16px; border: 1px solid var(--border); border-radius: 12px; background: rgba(255,255,255,0.02); }
.howto-h { font-size: 12px; font-weight: 700; color: var(--text); margin-bottom: 6px; }
.howto-b { font-size: 12px; color: var(--text-3); line-height: 1.7; }

/* ── About-model body helpers (replace former inline styles) ────── */
.am-p { font-size: 12px; color: var(--text-3); line-height: 1.7; margin-bottom: 14px; }
.am-mb { margin-bottom: 14px; }
.am-list { font-size: 11px; color: var(--text-4); line-height: 1.9; padding-left: 16px; margin-bottom: 14px; }
.am-who { margin-top: 14px; font-size: 12.5px; color: var(--text-3); line-height: 1.75; }
.am-who strong { color: var(--text); }
.am-who-h { font-family: var(--font-display); font-size: 12px; font-weight: 800; letter-spacing: 0.12em; text-transform: uppercase; color: var(--text-2); margin-bottom: 7px; }
.am-legal { margin-top: 14px; font-size: 10px; color: var(--text-4); line-height: 1.7; }

/* ── Footer / meta micro-text (replace former inline styles) ────── */
.page-refresh-meta { font-size: 10px; color: var(--text-4); margin: 3px 0 2px; font-family: var(--font-mono); }
.rg-resource { margin-top: 8px; font-size: 10px; color: var(--text-3); line-height: 1.6; }
.rg-resource a { color: var(--text-2); }
.footer-byline { margin-top: 10px; font-size: 10px; color: var(--text-4); letter-spacing: 0.04em; }

.record-strip {
  display: flex;
  gap: 10px;
  margin-bottom: 24px;
  flex-wrap: wrap;
  align-items: stretch;
}

.no-picks-yet {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 48px 24px;
  text-align: center;
  color: var(--text-4);
}
.no-picks-yet .np-icon { font-size: 36px; margin-bottom: 12px; }
.no-picks-yet .np-title { font-family: var(--font-display); font-size: 18px; color: var(--text-3); margin-bottom: 6px; letter-spacing: 0.05em; }
.no-picks-yet .np-sub { font-size: 12px; color: var(--text-4); line-height: 1.6; }

.picks-count-badge {
  font-size: 11px;
  color: var(--text-4);
  margin-bottom: 16px;
}

.single-pick { max-width: 540px; }

/* Posted-at timestamp on pick card */
.pick-posted {
  font-size: 9px;
  color: var(--text-4);
  font-family: var(--font-mono);
  margin-bottom: 6px;
  letter-spacing: 0.04em;
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 4px;
}
.pick-posted .posted-dot { display: inline-block; width: 5px; height: 5px; border-radius: 50%; background: var(--green); margin-right: 2px; vertical-align: middle; flex-shrink: 0; }

/* ── NEW: LIVE badge ── */
.live-badge {
  display: inline-flex; align-items: center; gap: 4px;
  font-size: 9px; font-weight: 700; letter-spacing: 0.1em;
  color: var(--green);
  background: rgba(34,197,94,0.1);
  border: 1px solid rgba(34,197,94,0.25);
  border-radius: 4px; padding: 2px 7px;
  vertical-align: middle;
}
.live-dot {
  width: 5px; height: 5px; border-radius: 50%;
  background: var(--green);
  animation: pulsedot 1.4s infinite;
  flex-shrink: 0;
}
/* Live badge tinted from the pick's perspective: ahead = green (default), behind = red, tied = neutral. */
.live-badge.live-behind { color: var(--red, #ef4444); background: rgba(239,68,68,0.10); border-color: rgba(239,68,68,0.28); }
.live-badge.live-tied   { color: var(--text-3, #94a3b8); background: rgba(148,163,184,0.10); border-color: rgba(148,163,184,0.28); }
@keyframes pulsedot { 0%,100%{opacity:1} 50%{opacity:0.3} }

/* ── NEW: Tooltip (CSS-only via data-tip) ── */
.tip {
  display: inline-flex; align-items: center; justify-content: center;
  width: 13px; height: 13px; border-radius: 50%;
  font-size: 8px; font-weight: 700;
  background: rgba(255,255,255,0.06); color: var(--text-4);
  cursor: help; position: relative; vertical-align: middle;
  margin-left: 3px; flex-shrink: 0;
}
.tip::after {
  content: attr(data-tip);
  position: absolute; bottom: calc(100% + 6px); left: 50%;
  transform: translateX(-50%);
  background: #1e293b; color: #cbd5e1;
  font-size: 10px; line-height: 1.45;
  padding: 6px 10px; border-radius: 7px;
  border: 1px solid rgba(255,255,255,0.1);
  pointer-events: none; opacity: 0;
  transition: opacity 0.15s; z-index: 200;
  font-family: 'Inter', sans-serif; font-weight: 400;
  letter-spacing: 0; text-transform: none;
  max-width: 220px; white-space: normal;
  text-align: center; width: max-content;
}
.tip:hover::after { opacity: 1; }

/* ── NEW: Copy pick button ── */
.copy-btn {
  padding: 3px 8px;
  background: rgba(255,255,255,0.03);
  border: 1px solid var(--border); border-radius: 5px;
  font-size: 10px; color: var(--text-4); cursor: pointer;
  transition: all 0.15s; white-space: nowrap;
}
.copy-btn:hover { color: var(--text-2); background: rgba(255,255,255,0.06); }
.copy-btn.copied { color: var(--green); border-color: rgba(34,197,94,0.3); }

/* ── NEW: Dog / fav label ── */
.bc-matchlabel {
  font-size: 8px; padding: 2px 7px; border-radius: 4px;
  font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; flex-shrink: 0;
}
.bc-matchlabel.dog { background: rgba(245,158,11,0.1); color: var(--amber); border: 1px solid rgba(245,158,11,0.25); }
.bc-matchlabel.fav { background: rgba(99,102,241,0.1); color: var(--indigo-lt); border: 1px solid rgba(99,102,241,0.25); }

/* ── NEW: SP line (prominent above matchup) ── */
.sp-line { font-size: 10px; color: var(--text-4); margin-bottom: 5px; }
.sp-line strong { color: var(--text-3); font-weight: 600; }

/* ── Combined SP + flags row ── */
.sp-flags-row { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; margin-bottom: 6px; }
.sp-flags-row .sp-line { margin-bottom: 0; flex: 1; min-width: 0; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.sp-flags-row .pick-flags { margin-bottom: 0; flex-shrink: 0; }

/* ── Prob context sub-line inside markets table ── */
.ml-prob-context { font-size: 9px; color: var(--text-4); padding: 3px 18px 5px; letter-spacing: 0.02em; border-bottom: 1px solid var(--border); }
.ml-prob-context strong { color: var(--text-2); }
.ml-prob-context .mpc-fair { color: var(--indigo-lt); }

/* ── FINAL badge for completed games ── */
.final-badge { font-size: 8px; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; color: var(--text-4); background: rgba(255,255,255,0.05); border: 1px solid rgba(255,255,255,0.08); padding: 2px 6px; border-radius: 4px; flex-shrink: 0; }

/* ── NEW: Kelly dollar amount ── */
.kelly-usd {
  font-size: 9px; color: var(--green); font-weight: 600;
  display: block; margin-top: 1px; min-height: 12px;
}

/* ── NEW: Bankroll widget ── */
.bankroll-widget {
  display: flex; align-items: center; gap: 8px;
  font-size: 10px; color: var(--text-4);
  margin-bottom: 16px; padding: 8px 14px;
  background: var(--bg-card); border: 1px solid var(--border); border-radius: 8px;
  flex-wrap: wrap;
}
.bw-label { font-weight: 600; color: var(--text-3); }
.bw-input {
  width: 72px; background: rgba(255,255,255,0.04);
  border: 1px solid var(--border); border-radius: 5px;
  color: var(--text-2); font-family: var(--font-mono);
  font-size: 11px; padding: 3px 7px; text-align: right;
}
.bw-input:focus { outline: none; border-color: rgba(99,102,241,0.4); }
.bw-hint { color: var(--text-4); font-size: 9px; }

/* ── NEW: Streak chip in record strip ── */
.streak-chip {
  display: inline-flex; flex-direction: column; align-items: center;
  padding: 10px 14px; background: var(--bg-card);
  border: 1px solid var(--border); border-radius: 10px; text-align: center;
}
.streak-chip .sc-lbl { font-size: 8px; font-weight: 700; letter-spacing: 0.14em; text-transform: uppercase; color: var(--text-4); margin-bottom: 5px; }
.streak-chip .sc-val { font-family: var(--font-display); font-size: 20px; font-weight: 700; line-height: 1; }
.streak-chip .sc-val.W { color: var(--green); }
.streak-chip .sc-val.L { color: var(--red); }

/* ── NEW: Mini sparkline pill ── */
.sparkline-pill {
  display: inline-flex; flex-direction: column; align-items: center;
  padding: 8px 14px; background: var(--bg-card);
  border: 1px solid var(--border); border-radius: 10px; gap: 4px;
}
.sparkline-pill .sp-lbl { font-size: 8px; font-weight: 700; letter-spacing: 0.14em; text-transform: uppercase; color: var(--text-4); }


/* Yesterday's results */
.yest-section { margin-top: 28px; }
.yest-title { font-size: 9px; font-weight: 700; letter-spacing: 0.2em; text-transform: uppercase; color: var(--text-4); margin-bottom: 10px; }
.yest-row { display: flex; align-items: center; justify-content: space-between; padding: 9px 12px; background: rgba(255,255,255,0.02); border-radius: 8px; margin-bottom: 5px; }
.yest-row:last-child { margin-bottom: 0; }
.yest-game { font-family: var(--font-display); font-size: 14px; font-weight: 600; color: var(--text-2); }
.yest-pick { font-size: 11px; color: var(--text-3); }
.yest-right { display: flex; align-items: center; gap: 10px; }
.yest-result { font-family: var(--font-display); font-size: 16px; font-weight: 700; min-width: 22px; text-align: center; }
.yest-result.W { color: var(--green); }
.yest-result.L { color: var(--red); }
.yest-pnl { font-size: 11px; font-weight: 600; min-width: 44px; text-align: right; }
.yest-pnl.pos { color: var(--green); }
.yest-pnl.neg { color: var(--red); }
.yest-clv { font-size: 9px; color: var(--text-4); min-width: 44px; text-align: right; }

/* Yesterday top-performer callout */
.yesterday-callout {
  display: flex; align-items: center; gap: 10px;
  margin: 0 0 10px; padding: 10px 14px;
  background: rgba(34,197,94,0.06); border-radius: 8px;
  border-left: 2px solid rgba(34,197,94,0.3);
}
.yc-icon  { font-size: 16px; flex-shrink: 0; }
.yc-text  { flex: 1; font-size: 11px; color: var(--text-2); line-height: 1.5; }
.yc-result { font-family: var(--font-display); font-size: 18px; font-weight: 700; flex-shrink: 0; }
.yc-result.W { color: var(--green); }
.yc-result.L { color: var(--red); }

/* Weather strip on pick card */
.wx-strip {
  font-size: 10px; color: var(--text-4);
  display: flex; align-items: center; gap: 6px;
  margin: 4px 0 10px;
}
.wx-strip .wx-icon { opacity: 0.6; }
.wx-high-wind { color: var(--amber) !important; }

/* Game time chip */
.game-time-chip {
  display: inline-block;
  font-size: 9px; font-family: var(--font-mono);
  color: var(--text-4); background: rgba(255,255,255,0.04);
  padding: 2px 7px; border-radius: 4px;
  vertical-align: middle;
}
/* Weather chip — ambient game context in the card header */
.wx-chip {
  display: inline-flex; align-items: center; gap: 3px;
  font-size: 9px; font-family: var(--font-mono);
  color: var(--text-4); background: rgba(255,255,255,0.03);
  border: 1px solid var(--border);
  padding: 1px 6px; border-radius: 4px;
  vertical-align: middle; white-space: nowrap;
}
.wx-chip .wx-ico { font-size: 9px; filter: grayscale(0.2); }
@media (max-width: 520px) { .wx-chip { display: none; } }

/* Line movement */
.line-posted { font-size: 9px; color: var(--text-4); margin-bottom: 10px; }
.line-posted strong { color: var(--text-3); }

/* Auto-refresh countdown */
.refresh-indicator {
  font-size: 9px; color: var(--text-4);
  font-family: var(--font-mono);
  margin-left: 8px; display: none;
}

/* ── Top pick spotlight ── */
.pick-card.top-pick {
  border-color: rgba(245,158,11,0.5) !important;
  box-shadow: 0 0 0 1px rgba(245,158,11,0.15), 0 6px 24px rgba(245,158,11,0.08);
}
.top-pick-banner {
  display: flex; align-items: center; gap: 6px;
  font-size: 9px; font-weight: 700; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--amber);
  background: rgba(245,158,11,0.07); border: 1px solid rgba(245,158,11,0.2);
  border-radius: 6px; padding: 5px 10px; margin-bottom: 8px;
}

/* ── Share button ── */
.share-btn {
  padding: 3px 8px;
  background: rgba(255,255,255,0.03);
  border: 1px solid var(--border); border-radius: 5px;
  font-size: 10px; color: var(--text-4); cursor: pointer;
  transition: all 0.15s; white-space: nowrap;
  text-decoration: none; display: inline-flex; align-items: center; gap: 3px;
}
.share-btn:hover { color: var(--indigo-lt); border-color: rgba(99,102,241,0.3); }
.share-btn:disabled { opacity: 0.5; cursor: default; }

/* ── Line movement indicator ── */
.line-move {
  font-size: 9px; font-weight: 700; padding: 1px 6px; border-radius: 4px;
  margin-left: 6px; white-space: nowrap;
}
.line-move.up   { color: var(--green); background: rgba(34,197,94,0.1); }
.line-move.down { color: var(--red);   background: rgba(239,68,68,0.1); }
.line-move.flat { color: var(--text-4); }

/* ── Today's in-play results chip ── */
.today-chip {
  display: inline-flex; flex-direction: column; align-items: center;
  padding: 8px 14px; background: rgba(99,102,241,0.07);
  border: 1px solid rgba(99,102,241,0.25); border-radius: 10px; text-align: center;
}
.today-chip .tc-val { font-family: var(--font-display); font-size: 18px; font-weight: 700; color: var(--indigo-lt); line-height: 1; }
.today-chip .tc-lbl { font-size: 8px; font-weight: 700; letter-spacing: 0.14em; text-transform: uppercase; color: var(--text-4); margin-top: 4px; }

/* ── Share all picks button ── */
.share-all-row { margin-bottom: 10px; }
.share-all-btn {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 6px 16px;
  background: rgba(99,102,241,0.12);
  border: 1px solid rgba(99,102,241,0.30); border-radius: 7px;
  font-size: 11px; font-weight: 600; color: var(--indigo-lt);
  cursor: pointer; transition: all 0.15s; letter-spacing: 0.01em;
}
.share-all-btn:hover { background: rgba(99,102,241,0.20); border-color: rgba(99,102,241,0.45); }

/* ── Personal tracker result badges ── */
.pt-result { font-family: var(--font-display); font-size: 13px; font-weight: 700; margin-left: auto; }
.pt-result.W { color: var(--green); }
.pt-result.L { color: var(--red); }

/* ── Refresh pill (better visibility) ── */
.refresh-pill {
  display: inline-flex; align-items: center; gap: 5px;
  font-size: 9px; color: var(--text-4); font-family: var(--font-mono);
  padding: 3px 8px; background: rgba(255,255,255,0.03);
  border: 1px solid var(--border); border-radius: 6px; margin-left: 6px;
  white-space: nowrap;
}
.refresh-pill .rp-dot {
  width: 5px; height: 5px; border-radius: 50%; background: var(--green);
  animation: pulsedot 2s infinite; flex-shrink: 0;
}

/* Mobile: collapsible analysis */
.analysis-toggle {
  display: none; width: 100%; margin: 8px 0;
  padding: 6px 10px;
  background: rgba(255,255,255,0.03);
  border: 1px solid var(--border); border-radius: 6px;
  font-size: 10px; color: var(--text-4); cursor: pointer; text-align: left;
}
.analysis-toggle::after { content: ' ▶'; font-size: 8px; }
.analysis-toggle.open::after { content: ' ▼'; }
@media (max-width: 600px) {
  .analysis-toggle { display: block; }
  .pick-analysis { display: none; }
  .pick-analysis.open { display: block; }
}

/* ── Mobile: compact pick card ── */
@media (max-width: 520px) {
  .prob-compare { margin: 8px 0 10px; }
  .prob-track-lbl { font-size: 8px; }
  .prob-track-lbl strong { font-size: 10px; }
  .prob-track-edge-lbl { font-size: 9px; }
  .book-odds-row { flex-wrap: wrap; gap: 5px; padding: 6px 10px; }
  .bor-books { gap: 8px; }
  .bor-shop { margin-left: 0; margin-top: 2px; }
  .fac-chip { font-size: 9px; padding: 2px 6px; }
  .pick-header-row { flex-wrap: wrap; gap: 4px; }
  /* .share-btn now visible on mobile — triggers Web Share API native sheet */
  .top-pick-banner { font-size: 8px; }
}

/* ── Model info strip ── */
.model-info-strip {
  font-size: 11px; color: var(--text-4); line-height: 1.6;
  padding: 8px 14px; margin-bottom: 14px;
  background: rgba(255,255,255,0.02); border: 1px solid var(--border); border-radius: 8px;
}
.model-info-strip strong { color: var(--text-3); }
/* Demoted, relocated under the picks header as fine print (no box) */

/* ── Line-move callout banner ── */
.line-move-callout {
  display: flex; align-items: center; gap: 8px;
  font-size: 10px; color: var(--green);
  background: rgba(34,197,94,0.07); border: 1px solid rgba(34,197,94,0.22);
  border-radius: 6px; padding: 6px 11px; margin: 4px 0 10px;
}


/* ── Stale / completed card ── */
.pick-card.card-stale { opacity: 0.60; }
/* Completed (final result known): subtle background tint + score line */
.pick-card.card-win  { background: rgba(34,197,94,0.025) !important; }
.pick-card.card-loss { background: rgba(239,68,68,0.02)  !important; }
/* Result score line displayed below team name on completed cards */
.uph-final-score {
  font-family: var(--font-mono); font-size: 12px;
  color: var(--text-4); letter-spacing: 0.04em; margin-top: 2px;
}
.uph-final-score.won { color: rgba(34,197,94,0.75); }
.uph-final-score.lost { color: rgba(239,68,68,0.6); }

/* ── Live score section headers ── */
.picks-section-header {
  display: flex; align-items: center; gap: 8px;
  margin: 20px 0 8px; padding: 0 2px;
}
.picks-section-header:first-child { margin-top: 0; }
.psh-dot { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; }
.psh-dot.live   { background: var(--green); animation: pulsedot 1.4s infinite; }
.psh-dot.upcoming  { background: rgba(255,255,255,0.22); }
.psh-dot.completed { background: rgba(255,255,255,0.1); }
.psh-label { font-family: var(--font-display); font-size: 11px; font-weight: 600; letter-spacing: 0.12em; text-transform: uppercase; }
.psh-label.live      { color: var(--green); }
.psh-label.upcoming  { color: var(--text-3); }
.psh-label.completed { color: var(--text-4); }
.psh-count { font-size: 10px; color: var(--text-4); background: rgba(255,255,255,0.05); border: 1px solid var(--border); border-radius: 10px; padding: 1px 8px; flex-shrink: 0; }
.psh-line  { flex: 1; height: 1px; background: var(--border); }
/* ── Today's-state summary strip (Upcoming · Live · Final W–L) ── */
.picks-state-summary { display: flex; align-items: center; gap: 8px; flex-wrap: wrap;
  font-family: var(--font-display); font-size: 13px; color: var(--text-3);
  margin: 0 0 14px; padding: 8px 12px; background: rgba(255,255,255,0.03);
  border: 1px solid var(--border); border-radius: 10px; }
.picks-state-summary .pss-up    { color: var(--text-2); font-weight: 700; }
.picks-state-summary .pss-live  { color: var(--green); font-weight: 600; }
.picks-state-summary .pss-final { color: var(--text-3); }
.picks-state-summary .pss-sep   { color: var(--text-4); }
.picks-state-summary.results-lead { margin-bottom: 6px; }
.picks-state-summary.results-lead .pss-up { color: var(--text-1, #fff); letter-spacing: 0.04em; }
.picks-results-note { font-size: 11px; color: var(--text-4); margin: 0 0 16px; padding: 0 2px; }

/* ── Result badge (W / L + score) ── */
.result-badge {
  font-family: var(--font-display); font-size: 11px; font-weight: 700;
  letter-spacing: 0.06em; padding: 2px 8px; border-radius: 4px; flex-shrink: 0;
}
.result-badge-win  { color: var(--green); background: rgba(34,197,94,0.12);   border: 1px solid rgba(34,197,94,0.35); }
.result-badge-loss { color: var(--red);   background: rgba(239,68,68,0.10);   border: 1px solid rgba(239,68,68,0.28); }
.result-badge-push { color: var(--text-3); background: rgba(148,163,184,0.10); border: 1px solid rgba(148,163,184,0.28); }
.ppd-badge {
  display: inline-flex; align-items: center;
  font-size: 9px; font-weight: 700; letter-spacing: 0.1em;
  color: var(--amber, #fbbf24);
  background: rgba(251,191,36,0.10);
  border: 1px solid rgba(251,191,36,0.30);
  border-radius: 4px; padding: 2px 7px; vertical-align: middle;
}

/* ── Card win / loss state ── */
.pick-card.card-win  { border-left: 3px solid rgba(34,197,94,0.55); }
.pick-card.card-loss { border-left: 3px solid rgba(239,68,68,0.45); opacity: 0.78; }

/* ── Historical context chip ── */
.hist-context {
  font-size: 10px; color: var(--text-3); line-height: 1.55;
  margin: 0 0 10px; padding: 6px 11px;
  background: rgba(99,102,241,0.07);
  border: 1px solid rgba(99,102,241,0.18); border-radius: 6px;
}
.hist-context strong { color: var(--indigo-lt); }

/* ── Posted-before-pitch badge ── */
.before-pitch {
  font-size: 9px; color: var(--text-4);
  background: rgba(255,255,255,0.04); border: 1px solid var(--border);
  border-radius: 4px; padding: 1px 6px;
  display: inline-flex; align-items: center; gap: 3px; white-space: nowrap;
}

/* ── SP "as of" staleness disclaimer ── */
.sp-as-of {
  font-size: 9px; color: var(--amber);
  opacity: 0.7;
  margin-left: 6px;
  font-family: var(--font-mono);
  cursor: help;
  white-space: nowrap;
}

/* ── Countdown chip ── */
.countdown-chip { transition: color 0.3s; }
.countdown-chip.starting-soon { color: var(--amber) !important; }
.countdown-chip.game-over { color: var(--text-4) !important; opacity: 0.6; }

/* ── Signal breakdown table (Option B) ── */
.adj-breakdown {
  margin: 10px 0 12px;
  padding: 10px 12px;
  background: rgba(255,255,255,0.015);
  border: 1px solid var(--border);
  border-radius: 7px;
}
.adj-breakdown-title {
  font-size: 8px; font-weight: 700; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--text-4); margin-bottom: 8px;
  display: flex; align-items: center; justify-content: space-between;
}
.adj-approx-note {
  font-weight: 400; font-size: 8px; letter-spacing: 0; text-transform: none;
  opacity: 0.6; font-family: var(--font-mono);
}
.adj-row {
  display: flex; align-items: center; gap: 7px; margin-bottom: 4px;
}
.adj-row:last-child { margin-bottom: 0; }
.adj-label {
  font-size: 10px; color: var(--text-3); flex: 1;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.adj-bar-wrap {
  width: 80px; height: 5px;
  background: rgba(255,255,255,0.05);
  border-radius: 100px; overflow: hidden; flex-shrink: 0;
}
.adj-bar-fill {
  height: 100%; border-radius: 100px; transition: width 0.3s;
}
.adj-bar-fill.pos { background: rgba(34,197,94,0.7); }
.adj-bar-fill.neg { background: rgba(239,68,68,0.6); }
.adj-pp {
  font-family: var(--font-mono);
  font-size: 10px; font-weight: 600; width: 42px;
  text-align: right; flex-shrink: 0;
}
.adj-pp.pos { color: var(--green); }
.adj-pp.neg { color: var(--red); }
.adj-divider { height: 1px; background: var(--border); margin: 6px 0; }
.adj-summary {
  display: flex; justify-content: space-between; align-items: baseline;
  font-size: 9px; color: var(--text-4); flex-wrap: wrap; gap: 4px;
}
.adj-summary strong { color: var(--text-2); font-size: 10px; }
.adj-shrink-note {
  font-size: 8.5px; color: var(--amber); margin-top: 5px;
  display: flex; align-items: center; gap: 4px;
}

/* ── v2 Pick card redesign ── */

/* Left-edge tier accent bar (replaces the redundant VALUE badge) */
.pick-card.strong  { border-left: 3px solid rgba(245,158,11,0.7)  !important; }
.pick-card.value   { border-left: 3px solid rgba(34,197,94,0.65)  !important; }
.pick-card.marginal { border-left: 3px solid rgba(255,255,255,0.12) !important; }

/* Win/loss override is still highest priority */
.pick-card.card-win  { border-left: 3px solid rgba(34,197,94,0.6)  !important; }
.pick-card.card-loss { border-left: 3px solid rgba(239,68,68,0.5)  !important; opacity: 0.78; }

/* Pick headline — the dominant section: large team name + odds */
.uc-pick-headline {
  display: flex; align-items: baseline; justify-content: space-between;
  padding: 6px 0 4px; gap: 8px;
}
.uph-team {
  font-family: var(--font-display); font-size: 30px; font-weight: 900;
  color: var(--text-1, #f1f5f9); line-height: 1; flex: 1; min-width: 0;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  letter-spacing: -.01em;
}
.uph-odds {
  font-family: var(--font-mono); font-size: 26px; font-weight: 700;
  line-height: 1; flex-shrink: 0;
}
/* Raw price is neutral — green/amber previously implied "good/bad" on what is
   just the line. The ROAD DOG / HOME DOG tag already conveys dog vs. favorite. */
.uph-odds.dog { color: var(--text); }
.uph-odds.fav { color: var(--text); }

/* Edge + prob row — prominent badge with inline context */
.uph-edge-row {
  display: flex; align-items: center; gap: 8px; margin-bottom: 6px;
  flex-wrap: wrap;
}
.uph-edge-badge {
  display: inline-flex; align-items: center;
  background: rgba(34,197,94,0.1); border: 1px solid rgba(34,197,94,0.3);
  border-radius: 5px; padding: 2px 9px;
  font-size: 11px; font-weight: 700; color: var(--green); letter-spacing: 0.04em;
  flex-shrink: 0;
}
.uph-prob-context {
  font-size: 10px; color: var(--text-4); letter-spacing: 0.02em;
}
.uph-prob-context strong { color: var(--text-2); font-weight: 600; }
.uph-fair { color: var(--indigo-lt); }

/* SP line — slightly larger and better contrast than before */
.sp-line { font-size: 11px !important; color: var(--text-3) !important; margin-bottom: 4px; }

/* Action row v2 — text links instead of box buttons */
.uc-action-row-v2 {
  display: flex; align-items: center; gap: 0;
  padding: 8px 0 2px; border-top: 1px solid var(--border); margin-top: 6px;
  flex-wrap: wrap;
}
.uav-btn {
  background: none; border: none; cursor: pointer; padding: 2px 10px;
  font-size: 11px; font-weight: 500; transition: color 0.15s;
  font-family: 'Inter', sans-serif;
}
.uav-btn.primary { color: var(--indigo-lt); }
.uav-btn.primary:hover { color: #a5b4fc; }
.uav-btn.secondary { color: var(--text-3); }
.uav-btn.secondary:hover { color: var(--text-2); }
.uav-btn.tracking { color: var(--green) !important; }
.uav-sep { color: var(--border); font-size: 12px; user-select: none; }

/* ── Record strip: match new card aesthetic ── */
.record-strip .stat-pill {
  border-radius: 10px;
  background: rgba(255,255,255,0.025);
  transition: border-color 0.15s;
}
.record-strip .stat-pill:hover { border-color: rgba(255,255,255,0.15); }

/* ── Kelly badge in edge row ── */
.uph-kelly-badge {
  display: inline-flex; align-items: center;
  background: rgba(99,102,241,0.08); border: 1px solid rgba(99,102,241,0.2);
  border-radius: 4px; padding: 1px 7px;
  font-size: 9.5px; font-weight: 600; color: var(--indigo-lt);
  letter-spacing: 0.03em; flex-shrink: 0;
}

/* ── Today's action strip ── */
.today-action-strip {
  display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
  padding: 8px 14px; border-radius: 8px; margin-bottom: 16px;
  background: rgba(255,255,255,0.02); border: 1px solid var(--border);
  font-size: 10px; color: var(--text-4);
}
.tas-label { font-size: 8px; font-weight: 700; letter-spacing: 0.14em;
             text-transform: uppercase; color: var(--text-4); flex-shrink: 0; }
.tas-stat { display: flex; flex-direction: column; align-items: center; }
.tas-val { font-family: var(--font-display); font-size: 15px; font-weight: 700;
           color: var(--text-2); line-height: 1; }
.tas-sub { font-size: 8px; color: var(--text-4); margin-top: 2px; }
.tas-div { width: 1px; height: 22px; background: var(--border); flex-shrink: 0; }

/* ── Narrative preview (always-visible) ── */
.uc-narrative-preview-line {
  font-size: 10.5px; color: var(--text-3); line-height: 1.55;
  margin: 4px 0 6px;
}

/* ── Card spacing: more breathing room between picks ── */
.pick-grid { gap: 14px !important; }

/* ── Marginal picks: visually secondary ── */
.pick-card.marginal { opacity: 0.70; }

/* ── Skeleton loading cards ── */
.skeleton-card {
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: 12px; padding: 18px 16px; border-left: 3px solid rgba(255,255,255,0.08);
}
.sk-line {
  height: 8px; border-radius: 4px; background: rgba(255,255,255,0.06);
  margin-bottom: 10px; animation: sk-pulse 1.6s ease-in-out infinite;
}
@keyframes sk-pulse { 0%,100%{opacity:0.5} 50%{opacity:1} }
.sk-line.wide  { width: 70%; }
.sk-line.tall  { height: 20px; width: 55%; margin-bottom: 6px; }
.sk-line.short { width: 40%; }
.sk-line.xs    { height: 6px; width: 80%; }

/* ── Details button — pill treatment, primary CTA ── */
.uav-btn.primary {
  font-weight: 700 !important;
  background: rgba(34,197,94,.09) !important;
  border: 1px solid rgba(34,197,94,.25) !important;
  border-radius: 6px !important;
  padding: 4px 12px !important;
  color: var(--green) !important;
}
.uav-btn.primary:hover { background: rgba(34,197,94,.16) !important; color: #4ade80 !important; }
.uav-btn.primary.open  { background: rgba(34,197,94,.18) !important; }
/* Details toggle is the row's prominent primary affordance — wide + centered so
   the deeper matchup analysis is clearly discoverable. */
.uc-action-row-v2 .details-toggle { flex: 1 1 auto; display: inline-flex; align-items: center; justify-content: center; gap: 6px; font-size: 12px !important; padding: 7px 14px !important; }
.uc-action-row-v2 .uav-btn.secondary { flex: 0 0 auto; }

/* ── Compact Playable To + Best Book line on collapsed card ── */
.pc-playable-line {
  display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
  padding: 5px 14px 7px;
  font-family: var(--font-ui);
  border-top: 1px solid rgba(255,255,255,.04);
}
.ppl-item { display: flex; align-items: center; gap: 5px; }
.ppl-lbl { font-size: 8px; font-weight: 700; letter-spacing: .09em; text-transform: uppercase; color: var(--text-4); }
.ppl-val { font-family: var(--font-mono); font-weight: 700; font-size: 12.5px; color: var(--text-2); }
.ppl-val.play { color: var(--amber); }
.ppl-sep { color: rgba(255,255,255,.10); }

/* ── Compact live edge line (replaces multi-row panel in collapsed card) ── */
.lep-compact {
  display: flex; align-items: center; gap: 7px; flex-wrap: wrap;
  padding: 6px 14px; font-size: 10.5px; font-family: var(--font-ui);
  background: rgba(255,255,255,.018); border-top: 1px solid rgba(255,255,255,.04);
}
.lep-c-label { font-size: 8px; font-weight: 700; letter-spacing: .10em; text-transform: uppercase; color: var(--text-4); }
.lep-c-val   { font-family: var(--font-mono); font-weight: 700; font-size: 11px; }
.lep-c-delta { font-size: 10px; font-weight: 600; font-family: var(--font-mono); }
.lep-c-sep   { color: rgba(255,255,255,.12); }
.lep-c-time  { font-size: 10px; color: var(--text-4); font-family: var(--font-mono); }

/* ── Win Probability Gap: larger numbers in expanded view ── */
.det-v8-panel .pv-val { font-size: 26px !important; }
.det-v8-panel .pv-val.edgev { font-size: 18px !important; }
.det-v8-panel .prob-v8-bar { height: 12px !important; border-radius: 5px !important; }

/* ── Expansion header connecting expanded panel to the card ── */
.det-exp-hdr {
  display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
  padding: 10px 14px; border-bottom: 1px solid rgba(255,255,255,.06);
  background: rgba(255,255,255,.02);
}
.deh-pick { font-family: var(--font-display); font-size: 18px; font-weight: 800; color: var(--text); letter-spacing: .02em; }
.deh-edge { font-family: var(--font-mono); font-size: 13px; font-weight: 700; }
.det-v8-panel.pick-tier-value  .deh-edge { color: var(--green); }
.det-v8-panel.pick-tier-strong .deh-edge { color: var(--amber); }
.det-v8-panel.pick-tier-cond   .deh-edge { color: var(--amber); }
.det-v8-panel.pick-tier-other  .deh-edge { color: var(--indigo-lt); }
.deh-label { font-size: 9px; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; color: var(--text-4); margin-left: auto; }
.deh-game  { font-size: 10px; color: var(--text-4); font-family: var(--font-ui); margin-left: 8px; }

/* ── Visual weight tiers for expanded sections ── */
/* Primary sections: slightly stronger */
.det-v8-sec.sec-primary { background: rgba(255,255,255,.01); }
/* Secondary sections: reduced label contrast */
.det-v8-sec.sec-secondary .det-v8-hdr { color: var(--text-4) !important; font-size: 8px !important; }
.det-v8-sec.sec-secondary { padding: 10px 14px; }

/* ── Week-at-a-Glance strip ─────────────────────────────────────────────── */
.week-strip {
  margin-bottom: 14px;
  border: 1px solid var(--border);
  border-radius: 10px;
  overflow: hidden;
  background: var(--bg-card);
}
.week-strip-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 9px 14px; cursor: pointer; user-select: none;
  border-bottom: 1px solid transparent;
  transition: background 0.15s;
}
.week-strip-header:hover { background: rgba(255,255,255,0.02); }
.week-strip.open .week-strip-header { border-bottom-color: var(--border); }
.wsh-left  { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.wsh-label { font-size: 9px; font-weight: 700; letter-spacing: 0.14em;
             text-transform: uppercase; color: var(--text-4); flex-shrink: 0; }
.wsh-record { font-family: var(--font-display); font-size: 15px;
              font-weight: 700; line-height: 1; }
.wsh-units  { font-size: 11px; font-weight: 600; }
.wsh-roi    { font-size: 10px; color: var(--text-4); padding: 1px 7px;
              border-radius: 4px; background: rgba(255,255,255,0.04);
              border: 1px solid var(--border); }
.wsh-chevron { font-size: 10px; color: var(--text-4); transition: transform 0.2s; flex-shrink: 0; }
.week-strip.open .wsh-chevron { transform: rotate(180deg); }
.week-strip-body  { display: none; padding: 12px 14px; }
.week-strip.open .week-strip-body { display: block; }
.week-picks-grid  { display: flex; flex-wrap: wrap; gap: 6px; }
.wpc {
  display: inline-flex; flex-direction: column; align-items: center;
  padding: 5px 10px; border-radius: 7px; min-width: 52px;
  border: 1px solid var(--border); background: rgba(255,255,255,0.02);
  cursor: default; text-decoration: none;
}
.wpc.wpc-win  { border-color: rgba(34,197,94,0.3);  background: rgba(34,197,94,0.05); }
.wpc.wpc-loss { border-color: rgba(239,68,68,0.25); background: rgba(239,68,68,0.04); opacity: 0.8; }
.wpc-pick   { font-family: var(--font-display); font-size: 13px; font-weight: 700;
              color: var(--text-1); line-height: 1.1; }
.wpc-date   { font-size: 8.5px; color: var(--text-4); margin-top: 1px; }
.wpc-pnl    { font-size: 9.5px; font-weight: 700; margin-top: 2px; }
.wpc-pnl.pos { color: var(--green); }
.wpc-pnl.neg { color: var(--red); }
.wpc-result { font-size: 8px; font-weight: 700; letter-spacing: 0.08em;
              padding: 1px 5px; border-radius: 3px; margin-top: 3px; }
.wpc-result.W { color: var(--green); background: rgba(34,197,94,0.12); }
.wpc-result.L { color: var(--red);   background: rgba(239,68,68,0.10); }
@media (max-width: 520px) {
  .wpc { min-width: 44px; padding: 4px 7px; }
  .wpc-pick { font-size: 12px; }
}

/* ── CLV validation banner ────────────────────────────────────────────────── */
/* Sits between the record strip and the picks. Only rendered when CLV > 0.   */
.clv-banner {
  display: flex; align-items: flex-start; gap: 14px;
  padding: 12px 16px; border-radius: 10px; margin-bottom: 16px;
  background: rgba(34,197,94,0.05);
  border: 1px solid rgba(34,197,94,0.2);
}
.clv-banner.negative {
  background: rgba(239,68,68,0.05);
  border-color: rgba(239,68,68,0.2);
}
.clv-banner-icon { font-size: 20px; flex-shrink: 0; margin-top: 1px; }
.clv-banner-body { flex: 1; min-width: 0; }
.clv-banner-headline {
  display: flex; align-items: baseline; gap: 10px; flex-wrap: wrap;
  margin-bottom: 4px;
}
.clv-banner-title {
  font-size: 12px; font-weight: 700; letter-spacing: 0.04em;
  color: var(--green); text-transform: uppercase;
}
.clv-banner-title.negative { color: var(--red); }
.clv-banner-stat {
  font-family: var(--font-display); font-size: 18px; font-weight: 700;
  color: var(--green); line-height: 1;
}
.clv-banner-stat.negative { color: var(--red); }
.clv-banner-meta {
  font-size: 10px; color: var(--text-4); font-style: italic;
}
.clv-banner-desc {
  font-size: 11px; color: var(--text-3); line-height: 1.55; margin-top: 3px;
}
.clv-banner-desc strong { color: var(--text-2); font-weight: 600; }
.clv-banner-pills {
  display: flex; gap: 8px; flex-wrap: wrap; margin-top: 8px;
}
.clv-mini-pill {
  display: inline-flex; flex-direction: column; align-items: center;
  padding: 5px 10px; border-radius: 6px;
  background: rgba(34,197,94,0.08); border: 1px solid rgba(34,197,94,0.18);
  min-width: 56px;
}
.clv-mini-pill .cmp-val {
  font-family: var(--font-mono); font-size: 12px; font-weight: 700;
  color: var(--green); line-height: 1.2;
}
.clv-mini-pill .cmp-lbl {
  font-size: 8.5px; color: var(--text-4); letter-spacing: 0.06em;
  text-transform: uppercase; margin-top: 2px;
}
/* Upgraded CLV stat-pill in record strip */
.stat-pill.clv-pill {
  border-color: rgba(34,197,94,0.3) !important;
  background: rgba(34,197,94,0.04) !important;
}
.stat-pill.clv-pill .stat-lbl { color: rgba(34,197,94,0.75); }
.stat-pill.clv-pill .stat-val { font-size: 17px !important; }

/* ── CLV validation banner ────────────────────────────────────────────────── */
/* ── Live edge panel ─────────────────────────────────────────────────────── */
/* Shows posted (locked) edge vs. current model assessment side-by-side.      */
/* Displayed on pick cards when lineup-confirmed refresh data is available.   */
.live-edge-panel {
  margin: 6px 0 10px;
  padding: 9px 12px;
  border-radius: 7px;
  border: 1px solid var(--border);
  background: rgba(255,255,255,0.018);
}
.lep-row {
  display: flex; align-items: center; gap: 6px;
  font-size: 11.5px; line-height: 1.6;
}
.lep-label {
  color: var(--text-4); font-size: 10.5px; font-weight: 500;
  min-width: 52px; flex-shrink: 0;
}
.lep-value { font-weight: 700; font-size: 12px; flex-shrink: 0; }
.lep-value.lep-green  { color: var(--green); }
.lep-value.lep-amber  { color: var(--amber); }
.lep-value.lep-muted  { color: var(--text-3); }
.lep-value.lep-red    { color: var(--red); }
.lep-meta {
  color: var(--text-4); font-size: 10px; font-style: italic;
  flex: 1; text-align: right; white-space: nowrap;
  overflow: hidden; text-overflow: ellipsis;
}
.lep-divider {
  border: none; border-top: 1px solid rgba(255,255,255,0.06); margin: 5px 0;
}
.lep-delta-bar {
  margin-top: 6px; height: 3px; border-radius: 2px;
  background: rgba(255,255,255,0.06); overflow: hidden;
}
.lep-delta-fill { height: 100%; border-radius: 2px; transition: width .3s; }
.lep-delta-label {
  display: flex; justify-content: space-between; align-items: center;
  font-size: 9.5px; color: var(--text-4); margin-top: 3px;
}
.lep-delta-status { font-weight: 600; }
/* Warning / flip banners */
.lep-warn-banner {
  display: flex; align-items: flex-start; gap: 8px;
  padding: 8px 12px; border-radius: 7px; margin: 0 0 10px;
  font-size: 11px; line-height: 1.5; border: 1px solid;
}
.lep-warn-banner.lep-orange {
  background: rgba(249,115,22,0.07); border-color: rgba(249,115,22,0.28);
  color: #fdba74;
}
.lep-warn-banner.lep-red {
  background: rgba(239,68,68,0.07); border-color: rgba(239,68,68,0.28);
  color: #fca5a5;
}
.lep-warn-icon { font-size: 13px; flex-shrink: 0; margin-top: 1px; }
.lep-warn-text strong {
  display: block; margin-bottom: 2px;
  font-weight: 600; color: inherit;
}

/* ── Current State Panel ── */
.cs-header {
  display: flex; align-items: center; gap: 8px; flex-wrap: wrap;
  margin: 10px 0 8px; padding-top: 4px;
}
.cs-title {
  font-size: 10px; font-weight: 700; letter-spacing: 0.08em;
  text-transform: uppercase; color: var(--text-4);
}
.cs-lineup-badge {
  font-size: 9px; font-weight: 700; letter-spacing: 0.06em;
  padding: 2px 7px; border-radius: 4px; flex-shrink: 0;
}
.cs-lc-confirmed { background: rgba(34,197,94,0.12); color: var(--green); }
.cs-lc-projected { background: rgba(245,158,11,0.12); color: var(--amber); }
.cs-lc-final     { background: rgba(148,163,184,0.14); color: #94a3b8; }
.cs-opp-lineup   { font-size: 9px; color: var(--text-4); }
.cs-metrics {
  display: flex; gap: 0; margin-bottom: 10px;
}
.cs-metric { flex: 1; text-align: center; padding: 8px 4px; }
.cs-metric + .cs-metric { border-left: 1px solid var(--border); }
.cs-m-label { font-size: 9px; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; color: var(--text-4); margin-bottom: 3px; }
.cs-m-val   { font-family: var(--font-mono); font-size: 14px; font-weight: 600; color: var(--text-2); }
.cs-signals { display: flex; flex-direction: column; gap: 5px; margin-top: 2px; }
.cs-sig-row {
  display: flex; align-items: center; gap: 6px; font-size: 11px;
}
.cs-sig-dot   { width: 7px; height: 7px; border-radius: 50%; flex-shrink: 0; }
.cs-sig-label { flex: 1; color: var(--text-2); min-width: 0; }
.cs-sig-bar-wrap {
  width: 60px; height: 5px; background: var(--border);
  border-radius: 3px; flex-shrink: 0; overflow: hidden;
}
.cs-sig-bar-fill { height: 100%; border-radius: 3px; }
.cs-sig-val { font-family: var(--font-mono); font-size: 10px; flex-shrink: 0; min-width: 44px; text-align: right; }

/* ── Pick card redesign ── */
.matchup-teams { display: flex; align-items: baseline; gap: 7px; margin-bottom: 3px; flex-wrap: wrap; }
.mt-pick { font-family: var(--font-display); font-size: 14px; font-weight: 600; color: var(--text-2); }
.mt-pick::after { content: ' ←'; font-size: 9px; color: var(--green); }
.mt-opp  { font-size: 12px; color: var(--text-4); }
.mt-at   { font-size: 10px; color: var(--text-4); }

/* BET callout box styles removed — bet callout no longer shown in card body */

/* Probability single-track: Market → Edge gap → Model, all on 0–100% axis */
.prob-compare { margin: 12px 0 14px; }
.prob-track-wrap {
  position: relative; height: 7px;
  background: rgba(255,255,255,0.06);
  border-radius: 100px; overflow: hidden; margin-bottom: 7px;
}
.prob-track-market {
  position: absolute; left: 0; top: 0; bottom: 0;
  background: rgba(255,255,255,0.18);
  border-radius: 100px 0 0 100px;
  transition: width 0.4s;
}
.prob-track-edge {
  position: absolute; top: 0; bottom: 0;
  background: linear-gradient(90deg, rgba(34,197,94,0.55), rgba(34,197,94,0.9));
  transition: left 0.4s, width 0.4s;
}
/* Vertical marker at the model's win probability — the model price itself */
.prob-track-tick {
  position: absolute; top: -2px; bottom: -2px; width: 2px;
  background: var(--indigo-lt); border-radius: 2px;
  box-shadow: 0 0 5px rgba(129,140,248,0.9);
  transition: left 0.4s;
}
.prob-track-labels {
  display: flex; justify-content: space-between; align-items: baseline;
}
.prob-track-lbl { font-size: 9px; color: var(--text-4); letter-spacing: 0.03em; }
.prob-track-lbl strong { color: var(--text-2); font-size: 11px; font-weight: 600; }
.prob-track-lbl.model strong { color: var(--green); }
.prob-track-edge-lbl {
  font-size: 10px; font-weight: 700; color: var(--green);
  letter-spacing: 0.04em;
}
.prob-track-subline {
  font-size: 9.5px; color: var(--text-4); text-align: center;
  margin-top: 4px; letter-spacing: 0.03em;
}

/* Tier section headers */
.tier-header { display: flex; align-items: center; gap: 8px; margin: 18px 0 10px; padding: 0 2px; }
.tier-header .tier-label { font-family: var(--font-display); font-size: 13px; font-weight: 600; letter-spacing: 0.06em; text-transform: uppercase; }
.tier-header .tier-edge-tag { font-size: 10px; font-weight: 600; padding: 2px 8px; border-radius: 20px; letter-spacing: 0.04em; }
.tier-header .tier-divider { flex: 1; height: 1px; background: var(--border); }
.tier-header.strong-tier .tier-label { color: var(--amber); }
.tier-header.strong-tier .tier-edge-tag { background: rgba(245,158,11,0.12); color: var(--amber); border: 1px solid rgba(245,158,11,0.25); }
.tier-header.value-tier  .tier-label { color: var(--green); }
.tier-header.value-tier  .tier-edge-tag { background: rgba(34,197,94,0.10); color: var(--green); border: 1px solid rgba(34,197,94,0.22); }
.tier-header.marginal-tier .tier-label { color: var(--text-3); }
.tier-header.marginal-tier .tier-edge-tag { background: rgba(255,255,255,0.05); color: var(--text-3); border: 1px solid var(--border); }

/* 4-box stats row */
.pick-stats-row { display: grid; grid-template-columns: repeat(4,1fr); gap: 7px; margin-bottom: 14px; }
@media (max-width:420px) { .pick-stats-row { grid-template-columns: repeat(2,1fr); } }

/* Model factors chips */
.factors-section { margin-bottom: 12px; }
.factors-title { font-size: 8.5px; font-weight: 700; letter-spacing: 0.14em; text-transform: uppercase; color: var(--text-4); margin-bottom: 6px; display: flex; align-items: center; }
.factor-chips { display: flex; flex-wrap: wrap; gap: 5px; }
.fac-chip { display: inline-flex; align-items: center; gap: 3px; padding: 3px 8px; border-radius: 5px; font-size: 10px; font-weight: 500; }
.fac-pos { background: rgba(34,197,94,0.08); color: var(--green); border: 1px solid rgba(34,197,94,0.2); }
.fac-neg { background: rgba(239,68,68,0.08); color: var(--red); border: 1px solid rgba(239,68,68,0.2); }

/* Edge narrative */
.edge-narrative {
  font-size: 11px; color: var(--text-3); line-height: 1.65;
  margin-bottom: 10px; padding: 10px 13px;
  background: rgba(255,255,255,0.018); border-radius: 7px;
  border-left: 2px solid rgba(99,102,241,0.3);
}
.edge-narrative strong { color: var(--text-2); }

/* EV line */
.ev-line { font-size: 10px; color: var(--text-4); margin-bottom: 12px; }
.ev-line strong { color: var(--green); }

/* Pick header row (type + copy) */
.pick-header-row {
  display: flex; align-items: center;
  justify-content: space-between;
  margin-bottom: 8px; gap: 8px;
}

/* ── Book odds comparison table ── */
.book-odds-table {
  margin: -2px 0 10px; padding: 8px 12px;
  background: rgba(255,255,255,0.015); border-radius: 6px;
}
.bot-label {
  font-size: 8px; font-weight: 700; letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--text-4); margin-bottom: 7px;
}
.bot-note { font-weight: 400; letter-spacing: 0; text-transform: none; opacity: 0.65; margin-left: 4px; }
.bot-chips { display: flex; flex-wrap: wrap; gap: 5px; }

/* Individual book chip */
.boc-chip {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 3px 8px; border-radius: 5px; text-decoration: none;
  border: 1px solid var(--border); background: rgba(255,255,255,0.03);
  transition: border-color 0.15s, background 0.15s; cursor: pointer;
}
.boc-chip:hover { background: rgba(255,255,255,0.06); border-color: rgba(255,255,255,0.15); }
/* Best odds — green highlight */
.boc-best {
  background: rgba(34,197,94,0.08);
  border-color: rgba(34,197,94,0.3);
}
.boc-best:hover { background: rgba(34,197,94,0.14); }
/* Pinnacle — subtle reference style */
.boc-pinn {
  border-color: rgba(99,102,241,0.2);
  background: rgba(99,102,241,0.04);
}
.boc-name { font-size: 9px; color: var(--text-4); }
.boc-odds { font-family: var(--font-mono); font-size: 11px; font-weight: 600; color: var(--text-2); }
.boc-best .boc-name { color: rgba(34,197,94,0.75); }
.boc-best .boc-odds { color: var(--green); }
.boc-pinn .boc-name { color: rgba(99,102,241,0.65); }
.boc-pinn .boc-odds { color: var(--indigo-lt); }
/* Exchange badge */
.boc-ex {
  font-size: 7px; font-weight: 700; letter-spacing: 0.08em;
  color: var(--amber); background: rgba(245,158,11,0.1);
  border: 1px solid rgba(245,158,11,0.2); border-radius: 3px;
  padding: 1px 3px; flex-shrink: 0;
}
/* Legacy fallback styles (kept for any pre-book_odds picks) */
.book-odds-row {
  display: flex; align-items: center; gap: 8px;
  padding: 7px 12px; margin: -2px 0 10px;
  background: rgba(255,255,255,0.015); border-radius: 6px; flex-wrap: wrap;
}
.bor-label { font-size: 8px; font-weight: 700; letter-spacing: 0.14em; text-transform: uppercase; color: var(--text-4); min-width: 60px; flex-shrink: 0; }
.bor-books { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; flex: 1; }
.bor-book { display: inline-flex; align-items: center; gap: 5px; }
.bor-bname { font-size: 9px; color: var(--text-4); }
.bor-bval { font-family: var(--font-mono); font-size: 11px; font-weight: 600; color: var(--text-2); }
.bor-bval.best { color: var(--green); }
.bor-pinn .bor-bval { color: var(--text-3); }

/* ── Track bet button ── */
.bet-toggle {
  padding: 3px 8px;
  background: rgba(255,255,255,0.03);
  border: 1px solid var(--border); border-radius: 5px;
  font-size: 10px; color: var(--text-4); cursor: pointer;
  transition: all 0.15s; white-space: nowrap;
}
.bet-toggle:hover { color: var(--text-2); background: rgba(255,255,255,0.06); }
.bet-toggle.tracking { color: var(--green); border-color: rgba(34,197,94,0.3); background: rgba(34,197,94,0.04); }

/* ── Personal tracker panel ── */
.personal-tracker {
  padding: 10px 14px; margin-bottom: 16px;
  background: rgba(99,102,241,0.05);
  border: 1px solid rgba(99,102,241,0.2); border-radius: 8px;
}
.pt-title { font-size: 9px; font-weight: 700; letter-spacing: 0.14em; text-transform: uppercase; color: var(--indigo-lt); margin-bottom: 8px; }
.pt-row { display: flex; align-items: center; gap: 8px; padding: 4px 0; font-size: 11px; border-top: 1px solid rgba(255,255,255,0.04); }
.pt-row:first-of-type { border-top: none; }
.pt-summary { font-size: 11px; color: var(--text-3); margin-bottom: 6px; }

/* ── Other Markets expandable section ── */
.other-markets-toggle {
  display: flex; align-items: center; justify-content: space-between;
  width: 100%; background: none; border: none; cursor: pointer;
  padding: 8px 0 2px; margin-top: 6px;
  border-top: 1px solid var(--border);
  color: var(--text-4); font-size: 9px; font-weight: 700;
  letter-spacing: 0.12em; text-transform: uppercase;
}
.other-markets-toggle:hover { color: var(--text-3); }
.omt-chevron { font-size: 10px; transition: transform 0.2s; }
.omt-chevron.open { transform: rotate(180deg); }
.other-markets-body {
  display: none; padding-top: 10px;
}
.other-markets-body.open { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.om-card {
  background: rgba(255,255,255,0.02); border: 1px solid var(--border);
  border-radius: 8px; padding: 10px 12px;
}
.om-title {
  font-size: 8px; font-weight: 700; letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--text-4); margin-bottom: 6px;
}
.om-main {
  font-family: var(--font-display); font-size: 16px; font-weight: 600;
  color: var(--text-2); margin-bottom: 4px;
}
.om-row {
  display: flex; justify-content: space-between; align-items: baseline;
  font-size: 10px; color: var(--text-4); margin-bottom: 2px;
}
.om-row .om-val { font-weight: 600; color: var(--text-2); }
.om-edge {
  display: inline-block; margin-top: 5px;
  font-size: 9px; font-weight: 700; padding: 2px 7px; border-radius: 4px;
  letter-spacing: 0.06em;
}
.om-edge.positive { color: var(--green); background: rgba(34,197,94,0.10); border: 1px solid rgba(34,197,94,0.22); }
.om-edge.negative { color: var(--text-4); background: rgba(255,255,255,0.04); border: 1px solid var(--border); }
.om-edge.neutral  { color: var(--amber); background: rgba(245,158,11,0.10); border: 1px solid rgba(245,158,11,0.22); }
.om-lean { font-size: 10px; font-weight: 700; }
.om-lean.over  { color: #f97316; }
.om-lean.under { color: #60a5fa; }
@media (max-width: 520px) {
  .other-markets-body.open { grid-template-columns: 1fr; }
}

/* ── Slim brand bar ──────────────────────────────────────────────────────────── */
/* First element inside the page container — identity + live track record.      */
/* .brand-bar removed — identity merged into phb-card */
.bb-left { display: flex; flex-direction: column; gap: 5px; min-width: 0; }
.bb-name {
  font-family: var(--font-display); font-size: 22px; font-weight: 700;
  color: var(--text-1); letter-spacing: 0.05em; line-height: 1;
}
.bb-name em { font-style: normal; color: var(--indigo-lt); }
.bb-tagline {
  font-size: 11px; color: var(--text-4); letter-spacing: 0.02em; line-height: 1.4;
}
.bb-record {
  display: flex; align-items: stretch; gap: 0; flex-shrink: 0; flex-wrap: wrap;
}
.bb-stat {
  display: flex; flex-direction: column; align-items: flex-end; justify-content: center;
  padding: 4px 14px; border-left: 1px solid var(--border);
}
.bb-stat:first-child { border-left: none; }
.bb-stat-val {
  font-family: var(--font-display); font-size: 22px;
  font-weight: 700; line-height: 1; white-space: nowrap;
}
.bb-stat-lbl {
  font-size: 8.5px; letter-spacing: 0.10em; text-transform: uppercase;
  color: var(--text-4); margin-top: 3px; white-space: nowrap;
}

/* ── Landing-page differentiator line ─────────────────────────────────────── */
.lp-tagline {
  font-size: 11.5px; color: var(--text-3); letter-spacing: 0.02em;
  margin: 0 0 12px; line-height: 1.5; font-style: italic;
}

/* ── Track record anchor link ─────────────────────────────────────────────── */
.track-record-link {
  display: block; text-align: right; font-size: 10px;
  color: var(--text-4); text-decoration: none; letter-spacing: 0.04em;
  margin-bottom: 14px; transition: color 0.15s;
}
.track-record-link:hover { color: var(--indigo-lt); }
@media (max-width: 600px) {
  .brand-bar { flex-direction: column; align-items: flex-start; gap: 12px; padding: 14px 16px; }
  .bb-record { gap: 0; }
  .bb-stat { align-items: flex-start; padding: 2px 12px 2px 0; border-left: none; border-right: 1px solid var(--border); }
  .bb-stat:last-child { border-right: none; }
  .bb-name { font-size: 20px; }
}

/* ── Context bar (compact, replaces large page-header) ───────────────────────── */
.today-context {
  display: flex; align-items: center; gap: 7px; flex-wrap: wrap;
  margin-bottom: 14px; font-size: 11px; color: var(--text-4);
}
.today-context .tc-date {
  font-family: var(--font-display); font-size: 14px; font-weight: 600;
  color: var(--text-2); letter-spacing: 0.02em;
}
.today-context .tc-sep { color: var(--border); user-select: none; }

/* ── Evening preview section ─────────────────────────────────────────────────── */
/* Tomorrow's opening-line picks — projected lineup, amber accent.               */
.preview-section {
  margin-bottom: 16px; padding: 0;
  background: var(--bg-card);
  border: 1px solid rgba(245,158,11,0.3);
  border-left: 3px solid rgba(245,158,11,0.6);
  border-radius: 10px; overflow: hidden;
}
.preview-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 10px 16px; cursor: pointer;
  border-bottom: 1px solid transparent; transition: background 0.15s;
}
.preview-section.open .preview-header { border-bottom-color: rgba(245,158,11,0.2); }
.preview-header:hover { background: rgba(245,158,11,0.03); }
.preview-header-left { display: flex; flex-direction: column; gap: 2px; }
.preview-title {
  font-size: 10px; font-weight: 700; letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--amber);
}
.preview-subtitle { font-size: 10px; color: var(--text-4); font-style: italic; }
.preview-chevron { font-size: 10px; color: var(--text-4); transition: transform 0.2s; }
.preview-section.open .preview-chevron { transform: rotate(180deg); }
.preview-body { display: none; }
.preview-section.open .preview-body { display: block; }
.preview-disclaimer {
  font-size: 10px; color: var(--amber); padding: 8px 16px;
  border-bottom: 1px solid rgba(245,158,11,0.15);
  background: rgba(245,158,11,0.04);
}
.preview-row {
  display: flex; align-items: center; gap: 10px;
  padding: 9px 16px; border-bottom: 1px solid rgba(255,255,255,0.04);
  font-size: 12px;
}
.preview-row:last-child { border-bottom: none; }
.preview-pick-name {
  font-family: var(--font-display); font-size: 14px;
  font-weight: 600; color: var(--text-2);
}
.preview-odds { font-family: var(--font-mono); color: var(--amber); font-size: 12px; }
.preview-meta { flex: 1; font-size: 10px; color: var(--text-4); min-width: 0;
                white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.preview-edge { font-size: 11px; font-weight: 700; color: var(--amber); flex-shrink: 0; }

/* ── Evidence section (below picks, 3 evidence-based claims) ─────────────────── */
.evidence-section {
  margin-bottom: 16px; padding: 22px;
  background: var(--bg-card);
  border: 1px solid var(--border); border-radius: 12px;
}
.evidence-heading {
  font-size: 10px; font-weight: 700; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--text-3); margin-bottom: 18px;
}
.evidence-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px;
}
/* Calibration (reliability) chart */
.calib-block {
  margin-top: 22px; padding-top: 20px;
  border-top: 1px solid var(--border);
}
.calib-hdr {
  font-size: 10px; font-weight: 700; letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--text-3); margin-bottom: 6px;
}
.calib-sub {
  font-size: 11.5px; line-height: 1.55; color: var(--text-4);
  max-width: 560px; margin-bottom: 14px;
}
.calib-svg {
  width: 100%; max-width: 380px; height: auto; display: block;
}
.evidence-claim { display: flex; flex-direction: column; gap: 5px; }
.ec-stat {
  font-family: var(--font-display); font-size: 22px; font-weight: 700;
  color: var(--green); line-height: 1;
}
.ec-stat.amber { color: var(--amber); }
.ec-label {
  font-size: 11px; font-weight: 600; color: var(--text-2); line-height: 1.35;
}
.ec-desc { font-size: 10.5px; color: var(--text-4); line-height: 1.55; }
@media (max-width: 640px) {
  .evidence-grid { grid-template-columns: 1fr; gap: 0; }
  .evidence-claim {
    padding: 14px 0; border-bottom: 1px solid var(--border);
  }
  .evidence-claim:first-child { padding-top: 0; }
  .evidence-claim:last-child  { padding-bottom: 0; border-bottom: none; }
}

/* ── Picks header block — unified dashboard header ───────────────────────────── */
/* Single card: brand identity → stats → sizing controls. Replaces the old       */
/* separate brand bar + header block.                                             */
.phb-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: 12px;
  border-top: 2px solid rgba(99,102,241,0.55);   /* indigo accent — page entry point */
  overflow: hidden;
  margin-bottom: 16px;
}
/* Brand identity row at top of the unified card */
.phb-brand-row {
  padding: 16px 20px 14px;
  border-bottom: 1px solid var(--border);
}
.phb-brand-tagline {
  font-size: 11px; color: var(--text-4);
  letter-spacing: 0.02em; margin-top: 4px; line-height: 1.4;
}
@media (max-width: 600px) {
  .phb-brand-row { padding: 12px 16px 12px; }
}
/* Row 1 — performance stats */
.phb-stats-row {
  display: flex; align-items: center; gap: 0;
  padding: 14px 18px; flex-wrap: wrap; row-gap: 10px;
}
.phb-stat-group {
  display: flex; flex-direction: column; align-items: flex-start;
  padding: 0 18px 0 0; min-width: 0; flex: 1;
}
.phb-stat-group:first-child { padding-left: 0; }
.phb-stat-label {
  font-size: 9px; font-weight: 700; letter-spacing: 0.12em;
  text-transform: uppercase; color: var(--text-4); margin-bottom: 3px;
  display: flex; align-items: center; gap: 3px;
}
.phb-stat-record {
  font-family: var(--font-display); font-size: 18px;
  font-weight: 700; color: var(--text-1); line-height: 1;
}
.phb-stat-val {
  font-family: var(--font-display); font-size: 18px;
  font-weight: 700; line-height: 1;
}
.phb-stat-val.green { color: var(--green); }
.phb-stat-val.red   { color: var(--red);   }
.phb-stat-val.muted { color: var(--text-4); font-size: 16px; }
/* CLV shown neutral on Today — flat/near-zero is not a proven edge (never green-by-sign) */
.phb-stat-val.clv-flat { color: var(--text); }
.phb-stat-sub {
  font-size: 9px; color: var(--text-4); margin-top: 2px;
}
.phb-vdivider {
  width: 1px; height: 32px; background: var(--border);
  margin: 0 18px 0 0; flex-shrink: 0; align-self: center;
}
.phb-right-group {
  display: flex; align-items: center; gap: 10px;
  margin-left: auto; flex-shrink: 0;
}
/* Row 2 — sizing controls */
.phb-sizing-row {
  display: flex; align-items: center; gap: 14px;
  padding: 10px 18px; border-top: 1px solid var(--border);
  flex-wrap: wrap;
}
/* Segmented toggle */
.phb-toggle {
  display: flex; align-items: center;
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--border); border-radius: 7px;
  padding: 2px; gap: 2px; flex-shrink: 0;
}
.phb-tog {
  padding: 5px 14px; border-radius: 5px; border: none;
  font-size: 11px; font-weight: 600; cursor: pointer;
  background: transparent; color: var(--text-4);
  transition: all 0.15s; white-space: nowrap; font-family: inherit;
}
.phb-tog:hover { color: var(--text-2); }
.phb-tog.active {
  background: var(--bg-card);
  color: var(--text-1);
  box-shadow: 0 1px 3px rgba(0,0,0,0.25);
  border: 1px solid var(--border);
}
/* Bankroll input */
.phb-bankroll {
  display: flex; align-items: center; gap: 7px; flex-shrink: 0;
}
.phb-bk-label {
  font-size: 10px; font-weight: 600; color: var(--text-3);
  white-space: nowrap;
}
.phb-bk-input-wrap {
  display: flex; align-items: center; gap: 2px;
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--border); border-radius: 6px;
  padding: 3px 8px;
}
.phb-bk-input-wrap:focus-within {
  border-color: rgba(99,102,241,0.4);
}
.phb-bk-dollar { font-size: 11px; color: var(--text-4); }
.phb-bk-input {
  background: transparent; border: none; outline: none;
  font-family: var(--font-mono); font-size: 11px;
  color: var(--text-2); width: 72px; text-align: right;
}
.phb-bk-input::placeholder { color: var(--text-4); }
/* Helper text */
.phb-helper {
  font-size: 10px; color: var(--text-4); font-style: italic;
  flex: 1; min-width: 0;
}
.phb-helper strong { color: var(--indigo-lt); font-style: normal; font-weight: 600; }
/* Streak mini-chip inside phb */
.phb-streak {
  display: flex; flex-direction: column; align-items: center;
  padding: 4px 10px; background: rgba(255,255,255,0.03);
  border: 1px solid var(--border); border-radius: 6px;
}
.phb-streak-lbl { font-size: 7.5px; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; color: var(--text-4); }
.phb-streak-val { font-family: var(--font-display); font-size: 16px; font-weight: 700; line-height: 1.1; }
.phb-streak-val.W { color: var(--green); }
.phb-streak-val.L { color: var(--red); }
/* Kelly mode: bankroll grays out in flat mode */
.phb-bankroll.flat-mode .phb-bk-label,
.phb-bankroll.flat-mode .phb-bk-dollar { opacity: 0.45; }

/* ── Single-column pick list (inline expansion, no grid ambiguity) ── */
.pick-grid {
  grid-template-columns: 1fr !important;
}

/* Right panel container */
.md-panel {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: 12px;
  overflow: hidden;
}
/* det-v8-panel always visible inside the right panel */
#md-right .det-v8-panel { display: block; overflow-x: hidden; }
/* Force single column — wrapper class is prob-action-v8 */
#md-right .prob-action-v8 { grid-template-columns: 1fr !important; }
#md-right .pa-v8-col.prob-c { border-right: none; border-bottom: 1px solid rgba(255,255,255,.04); }
#md-right .pa-v8-col.action-c { background: none; }
/* Section padding */
#md-right .det-v8-sec { padding: 12px 16px; }
/* Larger section header labels */
#md-right .det-v8-hdr {
  font-size: 9.5px !important;
  color: var(--text-3) !important;
  letter-spacing: .16em;
  margin-bottom: 10px;
}
/* Larger Win Probability Gap numbers */
#md-right .pv-val { font-size: 26px !important; }
#md-right .pv-val.edgev { font-size: 18px !important; }
#md-right .prob-v8-bar { height: 12px !important; border-radius: 5px !important; }
#md-right .pv-mkt, #md-right .pv-edge { border-radius: 0 !important; }
/* Prevent horizontal overflow */
#md-right { overflow-x: hidden; }

/* Two-row panel header */
.md-hdr-r1 { display:flex;align-items:center;gap:10px;margin-bottom:7px }
.md-hdr-r2 { display:flex;align-items:center;gap:7px;font-size:11px;flex-wrap:wrap }
.md-hdr-edge { font-family:var(--font-mono);font-weight:700;font-size:12px }
.v .md-hdr-edge,.value .md-hdr-edge { color:var(--green) }
.cond .md-hdr-edge,.conditional .md-hdr-edge { color:var(--amber) }
.md-hdr-model { color:var(--text-2) }
.md-hdr-model strong { color:#60a5fa }
.md-hdr-market { color:var(--text-3) }
.md-hdr-market strong { color:var(--text-2) }
.md-hdr-sep { color:rgba(255,255,255,.12);user-select:none }
.md-hdr-game { font-size:10px;color:var(--text-4) }
/* Verdict badge in header */
.md-vbadge { font-size:9.5px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;padding:2px 8px;border-radius:4px }
.md-vbadge.value  { background:rgba(34,197,94,.10);color:var(--green);border:1px solid rgba(34,197,94,.22) }
.md-vbadge.strong { background:rgba(245,158,11,.10);color:var(--amber);border:1px solid rgba(245,158,11,.22) }
.md-vbadge.conditional,.md-vbadge.reduced { background:rgba(245,158,11,.08);color:var(--amber);border:1px solid rgba(245,158,11,.18) }
.md-vbadge.watchlist,.md-vbadge.marginal { background:rgba(99,102,241,.08);color:var(--indigo-lt);border:1px solid rgba(99,102,241,.18) }

/* Below-threshold collapsible */
.odds-below-toggle { font-size:10px;color:var(--text-4);cursor:pointer;margin-top:6px;list-style:none }
.odds-below-toggle::-webkit-details-marker { display:none }
.odds-below-toggle summary { display:flex;align-items:center;gap:5px;padding:3px 0 }
.odds-below-toggle summary::before { content:'▶';font-size:8px;transition:transform .15s }
.odds-below-toggle[open] summary::before { transform:rotate(90deg) }

/* Right panel header (pick identity + close) */
.md-panel-hdr {
  display: flex; align-items: center; gap: 10px;
  padding: 11px 14px; border-bottom: 1px solid var(--border);
  background: rgba(255,255,255,.02); flex-wrap: wrap;
}
.md-panel-team {
  font-family: var(--font-display); font-size: 20px; font-weight: 800;
  color: var(--text-1, #f1f5f9); letter-spacing: .02em; line-height: 1;
}
.md-panel-odds { font-family: var(--font-mono); font-size: 15px; font-weight: 700; }
.md-panel-odds.neg { color: var(--indigo-lt); }
.md-panel-odds.pos { color: var(--amber); }
.md-panel-edge {
  font-size: 9.5px; font-weight: 700; padding: 2px 8px; border-radius: 4px;
  background: rgba(34,197,94,.09); color: var(--green);
  border: 1px solid rgba(34,197,94,.20);
}
.md-panel-game { font-size: 10px; color: var(--text-3); }
.md-panel-close {
  margin-left: auto; font-size: 11px; font-weight: 600; color: var(--text-4);
  background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.07);
  border-radius: 6px; padding: 4px 10px; cursor: pointer; transition: all .15s;
  font-family: var(--font-ui);
}
.md-panel-close:hover { color: var(--text-2); background: rgba(255,255,255,.07); }

/* Placeholder: shown when no pick is selected */
.md-placeholder {
  display: flex; flex-direction: column; align-items: center;
  justify-content: center; text-align: center;
  padding: 36px 24px; gap: 10px; min-height: 260px;
}
.mdp-icon { font-size: 28px; opacity: .3; }
.mdp-title {
  font-family: var(--font-display); font-size: 17px; font-weight: 700;
  color: var(--text-3); letter-spacing: .04em;
}
.mdp-sub { font-size: 11px; color: var(--text-4); line-height: 1.6; max-width: 210px; }
.mdp-picks { display: flex; flex-direction: column; gap: 6px; margin-top: 8px; width: 100%; }
.mdp-pick-btn {
  display: flex; align-items: center; gap: 8px;
  font-family: var(--font-ui); font-size: 11px; font-weight: 600;
  color: var(--text-3); background: rgba(255,255,255,.03);
  border: 1px solid var(--border); border-radius: 8px;
  padding: 8px 12px; cursor: pointer; text-align: left; transition: all .15s;
}
.mdp-pick-btn:hover {
  color: var(--text-2); background: rgba(255,255,255,.06);
  border-color: rgba(99,102,241,.25);
}
.mdp-pick-team {
  font-family: var(--font-display); font-size: 16px; font-weight: 800;
  color: var(--text); line-height: 1;
}
.mdp-pick-odds { font-family: var(--font-mono); font-size: 12px; }
.mdp-pick-game { font-size: 10px; color: var(--text-4); flex: 1; }
.mdp-pick-edge {
  font-family: var(--font-mono); font-size: 10px;
  color: var(--green); margin-left: auto; flex-shrink: 0;
}

/* Active card highlight when selected in master-detail */
.pick-card.ep-active {
  border-color: rgba(99,102,241,.40) !important;
  box-shadow: 0 0 0 1px rgba(99,102,241,.10);
}

/* ── Corrected exposure block (replaces today-action-strip) ── */
.exposure-block {
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: 12px; padding: 14px 18px; margin-bottom: 14px;
}
/* Compact one-line exposure summary (replaces the 4-card exposure band) */
.exposure-line {
  display: flex; flex-wrap: wrap; align-items: baseline; gap: 7px;
  font-size: 11.5px; color: var(--text-3); font-family: var(--font-ui);
  padding: 9px 14px; margin-bottom: 14px;
  background: rgba(255,255,255,0.02); border: 1px solid var(--border); border-radius: 8px;
}
.exposure-line .exl-title { font-size: 9px; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; color: var(--text-4); }
.exposure-line .exl-item strong { font-family: var(--font-mono); color: var(--text-1); font-weight: 700; }
.exposure-line .exl-item strong.g { color: var(--green); }
.exposure-line .exl-sep { color: var(--text-4); }
.exposure-line .exl-mode { margin-left: auto; font-size: 10px; color: var(--text-4); font-family: var(--font-mono); }
@media (max-width: 600px) { .exposure-line .exl-mode { margin-left: 0; } }
.eb-top {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 12px; flex-wrap: wrap; gap: 10px;
}
.eb-title {
  font-size: 9px; font-weight: 700; letter-spacing: .14em;
  text-transform: uppercase; color: var(--text-3);
}
.eb-sizing { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.eb-kelly-pill {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 10px; font-weight: 600; color: var(--green);
  background: rgba(34,197,94,.07); border: 1px solid rgba(34,197,94,.20);
  border-radius: 6px; padding: 4px 10px; white-space: nowrap;
}
.eb-ka-dot {
  width: 5px; height: 5px; border-radius: 50%; background: var(--green);
  animation: pulsedot 2s infinite; flex-shrink: 0;
}
.eb-flat-lbl {
  font-size: 10px; color: var(--text-4); white-space: nowrap;
}
.eb-bankroll {
  font-family: var(--font-mono); font-size: 10px; color: var(--text-2);
  padding: 4px 10px; background: rgba(255,255,255,.04);
  border: 1px solid var(--border); border-radius: 6px; white-space: nowrap;
}
.eb-grid {
  display: grid; grid-template-columns: repeat(4,1fr); gap: 9px;
}
@media (max-width: 540px) { .eb-grid { grid-template-columns: repeat(2,1fr); } }
.eb-stat {
  background: rgba(255,255,255,.02); border: 1px solid rgba(255,255,255,.05);
  border-radius: 8px; padding: 9px 11px;
}
.eb-stat.hi { border-color: rgba(34,197,94,.14); background: rgba(34,197,94,.025); }
.eb-lbl { font-size: 7.5px; font-weight: 700; letter-spacing: .11em; text-transform: uppercase; color: var(--text-4); margin-bottom: 2px; }
.eb-val { font-family: var(--font-mono); font-size: 17px; font-weight: 700; color: var(--text); line-height: 1; }
.eb-val.g { color: var(--green); }
.eb-sub { font-size: 8.5px; color: var(--text-3); margin-top: 2px; }

/* Kelly active indicator pill */
.phb-kelly-active {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 11px; font-weight: 600; color: var(--green);
  background: rgba(34,197,94,0.08); border: 1px solid rgba(34,197,94,0.22);
  border-radius: 6px; padding: 5px 12px; white-space: nowrap; flex-shrink: 0;
}
.phb-ka-dot {
  width: 6px; height: 6px; border-radius: 50%; background: var(--green);
  animation: pulsedot 2s infinite; flex-shrink: 0;
}
@media (max-width: 600px) {
  .phb-stats-row { padding: 12px 14px; }
  .phb-stat-group { padding-right: 12px; }
  .phb-vdivider { margin-right: 12px; }
  .phb-sizing-row { padding: 8px 14px; gap: 10px; }
  .phb-helper { display: none; }
}

/* ── Email Capture ── */
.email-capture-section {
  background: linear-gradient(135deg, rgba(99,102,241,0.07) 0%, rgba(15,23,42,0) 100%);
  border: 1px solid rgba(99,102,241,0.22);
  border-radius: 12px;
  margin: 8px 0 24px;
  padding: 28px 24px 22px;
}
.ec-inner { display: flex; flex-direction: column; gap: 14px; }
.ec-badge {
  display: inline-flex; align-items: center; gap: 6px;
  background: rgba(99,102,241,0.12); border: 1px solid rgba(99,102,241,0.25);
  border-radius: 20px; color: #818cf8; font-size: 0.72rem; font-weight: 700;
  letter-spacing: 0.06em; padding: 3px 10px; text-transform: uppercase; width: fit-content;
}
.ec-headline { font-size: 1.05rem; font-weight: 700; color: var(--text); margin: 0; }
.ec-sub { font-size: 0.84rem; color: var(--text-3, #94a3b8); line-height: 1.65; margin: 0; }
.ec-form { display: flex; gap: 8px; }
.ec-input {
  flex: 1; background: rgba(255,255,255,0.05); border: 1px solid rgba(255,255,255,0.11);
  border-radius: 7px; color: var(--text); font-size: 0.88rem; min-width: 0;
  outline: none; padding: 10px 14px; transition: border-color 0.15s;
}
.ec-input::placeholder { color: var(--text-4, #475569); }
.ec-input:focus { border-color: rgba(99,102,241,0.55); }
.ec-btn {
  background: var(--accent, #6366f1); border: none; border-radius: 7px; color: #fff;
  cursor: pointer; font-size: 0.84rem; font-weight: 600; padding: 10px 18px;
  transition: background 0.15s; white-space: nowrap;
}
.ec-btn:hover { background: #4f46e5; }
.ec-success {
  background: rgba(34,197,94,0.08); border: 1px solid rgba(34,197,94,0.25);
  border-radius: 7px; color: #4ade80; font-size: 0.84rem;
  padding: 10px 14px; display: none;
}
.ec-fine { color: var(--text-4, #475569); font-size: 0.76rem; margin: 0; }
@media (max-width: 560px) {
  .ec-form { flex-direction: column; }
  .ec-btn { width: 100%; }
}

/* ── Transparency Standards: collapsible ── */
.transparency-section .ts-header { cursor: pointer; user-select: none; }
.ts-list-wrap { display: none; }
.transparency-section.open .ts-list-wrap { display: block; }
.ts-chevron { font-size: 10px; color: var(--text-4); margin-left: auto; transition: transform 0.2s; }
.transparency-section.open .ts-chevron { transform: rotate(180deg); }

/* ── Floating results indicator ── */
#floating-results {
  position: fixed; bottom: 20px; right: 20px; z-index: 1000;
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: 20px; padding: 6px 14px;
  font-size: 11px; font-weight: 600; color: var(--text-2);
  box-shadow: 0 4px 12px rgba(0,0,0,0.3);
  display: none; align-items: center; gap: 6px;
  cursor: pointer; transition: opacity 0.2s;
}
#floating-results:hover { opacity: 0.8; }
#floating-results .fr-dot { width: 6px; height: 6px; border-radius: 50%; flex-shrink: 0; }
#floating-results .fr-dot.live { background: var(--green); animation: pulsedot 1.4s infinite; }
#floating-results .fr-dot.done { background: var(--text-4); }

/* ── Share card modal ── */
.share-modal-overlay {
  position: fixed; inset: 0; z-index: 9000;
  background: rgba(3,5,8,0.88);
  display: flex; align-items: center; justify-content: center;
  padding: 20px; overflow-y: auto;
}
.share-modal-overlay.hidden { display: none; }
.share-modal-box {
  background: #0f1829; border: 1px solid rgba(255,255,255,0.1);
  border-radius: 14px; width: min(92vw, 700px);
  overflow: hidden; display: flex; flex-direction: column;
  box-shadow: 0 24px 60px rgba(0,0,0,0.7); flex-shrink: 0;
}
.share-modal-hdr {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 20px; border-bottom: 1px solid rgba(255,255,255,0.07);
}
.share-modal-title {
  font-size: 13px; font-weight: 700; letter-spacing: 0.06em;
  text-transform: uppercase; color: var(--text-3);
}
.share-modal-close {
  background: rgba(255,255,255,0.05); border: 1px solid rgba(255,255,255,0.1);
  border-radius: 7px; padding: 4px 12px; font-size: 11px; font-weight: 600;
  color: var(--text-3); cursor: pointer; transition: all 0.15s;
}
.share-modal-close:hover { color: var(--text-1); background: rgba(255,255,255,0.09); }
.share-modal-preview {
  padding: 0; display: flex; justify-content: center; align-items: flex-start;
  background: #06090f; overflow: hidden; position: relative;
}
/* Scale wrapper: the .sc.sq card is 1080px wide; we scale it down to fit */
.share-modal-scale {
  transform-origin: top center;
  display: inline-block; flex-shrink: 0;
}
.share-modal-actions {
  display: flex; align-items: center; gap: 10px; padding: 16px 20px;
  border-top: 1px solid rgba(255,255,255,0.07); flex-wrap: wrap;
}
.share-dl-btn {
  display: inline-flex; align-items: center; gap: 6px;
  background: rgba(34,197,94,0.12); border: 1px solid rgba(34,197,94,0.3);
  border-radius: 7px; padding: 9px 18px;
  font-size: 12px; font-weight: 700; color: var(--green);
  cursor: pointer; transition: all 0.15s; font-family: inherit;
}
.share-dl-btn:hover { background: rgba(34,197,94,0.2); }
.share-dl-btn:disabled { opacity: 0.5; cursor: default; }
.share-native-btn {
  display: inline-flex; align-items: center; gap: 6px;
  background: rgba(99,102,241,0.12); border: 1px solid rgba(99,102,241,0.3);
  border-radius: 7px; padding: 9px 18px;
  font-size: 12px; font-weight: 700; color: var(--indigo-lt);
  cursor: pointer; transition: all 0.15s; font-family: inherit;
}
.share-native-btn:hover { background: rgba(99,102,241,0.2); }
.share-modal-hint {
  font-size: 10px; color: var(--text-4); font-style: italic;
}

/* ── Approved share card — 6-section design, 1080×1080 ── */
/* Heights: 62+198+280+200+150+190 = 1080px */
.sc-modal {
  font-family: "Inter", sans-serif;
  display: flex; flex-direction: column;
  position: relative; overflow: hidden; flex-shrink: 0;
  background: #060910; width: 1080px; height: 1080px;
}
.sc-modal::before {
  content: ''; position: absolute; left: 0; top: 0; bottom: 0;
  width: 4px; z-index: 2;
}
.sc-modal.val::before  { background: linear-gradient(175deg,#22c55e 0%,rgba(34,197,94,.08) 100%); }
.sc-modal.cond::before { background: linear-gradient(175deg,#f59e0b 0%,rgba(245,158,11,.06) 100%); }
.sc-modal.val::after {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 380px;
  background: radial-gradient(ellipse 110% 380px at 45% -60px,rgba(34,197,94,.075) 0%,transparent 100%);
  pointer-events: none; z-index: 0;
}
.sc-modal.cond::after {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 380px;
  background: radial-gradient(ellipse 110% 380px at 45% -60px,rgba(245,158,11,.06) 0%,transparent 100%);
  pointer-events: none; z-index: 0;
}
.sc-modal > * { position: relative; z-index: 1; }
.scm-topbar { position:absolute;top:0;left:0;right:0;height:6px;background:var(--team-accent,#3a4658);z-index:3; }
/* Header */
.scm-hdr { display:flex;align-items:center;height:78px;flex-shrink:0;padding:0 48px 0 46px;border-bottom:1px solid rgba(255,255,255,.055); }
.scm-brand { display:flex;align-items:center;gap:14px; }
.scm-logo { width:50px;height:50px;flex-shrink:0;background:rgba(99,102,241,.14);border:1px solid rgba(99,102,241,.34);border-radius:50%;display:flex;align-items:center;justify-content:center; }
.scm-wm { font-family:"Barlow Condensed",sans-serif;font-size:29px;font-weight:800;letter-spacing:.04em;color:#eaf2fb;line-height:1; }
.scm-wm .f { color:#8fa6bd;font-weight:600; }
.scm-wm em { color:var(--indigo-lt);font-style:normal;font-weight:700;font-size:.74em;letter-spacing:.06em; }
.scm-tagline { font-family:"Inter",sans-serif;font-size:13px;font-weight:500;color:#5f7c98;letter-spacing:.01em;margin-top:4px; }
.scm-badge { font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:4px 12px;border-radius:5px;margin:0 auto; }
.scm-badge.val  { background:rgba(34,197,94,.09);color:#2ecc71;border:1px solid rgba(34,197,94,.24); }
.scm-badge.cond { background:rgba(245,158,11,.09);color:#f5a523;border:1px solid rgba(245,158,11,.22); }
.scm-date { font-family:"IBM Plex Mono",monospace;font-size:13px;font-weight:500;color:#4a6880;margin-left:auto; }
/* Lineup */
.scm-lineup { display:flex;flex-direction:column;justify-content:center;height:170px;flex-shrink:0;padding:0 46px;border-bottom:1px solid rgba(255,255,255,.055);gap:12px; }
.scm-matchup-row { display:flex;align-items:center;gap:16px; }
.scm-matchup-name { font-family:"Barlow Condensed",sans-serif;font-size:24px;font-weight:700;letter-spacing:.04em;color:#7a9ab8; }
.scm-matchup-sep { color:rgba(255,255,255,.15); }
.scm-gametime { font-family:"IBM Plex Mono",monospace;font-size:13px;color:#445a6e; }
.scm-pitchers { display:flex;align-items:baseline;gap:12px;font-family:"Inter",sans-serif;line-height:1.2; }
.scm-pitcher-pick { font-size:21px;font-weight:700;color:#d4ecff; }
.scm-pitcher-opp  { font-size:21px;font-weight:700;color:#4a6878; }
.scm-pitcher-xfip { font-family:"IBM Plex Mono",monospace;font-size:15px;font-weight:600;color:#4a6a80; }
.scm-pitcher-vs   { font-size:14px;font-weight:400;color:#2e4050;font-family:"Barlow Condensed",sans-serif;letter-spacing:.03em; }
.scm-lineup-status { display:flex;align-items:center;gap:20px;font-size:14px;font-family:"Inter",sans-serif; }
.scm-lu-item { display:flex;align-items:center;gap:7px; }
.scm-lu-dot { width:7px;height:7px;border-radius:50%;flex-shrink:0; }
.scm-lu-dot.proj { background:#f59e0b; } .scm-lu-dot.conf { background:#22c55e; }
.scm-lu-team { font-size:14px;font-weight:600;color:#6a8ea8; }
.scm-lu-stat.proj { color:#d4901a; } .scm-lu-stat.conf { color:#22c55e; }
.scm-lu-warn { font-size:13px;color:#c08020;margin-left:6px; }
/* Pick + Stats two-column */
.scm-pick-stats { display:flex;align-items:stretch;height:220px;flex-shrink:0;border-bottom:1px solid rgba(255,255,255,.055); }
.scm-pick-left { flex:1;min-width:0;display:flex;flex-direction:column;justify-content:center;padding:0 32px 0 46px;border-right:1px solid rgba(255,255,255,.055);gap:12px; }
.scm-pick-headline { display:flex;align-items:baseline;gap:14px;line-height:1; }
.scm-team { font-family:"Barlow Condensed",sans-serif;font-size:130px;font-weight:900;color:#f0f8ff;letter-spacing:-.015em;line-height:.84; }
.scm-bet-type { font-family:"Barlow Condensed",sans-serif;font-size:52px;font-weight:500;color:#7090a8;letter-spacing:.02em;padding-bottom:8px; }
.scm-odds { font-family:"Barlow Condensed",sans-serif;font-size:130px;font-weight:800;line-height:.84;letter-spacing:-.01em; }
.scm-odds.neg, .scm-odds.pos { color:#eef4fb; }
.scm-stake-row { display:flex;align-items:baseline;gap:14px; }
.scm-stake-lbl { font-size:9.5px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:#2e4050;flex-shrink:0; }
.scm-stake-val { font-family:"IBM Plex Mono",monospace;font-size:42px;font-weight:700;color:#eef4fb;line-height:1; }
.scm-stake-note { font-size:13px;color:#56708a;font-family:"Inter",sans-serif; }
.scm-pick-right { width:320px;flex-shrink:0;display:flex;flex-direction:column;justify-content:center;padding:0 46px 0 32px;gap:22px; }
.scm-stat-item { display:flex;flex-direction:column;gap:6px; }
.scm-stat-lbl { font-size:9px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:#2e4050; }
.scm-stat-lbl.play { color:#8a6820; }
.scm-stat-val { font-family:"IBM Plex Mono",monospace;font-size:36px;font-weight:700;line-height:1; }
.scm-stat-val.play { color:#f5a523; } .scm-stat-val.fair { color:#818cf8; } .scm-stat-val.book { color:#6a90a8;font-size:28px; }
.scm-stat-sub { font-size:11px;color:#2a3e4e;font-family:"Inter",sans-serif; }
/* Best-price block (sole right-column stat — fair/playable removed) */
.scm-best-block { display:flex;flex-direction:column;gap:4px;padding:20px 22px;background:rgba(34,197,94,.05);border:1px solid rgba(34,197,94,.18);border-radius:14px; }
.scm-best-odds { font-family:"Barlow Condensed",sans-serif;font-size:62px;font-weight:800;line-height:.9;color:#4ade80; }
.scm-best-book { font-family:"IBM Plex Mono",monospace;font-size:20px;font-weight:600;color:#7fae90;line-height:1; }
/* Result-card variant (settled picks) */
.scm-badge.won  { background:rgba(34,197,94,.12);color:#34d36a;border:1px solid rgba(34,197,94,.30); }
.scm-badge.lost { background:rgba(239,68,68,.10);color:#f0726f;border:1px solid rgba(239,68,68,.26); }
.scm-result-block { display:flex;flex-direction:column;gap:5px;padding:20px 22px;border-radius:14px; }
.scm-result-block.won  { background:rgba(34,197,94,.06);border:1px solid rgba(34,197,94,.22); }
.scm-result-block.lost { background:rgba(239,68,68,.05);border:1px solid rgba(239,68,68,.20); }
.scm-result-word { font-family:"Barlow Condensed",sans-serif;font-size:48px;font-weight:800;line-height:.9;letter-spacing:.01em; }
.scm-result-word.won  { color:#34d36a; } .scm-result-word.lost { color:#f0726f; }
.scm-result-pnl { font-family:"IBM Plex Mono",monospace;font-size:24px;font-weight:700;color:#9fb4c4;line-height:1; }
/* Loss accent for the whole card */
.sc-modal.lost::before { background:linear-gradient(175deg,#ef4444 0%,rgba(239,68,68,.08) 100%); }
.sc-modal.lost::after  { content:'';position:absolute;top:0;left:0;right:0;height:380px;background:radial-gradient(ellipse 110% 380px at 45% -60px,rgba(239,68,68,.06) 0%,transparent 100%);pointer-events:none;z-index:0; }
.sc-modal.lost .scm-edge-num { color:#f0726f; }
.sc-modal.lost .scm-edge-kicker { color:rgba(240,114,111,.85); }
.sc-modal.lost .scm-bar-edg { background:rgba(239,68,68,.55); }
.sc-modal.lost .scm-driver-inner { border-color:rgba(239,68,68,.45); }
/* Edge + bar */
.scm-edge { display:flex;flex-direction:column;justify-content:center;height:228px;flex-shrink:0;padding:0 46px;border-bottom:1px solid rgba(255,255,255,.055);gap:20px; }
.scm-edge-top { display:flex;align-items:baseline;gap:18px; }
.scm-edge-num { font-family:"IBM Plex Mono",monospace;font-size:84px;font-weight:700;line-height:.92; }
.sc-modal.val  .scm-edge-num { color:#4ade80; }
.sc-modal.cond .scm-edge-num { color:#f5a523; }
.scm-edge-kicker { font-size:18px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;align-self:center; }
.sc-modal.val  .scm-edge-kicker { color:rgba(74,222,128,.88); }
.sc-modal.cond .scm-edge-kicker { color:rgba(245,165,35,.85); }
.scm-bar-hdr { display:flex;justify-content:space-between;margin-bottom:9px; }
.scm-bar-lbl { font-size:14px;font-weight:600;letter-spacing:.03em;text-transform:uppercase;font-family:"Inter",sans-serif; }
.scm-bar-lbl.mkt { color:#3e5870; } .scm-bar-lbl.mdl { color:#5a80a0; }
.scm-bar-track { height:26px;background:rgba(255,255,255,.05);border-radius:7px;position:relative;overflow:hidden; }
.scm-bar-mkt { position:absolute;left:0;top:0;bottom:0;background:rgba(80,110,140,.55);border-radius:6px 0 0 6px; }
.scm-bar-edg { position:absolute;top:0;bottom:0;border-radius:0 6px 6px 0; }
.sc-modal.val  .scm-bar-edg { background:rgba(74,222,128,.70); }
.sc-modal.cond .scm-bar-edg { background:rgba(245,165,35,.70); }
/* Driver */
.scm-driver-section { display:flex;align-items:center;height:164px;flex-shrink:0;padding:0 46px;border-bottom:1px solid rgba(255,255,255,.055); }
.scm-driver-inner { border-left:3px solid;padding-left:20px; }
.sc-modal.val  .scm-driver-inner { border-color:rgba(34,197,94,.50); }
.sc-modal.cond .scm-driver-inner { border-color:rgba(245,158,11,.45); }
.scm-driver-text { font-family:"Inter",sans-serif;font-size:18px;font-weight:500;color:#90b0c8;line-height:1.48; }
.scm-driver-text strong { color:#c4dff0;font-weight:600; }
/* Model factor decomposition (inputs) */
.scm-factors { display:flex;flex-wrap:wrap;gap:7px 18px;margin-top:14px; }
.scm-factor { display:flex;align-items:baseline;gap:6px;font-family:"Inter",sans-serif; }
.scm-factor-lbl { font-size:13px;color:#5a7088; }
.scm-factor-pp { font-family:"IBM Plex Mono",monospace;font-size:14px;font-weight:700; }
.scm-factor-pp.pos { color:#4ade80; } .scm-factor-pp.neg { color:#f0726f; }
/* Edge-tier track record (credibility) */
.scm-tier-line { font-family:"Inter",sans-serif;font-size:13.5px;color:#5a7088;margin-top:6px;letter-spacing:.01em; }
.scm-tier-tag { font-weight:600;color:#7e98b0; }
.scm-tier-roi { font-family:"IBM Plex Mono",monospace;color:#4ade80;font-weight:700; }
/* Footer */
.scm-ftr { display:flex;flex-direction:column;justify-content:space-between;height:220px;flex-shrink:0;padding:26px 46px 24px;background:rgba(0,0,0,.22); }
.scm-ftr-url { font-family:"Barlow Condensed",sans-serif;font-size:30px;font-weight:700;letter-spacing:.06em;color:#527898; }
.scm-ftr-record { font-family:"IBM Plex Mono",monospace;font-size:14px;color:#3a5262;font-weight:500;line-height:1.6; }
.scm-ftr-meta { display:flex;align-items:center;gap:14px;flex-wrap:wrap; }
.scm-fi { display:flex;align-items:center;gap:6px; }
.scm-fi-lbl { font-size:8.5px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#1e2e3a; }
.scm-fi-val { font-family:"IBM Plex Mono",monospace;font-size:12px;color:#3a5262;font-weight:500; }
.scm-fi-dot { width:3px;height:3px;border-radius:50%;background:#101820;flex-shrink:0; }
.scm-ftr-disc { font-size:11px;color:#41566a;letter-spacing:.02em;font-family:"Inter",sans-serif;line-height:1.55; }

/* ── Styled inline disclaimer box ── */
.site-disclaimer-box {
  display: flex; align-items: flex-start; gap: 8px;
  padding: 10px 14px; border-radius: 8px; margin-bottom: 16px;
  background: rgba(255,255,255,0.02); border: 1px solid rgba(255,255,255,0.06);
  font-size: 10px; color: var(--text-4); line-height: 1.55;
}
.sdb-icon { font-size: 12px; flex-shrink: 0; margin-top: 1px; }
.sdb-text { flex: 1; }

@media (max-width: 600px) {
  /* Header block: stats wrap into 2×3 grid on mobile */
  .phb-stats-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0;
    padding: 12px 14px;
  }
  .phb-stat-group {
    padding: 10px 8px;
    border-right: none;
    border-bottom: 1px solid var(--border);
  }
  .phb-stat-group:nth-child(odd) { border-right: 1px solid var(--border); }
  .phb-stat-group:last-child,
  .phb-stat-group:nth-last-child(2):nth-child(odd) { border-bottom: none; }
  .phb-vdivider { display: none; }
  .phb-stat-val { font-size: 18px; }
  .phb-stat-record { font-size: 18px; }
  .phb-right-group { display: none; }
  /* Sizing row: stack toggle + bankroll */
  .phb-sizing-row { flex-direction: column; gap: 10px; align-items: flex-start; }
  .phb-helper { display: none; }
}

@media (max-width: 600px) {
  /* Pick card action row: larger touch targets */
  .uc-action-row-v2 { gap: 0; }
  .uav-btn { padding: 6px 12px; font-size: 12px; }
  .uav-sep { padding: 0 2px; }
}

@media (max-width: 480px) {
  /* Floating results indicator: move up and shrink on very small screens */
  #floating-results { bottom: 12px; right: 12px; font-size: 10px; padding: 5px 11px; }
}

/* ── v8 Pick Card: collapsed card hierarchy ── */
.pc-v8-top { display:flex;align-items:center;flex-wrap:wrap;gap:5px;padding:10px 14px 0 }
.pc-v8-verdict-row { display:flex;align-items:center;gap:5px;flex-wrap:wrap;margin-bottom:0 }

/* Context tags (Away Fav / Home Dog etc.) */
.ctx-tag-v8 { font-size:9px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;padding:2px 7px;border-radius:4px;flex-shrink:0;font-family:var(--font-ui) }
.ctx-tag-v8.fav  { background:rgba(99,102,241,.10);color:var(--indigo-lt);border:1px solid rgba(99,102,241,.20) }
.ctx-tag-v8.dog  { background:rgba(245,158,11,.10);color:var(--amber);border:1px solid rgba(245,158,11,.20) }
.ctx-tag-v8.hfav { background:rgba(34,197,94,.08);color:var(--green);border:1px solid rgba(34,197,94,.18) }

/* Pick price subtitle */
.pc-v8-price-meta { font-size:9.5px;color:var(--text-3);font-weight:500;margin-top:3px;font-family:var(--font-ui) }
.pc-v8-price-meta strong { color:var(--text-2);font-weight:600 }

/* Key metric strip */
.pc-v8-nums { display:flex;padding:6px 14px 0;border-top:1px solid rgba(255,255,255,.045);margin-top:6px }
.pc-v8-num { flex:1;padding:6px 0;border-right:1px solid var(--border) }
.pc-v8-num:last-child { border-right:none }
.pc-v8-num:not(:first-child) { padding-left:8px }
.pc-v8-num .nv-lbl { font-size:9.5px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--text-3);margin-bottom:3px;font-family:var(--font-ui) }
.pc-v8-num .nv-val { font-family:var(--font-mono);font-size:13px;font-weight:600;color:var(--text) }
.pc-v8-num .nv-val.edge  { color:var(--green) }
.pc-v8-num .nv-val.model { color:#60a5fa }
.pc-v8-num .nv-val.fair  { color:var(--indigo-lt) }
.pc-v8-num .nv-val.play  { color:var(--amber) }
@media(max-width:380px) { .pc-v8-num .nv-val { font-size:11px } .pc-v8-num .nv-lbl { font-size:7px } }

/* Probability bar */
.pc-v8-bar { padding:10px 14px 8px }
.pc-v8-bar .pb8-hdr { display:flex;justify-content:space-between;align-items:center;margin-bottom:6px }
.pc-v8-bar .pb8-lbl { font-size:12px;font-weight:600;letter-spacing:.03em;text-transform:uppercase;font-family:var(--font-ui) }
.pc-v8-bar .pb8-lbl.mkt { color:var(--text-3) }
.pc-v8-bar .pb8-lbl.mdl { color:#60a5fa }
.pc-v8-bar .pb8-edge-ctr { font-family:var(--font-mono);font-size:12px;font-weight:700;color:var(--green) }
.pc-v8-bar .pb8-edge-ctr.wl { color:var(--indigo-lt) }
.pc-v8-bar .pb8-track { height:7px;background:rgba(255,255,255,.05);border-radius:4px;position:relative;overflow:hidden }
.pb8-mkt-fill { position:absolute;left:0;top:0;bottom:0;background:rgba(115,130,155,.45);border-radius:4px 0 0 4px }
.pb8-edge-fill { position:absolute;top:0;bottom:0;background:rgba(34,197,94,.65);border-radius:0 4px 4px 0 }
.pb8-edge-fill.wl { background:rgba(99,102,241,.45) }
.pb8-tick { position:absolute;top:-2px;bottom:-2px;width:2px;background:var(--indigo-lt);border-radius:2px;box-shadow:0 0 5px rgba(129,140,248,.9);transition:left .4s }
.pc-v8-bar .pb8-legend { font-size:9.5px;color:var(--text-4);text-align:center;margin-top:5px;letter-spacing:.02em;font-family:var(--font-ui) }
/* Single shared bar legend above the pick list (replaces the per-card legend) */

/* Stake + lineup row */
.pc-v8-sl-row { display:flex;align-items:stretch;gap:8px;padding:8px 14px }
.stake-v8 { background:rgba(255,255,255,.03);border:1px solid var(--border);border-radius:8px;padding:8px 10px;flex-shrink:0;min-width:106px }
.stake-v8.reduced { border-color:rgba(245,158,11,.25);background:rgba(245,158,11,.04) }
.stake-v8.muted   { border-color:rgba(255,255,255,.04);opacity:.60;border-style:dashed }
.stake-v8 .sv-lbl { font-size:9.5px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--text-3);margin-bottom:3px;font-family:var(--font-ui) }
.stake-v8.reduced .sv-lbl { color:var(--amber) }
.stake-v8 .sv-units  { font-family:var(--font-mono);font-size:20px;font-weight:700;color:var(--text);line-height:1 }
.stake-v8 .sv-dollars { font-size:12px;font-weight:600;color:var(--text-2);font-family:var(--font-mono) }
.stake-v8 .sv-note { font-size:8.5px;color:var(--text-3);margin-top:3px }
.lu-v8-block { flex:1;display:flex;flex-direction:column;justify-content:center;gap:5px }
.lu-v8-item { display:flex;align-items:center;gap:6px }
.lu-v8-dot { width:6px;height:6px;border-radius:50%;flex-shrink:0 }
.lu-v8-dot.conf { background:var(--green) }
.lu-v8-dot.proj { background:var(--amber) }
.lu-v8-dot.unk  { background:var(--text-4) }
.lu-v8-team { font-size:10px;font-weight:600;color:var(--text-2);min-width:28px }
.lu-v8-status { font-size:9.5px }
.lu-v8-status.conf { color:var(--green) }
.lu-v8-status.proj { color:var(--amber) }
.lu-v8-status.unk  { color:var(--text-3) }

/* Primary driver line */
.pc-v8-driver { padding:10px 14px;font-size:11px;color:#b8ccdf;line-height:1.55;border-top:1px solid rgba(255,255,255,.065) }
.pc-v8-driver strong { color:var(--text);font-weight:600 }
.pc-v8-flag-line { padding:7px 14px;font-size:10px;color:var(--amber);line-height:1.5;background:rgba(245,158,11,.06);border-top:1px solid rgba(245,158,11,.15) }
.pc-v8-flag-line strong { font-weight:600 }

/* Completed-pick result + CLV summary — replaces the stake row once a game is final.
   Bet sizing is no longer actionable, so the focus shifts to outcome (P&L) + CLV. */
.pc-result-row { display:flex;align-items:stretch;gap:8px;margin:8px 14px 2px;flex-wrap:wrap }
.pcr-pnl, .pcr-clv { flex:1;min-width:106px;display:flex;flex-direction:column;justify-content:center;gap:3px;border-radius:8px;padding:8px 10px;border:1px solid var(--border);background:rgba(255,255,255,.03) }
.pc-result-row.won  .pcr-pnl { border-color:rgba(34,197,94,.3);background:rgba(34,197,94,.06) }
.pc-result-row.lost .pcr-pnl { border-color:rgba(239,68,68,.25);background:rgba(239,68,68,.05) }
.pcr-pnl-lbl { font-size:9.5px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;font-family:var(--font-ui) }
.pc-result-row.won  .pcr-pnl-lbl { color:var(--green) }
.pc-result-row.lost .pcr-pnl-lbl { color:var(--red) }
.pcr-pnl-val { font-family:var(--font-mono);font-size:18px;font-weight:700;color:var(--text);line-height:1 }
.pcr-pnl-val.pending { font-family:var(--font-ui);font-size:12px;font-weight:600;color:var(--text-3) }
.pc-result-row.pending .pcr-pnl-lbl { color:var(--text-3) }
.pcr-clv.pos { border-color:rgba(34,197,94,.25) }
.pcr-clv.neg { border-color:rgba(239,68,68,.2) }
.pcr-clv-lbl { font-size:9.5px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--text-3);font-family:var(--font-ui) }
.pcr-clv-val { font-family:var(--font-mono);font-size:16px;font-weight:700;line-height:1;color:var(--text-2) }
.pcr-clv.pos .pcr-clv-val { color:var(--green) }
.pcr-clv.neg .pcr-clv-val { color:var(--red) }
.pcr-clv-note { font-size:8.5px;color:var(--text-3) }
/* Completed-card compact edge line (replaces the full prob bar) */
.pc-edge-line { padding:6px 14px 2px;font-size:10.5px;color:var(--text-3);font-family:var(--font-ui) }
.pc-edge-line .pel-edge { color:var(--green);font-weight:700;font-family:var(--font-mono) }
.pc-edge-line .pel-sep { color:var(--text-4);margin:0 2px }

/* ── v8 Expanded Details Panel ── */
.det-v8-panel { background:rgba(255,255,255,.016);border-top:2px solid rgba(255,255,255,.055);display:none }
.det-v8-panel.open { display:block }
.det-v8-sec { padding:12px 14px;border-bottom:1px solid rgba(255,255,255,.045) }
.det-v8-sec:last-child { border-bottom:none }
.det-v8-hdr { font-size:8px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--text-3);margin-bottom:8px;font-family:var(--font-ui) }

/* Quick Audit */
.qa-v8 { border:1px solid rgba(255,255,255,.055);border-radius:8px;overflow:hidden }
.qa-v8-row { display:flex;align-items:baseline;gap:8px;padding:7px 10px;border-bottom:1px solid rgba(255,255,255,.04) }
.qa-v8-row:last-child { border-bottom:none }
.qa-v8-lbl { font-size:9.5px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;flex-shrink:0;min-width:60px;font-family:var(--font-ui) }
.qa-v8-lbl.thesis { color:var(--text-3) }
.qa-v8-lbl.driver { color:#60a5fa }
.qa-v8-lbl.risk   { color:var(--amber) }
.qa-v8-lbl.ev     { color:var(--green) }
.qa-v8-val { font-size:11px;color:var(--text-2);line-height:1.4;font-family:var(--font-ui) }
.qa-v8-val strong { color:var(--text);font-weight:600 }
.qa-v8-val.ev-good { color:var(--green);font-family:var(--font-mono);font-weight:700;font-size:12px }
.qa-v8-val.ev-bad  { color:var(--text-3);font-family:var(--font-mono);font-weight:600;font-size:12px }

/* Prob + Action side-by-side on desktop */
.prob-action-v8 { display:grid;grid-template-columns:1fr;border-bottom:1px solid rgba(255,255,255,.045) }
@media(min-width:900px) { .prob-action-v8 { grid-template-columns:1fr 1fr } }
.pa-v8-col { padding:12px 14px }
.pa-v8-col.prob-c { border-bottom:1px solid rgba(255,255,255,.04) }
@media(min-width:900px) {
  .pa-v8-col.prob-c { border-bottom:none;border-right:1px solid rgba(255,255,255,.045) }
  .pa-v8-col.action-c { background:rgba(34,197,94,.028) }
  .pa-v8-col.action-c.cond-c { background:rgba(245,158,11,.022) }
}
.prob-v8-card { background:rgba(255,255,255,.02);border:1px solid var(--border);border-radius:8px;padding:12px 14px }
.prob-v8-row  { display:flex;align-items:center;justify-content:space-between;gap:6px;margin-bottom:10px }
.prob-v8-col  { text-align:center;flex:1 }
.prob-v8-col .pv-lbl { font-size:9.5px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;margin-bottom:2px;color:var(--text-4);display:block;font-family:var(--font-ui) }
.prob-v8-col .pv-val { font-family:var(--font-mono);font-size:18px;font-weight:700;line-height:1 }
.pv-val.mkt   { color:var(--text-2) }
.pv-val.edgev { color:var(--green);font-size:15px }
.pv-val.mdl   { color:#60a5fa }
.prob-v8-div  { width:1px;background:var(--border);height:34px;flex-shrink:0 }
.prob-v8-bar  { height:8px;background:rgba(255,255,255,.05);border-radius:4px;position:relative;overflow:hidden }
.pv-mkt  { position:absolute;left:0;top:0;bottom:0;background:rgba(115,130,155,.45);border-radius:4px 0 0 4px }
.pv-edge { position:absolute;top:0;bottom:0;background:rgba(34,197,94,.65);border-radius:0 4px 4px 0 }
.pv-edge.wl { background:rgba(99,102,241,.45) }

/* Action Summary */
.as-v8 { border:1px solid rgba(34,197,94,.28);border-radius:8px;overflow:hidden;background:rgba(34,197,94,.04) }
.as-v8.cond    { border-color:rgba(245,158,11,.28);background:rgba(245,158,11,.04) }
.as-v8.reduced { border-color:rgba(245,158,11,.30);background:rgba(245,158,11,.05) }
.as-v8.wl      { border-color:rgba(99,102,241,.22);background:rgba(99,102,241,.04) }
.as-v8-row { display:flex;align-items:baseline;gap:10px;padding:7px 10px;border-bottom:1px solid rgba(255,255,255,.045);flex-wrap:wrap }
.as-v8-row:first-child { padding:9px 10px }
.as-v8-row:last-child { border-bottom:none }
.as-v8-lbl { font-size:9.5px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--text-4);min-width:100px;flex-shrink:0;font-family:var(--font-ui) }
.as-v8-val { font-size:11px;font-weight:600;font-family:var(--font-mono) }
.as-v8-val.g { color:var(--green) } .as-v8-val.a { color:var(--amber) } .as-v8-val.r { color:var(--red) }
.as-v8-val.m { color:var(--text-2) } .as-v8-val.d { color:var(--text-3) }
.det-v8-cta { display:flex;gap:8px;flex-wrap:wrap;margin-top:10px }
.cta-v8 { font-size:11px;font-weight:700;padding:8px 16px;border-radius:7px;border:1px solid;cursor:pointer;font-family:var(--font-ui) }
.cta-v8.bet { background:rgba(34,197,94,.13);border-color:rgba(34,197,94,.32);color:var(--green) }
.cta-v8.trk { background:rgba(99,102,241,.10);border-color:rgba(99,102,241,.25);color:var(--indigo-lt) }
.cta-v8.mon { background:rgba(99,102,241,.06);border-color:rgba(99,102,241,.18);color:var(--indigo-lt);opacity:.75 }

/* Drivers table */
.drv-v8 { width:100%;border-collapse:collapse }
.drv-v8 th { font-size:9.5px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--text-4);padding:3px 6px;border-bottom:1px solid var(--border);font-family:var(--font-ui) }
.drv-v8 th:nth-child(2) { text-align:right }
.drv-v8 th:nth-child(3) { text-align:center }
.drv-v8 td { padding:5px 6px;border-bottom:1px solid rgba(255,255,255,.03);vertical-align:middle }
.drv-v8 tr:last-child td { border-bottom:none }
.drv-v8 td.dv-factor { color:var(--text-2);font-size:11px;font-family:var(--font-ui) }
.drv-v8 td.dv-impact { font-family:var(--font-mono);font-weight:700;font-size:13px;text-align:right;white-space:nowrap }
.dv-impact.pos { color:#4ade80 } .dv-impact.risk { color:#fbbf24 } .dv-impact.neg { color:#f87171 }
.drv-v8 td.dv-type { text-align:center;padding:5px 4px }
.dv-pill { font-size:9px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;padding:2px 6px;border-radius:3px;font-family:var(--font-ui) }
.dv-pill.pos  { background:rgba(34,197,94,.10);color:var(--green) }
.dv-pill.risk { background:rgba(245,158,11,.10);color:var(--amber) }

/* Matchup quality (pick vs opponent) */
.mq-v8 { width:100%;border-collapse:collapse }
.mq-v8 th { font-size:9.5px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--text-4);padding:3px 6px 6px;border-bottom:1px solid var(--border);font-family:var(--font-ui) }
.mq-v8 th.mq-team { text-align:right;width:26% }
.mq-v8 th.mq-pick { color:var(--text-2) }
.mq-v8 td { padding:6px;border-bottom:1px solid rgba(255,255,255,.03);vertical-align:middle }
.mq-v8 tr:last-child td { border-bottom:none }
.mq-v8 td.mq-lbl { color:var(--text-3);font-size:11px;font-family:var(--font-ui) }
.mq-v8 td.mq-val { font-family:var(--font-mono);font-weight:700;font-size:13px;text-align:right;color:var(--text-3);white-space:nowrap }
.mq-v8 td.mq-val.mq-win { color:var(--green) }
.mq-note { font-size:9.5px;color:var(--text-4);margin-top:7px;font-family:var(--font-ui) }

/* Best odds */
.odds-v8-note { font-family:var(--font-mono);font-size:10.5px;color:var(--amber);font-weight:600;margin-bottom:8px }
.odds-v8-group { margin-bottom:7px } .odds-v8-group:last-child { margin-bottom:0 }
.odds-v8-glbl { font-size:9.5px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--text-4);margin-bottom:4px;font-family:var(--font-ui) }
.odds-v8-best { display:flex;align-items:center;gap:8px;padding:6px 10px;background:rgba(34,197,94,.08);border:1px solid rgba(34,197,94,.22);border-radius:6px }
.odds-v8-best .ov8-name { font-weight:600;color:var(--text);flex:1;font-size:11px;font-family:var(--font-ui) }
.odds-v8-best .ov8-odds { font-family:var(--font-mono);font-weight:700;font-size:13px;color:var(--green) }
.ov8-best-tag { font-size:8.5px;font-weight:700;padding:2px 6px;border-radius:3px;background:rgba(34,197,94,.15);color:var(--green);font-family:var(--font-ui) }
.ov8-exch-tag { font-size:8.5px;font-weight:700;padding:2px 5px;border-radius:3px;background:rgba(20,184,166,.12);color:#14b8a6;border:1px solid rgba(20,184,166,.20);font-family:var(--font-ui) }
.odds-v8-inline { font-size:11px;color:var(--text-2);line-height:1.7;font-family:var(--font-ui) }
.odds-v8-inline .ov8-below { color:var(--text-4) }

/* Lineup status */
.lu-tbl-v8 { width:100%;border-collapse:collapse }
.lu-tbl-v8 td { padding:5px 6px;border-bottom:1px solid rgba(255,255,255,.03) }
.lu-tbl-v8 tr:last-child td { border-bottom:none }
.lu-tbl-v8 td.lt-lbl { font-size:9px;color:var(--text-4);font-weight:600;width:42%;letter-spacing:.03em;font-family:var(--font-ui) }
.lu-tbl-v8 td.lt-val { font-weight:600;font-size:11px;font-family:var(--font-ui) }
.lt-val.conf { color:var(--green) } .lt-val.proj { color:var(--amber) } .lt-val.ok { color:var(--text-2) }

/* Historical context footer */
.hist-v8 { padding:9px 14px 11px;font-size:10px;color:var(--text-4);line-height:1.5;font-family:var(--font-ui);font-style:italic }
.hist-v8 strong { font-style:normal;color:var(--text-3);font-weight:600 }
