/* =============================================================================
   Project Leggy — design system
   ============================================================================= */
:root {
  /* palette */
  --bg: #0e0e14;
  --bg2: #15151f;
  --bg3: #1a1a26;
  --row: rgba(255,255,255,0.02);
  --row-hover: rgba(255,255,255,0.05);
  --border: rgba(255,255,255,0.06);
  --border2: rgba(255,255,255,0.1);
  --t1: rgba(255,255,255,0.92);
  --t2: rgba(255,255,255,0.6);
  --t3: rgba(255,255,255,0.55);
  --t4: rgba(255,255,255,0.5);

  --team-a: #E9A752;       /* Vitality-left, logo bracket left */
  --team-a-dark: #D4893F;  /* gradient toe */
  --team-b: #8B82E8;       /* NAVI-right, logo bracket right */
  --team-b-dark: #7269d8;
  --team-b-strong: #5b50b0; /* AA-contrast variant for white-on-purple buttons */
  --accent: #C5A572;       /* muted editorial gold — kickers, decider tag, hot/fresh signals */
  --green: #58D58A;        /* win */
  --red:   #F27373;        /* loss */
  --star:  #E9A752;        /* event tier stars */

  --sans:  "Space Grotesk", -apple-system, "Segoe UI", "Inter", sans-serif;
  --serif: "Source Serif 4", "Iowan Old Style", Georgia, serif;
  --mono:  "JetBrains Mono", "Cascadia Code", monospace;
}

* { box-sizing: border-box; margin: 0; padding: 0; }

body {
  background: var(--bg);
  color: var(--t1);
  font-family: var(--sans);
  font-size: 14px;
  min-height: 100vh;
}

.app { max-width: 1040px; margin: 0 auto; padding: 20px 16px 60px; }

