/* The Tiresias Report, public site styles.
   Mirrors the dashboard design system (dashboard/frontend/app/globals.css):
   warm paper neutrals, serif body, sans labels, mono numerics, teal/rust
   semantics. Static (no build). */

:root{
  --paper:#f6f3ec; --paper-2:#efeadf; --paper-3:#e6dfd0;
  --ink:#1c1a17; --ink-2:#3b3833; --ink-3:#6a655c; --ink-4:#908a7e; --ink-5:#b8b1a3;
  --rule:#d6cfbf; --rule-2:#c4bca9;
  --home:#0f5f5c; --home-2:#1a7975; --home-soft:rgba(15,95,92,0.10); --home-softer:rgba(15,95,92,0.06);
  --away:#b85837; --away-2:#d06d4a; --away-soft:rgba(184,88,55,0.10);
  --actual:#4a463f;
  --verdict-hit:#2c6e3a; --verdict-miss:#a83229; --verdict-push:#7a7569;
  --serif:"Source Serif 4","Charter","Iowan Old Style",Georgia,serif;
  --sans:"Inter",-apple-system,"Segoe UI",Roboto,sans-serif;
  --mono:"JetBrains Mono","IBM Plex Mono",ui-monospace,"SF Mono",Menlo,monospace;
}

*{box-sizing:border-box}
html,body{margin:0}
body{
  background:var(--paper); color:var(--ink);
  font-family:var(--serif); font-size:15px; line-height:1.5;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  font-feature-settings:"kern","liga";
}
a{color:inherit;text-decoration:none}
.serif{font-family:var(--serif)} .sans{font-family:var(--sans)}
.num{font-family:var(--mono);font-variant-numeric:tabular-nums}
.eyebrow{
  font-family:var(--sans); font-size:10.5px; font-weight:600;
  letter-spacing:.12em; text-transform:uppercase; color:var(--ink-3);
}

/* ---- app shell ---- */
.app{max-width:1080px;margin:0 auto;padding:0 32px 64px}
.measure{max-width:720px}

/* ---- masthead (mirrors dashboard) ---- */
.masthead{
  display:flex; align-items:flex-end; justify-content:space-between; gap:32px;
  padding:32px 0 16px; border-bottom:1px solid var(--ink);
}
.masthead-brand{display:flex;align-items:baseline;gap:16px;transition:color 120ms ease}
.masthead-title{
  margin:0; font-family:var(--serif); font-weight:700; font-size:30px;
  letter-spacing:-.022em; line-height:1; color:var(--ink); transition:color 120ms ease;
}
.masthead-title em{font-style:italic;font-weight:600;color:var(--ink-2);transition:color 120ms ease}
.masthead-brand:hover .masthead-title,.masthead-brand:hover .masthead-title em{color:var(--home)}
.masthead-tag{
  font-family:var(--sans); font-size:10.5px; font-weight:600; letter-spacing:.14em;
  text-transform:uppercase; color:var(--ink-3); white-space:nowrap;
}
.masthead-nav{
  display:flex; align-items:baseline; gap:18px;
  font-family:var(--sans); font-size:12.5px; font-weight:500; letter-spacing:.02em;
}
.masthead-nav a,.masthead-nav .soon{
  color:var(--ink-2); padding-bottom:2px; border-bottom:1px solid transparent;
  transition:color 100ms ease,border-color 100ms ease;
}
.masthead-nav a:hover{color:var(--ink);border-bottom-color:var(--ink-3)}
.masthead-nav .soon{color:var(--ink-4);cursor:default}
.masthead-nav .soon span{font-size:9px;letter-spacing:.12em;color:var(--ink-4);margin-left:4px}
.masthead-substack{color:var(--home)!important}
.masthead-substack:hover{border-bottom-color:var(--home)!important}

/* ---- hero (landing) ---- */
.hero{padding:9vh 0 6vh}
.hero .eyebrow{margin:0 0 16px}
.hero h1{
  font-family:var(--serif); font-weight:700; letter-spacing:-.018em;
  font-size:clamp(32px,5.5vw,46px); line-height:1.08; margin:0 0 24px; color:var(--ink);
}
.hero .mission{font-size:18px;line-height:1.55;color:var(--ink-2);margin:0 0 28px}
.hero .mission b{color:var(--ink);font-weight:600}
.cta{
  display:inline-block; font-family:var(--sans); font-size:14px; font-weight:500;
  color:var(--home); border:1px solid var(--home); border-radius:4px; padding:10px 18px;
  transition:background 120ms ease,color 120ms ease;
}
.cta:hover{background:var(--home);color:var(--paper)}
.cta-note{font-family:var(--sans);color:var(--ink-3);font-size:13px;margin:14px 0 0}