/* --- Top bar ------------------------------------------------------------- */
.app-topbar { display:flex; align-items:flex-end; justify-content:space-between; padding-bottom:16px; border-bottom:1px solid var(--border); margin-bottom:16px; gap:16px; }
.app-brand  { display:inline-flex; line-height:0; }
.app-brand img { height:180px; width:auto; display:block; }
.app-topbar-right { display:flex; align-items:center; gap:14px; }
.app-back   { font-size:13px; color:var(--team-b); cursor:pointer; font-family:var(--sans); }
.app-back:hover { color:#fff; }
.app-cta    { display:inline-flex; align-items:center; gap:8px; font-size:13px; padding:8px 16px; border-radius:8px; background:rgba(233,167,82,0.12); color:var(--team-a); border:0.5px solid rgba(233,167,82,0.3); cursor:pointer; font-family:var(--sans); }
.app-cta:hover { background:rgba(233,167,82,0.2); }
.app-cta .plus { font-size:16px; font-weight:500; line-height:1; }

/* --- Custom matchup panel ------------------------------------------------ */
.custom-panel { background:var(--bg2); border:0.5px solid var(--border); border-radius:10px; padding:16px; margin-bottom:18px; }
.cp-row { display:flex; gap:10px; align-items:end; }
.cp-field { flex:1; position:relative; }
.cp-field-fmt { max-width:100px; flex:0 0 100px; }
.cp-field label { font-size:12px; color:var(--t3); display:block; margin-bottom:4px; }
.cp-field input, .cp-field select { width:100%; padding:8px 10px; border-radius:6px; border:0.5px solid var(--border2); background:var(--bg3); color:#fff; font-family:var(--sans); font-size:14px; outline:0; }
.cp-field input:focus { border-color:var(--team-b); }
.cp-go { padding:8px 24px; border-radius:6px; background:var(--team-b); color:#fff; border:0; cursor:pointer; font-family:var(--sans); font-size:14px; font-weight:500; white-space:nowrap; }
.cp-go:hover { background:var(--team-b-dark); }
.acl { position:absolute; background:var(--bg2); border:0.5px solid var(--border2); border-radius:6px; max-height:180px; overflow-y:auto; z-index:99; width:100%; margin-top:2px; }
.acl div { padding:6px 10px; cursor:pointer; font-size:13px; color:var(--t1); }
.acl div:hover { background:rgba(255,255,255,0.05); }
.acl .ac-rank { color:var(--t3); font-size:11px; margin-left:6px; }

/* --- Schedule view ------------------------------------------------------- */
.sch-sort { display:flex; gap:4px; padding:3px; background:rgba(255,255,255,0.03); border-radius:8px; margin-bottom:12px; max-width:240px; }
.sch-sort-btn { flex:1; padding:7px 14px; border-radius:6px; font-size:12px; font-weight:500; text-align:center; cursor:pointer; color:var(--t3); font-family:var(--sans); transition:background .12s, color .12s; letter-spacing:0.3px; background:transparent; border:0; }
.sch-sort-btn.active { background:rgba(139,130,232,0.16); color:var(--team-b); }

.app-date { font-size:12px; color:var(--t3); font-family:var(--mono); letter-spacing:0.5px; text-transform:uppercase; margin-bottom:14px; }

.sch-match {
  display:grid;
  grid-template-columns: 60px 1fr 80px 1fr 240px 20px;
  gap:12px; align-items:center; padding:14px 12px; border-radius:8px; cursor:pointer; transition:background .12s;
  text-decoration:none; color:inherit;
}
.sch-match:hover { background:var(--row-hover); }
.sch-match-disabled { cursor: default; opacity: 0.6; pointer-events: none; }
.sch-match + .sch-match { border-top:1px dashed rgba(255,255,255,0.04); border-radius:0; }
.sch-time { font-size:13px; color:var(--t2); font-family:var(--mono); letter-spacing:0.5px; }
.sch-team { display:flex; align-items:center; gap:12px; min-width:0; }
.sch-team.r { flex-direction:row-reverse; text-align:right; }
.sch-logo { width:34px; height:34px; border-radius:7px; display:flex; align-items:center; justify-content:center; flex-shrink:0; border:1px solid transparent; overflow:hidden; font-size:0; color:transparent; }
.sch-logo.L { background:var(--team-a); border-color:var(--team-a); }
.sch-logo.R { background:var(--team-b); border-color:var(--team-b); }
.sch-logo.L.has-logo { background:#e8e8e8; }
.sch-logo.R.has-logo { background:#e8e8e8; }
.sch-logo img { width:100%; height:100%; object-fit:contain; padding:2px; display:block; }
.sch-info   { min-width:0; }
.sch-name   { font-size:15px; font-weight:600; letter-spacing:-0.2px; color:var(--t1); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.sch-rank   { font-size:11px; color:var(--t3); font-family:var(--mono); margin-top:1px; }
.sch-center { display:flex; flex-direction:column; align-items:center; gap:4px; }
.sch-vs     { font-size:12px; color:var(--t4); font-weight:400; letter-spacing:1px; text-transform:uppercase; }
.sch-fmt    { font-size:11px; color:var(--t3); font-family:var(--mono); text-transform:uppercase; letter-spacing:0.5px; background:rgba(255,255,255,0.04); padding:2px 8px; border-radius:4px; }
.sch-event  { display:flex; flex-direction:column; align-items:flex-end; gap:3px; text-align:right; min-width:0; }
.sch-event .stars { color:var(--star); font-size:9px; letter-spacing:1.5px; }
.sch-event .name  { font-size:12px; color:var(--t2); overflow:hidden; text-overflow:ellipsis; white-space:nowrap; max-width:100%; letter-spacing:0.1px; }
.sch-event .name.high-star { color:var(--accent); }
.sch-arrow  { color:var(--t4); font-size:16px; text-align:center; }
.sch-match:hover .sch-arrow { color:var(--team-b); }

.sch-event-head { display:flex; align-items:center; gap:10px; padding:16px 10px 8px; border-bottom:1px solid var(--border); margin:14px 0 4px; }
.sch-event-head .stars { color:var(--star); font-size:10px; letter-spacing:2px; }
.sch-event-head .name  { font-size:13px; font-weight:600; color:var(--t1); letter-spacing:-0.2px; }
.sch-event-head .count { margin-left:auto; font-size:11px; color:var(--t3); font-family:var(--mono); text-transform:uppercase; letter-spacing:1px; }
.sch-group { margin-bottom:14px; }
.sch-group .sch-match { grid-template-columns: 60px 1fr 80px 1fr 20px; }
.sch-group .sch-event { display:none; }

.sch-empty { text-align:center; color:var(--t3); padding:40px 0; font-size:13px; }

/* --- Section labels (shared) -------------------------------------------- */
.lp-section { font-size:12px; color:var(--t2); text-transform:uppercase; letter-spacing:1.5px; font-weight:600; padding:14px 0 8px; border-bottom:1px solid var(--border); margin-bottom:10px; display:flex; align-items:center; gap:8px; }
.lp-section .count { margin-left:auto; font-weight:400; color:var(--t3); letter-spacing:0.5px; }

/* --- Series hero -------------------------------------------------------- */
.lp-hero { background:linear-gradient(180deg, rgba(233,167,82,0.05), rgba(139,130,232,0.03)); border:1px solid var(--border); border-radius:10px; padding:20px 24px; margin-bottom:14px; }
.lp-hero-top { display:flex; align-items:center; justify-content:space-between; font-size:12px; color:var(--t3); text-transform:uppercase; letter-spacing:1px; margin-bottom:14px; }
.lp-hero-event { color:var(--t1); }
.lp-hero-main { display:grid; grid-template-columns:1fr auto 1fr; gap:20px; align-items:center; }
.lp-team { display:flex; align-items:center; gap:12px; }
.lp-team.r { flex-direction:row-reverse; text-align:right; }
.lp-logo { width:44px; height:44px; border-radius:8px; display:flex; align-items:center; justify-content:center; border:1px solid transparent; overflow:hidden; font-size:0; color:transparent; }
.lp-logo.L { background:var(--team-a); border-color:var(--team-a); }
.lp-logo.R { background:var(--team-b); border-color:var(--team-b); }
.lp-logo.L.has-logo { background:#e8e8e8; }
.lp-logo.R.has-logo { background:#e8e8e8; }
.lp-logo img { width:100%; height:100%; object-fit:contain; padding:3px; display:block; }
.lp-tname { font-size:17px; font-weight:600; letter-spacing:-0.3px; }
.lp-trank { font-size:12px; color:var(--t3); font-family:var(--mono); }
.lp-vs { font-size:22px; font-weight:300; color:var(--t4); text-align:center; }
.lp-prob { display:flex; align-items:center; gap:14px; margin-top:16px; }
.lp-pct { font-size:28px; font-weight:600; font-variant-numeric: tabular-nums; letter-spacing:-1px; }
.lp-pct.l { color:var(--team-a); }
.lp-pct.r { color:var(--team-b); }
.lp-pbar { flex:1; height:8px; background:rgba(255,255,255,0.06); border-radius:4px; overflow:hidden; display:flex; }
.lp-pbar .l { background:linear-gradient(90deg,var(--team-a-dark),var(--team-a)); }
.lp-pbar .r { background:linear-gradient(90deg,var(--team-b),var(--team-b-dark)); }
.lp-prob-label { font-size:12px; color:var(--t3); text-align:center; text-transform:uppercase; letter-spacing:1px; margin-top:8px; }
.lp-chips { display:flex; justify-content:center; gap:6px; margin-top:10px; flex-wrap:wrap; }
.lp-chip {
  display:inline-flex; align-items:baseline; gap:6px;
  font-size:13px; padding:4px 10px; border-radius:12px;
  background:rgba(255,255,255,0.04); color:var(--t3);
  font-family:var(--mono);
}
.lp-chip .chip-team { font-size:10px; font-weight:600; letter-spacing:0.5px; opacity:0.85; }
.lp-chip .chip-score { font-variant-numeric:tabular-nums; }
.lp-chip .chip-prob { font-size:11px; opacity:0.65; }
/* Team-colored chips — winner determines hue. Only the favorite gets a
   tinted pill background; the rest are plain text in the team color. */
.lp-chip-a { background:transparent; color:var(--team-a); }
.lp-chip-a .chip-team { color:var(--team-a); }
.lp-chip-b { background:transparent; color:var(--team-b); }
.lp-chip-b .chip-team { color:var(--team-b); }
.lp-chip.fav { font-weight:600; }
.lp-chip-a.fav { background:rgba(233,167,82,0.22); }
.lp-chip-b.fav { background:rgba(139,130,232,0.22); }
/* Actual outcome — green outline overrides any tint */
.lp-chip-actual {
  background:rgba(88,213,138,0.18) !important;
  outline:1.5px solid var(--green); outline-offset:-1px;
  color:var(--green) !important;
}
.lp-chip-actual .chip-team { color:var(--green) !important; }

/* Actual result — per-map breakdown under the hero */
.lp-actual {
  margin-top:14px; padding-top:12px;
  border-top:1px dashed rgba(255,255,255,0.06);
}
.lp-actual-label {
  font-family:var(--mono); font-size:11px; letter-spacing:1.2px;
  text-transform:uppercase; color:var(--t3);
  text-align:center; margin-bottom:8px;
}
.lp-actual-row {
  display:grid; grid-template-columns:1fr 90px 1fr;
  align-items:baseline; gap:10px;
  font-family:var(--mono); font-size:13px;
  padding:4px 0; max-width:480px; margin:0 auto;
}
.lp-actual-map {
  text-align:right; color:var(--t1); font-weight:500;
  text-transform:capitalize;
}
.lp-actual-score {
  text-align:center; font-weight:600; color:var(--t1);
  font-variant-numeric:tabular-nums;
}
.lp-actual-winner { font-weight:600; }
.lp-actual-winner.l { color:var(--team-a); }
.lp-actual-winner.r { color:var(--team-b); }

/* --- Editorial summary -------------------------------------------------- */
.lp-summary { margin:18px 0; padding:22px 28px; background:var(--bg2); border-left:3px solid var(--accent); border-radius:0 8px 8px 0; }
.lp-summary .kicker { font-family:var(--sans); font-size:11px; color:var(--accent); text-transform:uppercase; letter-spacing:2px; margin-bottom:10px; }
.lp-summary .prose  { font-family:var(--serif); font-size:16px; line-height:1.6; color:#eae4d8; letter-spacing:0.1px; }

/* --- Veto scenario tabs + inline permabans ------------------------------ */
.lp-section.has-tabs { border-bottom:none; padding-bottom:4px; }
.lp-section.has-tabs .count { margin-left:0; color:var(--t2); font-weight:600; letter-spacing:1.5px; font-size:12px; }
.lp-section.has-tabs .lp-permabans-wrap { flex:1; display:flex; justify-content:center; align-items:center; gap:10px; font-family:var(--mono); font-size:11px; letter-spacing:0.5px; text-transform:uppercase; color:var(--t3); }
.lp-section.has-tabs .lp-permabans-wrap .pb-label { color:var(--t4); }
.lp-section.has-tabs .lp-permabans-wrap .pb-item { display:inline-flex; align-items:baseline; gap:4px; }
.lp-section.has-tabs .lp-permabans-wrap .pb-map { color:var(--red); font-weight:600; letter-spacing:0.3px; }
.lp-section.has-tabs .lp-permabans-wrap .pb-map.pb-none { color:var(--t4); font-weight:400; }
.lp-section.has-tabs .lp-permabans-wrap .pb-by { font-size:10px; }
.lp-section.has-tabs .lp-permabans-wrap .pb-by.L { color:var(--team-a); }
.lp-section.has-tabs .lp-permabans-wrap .pb-by.R { color:var(--team-b); }

.lp-scen-tabs { display:flex; gap:4px; background:rgba(255,255,255,0.03); padding:3px; border-radius:8px; margin:0 0 10px; border-bottom:1px solid var(--border); padding-bottom:3px; }
.lp-scen-tab { padding:6px 14px; border-radius:6px; cursor:pointer; font-size:12px; color:var(--t3); display:flex; align-items:center; gap:10px; transition:background .12s, color .12s; font-family:var(--sans); user-select:none; }
.lp-scen-tab:hover { color:var(--t2); }
.lp-scen-tab.active { background:rgba(233,167,82,0.18); color:var(--team-a); }
.lp-scen-tab-correct { outline:1.5px solid var(--green); outline-offset:-1px; }
.lp-scen-tab-correct .name, .lp-scen-tab-correct .maplist { color:var(--green); }
.lp-scen-tab.active.lp-scen-tab-correct { background:rgba(88,213,138,0.16); color:var(--green); }
.lp-scen-tab .name { font-weight:600; letter-spacing:-0.1px; }
.lp-scen-tab .pct  { font-family:var(--mono); font-size:11px; opacity:0.8; }
.lp-scen-tab .maplist { font-family:var(--mono); font-size:10px; color:var(--t4); text-transform:uppercase; letter-spacing:0.5px; margin-left:4px; }
.lp-scen-tab.active .maplist { color:var(--t2); }
.lp-scenario { display:none; }
.lp-scenario.active { display:block; }

/* --- Map card ----------------------------------------------------------- */
.lp-map-card { background:var(--row); border:1px solid var(--border); border-radius:8px; margin-bottom:10px; overflow:hidden; }
.lp-map-card-correct { border-color:rgba(88,213,138,0.45); box-shadow:inset 3px 0 0 var(--green); }
.lp-map-card-missed  { border-color:rgba(242,115,115,0.35); box-shadow:inset 3px 0 0 var(--red); }
.lp-map-head { padding:12px 16px; display:grid; grid-template-columns: 160px 1fr 180px; gap:16px; align-items:center; border-bottom:1px solid var(--border); background:rgba(255,255,255,0.015); }
.lp-map-name { font-size:16px; font-weight:600; letter-spacing:-0.2px; }
.lp-map-tag { font-size:11px; text-transform:uppercase; letter-spacing:1px; margin-top:3px; font-family:var(--mono); }
.lp-map-tag.tp  { color:var(--team-a); }
.lp-map-tag.op  { color:var(--team-b); }
.lp-map-tag.dec { color:var(--accent); }
.lp-map-tag.alt { color:var(--t3); font-style:italic; }

.lp-map-score { display:grid; grid-template-columns: 1fr auto auto auto 1fr; gap:10px; align-items:center; font-family:var(--mono); }
.lp-map-score .abbr { font-size:13px; color:var(--t3); text-transform:uppercase; letter-spacing:1px; }
.lp-map-score .abbr.l { text-align:right; }
.lp-map-score .abbr.r { text-align:left; }
.lp-map-score .abbr.winL { color:var(--team-a); font-weight:600; }
.lp-map-score .abbr.winR { color:var(--team-b); font-weight:600; }
.lp-map-score .num { font-size:22px; font-weight:600; font-variant-numeric: tabular-nums; letter-spacing:-0.5px; }
.lp-map-score .num.l { color:var(--team-a); text-align:right; }
.lp-map-score .num.r { color:var(--team-b); text-align:left; }
.lp-map-score .dash { font-size:16px; color:var(--t4); }
.lp-map-score .num.loser { opacity:0.45; }

.lp-map-prob { display:flex; flex-direction:column; gap:4px; }
.lp-map-prob-row { display:flex; align-items:center; gap:8px; }
.lp-map-prob-row .pct { font-family:var(--mono); font-size:13px; min-width:26px; }
.lp-map-prob-row .pct.l { color:var(--team-a); text-align:right; }
.lp-map-prob-row .pct.r { color:var(--team-b); }
.lp-map-prob-row .bar { flex:1; height:4px; background:rgba(255,255,255,0.06); border-radius:2px; overflow:hidden; display:flex; }
.lp-map-prob-row .bar .l { background:var(--team-a); }
.lp-map-prob-row .bar .r { background:var(--team-b); }
.lp-map-prob-sub { display:flex; justify-content:space-between; font-size:11px; color:var(--t3); text-transform:uppercase; letter-spacing:1px; font-family:var(--mono); }
.lp-ot { font-size:12px; font-family:var(--mono); color:var(--t3); }
.lp-ot.hot { color:var(--accent); }
.lp-tossup { color:var(--accent); }

.lp-map-body { padding:14px 16px; display:grid; grid-template-columns:1fr 1fr; gap:20px; }
.lp-drivers .title, .lp-recent .title { font-size:11px; color:var(--t3); text-transform:uppercase; letter-spacing:1.5px; margin-bottom:10px; font-weight:600; }

.lp-driver { display:grid; grid-template-columns:130px 34px 1fr 34px; gap:8px; align-items:center; padding:5px 0; font-size:14px; }
.lp-driver .lab { color:var(--t2); }
.lp-driver .anchor { font-family:var(--mono); font-size:12px; text-transform:uppercase; letter-spacing:0.5px; font-weight:600; }
.lp-driver .anchor.l { color:var(--team-a); text-align:right; }
.lp-driver .anchor.r { color:var(--team-b); text-align:left; }
.lp-driver .barwrap { height:12px; position:relative; background:rgba(255,255,255,0.03); border-radius:2px; }
.lp-driver .midline { position:absolute; left:50%; top:0; bottom:0; width:1px; background:rgba(255,255,255,0.15); z-index:2; }
.lp-driver .fill { position:absolute; height:5px; top:3.5px; border-radius:2px; z-index:1; }
.lp-driver .fill.l { right:50%; background:var(--team-a); }
.lp-driver .fill.r { left:50%; background:var(--team-b); }

.lp-recent-cols { display:grid; grid-template-columns:1fr 1fr; gap:14px; font-family:var(--mono); }
.lp-recent-col-head { font-size:11px; color:var(--t3); text-transform:uppercase; letter-spacing:1px; padding-bottom:4px; margin-bottom:4px; border-bottom:1px solid var(--border); text-align:center; }
.lp-recent-col-head.l { color:var(--team-a); }
.lp-recent-col-head.r { color:var(--team-b); }
.lp-rr { display:flex; gap:8px; padding:3px 0; color:var(--t3); font-size:12px; }
.lp-rr .sc { width:40px; font-weight:600; font-size:13px; }
.lp-rr .sc.w  { color:var(--green); }
.lp-rr .sc.lo { color:var(--red); }
.lp-rr .opp { flex:1; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; color:var(--t2); }
.lp-rr .dt  { color:var(--t4); font-size:11px; }

/* --- Recent Results (series-level) ------------------------------------- */
.lp-rres-wrap { border:1px solid var(--border); border-radius:8px; overflow:hidden; background:var(--row); }
.lp-rres-head { display:grid; grid-template-columns:1fr 1fr; background:var(--bg2); padding:10px 14px; border-bottom:1px solid var(--border); }
.lp-rres-head > div { font-size:14px; font-weight:600; text-align:center; letter-spacing:-0.2px; }
.lp-rres-head .l { color:var(--team-a); }
.lp-rres-head .r { color:var(--team-b); }
.lp-rres-body { display:grid; grid-template-columns:1fr 1px 1fr; }
.lp-rres-divider { background:var(--border); }
.lp-rres-col { padding:2px 12px 4px; }
.lp-rres-row { display:flex; align-items:center; gap:10px; padding:5px 0; font-size:14px; font-family:var(--mono); border-bottom:1px dashed rgba(255,255,255,0.04); }
.lp-rres-row:last-child { border-bottom:none; }
.lp-rres-row .when { display:inline-flex; align-items:baseline; gap:10px; flex-shrink:0; margin-left:auto; }
.lp-rres-row .when .abs { color:var(--t3); font-size:12px; }
.lp-rres-row .when .rel { color:var(--t4); font-size:11px; font-family:var(--sans); text-transform:lowercase; letter-spacing:0.3px; text-align:right; }
.lp-rres-row .when .rel.fresh { color:var(--accent); }
.lp-rres-row .wl { font-weight:700; font-size:12px; letter-spacing:0.5px; text-align:center; width:16px; flex-shrink:0; }
.lp-rres-row .wl.w { color:var(--green); }
.lp-rres-row .wl.l { color:var(--red); }
.lp-rres-row .sc { font-weight:600; color:var(--t1); width:42px; flex-shrink:0; }
.lp-rres-row:has(.wl.w) .sc { color:var(--green); }
.lp-rres-row:has(.wl.l) .sc { color:var(--red); }
.lp-rres-row .opp { color:var(--t2); overflow:hidden; text-overflow:ellipsis; white-space:nowrap; font-family:var(--sans); flex:0 0 90px; min-width:0; font-size:12px; }
.lp-rres-row .maps { display:flex; justify-content:center; align-items:center; gap:3px; flex:0 1 auto; min-width:0; white-space:nowrap; }
.lp-rres-row .mp { font-size:10px; font-family:var(--mono); text-transform:uppercase; letter-spacing:0.3px; font-weight:600; flex-shrink:0; }
.lp-rres-row .mp.w { color:var(--green); }
.lp-rres-row .mp.l { color:var(--red); }
.lp-rres-row .mp + .mp::before { content:'-'; color:var(--t4); margin-right:4px; font-weight:400; }

/* --- Player Matchups ---------------------------------------------------- */
.lp-players-head { display:grid; grid-template-columns:1fr 120px 1fr; gap:10px; padding:10px 14px; background:var(--bg2); border:1px solid var(--border); border-radius:6px 6px 0 0; border-bottom:none; align-items:center; }
.lp-players-tname { font-size:14px; font-weight:600; }
.lp-players-tname.l { color:var(--team-a); text-align:right; }
.lp-players-tname.r { color:var(--team-b); }
.lp-players-mid { font-size:11px; color:var(--t3); text-align:center; text-transform:uppercase; letter-spacing:1.5px; }
.lp-player-row { display:grid; grid-template-columns:1fr 120px 1fr; gap:10px; padding:10px 14px; background:var(--row); border:1px solid var(--border); border-top:none; align-items:center; }
.lp-pcell { display:flex; align-items:center; gap:10px; }
.lp-pcell.r { flex-direction:row-reverse; text-align:right; }
.lp-pavatar { width:28px; height:28px; border-radius:50%; background:rgba(255,255,255,0.05); display:flex; align-items:center; justify-content:center; font-size:10px; color:var(--t3); font-weight:600; }
.lp-pavatar.L { background:rgba(233,167,82,0.12); color:var(--team-a); }
.lp-pavatar.R { background:rgba(139,130,232,0.12); color:var(--team-b); }
.lp-pinfo { flex:1; min-width:0; }
.lp-pname { font-size:14px; font-weight:600; }
.lp-pstats { font-size:12px; color:var(--t3); font-family:var(--mono); margin-top:2px; }
.lp-pstats span { margin-right:8px; }
.lp-pstats .hi { color:var(--accent); }
.lp-prating-mid { display:flex; flex-direction:column; align-items:center; gap:4px; }
.lp-prating { display:flex; align-items:center; gap:6px; }
.lp-prating .nL { color:var(--team-a); font-weight:600; font-family:var(--mono); font-size:15px; }
.lp-prating .nR { color:var(--team-b); font-weight:600; font-family:var(--mono); font-size:15px; }
.lp-prating .vs { font-size:10px; color:var(--t4); }
.lp-prating-bar { width:100px; height:3px; background:rgba(255,255,255,0.06); border-radius:2px; overflow:hidden; display:flex; }
.lp-prating-bar .l { background:var(--team-a); }
.lp-prating-bar .r { background:var(--team-b); }

.lp-team-agg { display:grid; grid-template-columns:1fr 120px 1fr; gap:10px; padding:12px 14px; background:var(--bg3); border:1px solid var(--border2); border-top:none; border-radius:0 0 6px 6px; font-size:13px; font-family:var(--mono); }
.lp-team-agg .l { color:var(--team-a); text-align:right; }
.lp-team-agg .r { color:var(--team-b); }
.lp-team-agg .mid { color:var(--t3); text-align:center; font-size:11px; text-transform:uppercase; letter-spacing:1px; }
.lp-team-agg strong { font-weight:600; font-size:14px; }

/* --- Loading / empty state --------------------------------------------- */
.loading { text-align:center; color:var(--t3); padding:40px 0; }
.spinner { display:inline-block; width:20px; height:20px; border:2px solid rgba(255,255,255,0.1); border-top-color:var(--team-b); border-radius:50%; animation:spin .7s linear infinite; margin-bottom:8px; }
@keyframes spin { to { transform:rotate(360deg); } }
.empty { text-align:center; color:var(--t3); padding:40px 0; }

/* =============================================================================
   Public site additions — ported from site-mockup.html inline styles
   ============================================================================= */

/* --- Public nav & topbar ------------------------------------------------- */
.pub-topbar {
  display:flex; align-items:flex-end; justify-content:space-between;
  padding-bottom:16px; border-bottom:1px solid var(--border); margin-bottom:24px;
}
.pub-brand img { height:116px; width:auto; display:block; }
.pub-nav { display:flex; align-items:center; gap:24px; }
.pub-nav a {
  font-size:13px; color:var(--t2); text-decoration:none;
  font-family:var(--sans); letter-spacing:0.2px;
  padding:6px 0; border-bottom:1px solid transparent;
  transition:color .12s, border-color .12s;
}
.pub-nav a:hover { color:var(--t1); }
.pub-nav a.active { color:var(--t1); border-bottom-color:var(--team-a); }
.pub-nav a[href="/matches/"].active { border-bottom-color:var(--team-b); }

/* --- Back link (styled like an active sch-sort-btn pill) ----------------- */
.pub-back {
  display:inline-flex; align-items:center; gap:6px;
  font-size:12px; font-weight:500; letter-spacing:0.3px;
  padding:7px 14px; border-radius:6px;
  color:var(--team-b); background:rgba(139,130,232,0.16);
  font-family:var(--sans); text-decoration:none;
  transition:background .12s;
}
.pub-back:hover { background:rgba(139,130,232,0.26); }
.pub-back .chev { font-size:14px; line-height:1; color:var(--team-a); }

/* --- Public footer ------------------------------------------------------- */
.pub-footer {
  max-width:1040px; margin:60px auto 0; padding:20px 16px;
  border-top:1px solid var(--border);
  display:flex; justify-content:space-between; align-items:center;
  font-family:var(--mono); font-size:11px; color:var(--t4); letter-spacing:0.5px;
}
.pub-footer a { color:var(--t3); text-decoration:none; }
.pub-footer a:hover { color:var(--t2); }

/* --- Splash hero --------------------------------------------------------- */
.splash {
  display:grid; grid-template-columns:1.1fr 1fr;
  gap:32px; padding:28px 0 40px;
  align-items:start;
  border-bottom:1px solid var(--border); margin-bottom:32px;
}
.splash-left h1 {
  font-family:var(--serif); font-size:52px; font-weight:600;
  line-height:1.05; letter-spacing:-1.2px; color:var(--t1); margin-bottom:18px;
}
.splash-left h1 em { font-style:italic; color:var(--accent); }
.splash-tagline { font-size:16px; color:var(--t2); line-height:1.55; margin-bottom:24px; max-width:480px; }
.splash-cta {
  display:inline-flex; align-items:center; gap:8px; padding:10px 20px;
  border-radius:8px; background:var(--team-b-strong); color:#fff;
  text-decoration:none; font-family:var(--sans); font-size:14px; font-weight:600;
  transition:background .12s;
}
.splash-cta:hover { background:#4d4395; }
.splash-cta .arrow { font-size:16px; }

.splash-stat {
  background:var(--bg2); border:1px solid var(--border); border-radius:12px;
  padding:24px 28px; display:flex; flex-direction:column; gap:18px;
}
.splash-stat-head {
  display:flex; align-items:baseline; justify-content:space-between;
  padding-bottom:12px; border-bottom:1px solid var(--border);
}
.splash-stat-title { font-family:var(--mono); font-size:11px; letter-spacing:1.5px; text-transform:uppercase; color:var(--t3); }
.splash-stat-window { font-family:var(--mono); font-size:11px; color:var(--t4); }
.splash-stat-row { display:grid; grid-template-columns:auto 1fr auto; align-items:baseline; gap:14px; }
.splash-stat-num { font-family:var(--mono); font-size:32px; font-weight:600; color:var(--green); font-variant-numeric:tabular-nums; letter-spacing:-1px; }
.splash-stat-label { font-size:13px; color:var(--t2); }
.splash-stat-frac { font-family:var(--mono); font-size:12px; color:var(--t3); font-variant-numeric:tabular-nums; }

/* Right column wrap (just the stat panel now that streak moved out) */
.splash-right { display:flex; flex-direction:column; gap:14px; }

/* Best Daily Streak — compact card under accuracy in right column, centered */
.splash-bestday {
  background:var(--bg2); border:1px solid var(--border); border-radius:12px;
  padding:12px 22px;
  display:inline-flex; flex-direction:column; gap:6px;
  align-self:center;
  min-width:280px; max-width:360px;
}
.splash-bestday-head {
  display:flex; align-items:baseline; justify-content:space-between; gap:16px;
}
.splash-bestday-title {
  font-family:var(--mono); font-size:11px; letter-spacing:1.5px;
  text-transform:uppercase; color:var(--t3);
}
.splash-bestday-date {
  font-family:var(--mono); font-size:11px; color:var(--t4);
}
.splash-bestday-row {
  display:flex; justify-content:center; align-items:baseline; gap:10px;
}
.splash-bestday-num {
  font-family:var(--mono); font-size:24px; font-weight:600; color:var(--green);
  font-variant-numeric:tabular-nums; letter-spacing:-1px;
}
.splash-bestday-label { font-size:13px; color:var(--t2); }
.splash-bestday-frac {
  font-family:var(--mono); font-size:12px; color:var(--t3); font-variant-numeric:tabular-nums;
}
.splash-bestday-foot {
  font-family:var(--mono); font-size:10px; letter-spacing:0.5px;
  color:var(--t4); text-align:center; margin-top:2px;
}

/* --- Splash today strip -------------------------------------------------- */
.splash-today { display:grid; grid-template-columns:1fr 1fr 1fr; gap:14px; margin-bottom:32px; }
.splash-card {
  background:var(--bg2); border:1px solid var(--border); border-radius:10px;
  padding:14px 16px; display:flex; flex-direction:column; gap:8px;
  cursor:pointer; transition:border-color .12s, background .12s;
  text-decoration:none; color:inherit;
}
.splash-card:hover { border-color:var(--border2); background:var(--bg3); }
.splash-card-head {
  display:flex; justify-content:space-between;
  font-size:11px; color:var(--t3); font-family:var(--mono);
  letter-spacing:0.5px; text-transform:uppercase;
}
.splash-card-pick { display:flex; align-items:baseline; gap:8px; }
.splash-card-pick .team { font-size:15px; font-weight:600; color:var(--t1); }
.splash-card-pick .team.a { color:var(--team-a); }
.splash-card-pick .team.b { color:var(--team-b); }
.splash-card-pick .pct { font-family:var(--mono); font-size:13px; color:var(--t2); font-variant-numeric:tabular-nums; }
.splash-card-vs { font-size:11px; color:var(--t4); font-family:var(--mono); }
.splash-section-label {
  font-family:var(--mono); font-size:11px; letter-spacing:1.5px; text-transform:uppercase;
  color:var(--t3); margin-bottom:12px; padding-bottom:8px; border-bottom:1px solid var(--border);
}
.splash-section-label .more { float:right; color:var(--team-b); font-size:11px; cursor:pointer; letter-spacing:0.5px; text-transform:none; text-decoration:none; }

/* --- Archive page -------------------------------------------------------- */
.archive-head {
  display:flex; align-items:baseline; justify-content:space-between;
  padding-bottom:12px; border-bottom:1px solid var(--border); margin-bottom:24px;
}
.archive-title { font-family:var(--serif); font-size:28px; font-weight:600; letter-spacing:-0.5px; color:var(--t1); }
.archive-cumulative { font-family:var(--mono); font-size:12px; color:var(--t3); }
.archive-cumulative .num { color:var(--t2); font-weight:500; }
.archive-month { margin-bottom:28px; }
.archive-month-label {
  font-family:var(--mono); font-size:11px; letter-spacing:2px; text-transform:uppercase;
  color:var(--t3); padding-bottom:8px; border-bottom:1px solid var(--border); margin-bottom:6px;
}
.archive-row {
  display:grid; grid-template-columns:220px 1fr auto;
  gap:18px; padding:12px 12px; border-radius:8px;
  align-items:baseline; cursor:pointer; transition:background .12s;
  text-decoration:none; color:inherit;
}
.archive-row:hover { background:var(--row-hover); }
.archive-row + .archive-row { border-top:1px dashed rgba(255,255,255,0.04); border-radius:0; }
.archive-row-date { font-size:14px; color:var(--t1); font-weight:500; }
.archive-row-date .weekday { color:var(--t3); font-weight:400; }
.archive-row-stats {
  display:flex; gap:24px; align-items:baseline;
  font-family:var(--mono); font-size:13px; color:var(--t2); font-variant-numeric:tabular-nums;
}
.archive-row-stats .frac { color:var(--t3); font-size:11px; letter-spacing:0.3px; }
.archive-row-stats .pct.good { color:var(--green); }
.archive-row-stats .pct.mid  { color:var(--accent); }
.archive-row-stats .pct.bad  { color:var(--red); }
.archive-row-stats .label { color:var(--t3); font-size:11px; text-transform:uppercase; letter-spacing:0.5px; font-family:var(--sans); }
.archive-row-pending { font-family:var(--mono); font-size:11px; color:var(--t4); letter-spacing:0.5px; }
.archive-row-arrow { color:var(--t4); font-size:14px; }

/* --- About page ---------------------------------------------------------- */
.about-page { max-width:680px; margin:0 auto; padding:8px 0 60px; }
.about-title { font-family:var(--serif); font-size:36px; font-weight:600; line-height:1.1; letter-spacing:-0.5px; margin-bottom:8px; }
.about-kicker { font-family:var(--mono); font-size:11px; letter-spacing:2px; text-transform:uppercase; color:var(--accent); margin-bottom:24px; }
.about-page p { font-family:var(--serif); font-size:17px; line-height:1.65; color:var(--t1); margin-bottom:18px; }
.about-page p em { color:var(--accent); font-style:italic; }
.about-page h2 {
  font-family:var(--sans); font-size:13px; font-weight:600;
  letter-spacing:1.5px; text-transform:uppercase; color:var(--t3);
  margin-top:36px; margin-bottom:12px; padding-bottom:6px; border-bottom:1px solid var(--border);
}
.about-stats { display:flex; justify-content:center; gap:18px; margin:16px 0 24px; }
.about-stat { background:var(--bg2); border:1px solid var(--border); border-radius:10px; padding:18px 20px; text-align:center; }
.about-stat-num { font-family:var(--mono); font-size:28px; font-weight:600; color:var(--green); font-variant-numeric:tabular-nums; line-height:1; }
.about-stat-label { font-family:var(--sans); font-size:12px; color:var(--t2); margin-top:8px; }
.about-stat-frac { font-family:var(--mono); font-size:11px; color:var(--t3); margin-top:4px; }

.about-faq { display:flex; flex-direction:column; gap:8px; margin:8px 0 24px; }
.about-faq details {
  background:var(--bg2); border:1px solid var(--border); border-radius:10px;
  padding:0 18px; transition:background .12s;
}
.about-faq details[open] { background:var(--bg3); }
.about-faq summary {
  font-family:var(--sans); font-size:15px; font-weight:600; color:var(--t1);
  padding:14px 0; cursor:pointer; list-style:none; display:flex; justify-content:space-between; align-items:center; gap:12px;
}
.about-faq summary::-webkit-details-marker { display:none; }
.about-faq summary::after { content:'+'; font-family:var(--mono); font-size:18px; color:var(--t3); font-weight:400; transition:transform .12s; }
.about-faq details[open] summary::after { content:'−'; }
.about-faq p {
  font-family:var(--serif); font-size:15px; line-height:1.6; color:var(--t2);
  padding:0 0 16px; margin:0;
}

/* --- Dated page result banner -------------------------------------------- */
.dated-banner {
  margin-bottom:18px; padding:12px 16px; border-radius:8px;
  background:var(--bg2); border:1px solid var(--border);
  font-family:var(--mono); font-size:12px; color:var(--t3);
  display:flex; align-items:center; gap:16px; flex-wrap:wrap;
  text-transform:uppercase; letter-spacing:0.5px;
}
.dated-banner .banner-label { color:var(--t4); font-size:11px; margin-right:4px; }
.dated-banner .pct.good { color:var(--green); font-weight:600; }
.dated-banner .pct.mid  { color:var(--accent); font-weight:600; }
.dated-banner .pct.bad  { color:var(--red); font-weight:600; }
.dated-banner .frac { color:var(--t2); }
.dated-date { font-family:var(--mono); font-size:12px; color:var(--t3); letter-spacing:1px; text-transform:uppercase; margin-bottom:14px; }

/* --- Match card result indicator ---------------------------------------- */
.sch-result { font-size:12px; font-family:var(--mono); font-weight:700; letter-spacing:0.5px; margin-left:4px; }
.sch-result.ok  { color:var(--green); }
.sch-result.bad { color:var(--red); }