/* ---- feature cards ---- */
.section{padding:5vh 0;border-top:1px solid var(--rule)}
.section > .app-h{
  font-family:var(--sans); font-size:11px; font-weight:600; letter-spacing:.14em;
  text-transform:uppercase; color:var(--ink-3); margin:0 0 24px;
}
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.card{border:1px solid var(--rule);background:var(--paper-2);border-radius:6px;padding:20px 18px}
.card h3{font-family:var(--serif);font-size:17px;font-weight:600;margin:0 0 8px;color:var(--ink)}
.card p{font-family:var(--sans);font-size:13px;line-height:1.5;color:var(--ink-3);margin:0}
.card .pill{
  display:inline-block; font-family:var(--sans); font-size:9.5px; text-transform:uppercase;
  letter-spacing:.12em; color:var(--ink-3); border:1px solid var(--rule); border-radius:20px;
  padding:2px 9px; margin-top:14px;
}

/* ---- content pages (about / faq) ---- */
.content{padding:6vh 0 8vh}
.content h1{font-family:var(--serif);font-weight:700;letter-spacing:-.018em;font-size:clamp(28px,5vw,40px);margin:0 0 6px}
.content .lede{font-family:var(--sans);color:var(--ink-3);font-size:14px;margin:0 0 34px}
.content h2{font-family:var(--serif);font-size:19px;font-weight:600;margin:34px 0 10px;color:var(--ink);line-height:1.35}
.content p{margin:0 0 18px;color:var(--ink-2);font-size:16px;line-height:1.6}
.content em{color:var(--ink-3)}
.content a{color:var(--home);border-bottom:1px solid var(--rule-2)}
.content a:hover{border-bottom-color:var(--home)}

/* ---- site footer (mirrors dashboard) ---- */
.site-footer{
  display:flex; align-items:baseline; justify-content:space-between; gap:24px;
  margin-top:48px; padding:22px 0 14px; border-top:1px solid var(--rule);
  font-family:var(--sans); font-size:12px; color:var(--ink-3);
}
.site-footer-left{display:flex;align-items:baseline;gap:14px;flex-wrap:wrap}
.site-footer-brand{font-family:var(--serif);font-weight:600;font-size:14px;color:var(--ink-2);letter-spacing:-.01em}
.site-footer-sub{font-style:italic;color:var(--ink-3)}
.site-footer-right{display:flex;align-items:baseline;gap:10px}
.site-footer-right a{color:var(--ink-2);border-bottom:1px solid transparent;padding-bottom:1px}
.site-footer-right a:hover{color:var(--ink);border-bottom-color:var(--ink-3)}
.site-footer-sep{color:var(--ink-5)}
.disclaimer{
  font-family:var(--sans); font-size:11px; line-height:1.7; color:var(--ink-4);
  border-top:1px solid var(--rule); padding:16px 0 40px; max-width:640px;
}
.site-version{
  font-family:var(--sans); font-size:11px; color:var(--ink-4);
  margin:0; padding:14px 0 2px; letter-spacing:.01em;
}

/* ---- responsive ---- */
@media (max-width:760px){
  .masthead{flex-direction:column;align-items:flex-start;gap:14px;padding:24px 0 14px}
  .masthead-title{font-size:26px}
  .cards{grid-template-columns:1fr}
  .app{padding:0 20px 48px}
}
@media (max-width:600px){
  .site-footer{flex-direction:column;align-items:flex-start;gap:8px}
}

/* ===== data pages (this-week / game / season) ===== */
.muted{color:var(--ink-3);font-family:var(--sans);font-size:13px}
.page-head{padding:5vh 0 1vh}
.page-head h1{font-family:var(--serif);font-weight:700;letter-spacing:-.018em;font-size:clamp(26px,5vw,38px);margin:0 0 4px}
.page-head .eyebrow{margin:0 0 14px}
.page-head .sub{font-family:var(--sans);color:var(--ink-3);font-size:14px;margin:0}

/* slate */
.slate{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;padding:3vh 0 6vh}
.gamecard{display:block;border:1px solid var(--rule);background:var(--paper-2);border-radius:8px;padding:16px 18px;transition:border-color 120ms ease}
.gamecard:hover{border-color:var(--ink-3)}
.gc-teams{font-family:var(--serif);font-weight:600;font-size:18px;color:var(--ink);margin-bottom:10px}
.gc-teams .at{color:var(--ink-4);font-weight:400}
.gc-row{display:grid;grid-template-columns:auto 1fr auto 1fr;gap:5px 10px;align-items:baseline;margin-bottom:4px}
.gc-k{font-family:var(--sans);font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-4)}
.gc-row .num{font-family:var(--mono);font-variant-numeric:tabular-nums;color:var(--ink-2);font-size:13px}
.gc-foot{display:flex;gap:10px;margin-top:10px;border-top:1px solid var(--rule);padding-top:9px}
.gc-pick{flex:1;display:flex;align-items:center;flex-wrap:wrap;gap:6px;font-family:var(--sans);font-size:12px;color:var(--ink-2)}
.gc-pick b{color:var(--ink)}
.gc-conf{font-family:var(--mono);font-variant-numeric:tabular-nums;font-size:11px;color:var(--ink-3)}
.conf-badge{font-family:var(--sans);font-size:8.5px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--home);background:var(--home-soft);border-radius:3px;padding:1px 4px}
.conf-note{font-family:var(--sans);font-size:11px;line-height:1.6;color:var(--ink-4);max-width:640px;margin:18px 0 0}
.conf-note b{color:var(--home)}
.conf-note a{color:var(--home);border-bottom:1px solid var(--rule-2)}

/* charts */
.charts2{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;padding:1vh 0 1vh}
.chart-h{font-family:var(--sans);font-size:11px;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:var(--ink-3);margin-bottom:6px}
.chart-dek{font-family:var(--sans);font-size:12px;color:var(--ink-4);margin-top:5px}
.chart-empty{font-family:var(--sans);font-size:12px;color:var(--ink-4);height:150px;display:flex;align-items:center}
svg.kde{width:100%;height:auto;display:block}
.kde-area{fill:var(--home-softer)}
.kde-line{stroke:var(--ink-3);stroke-width:1.4;fill:none}
.kde-axis{stroke:var(--rule-2);stroke-width:1}
.mk-vegas{stroke:var(--away);stroke-width:1.4;stroke-dasharray:4 3}
.mk-actual{stroke:var(--actual);stroke-width:1.6}
.mk-mean{fill:var(--home)}
.mk-median{fill:var(--paper);stroke:var(--home);stroke-width:1.4}
.kde-tick{fill:var(--ink-4);font-family:var(--mono);font-size:9px}
.kde-tick-r{text-anchor:end}
.chart-legend{display:flex;flex-wrap:wrap;gap:16px;font-family:var(--sans);font-size:11.5px;color:var(--ink-3);padding:1vh 0 1vh}
.chart-legend .lg{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:5px}
.chart-legend .lg.mk-mean{background:var(--home)}
.chart-legend .lg.mk-median{background:var(--paper);border:1.5px solid var(--home);width:7px;height:7px}
.chart-legend .lg-vegas{background:var(--away)}
.chart-legend .lg-actual{background:var(--actual)}

/* box score */
table.box{width:100%;border-collapse:collapse;margin:3vh 0 6vh;font-family:var(--sans);font-size:13.5px}
table.box th{font-size:10px;letter-spacing:.07em;text-transform:uppercase;color:var(--ink-4);font-weight:600;text-align:right;padding:6px 10px;border-bottom:1px solid var(--ink)}
table.box th:first-child{text-align:left}
table.box td{padding:7px 10px;text-align:right;border-bottom:1px solid var(--rule);color:var(--ink-2)}
table.box td.rk{text-align:left;color:var(--ink-3);font-family:var(--serif)}
table.box .num{font-family:var(--mono);font-variant-numeric:tabular-nums}
table.box tr.actual-row td{color:var(--ink);font-weight:600}

/* season data table */
table.data-table{width:100%;border-collapse:collapse;font-family:var(--sans);font-size:13px;margin:3vh 0 1vh}
table.data-table th{font-size:10px;letter-spacing:.05em;text-transform:uppercase;color:var(--ink-4);font-weight:600;text-align:right;padding:8px;border-bottom:1px solid var(--ink)}
table.data-table th:first-child{text-align:left}
table.data-table td{padding:7px 8px;text-align:right;border-bottom:1px solid var(--rule);color:var(--ink-2)}
table.data-table td:first-child{text-align:left;color:var(--ink-3)}
table.data-table .num{font-family:var(--mono);font-variant-numeric:tabular-nums}
table.data-table td.beat{color:var(--home);font-weight:600}
table.data-table tfoot td{border-top:1px solid var(--ink);border-bottom:none;color:var(--ink);font-weight:700;padding-top:9px}
table.data-table tr.tot td:first-child{color:var(--ink)}
.tbl-note{max-width:720px;margin:14px 0 6vh;line-height:1.6}
.table-wrap{overflow-x:auto}
.data-table .conf-cell{color:var(--ink-3)}
.data-table .cn{font-family:var(--sans);font-size:10px;color:var(--ink-4)}

/* ===== game detail (ported from dashboard game page) ===== */
.stat-toggle-bar{display:flex;align-items:center;gap:12px;padding:3vh 0 0}
.stat-toggle-lbl{font-family:var(--sans);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3)}
.stat-toggle{display:inline-flex;border:1px solid var(--rule);border-radius:3px;overflow:hidden;font-family:var(--sans);font-size:10px}
.stat-toggle button{padding:4px 11px;border:none;background:transparent;color:var(--ink-3);cursor:pointer;letter-spacing:.06em;text-transform:uppercase;font-weight:500}
.stat-toggle button.on{background:var(--ink-2);color:var(--paper);font-weight:600}

/* scoreboard hero */
.sbh{border:1px solid var(--rule);border-radius:8px;overflow:hidden;margin:16px 0 0}
.sbh-band{display:grid;grid-template-columns:1fr 56px 1fr;align-items:stretch;background:var(--paper-2)}
.sbh-side{display:flex;align-items:center;gap:14px;padding:20px 22px;position:relative}
.sbh-side.model-win::before{content:"";position:absolute;top:0;bottom:0;left:0;width:3px;background:var(--home)}
.sbh-side:nth-child(3).model-win::before{left:auto;right:0}
.sbh-mono{font-family:var(--mono);font-weight:600;font-size:13px;letter-spacing:.02em;color:var(--ink);background:var(--paper-3);border:1px solid var(--rule);border-radius:6px;padding:8px 9px;min-width:46px;text-align:center}
.sbh-side-text{display:flex;flex-direction:column;flex:1;min-width:0}
.sbh-side-text.right{align-items:flex-end;text-align:right}
.sbh-side-name{font-family:var(--serif);font-weight:600;font-size:18px;letter-spacing:-.01em;color:var(--ink)}
.sbh-side-sub{font-family:var(--sans);font-size:9.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-4);margin-top:2px}
.sbh-scores{display:flex;flex-direction:column;align-items:flex-end}
.sbh-scores.left{align-items:flex-start}
.sbh-pred-label{font-family:var(--sans);font-size:9px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-4)}
.sbh-pred{font-family:var(--mono);font-variant-numeric:tabular-nums;font-size:40px;font-weight:500;letter-spacing:-.025em;color:var(--ink-2);line-height:1;margin:2px 0}
.sbh-side.model-win .sbh-pred{color:var(--ink)}
.sbh-actual{display:flex;align-items:baseline;gap:6px;margin-top:4px;padding-top:6px;border-top:1px dotted var(--rule-2);width:100%;justify-content:flex-end}
.sbh-scores.left .sbh-actual{justify-content:flex-start}
.sbh-actual-label{font-family:var(--sans);font-size:9px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-4)}
.sbh-actual-num{font-family:var(--mono);font-variant-numeric:tabular-nums;font-size:22px;font-weight:500;color:var(--actual)}
.sbh-actual.win .sbh-actual-num{color:var(--ink);font-weight:600}
.sbh-divider{display:flex;align-items:center;justify-content:center}
.sbh-divider .at{font-family:var(--serif);font-style:italic;font-size:18px;color:var(--ink-4)}
.sbh-strip{display:grid;grid-template-columns:repeat(5,1fr);align-items:center;border-top:1px solid var(--rule);background:var(--paper)}
.sbh-strip-cell{padding:12px 16px;border-right:1px solid var(--rule)}
.sbh-strip-cell:last-child{border-right:none}
.sbh-strip-k{font-family:var(--sans);font-size:9.5px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3);margin-bottom:4px}
.sbh-strip-v{font-family:var(--mono);font-variant-numeric:tabular-nums;font-size:14px;font-weight:500;color:var(--ink);display:flex;align-items:baseline;gap:8px;flex-wrap:wrap}
.sbh-conf{font-family:var(--sans);font-size:10.5px;color:var(--ink-3);font-weight:500}
.sbh-strip-verdicts{display:flex;gap:6px;flex-wrap:wrap}

/* box score */
.box-score{margin-top:22px;overflow-x:auto}
.box-score table{width:100%;border-collapse:collapse;font-family:var(--sans)}
.box-score th{font-family:var(--sans);font-size:10px;font-weight:600;letter-spacing:.10em;text-transform:uppercase;color:var(--ink-3);text-align:left;padding:8px 12px;border-bottom:1px solid var(--ink)}
.box-score th.r{text-align:right}
.box-score td{padding:13px 12px;border-bottom:1px solid var(--rule);font-family:var(--sans);font-size:13px;color:var(--ink-2)}
.box-score td.num{font-family:var(--mono);font-variant-numeric:tabular-nums;font-size:16px;font-weight:500;color:var(--ink)}
.box-score td.r{text-align:right}
.box-score .bs-rowlabel{display:flex;align-items:center;gap:8px;font-family:var(--sans);font-weight:600;color:var(--ink);font-size:13px}
.box-score .bs-rowdot{width:8px;height:8px;border-radius:50%;display:inline-block;flex-shrink:0}
.box-score tr.bs-model td{background:var(--home-softer)}
.box-score tr.bs-final td{background:rgba(74,70,63,0.05)}
.box-score .bs-pick{color:var(--home);font-weight:600;font-size:12px;font-family:var(--mono)}
.box-score .bs-verdicts{display:inline-flex;gap:6px;flex-wrap:wrap;justify-content:flex-end}
.bs-flip{margin-left:6px;font-size:9px;letter-spacing:.08em;color:var(--away);border:1px solid var(--away);border-radius:2px;padding:0 3px}

/* chart blocks */
.chart-block{margin-top:28px;padding-top:18px;border-top:1px solid var(--rule)}
.chart-block .chart-head,.two-up .chart-head{display:flex;flex-direction:column;align-items:flex-start;gap:2px;margin-bottom:6px}
.chart-block .chart-subtitle,.two-up .chart-subtitle{font-family:var(--sans);font-size:11px;color:var(--ink-3);letter-spacing:.10em;text-transform:uppercase;order:-1}
.chart-block .chart-title,.two-up .chart-title{font-family:var(--serif);font-weight:600;font-size:18px;letter-spacing:-.01em;color:var(--ink)}
.chart-block .chart-dek{font-family:var(--serif);font-style:italic;font-size:13.5px;color:var(--ink-2);max-width:600px;margin:0 0 10px}
.two-up{display:grid;grid-template-columns:1fr 1fr;gap:28px;margin-top:28px;padding-top:18px;border-top:1px solid var(--rule)}
.chart-mount{position:relative;width:100%}

/* interactive KDE svg */
.kde-svg{display:block;width:100%;height:auto}
.kde-svg text{font-family:var(--sans);font-size:10.5px;fill:var(--ink-3)}
.kde-svg .annot-label{font-family:var(--sans);font-size:10.5px;font-weight:600;letter-spacing:.02em}
.kde-svg .annot-sub{font-family:var(--mono);font-variant-numeric:tabular-nums;font-size:10.5px}
.kde-svg .axis-tick{font-size:9.5px;fill:var(--ink-4);font-family:var(--mono)}
.kde-svg .kde-xlabel{font-family:var(--sans);font-size:10.5px;fill:var(--ink-3);letter-spacing:.10em;text-transform:uppercase}
.kde-wrap{cursor:crosshair;-webkit-user-select:none;user-select:none}
.kde-tip{position:absolute;width:130px;pointer-events:none;background:var(--paper);border:1px solid var(--ink-2);padding:8px 10px 9px;font-family:var(--sans);font-size:11px;line-height:1.35;color:var(--ink);box-shadow:0 4px 12px rgba(28,26,23,.12);z-index:5}
.kde-tip .kt-val{font-family:var(--mono);font-variant-numeric:tabular-nums;font-size:14px;color:var(--ink);margin-bottom:4px}
.kde-tip .kt-u{font-family:var(--sans);font-size:10px;color:var(--ink-3);margin-left:4px}
.kde-tip .kt-grid{display:grid;grid-template-columns:1fr auto;gap:1px 8px}
.kde-tip .kt-grid span:nth-child(odd){color:var(--ink-3)}
.kde-tip .kt-grid .num{font-family:var(--mono);font-variant-numeric:tabular-nums}

/* stats table */
.stats-table{width:100%;border-collapse:collapse;font-family:var(--mono);font-variant-numeric:tabular-nums;font-size:12px;margin-top:24px}
.stats-table th,.stats-table td{padding:8px 10px;text-align:right;border-bottom:1px solid var(--rule)}
.stats-table th:first-child,.stats-table td:first-child{text-align:left;font-family:var(--sans);font-weight:500;color:var(--ink-2)}
.stats-table thead th{font-family:var(--sans);font-size:10px;font-weight:600;letter-spacing:.10em;text-transform:uppercase;color:var(--ink-3);border-bottom:1px solid var(--ink)}
.stats-table .row-label{display:flex;align-items:center;gap:8px}
.stats-table .swatch{width:10px;height:10px;border-radius:2px;display:inline-block}

/* verdict pills */
.verdict-icon{width:16px;height:16px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}
.verdict-icon svg{display:block}
.verdict-icon.hit{background:var(--verdict-hit);color:var(--paper)}
.verdict-icon.miss{background:var(--verdict-miss);color:var(--paper)}
.verdict-icon.push{background:var(--verdict-push);color:var(--paper)}
.verdict-icon.pending{background:transparent;border:1px dashed var(--rule-2);color:var(--ink-4)}
.verdict-tag{display:inline-flex;align-items:center;gap:5px;padding:2px 7px 2px 4px;border-radius:999px;font-family:var(--sans);font-size:10px;font-weight:600;letter-spacing:.06em;text-transform:uppercase}
.verdict-tag.hit{background:rgba(44,110,58,.10);color:var(--verdict-hit)}
.verdict-tag.miss{background:rgba(168,50,41,.10);color:var(--verdict-miss)}
.verdict-tag.push{background:rgba(122,117,105,.10);color:var(--verdict-push)}
.verdict-tag.pending{background:transparent;border:1px dashed var(--rule-2);color:var(--ink-4)}

@media (max-width:760px){
  .slate{grid-template-columns:1fr}
  .charts2{grid-template-columns:1fr}
  .two-up{grid-template-columns:1fr}
  .sbh-strip{grid-template-columns:repeat(2,1fr)}
  .sbh-strip-cell:nth-child(2n){border-right:none}
  .sbh-pred{font-size:32px}
  .sbh-side{padding:16px 16px}
}

/* ===== rich slate / week view (ported from dashboard) ===== */
.week-nav{display:flex;flex-wrap:nowrap;gap:5px;overflow-x:auto;padding:1vh 0 2vh;-webkit-overflow-scrolling:touch}
.week-chip{flex:0 0 auto;white-space:nowrap;font-family:var(--sans);font-size:11px;color:var(--ink-3);border:1px solid var(--rule);border-radius:999px;padding:3px 8px;transition:all 80ms ease}
.week-chip:hover{border-color:var(--ink-3);color:var(--ink)}
.week-chip.on{background:var(--ink);color:var(--paper);border-color:var(--ink)}

.run-strip{display:grid;grid-template-columns:repeat(5,1fr);border-top:1px solid var(--ink);border-bottom:1px solid var(--ink);margin:0 0 6px}
.run-strip .cell{padding:12px 16px 12px 0;border-right:1px solid var(--rule)}
.run-strip .cell:last-child{border-right:none}
.run-strip .cell:not(:first-child){padding-left:16px}
.run-strip .k{font-family:var(--sans);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3);margin-bottom:4px}
.run-strip .v{font-family:var(--mono);font-variant-numeric:tabular-nums;font-size:18px;font-weight:500;color:var(--ink);letter-spacing:-.01em}
.rec{font-family:var(--mono);font-variant-numeric:tabular-nums;font-size:17px}
.rec .rh{color:var(--verdict-hit);font-weight:600}
.rec .rm{color:var(--verdict-miss);font-weight:600}
.rec .rp{color:var(--ink-4)}
.rec .rs{color:var(--ink-5);margin:0 3px}

.slate-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:0;border-top:1px solid var(--ink);border-left:1px solid var(--rule);margin-top:8px}
.game-card{display:block;border-right:1px solid var(--rule);border-bottom:1px solid var(--rule);padding:16px 16px 18px;background:var(--paper);color:inherit;position:relative;transition:background 80ms ease}
.game-card:hover{background:var(--paper-2)}
.game-card .edge-marker{position:absolute;top:14px;right:14px;width:8px;height:8px;border-radius:50%}
.game-card .edge-marker.pos{background:var(--home)}
.game-card .edge-marker.neg{background:var(--away)}

.csb{display:flex;flex-direction:column;gap:6px;padding:10px 12px 8px;background:linear-gradient(180deg,var(--paper-2) 0%,var(--paper) 100%);border:1px solid var(--rule);border-radius:4px;margin:-4px -4px 12px}
.csb-row{display:grid;grid-template-columns:auto minmax(0,1fr) auto auto;align-items:center;gap:8px;font-family:var(--sans);position:relative}
.csb-row.csb-winner::before{content:"\25B8";position:absolute;left:-10px;top:50%;transform:translateY(-50%);color:var(--ink-2);font-size:9px}
.csb-code{font-family:var(--sans);font-weight:700;letter-spacing:.04em;font-size:14px;color:var(--ink-3)}
.csb-name{font-family:var(--serif);font-size:13px;color:var(--ink-4);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.csb-row.csb-winner .csb-code{color:var(--ink)}
.csb-mono{font-family:var(--mono);font-weight:700;font-size:11px;letter-spacing:.02em;padding:3px 6px;border-radius:4px;min-width:38px;text-align:center}
.csb-row.csb-winner .csb-name{color:var(--ink-2)}
.csb-pred{font-family:var(--mono);font-variant-numeric:tabular-nums;font-size:18px;font-weight:500;color:var(--ink-2);letter-spacing:-.01em;min-width:32px;text-align:right}
.csb-row.csb-winner .csb-pred{color:var(--ink);font-weight:600}
.csb-actual{font-family:var(--mono);font-variant-numeric:tabular-nums;font-size:14px;font-weight:500;color:var(--ink-4);min-width:22px;text-align:right;padding-left:8px;border-left:1px solid var(--rule)}
.csb-actual.win{color:var(--ink);font-weight:600}
.csb-meta{display:flex;align-items:center;justify-content:space-between;font-family:var(--sans);font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-3);border-top:1px dotted var(--rule);padding-top:6px;margin-top:2px}
.csb-meta .csb-vegas{font-family:var(--mono);font-variant-numeric:tabular-nums;letter-spacing:0;text-transform:none;color:var(--ink-2)}
.csb-meta .csb-sep{color:var(--ink-5);margin:0 6px}
.csb-meta-r{font-family:var(--sans);font-size:9.5px;font-weight:600;letter-spacing:.08em;color:var(--ink-4)}

.mini-block{margin-bottom:10px}
.mini-block:last-of-type{margin-bottom:0}
.mini-head{display:flex;align-items:baseline;justify-content:space-between;font-family:var(--sans);font-size:10px;letter-spacing:.10em;text-transform:uppercase;color:var(--ink-3);margin-bottom:2px}
.mini-head .pct{letter-spacing:0;text-transform:none}
.mini-head .pick-team{font-family:var(--serif);font-size:12.5px;font-weight:500;color:var(--ink)}
.mini-head .pick-verb{font-family:var(--sans);font-size:10px;font-weight:500;color:var(--ink-3);letter-spacing:.06em;text-transform:uppercase}
.mini-head .pick-conf{font-family:var(--mono);font-variant-numeric:tabular-nums;font-size:11.5px;font-weight:600;color:var(--ink)}
.kde-mini{display:block;width:100%;height:auto}
.kde-mini-tag{font-family:var(--sans);font-size:8px;font-weight:500;letter-spacing:.05em;text-transform:uppercase}
.mini-empty{height:78px}
.mini-wrap{position:relative;width:100%}
.mini-tag{position:absolute;font-family:var(--sans);font-size:9px;font-weight:500;letter-spacing:.02em;line-height:1;white-space:nowrap;pointer-events:none}
.mini-tag-top{top:0}
.mini-tag-bot{bottom:0}

.verdict-row{display:flex;border-top:1px dashed var(--rule);margin-top:12px;padding-top:10px;font-family:var(--sans);font-size:10.5px;color:var(--ink-3)}
.verdict-cell{flex:1;display:flex;align-items:center;gap:6px;border-right:1px dotted var(--rule-2);padding-right:10px}
.verdict-cell:last-child{border-right:none;padding-left:10px;padding-right:0}
.verdict-cell:first-child{padding-left:0}
.verdict-cell .market{font-weight:600;letter-spacing:.10em;text-transform:uppercase;color:var(--ink-3);font-size:9.5px}
.verdict-cell .pick{font-family:var(--mono);font-variant-numeric:tabular-nums;font-size:11px;color:var(--ink-2);margin-right:auto;display:flex;align-items:center;gap:4px}
.verdict-cell .vc-end{display:flex;flex-direction:column;align-items:center;gap:2px;flex:none}

@media (max-width:900px){.slate-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.run-strip{grid-template-columns:repeat(3,1fr)}}
@media (max-width:560px){.slate-grid{grid-template-columns:minmax(0,1fr)}.run-strip{grid-template-columns:repeat(2,1fr)}}

/* ===== player props ===== */
.props-link{margin-left:auto;align-self:center;font-family:var(--sans);font-size:12px;color:var(--home);border-bottom:1px solid var(--rule-2)}
.dense-table{width:100%;border-collapse:collapse;font-family:var(--sans);font-size:13px;margin-top:8px}
.dense-table th{font-family:var(--sans);font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3);text-align:left;padding:7px 10px;border-bottom:1px solid var(--ink)}
.dense-table th.r{text-align:right}
.dense-table td{padding:9px 10px;border-bottom:1px solid var(--rule);color:var(--ink-2);vertical-align:top}
.dense-table td.r{text-align:right}
.dense-table td.num{font-family:var(--mono);font-variant-numeric:tabular-nums}
.dense-table tbody tr:hover{background:var(--paper-2)}
.dense-table .label{font-family:var(--serif);font-weight:600;font-size:14px;color:var(--home)}
.dense-table a:hover .label{border-bottom:1px solid var(--rule-2)}
.dense-table .sub{font-family:var(--mono);font-size:11px;color:var(--ink-3)}
.ma-actual{font-family:var(--mono);font-size:10px;color:var(--ink-4)}
.prop-pos-h{font-family:var(--serif);font-weight:600;font-size:17px;margin:26px 0 2px;color:var(--ink)}
.td-card{margin-top:18px;padding:14px 20px;border:1px solid var(--rule);background:var(--paper-2);border-radius:6px;display:flex;gap:30px;align-items:center;font-family:var(--sans)}
.td-card .k{font-size:10px;color:var(--ink-3);text-transform:uppercase;letter-spacing:.08em;margin-bottom:3px}
.td-card .v{font-family:var(--mono);font-size:22px;color:var(--ink)}
.td-card .va{font-family:var(--mono);font-size:16px;color:var(--actual)}
.td-card .sep{width:1px;height:34px;background:var(--rule)}
.prop-charts{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px;margin-top:24px}
@media (max-width:760px){.prop-charts{grid-template-columns:1fr}}

/* ===== player-props browser ===== */
.props-controls{display:flex;flex-wrap:wrap;gap:14px;align-items:flex-end;padding:1vh 0 2vh;border-bottom:1px solid var(--rule);margin-bottom:2vh}
.props-field{display:flex;flex-direction:column;gap:4px;font-family:var(--sans);font-size:10px;font-weight:600;letter-spacing:.10em;text-transform:uppercase;color:var(--ink-3)}
.props-field.grow{flex:1;min-width:200px}
.props-sel,.props-search{font-family:var(--sans);font-size:13px;color:var(--ink);background:var(--paper);border:1px solid var(--rule-2);border-radius:4px;padding:7px 10px;letter-spacing:0;text-transform:none;font-weight:400}
.props-sel{cursor:pointer;min-width:150px}
.props-search{width:100%}
.props-sel:focus,.props-search:focus{outline:none;border-color:var(--home)}
.props-grid{display:block}
.props-table{width:100%;border-collapse:collapse;font-family:var(--sans)}
.props-table thead th{font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-4);text-align:left;padding:7px 10px;border-bottom:1px solid var(--ink);white-space:nowrap}
.props-table th.pt-num{text-align:right}
.props-table th.sortable{cursor:pointer;user-select:none}
.props-table th.sortable:hover{color:var(--ink-2)}
.props-table th.sorted{color:var(--ink)}
.props-table th.sorted::after{content:" \25BE";font-size:9px}
.pt-row{cursor:pointer;border-bottom:1px solid var(--rule)}
.pt-row:hover{background:var(--paper-2)}
.pt-rank{font-family:var(--mono);font-variant-numeric:tabular-nums;font-size:11px;color:var(--ink-5);text-align:right;padding:8px;width:1%;white-space:nowrap}
.pt-player{padding:6px 10px}
.pt-player a{display:flex;align-items:center;gap:8px;text-decoration:none;color:inherit}
.pt-team{font-family:var(--mono);font-weight:700;font-size:10px;letter-spacing:.02em;padding:2px 5px;border-radius:3px;min-width:34px;text-align:center}
.pt-name{font-family:var(--serif);font-size:14px;color:var(--ink)}
.pt-player a:hover .pt-name{text-decoration:underline}
.pt-pos{font-family:var(--sans);font-size:9.5px;font-weight:600;letter-spacing:.06em;color:var(--ink-4)}
.pt-num{font-family:var(--mono);font-variant-numeric:tabular-nums;text-align:right;padding:8px 10px;white-space:nowrap}
.pt-proj{font-size:14px;font-weight:500;color:var(--ink)}
.pt-range{font-size:12px;color:var(--ink-4)}
.pt-range .pt-dashr{margin:0 2px;color:var(--ink-5)}
.pt-actual{font-size:13px;color:var(--ink-2)}
.pt-dash{color:var(--ink-5)}
.pt-vs{padding:8px;width:1%}
.pt-vs span{font-family:var(--sans);font-size:9px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;padding:2px 6px;border-radius:3px;white-space:nowrap}
.vs-above{background:var(--home);color:#fff}
.vs-below{background:var(--away);color:#fff}
.vs-in{background:var(--paper-2);color:var(--ink-4);border:1px solid var(--rule)}
.prop-card{border:1px solid var(--rule);border-radius:6px;padding:14px 16px 10px;background:var(--paper)}
.prop-card .pc-head{display:flex;align-items:baseline;justify-content:space-between;gap:8px;margin-bottom:1px}
.prop-card .pc-name{font-family:var(--serif);font-weight:600;font-size:16px;color:var(--ink)}
.prop-card .pc-name:hover{border-bottom:1px solid var(--rule-2)}
.prop-card .pc-team{font-family:var(--sans);font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-4);white-space:nowrap}
.prop-card .pc-sub{font-family:var(--mono);font-variant-numeric:tabular-nums;font-size:11px;color:var(--ink-3);margin-bottom:4px}
.prop-card .pc-act{color:var(--actual)}
@media (max-width:560px){.pt-col-range{display:none}.pt-name{font-size:13px}.pt-num{padding:8px 6px}}
