:root{
  --bg:#0e1116; --panel:#161b22; --panel2:#1c2430; --ink:#e8edf3; --muted:#8b97a7;
  --line:#263041; --accent:#33d17a; --accent2:#2bb1ff; --warn:#ffb44d;
  --h:#33d17a; --d:#6b7686; --a:#2bb1ff;
  --radius:14px; --max:1080px;
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
}
*{box-sizing:border-box}
body{margin:0;background:var(--bg);color:var(--ink);line-height:1.55}
a{color:var(--accent2);text-decoration:none}
a:hover{text-decoration:underline}
code{background:#0a0d12;padding:.1em .35em;border-radius:5px;font-size:.85em;color:var(--warn)}
.muted{color:var(--muted)}
.small{font-size:.85rem}
.num{text-align:right}

.site-head{display:flex;align-items:baseline;gap:1rem;padding:1rem 1.25rem;
  border-bottom:1px solid var(--line);position:sticky;top:0;background:rgba(14,17,22,.9);
  backdrop-filter:blur(8px);z-index:5}
.brand{font-weight:800;font-size:1.5rem;color:var(--ink)}
.brand .accent{color:var(--accent)}
.tagline{color:var(--muted);font-size:.85rem}
main{max-width:var(--max);margin:0 auto;padding:1.5rem 1.25rem}
.site-foot{max-width:var(--max);margin:2rem auto;padding:1.25rem;border-top:1px solid var(--line);color:var(--muted);font-size:.85rem}

.hero h1{font-size:2.1rem;line-height:1.15;margin:.2em 0 .3em;letter-spacing:-.02em}
.hero .lede{color:var(--muted);font-size:1.1rem;max-width:60ch}

section{margin:2.5rem 0}
h2{font-size:1.5rem;letter-spacing:-.01em;border-left:3px solid var(--accent);padding-left:.6rem}

/* simulator */
.sim-head{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:1rem}
.controls{display:flex;gap:1rem}
.controls label{display:flex;flex-direction:column;font-size:.75rem;color:var(--muted);gap:.25rem}
select{background:var(--panel2);color:var(--ink);border:1px solid var(--line);border-radius:8px;padding:.4rem .6rem}
.sim-table{width:100%;border-collapse:collapse;margin-top:1rem;background:var(--panel);border-radius:var(--radius);overflow:hidden}
.sim-table th{font-size:.72rem;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);text-align:left;padding:.6rem .7rem;border-bottom:1px solid var(--line)}
.sim-table td{padding:.5rem .7rem;border-bottom:1px solid var(--line);font-variant-numeric:tabular-nums}
.sim-table tr:last-child td{border-bottom:0}
.advance-cell{min-width:160px}
.adv-wrap{display:flex;align-items:center;gap:.5rem}
.adv-bar{flex:1;height:8px;background:#0a0d12;border-radius:5px;overflow:hidden}
.adv-fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--accent2))}
.adv-pct{width:3.2em;text-align:right;font-size:.85rem}
.flag{font-size:1rem;margin-right:.35rem}

/* match grid */
.match-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:.8rem;margin-top:1rem}
.match-card{display:block;background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:.8rem;color:var(--ink)}
.match-card:hover{border-color:var(--accent);text-decoration:none;transform:translateY(-1px);transition:.12s}
.mc-top{display:flex;justify-content:space-between;align-items:center}
.grp{background:var(--panel2);color:var(--muted);font-size:.7rem;padding:.1rem .45rem;border-radius:5px}
.mc-teams{font-weight:700;margin:.45rem 0;font-size:1.05rem}
.mc-teams .v{color:var(--muted);font-weight:400;font-size:.85em;margin:0 .25em}
.mc-bar{display:flex;height:7px;border-radius:5px;overflow:hidden;background:#0a0d12}
.mc-bar .b-h{background:var(--h)}.mc-bar .b-d{background:var(--d)}.mc-bar .b-a{background:var(--a)}
.mc-foot{margin-top:.5rem}

/* dossier */
.crumb{margin:0 0 1rem}
.dossier{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:1.4rem 1.6rem}
.dossier h2{border:0;padding:0;margin-top:0;font-size:1.7rem}
.dossier h3{font-size:1.1rem;color:var(--accent);margin-top:1.4rem}
.dossier table{width:100%;border-collapse:collapse;margin:.6rem 0}
.dossier th,.dossier td{padding:.4rem .6rem;border-bottom:1px solid var(--line);text-align:left}
.dossier blockquote{margin:.8rem 0;padding:.6rem .9rem;background:var(--panel2);border-left:3px solid var(--accent2);border-radius:0 8px 8px 0}
.dossier ul{padding-left:1.1rem}
.dossier code{color:var(--ink)}

.model-strip{display:flex;gap:.6rem;margin:1.2rem 0}
.ms-cell{flex:1;background:var(--panel2);border:1px solid var(--line);border-radius:10px;padding:.7rem;text-align:center}
.ms-k{display:block;color:var(--muted);font-size:.8rem}
.ms-v{display:block;font-size:1.6rem;font-weight:800}

/* analyst */
.analyst{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:1.2rem 1.4rem}
.analyst h3{margin-top:0;color:var(--accent)}
#askForm{display:flex;gap:.5rem;margin:.6rem 0}
#askInput{flex:1;background:var(--panel2);border:1px solid var(--line);border-radius:9px;padding:.6rem .8rem;color:var(--ink)}
#askForm button{background:var(--accent);color:#08130c;font-weight:700;border:0;border-radius:9px;padding:.6rem 1.1rem;cursor:pointer}
.ask-out{margin:.6rem 0;white-space:pre-wrap}
.ask-out .ans{background:var(--panel2);border-radius:10px;padding:.8rem 1rem;border-left:3px solid var(--accent)}
.ask-out .cite{font-size:.8rem;color:var(--muted);margin-top:.4rem}
.ask-out .vflag{font-size:.8rem;color:#b8860b;margin-top:.3rem}
.suggest{display:flex;gap:.5rem;flex-wrap:wrap}
.chip{background:var(--panel2);border:1px solid var(--line);color:var(--muted);border-radius:20px;padding:.35rem .8rem;font-size:.8rem;cursor:pointer}
.chip:hover{border-color:var(--accent);color:var(--ink)}

.verify-banner{background:#3a2a12;border:1px solid var(--warn);color:var(--warn);padding:.8rem 1rem;border-radius:10px;margin-top:1.2rem;font-size:.9rem}
@media(max-width:560px){.hero h1{font-size:1.6rem}.model-strip{flex-direction:column}}

/* title race — odds to win it all (home-page hook) */
.title-race{margin:1.5rem 0}
.tr-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.5rem .9rem;margin-top:1rem}
@media (max-width:680px){.tr-grid{grid-template-columns:1fr}}
.tr-card{display:flex;align-items:center;gap:.7rem;background:var(--panel);border:1px solid var(--line);border-radius:11px;padding:.55rem .8rem}
.tr-card:hover{border-color:var(--warn)}
.tr-rank{font-weight:800;color:var(--muted);width:1.4rem;text-align:center;font-variant-numeric:tabular-nums}
.tr-main{flex:1;min-width:0}
.tr-name{font-weight:700;font-size:.95rem;margin-bottom:.3rem}
.tr-bar{height:8px;background:#0a0d12;border-radius:5px;overflow:hidden}
.tr-fill{height:100%;background:linear-gradient(90deg,var(--warn),var(--accent))}
.tr-pct{font-weight:800;font-variant-numeric:tabular-nums;color:var(--ink);min-width:3.2rem;text-align:right}
.sim-table .win-all{font-weight:700;color:var(--warn)}

/* header nav + matchday-3 scenarios page */
.site-nav{display:flex;gap:.9rem;margin-left:.4rem}
.site-nav a{color:var(--muted);font-size:.9rem;font-weight:600}
.site-nav a:hover{color:var(--accent)}
.banner{border-radius:11px;padding:.7rem .95rem;margin:1rem 0;font-size:.92rem;border:1px solid var(--line)}
.banner-illustrative{background:rgba(255,180,77,.08);border-color:rgba(255,180,77,.4)}
.banner-illustrative strong{color:var(--warn)}
.banner-live{background:rgba(51,209,122,.08);border-color:rgba(51,209,122,.4)}
.banner-live strong{color:var(--accent)}
.scenarios h2{margin-top:2rem;font-size:1.15rem}
.scenarios ul{padding-left:1.1rem}
.scenarios li{margin:.3rem 0}
.scenarios strong{color:var(--ink)}

/* ---- teams index ---- */
.teams-index h1{font-size:1.7rem;letter-spacing:-.02em}
.teams-index>.muted{max-width:60ch;margin:.4rem 0 1.6rem}
.team-group{margin:1.4rem 0}
.team-group h2{font-size:1.15rem}
.team-list{list-style:none;padding:0;margin:.7rem 0 0;
  display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:.5rem}
.team-list li{background:var(--panel);border:1px solid var(--line);border-radius:10px;
  padding:.6rem .8rem;display:flex;flex-direction:column;gap:.15rem}
.team-list li:hover{border-color:var(--accent);transition:.12s}
.team-list a{color:var(--ink)}
.team-list a:hover{color:var(--accent)}
.team-list .small{font-size:.78rem}
/* team dossier: tighten the "by the numbers" table like the match card */
.team-dossier table{width:100%;border-collapse:collapse;margin:.6rem 0}
.team-dossier table td,.team-dossier table th{border:1px solid var(--line);padding:.4rem .6rem;text-align:left}
.team-dossier table th{background:var(--panel2)}

/* ---- pre-match watch board ---- */
.watch-hero h1{font-size:2rem;line-height:1.15;margin:.15rem 0 .35rem}
.eyebrow{margin:0;color:var(--accent);font-size:.78rem;font-weight:800;text-transform:uppercase;letter-spacing:.08em}
.section-head{display:flex;align-items:flex-end;justify-content:space-between;gap:1rem;flex-wrap:wrap}
.section-head p{max-width:54ch;margin:.2rem 0 0}
.watch-entry{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:1rem 1.1rem}
.watch-entry h2{margin-top:0}
.cta-link{display:inline-block;margin-top:.35rem;background:var(--accent);color:#08130c;
  border-radius:9px;padding:.55rem .85rem;font-weight:800}
.cta-link:hover{text-decoration:none;filter:brightness(1.06)}
.watch-tools{display:grid;grid-template-columns:minmax(220px,1fr) 2fr minmax(150px,.7fr);
  gap:.8rem;align-items:end;background:var(--panel);border:1px solid var(--line);
  border-radius:12px;padding:1rem}
.watch-search,.watch-sort{display:flex;flex-direction:column;gap:.25rem}
.watch-search label,.watch-sort label{font-size:.72rem;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}
.watch-search input{background:var(--panel2);color:var(--ink);border:1px solid var(--line);
  border-radius:9px;padding:.55rem .7rem;min-width:0}
.watch-lenses{display:flex;gap:.45rem;flex-wrap:wrap}
.watch-lenses .chip.is-active{border-color:var(--accent);color:var(--ink);background:rgba(51,209,122,.12)}
.watch-count{margin:.3rem 0 0;grid-column:1/-1}
.watch-empty{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:1rem}
.watch-date{margin:1.4rem 0}
.watch-date h3{margin:.4rem 0 .7rem;color:var(--muted);font-size:.95rem}
.watch-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:.85rem}
.watch-grid-featured{grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}
.watch-card{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:1rem;color:var(--ink)}
.watch-card:hover{border-color:var(--accent);transition:.12s}
.watch-top{display:flex;justify-content:space-between;gap:.75rem;align-items:center}
.watch-card h3{margin:.55rem 0 .1rem;font-size:1.1rem;line-height:1.25}
.watch-card h3 a{color:var(--ink)}
.watch-card h3 span{color:var(--muted);font-weight:400;font-size:.9em;margin:0 .2rem}
.watch-tags{display:flex;flex-wrap:wrap;gap:.35rem;margin:.7rem 0}
.watch-tags span{border:1px solid var(--line);background:var(--panel2);border-radius:999px;
  color:var(--muted);font-size:.72rem;padding:.15rem .5rem}
.watch-when{font-size:.72rem;color:var(--muted);font-variant-numeric:tabular-nums}
.watch-tv{color:var(--accent2);white-space:nowrap}
.watch-card p{margin:.55rem 0}
/* favourite-tilt cue — a bar with no numbers on it */
.watch-tilt{display:flex;align-items:center;gap:.55rem;margin:.7rem 0 .2rem}
.watch-tilt-bar{flex:1;height:6px;background:var(--panel-3,var(--panel2));border:1px solid var(--line);
  border-radius:6px;overflow:hidden}
.watch-tilt-bar span{display:block;height:100%;background:var(--accent)}
.watch-tilt-label{font-size:.74rem;color:var(--muted);white-space:nowrap}
.watch-why{font-size:.9rem;line-height:1.5;color:var(--ink-2,var(--ink))}
.watch-star{font-size:.85rem;color:var(--ink-2,var(--ink))}
.watch-star strong{color:var(--accent2)}
/* reader-language tag colours */
.watch-tags .wt-opener{border-color:var(--accent);color:#08130c;background:var(--accent);font-weight:700}
.watch-tags .wt-big-game{border-color:var(--accent);color:var(--accent);background:rgba(51,209,122,.10)}
.watch-tags .wt-upset-alert{border-color:var(--warn,#e0a83a);color:var(--warn,#e0a83a)}
.watch-tags .wt-rematch{border-color:var(--accent2);color:var(--accent2)}
.watch-tags .wt-decider{border-color:var(--accent2-strong,var(--accent2));color:var(--accent2-strong,var(--accent2))}
.watch-links{display:flex;gap:.45rem;flex-wrap:wrap;margin-top:.75rem}
.watch-links a{font-size:.78rem;border:1px solid var(--line);border-radius:8px;padding:.25rem .5rem;color:var(--accent2)}
.watch-links a:hover{border-color:var(--accent);text-decoration:none}
/* day board day-parts */
.watch-day-head{display:flex;justify-content:space-between;align-items:baseline;gap:1rem;flex-wrap:wrap;
  border-bottom:2px solid var(--line);padding-bottom:.35rem;margin:.4rem 0 .8rem}
.watch-day-head h3{margin:0;color:var(--ink);font-family:var(--font-wide);font-size:1.15rem}
.watch-day-head strong{color:var(--ink)}
.watch-part{margin:0 0 1rem}
.watch-part-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);
  font-weight:700;margin:.2rem 0 .5rem}
/* knockout scaffold */
.watch-knockouts{margin-top:2.4rem}
.ko-round{margin:1.2rem 0}
.ko-round-title{margin:.2rem 0 .7rem;font-family:var(--font-wide);color:var(--ink);font-size:1.05rem;
  border-left:3px solid var(--accent2);padding-left:.55rem}
.ko-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:.7rem}
.ko-card{background:var(--panel);border:1px dashed var(--line);border-radius:11px;padding:.85rem .95rem}
.ko-card-head{display:flex;justify-content:space-between;gap:.6rem;align-items:center}
.ko-num{font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);font-weight:700}
.ko-tie{display:flex;align-items:center;gap:.5rem;margin:.5rem 0 .1rem;font-weight:700;font-size:.92rem}
.ko-slot{flex:1;color:var(--ink)}
.ko-slot:last-child{text-align:right}
.ko-v{color:var(--muted);font-size:.75rem;font-weight:400}
@media(max-width:780px){
  .watch-tools{grid-template-columns:1fr}
  .watch-count{grid-column:auto}
}

/* match briefing */
.match-brief{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:1.25rem 1.35rem;margin-top:1rem}
.match-brief h1{font-size:2rem;line-height:1.1;margin:.1rem 0 .3rem}
.brief-lede{font-size:1.05rem;max-width:72ch;margin:1rem 0;color:var(--ink)}
.brief-actions{display:flex;gap:.55rem;flex-wrap:wrap;margin:.8rem 0 1rem}
.brief-actions a{border:1px solid var(--line);border-radius:9px;padding:.38rem .65rem;color:var(--accent2);font-size:.85rem}
.brief-actions a:hover{border-color:var(--accent);text-decoration:none}
.brief-model{display:grid;grid-template-columns:repeat(6,1fr);gap:.45rem;margin:1rem 0 0}
.brief-model div{background:#0a0d12;border:1px solid var(--line);border-radius:9px;padding:.55rem .65rem}
.brief-model dt{color:var(--muted);font-size:.68rem;text-transform:uppercase;letter-spacing:.04em}
.brief-model dd{margin:0;font-weight:800;font-variant-numeric:tabular-nums}
.brief-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:.85rem;align-items:start}
.brief-card{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:1rem 1.1rem}
.brief-card h2{font-size:1.05rem;margin:.1rem 0 .7rem;border:0;padding:0;color:var(--accent)}
.brief-card p{margin:.55rem 0}
.brief-card ul{padding-left:1.1rem;margin:.5rem 0}
.brief-card li{margin:.35rem 0}
.brief-card-wide{grid-row:span 2}
.verify-list{color:var(--muted);font-size:.85rem}
.full-dossier{margin:2rem 0}
.full-dossier summary{cursor:pointer;background:var(--panel);border:1px solid var(--line);
  border-radius:12px;padding:.85rem 1rem;font-weight:800;color:var(--accent2)}
.full-dossier[open] summary{border-radius:12px 12px 0 0}
.full-dossier .dossier{border-top:0;border-radius:0 0 var(--radius) var(--radius)}
@media(max-width:900px){
  .brief-model{grid-template-columns:repeat(3,1fr)}
  .brief-grid{grid-template-columns:1fr}
  .brief-card-wide{grid-row:auto}
}
@media(max-width:560px){
  .match-brief h1{font-size:1.55rem}
  .brief-model{grid-template-columns:repeat(2,1fr)}
}

/* ---- editorial light design system overrides ---- */
:root{
  --paper:#faf9f6; --bg:#faf9f6; --bg-2:#f4f2ec;
  --panel:#ffffff; --panel-2:#f4f2ec; --panel2:#f4f2ec; --panel-3:#ece9e0;
  --line:#e4e0d6; --line-soft:#efece4; --line-strong:#d3cec2;
  --ink:#1b1b18; --ink-2:#4a4a44; --muted:#87847a; --faint:#b0ac9f;
  --accent:#1a9d54; --accent-strong:#0f7a3f; --accent-bright:#25c068;
  --accent-deep:#0b5e30; --accent2:#2f6fb3; --accent2-strong:#245a92;
  --warn:#c8851b; --warn-soft:#f3e6c8; --danger:#cc3b3b;
  --res-home:#1a9d54; --res-draw:#b8b3a3; --res-away:#2f6fb3;
  --h:var(--res-home); --d:var(--res-draw); --a:var(--res-away);
  --r-sm:4px; --r-md:7px; --r-lg:10px; --r-xl:14px; --r-pill:999px;
  --radius:14px; --max:1120px; --maxw:1120px;
  --sh-1:0 1px 2px rgba(30,28,22,.05);
  --sh-2:0 2px 10px -2px rgba(30,28,22,.10);
  --font-display:"Archivo",system-ui,sans-serif;
  --font-wide:"Archivo Expanded","Archivo",system-ui,sans-serif;
  --font-text:"Archivo",system-ui,-apple-system,"Segoe UI",sans-serif;
  --font-serif:"Source Serif 4",Georgia,"Times New Roman",serif;
  /* JetBrains Mono retired — lean two-family stack (Archivo + Source Serif).
     The mono token now resolves to Archivo so label/eyebrow rules keep working. */
  --font-mono:"Archivo",system-ui,-apple-system,"Segoe UI",sans-serif;
}
body{background:var(--paper);color:var(--ink);font-family:var(--font-text)}
p{color:var(--ink-2)}
a{color:var(--accent2-strong)}
code{font-family:var(--font-mono);background:var(--warn-soft);color:#9a6510}
main,.site-foot{max-width:var(--maxw)}
/* Masthead Chrome */
.masthead{
  position:sticky; top:0; z-index:20; background:rgba(250,249,246,.92);
  backdrop-filter:saturate(1.4) blur(6px); -webkit-backdrop-filter:saturate(1.4) blur(6px);
  border-bottom:1px solid var(--line);
}
.masthead-in{ max-width:var(--maxw); margin:0 auto; display:flex; align-items:center; gap:22px; padding:12px 22px; }
.brand{ font-family:var(--font-wide); letter-spacing:-.02em; font-weight:800; font-size:1.5rem; color:var(--ink); }
.brand .accent{ color:var(--accent); }
.mast-nav{ display:flex; gap:4px; margin-left:6px; }
.mast-nav button{
  font-family:var(--font-text); font-weight:600; font-size:14px; color:var(--muted);
  background:none; border:0; padding:7px 11px; border-radius:var(--r-md); cursor:pointer; transition:.12s;
}
.mast-nav button:hover{ color:var(--ink); background:var(--panel-2); }
.mast-nav button.active{ color:var(--ink); background:var(--panel-2); box-shadow:inset 0 -2px 0 var(--accent); }
.mast-tag{ margin-left:auto; font-family:var(--font-mono); font-size:11px; color:var(--muted); letter-spacing:.04em; }

/* Footer Chrome */
.wc-foot{ border-top:1px solid var(--line); background:var(--bg-2); }
.wc-foot-in{ max-width:var(--maxw); margin:0 auto; padding:24px 22px; font-size:13px; color:var(--muted); line-height:1.5; }
.wc-foot strong{ color:var(--ink); }
.kicker,.label{
  font-family:var(--font-display);font-size:11.5px;font-weight:700;text-transform:uppercase;
  letter-spacing:.08em;color:var(--accent-strong)
}
.label{font-weight:500;letter-spacing:.07em;color:var(--muted)}
.display,.stat{font-family:var(--font-wide);font-weight:800;letter-spacing:-.02em;color:var(--ink)}
.card,.dossier,.analyst,.watch-card,.watch-tools,.watch-entry,.watch-empty,.team-list li,.tr-card{
  background:var(--panel);border:1px solid var(--line);box-shadow:var(--sh-1);
  border-radius:var(--r-lg)
}
.accent-top{border-top:3px solid var(--accent)}
.tag-pill{display:inline-flex;align-items:center;gap:.45em;font-family:var(--font-mono);
  font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;
  color:var(--accent-strong);background:rgba(26,157,84,.09);
  border:1px solid rgba(26,157,84,.28);padding:.25em .6em;border-radius:var(--r-pill)}
.tag-pill-dot{width:7px;height:7px;border-radius:50%;background:var(--accent);display:inline-block}
.rounded-flag{width:24px;height:24px;border-radius:50%;display:inline-block;flex:none;
  background-size:cover;background-position:center;box-shadow:inset 0 0 0 1px rgba(0,0,0,.12)}
.rounded-flag.md{width:24px;height:24px}.rounded-flag.lg{width:34px;height:34px}
.rounded-flag.xl{width:28px;height:28px}
.win-prob-hero{display:flex;height:46px;border:1px solid var(--line);border-radius:var(--r-md);
  overflow:hidden;background:var(--panel-3)}
.win-prob-hero .seg{display:flex;align-items:center;justify-content:center;font-family:var(--font-wide);
  font-weight:800;font-size:17px;font-variant-numeric:tabular-nums;min-width:2.4rem}
.seg-home{background:var(--res-home);color:#fff}.seg-draw{background:var(--res-draw);color:#3a382f}
.seg-away{background:var(--res-away);color:#fff}
.dossier-grid{display:grid;grid-template-columns:1.55fr 1fr;gap:18px;align-items:start}
.prose p{font-size:16px;line-height:1.62;color:var(--ink-2);margin:0 0 .95em}
.prose p:first-of-type{font-size:17px;color:var(--ink)}
.dossier h2{font-family:var(--font-display);font-size:26px;line-height:1.18;
  border:0;padding:0;margin:0 0 .45em;color:var(--ink)}
.dossier h3{color:var(--accent-strong)}
.dossier blockquote{background:var(--panel-2);border-left-color:var(--accent2)}
#askInput,.watch-search input,select{background:var(--panel);color:var(--ink);border:1px solid var(--line)}
#askForm button,.btn-primary{background:var(--accent);color:#fff}
#askForm button:hover,.btn-primary:hover{background:var(--accent-deep)}
.chip{background:var(--panel);color:var(--ink-2);border:1px solid var(--line)}
.chip:hover,.watch-card:hover,.match-card:hover,.team-list li:hover{border-color:var(--accent);
  box-shadow:var(--sh-2);text-decoration:none}
.brief-model div,.adv-bar,.tr-bar,.mc-bar{background:var(--panel-3)}
.brief-model div{border-color:var(--line)}
.watch-tags span{background:var(--panel-2);border-color:var(--line)}
.watch-tilt-bar{background:var(--panel-3)}
.watch-links a,.brief-actions a{border-color:var(--line);color:var(--accent2-strong)}
.watch-lenses .chip.is-active{background:rgba(26,157,84,.10);border-color:var(--accent);
  color:var(--accent-strong)}
.btn{font-family:var(--font-text);font-weight:700;font-size:14px;border:0;border-radius:var(--r-md);
  padding:.62em 1.05em;cursor:pointer;transition:.13s ease-out;white-space:nowrap;line-height:1.2}
.sec-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;flex-wrap:wrap;
  border-bottom:2px solid var(--ink);padding-bottom:8px;margin-bottom:18px}
.sec-head h2{border:0;padding:0;margin:0}
.sec-head .note{font-family:var(--font-mono);font-size:11px;color:var(--muted);max-width:44ch;text-align:right}
.etable{width:100%;border-collapse:collapse;font-variant-numeric:tabular-nums}
.etable th{font-family:var(--font-mono);font-size:10.5px;text-transform:uppercase;
  letter-spacing:.07em;color:var(--muted);text-align:right;padding:8px 10px;
  border-bottom:2px solid var(--ink);white-space:nowrap}
.etable th.l,.etable td.l{text-align:left}.etable td{padding:9px 10px;border-bottom:1px solid var(--line);text-align:right;font-size:14px}
.etable tbody tr:hover{background:var(--panel-2)}
@media(max-width:860px){.dossier-grid{grid-template-columns:1fr}.display{font-size:30px!important}}
@media(max-width:620px){
  .site-head{align-items:flex-start;flex-direction:column;gap:.55rem}
  .win-prob-hero{height:38px}.win-prob-hero .seg{font-size:13px}
}

/* Sandbox Standings and Score Inputs styles */
.sandbox-fixture {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 12px;
  background: var(--panel-2, #1c2430);
  border: 1px solid var(--line);
  padding: 10px 14px;
  border-radius: var(--r-md, 10px);
}
.sandbox-fixture .team-name {
  flex: 1;
  font-weight: 700;
  font-size: 13.5px;
}
.sandbox-fixture .team-name.r {
  text-align: right;
}
.sandbox-score-input {
  width: 44px;
  height: 32px;
  text-align: center;
  background: var(--panel) !important;
  color: var(--ink) !important;
  border: 1px solid var(--line) !important;
  border-radius: 6px;
  font-family: var(--font-mono);
  font-size: 14px;
  font-weight: 700;
}
.sandbox-score-input:focus {
  border-color: var(--accent) !important;
  outline: none;
}
.standings-table {
  width: 100%;
  border-collapse: collapse;
  font-variant-numeric: tabular-nums;
  margin-bottom: 20px;
}
.standings-table th {
  font-family: var(--font-mono);
  font-size: 10.5px;
  text-transform: uppercase;
  letter-spacing: .07em;
  color: var(--muted);
  text-align: right;
  padding: 8px 10px;
  border-bottom: 2px solid var(--ink);
  white-space: nowrap;
}
.standings-table th.l, .standings-table td.l {
  text-align: left;
}
.standings-table td {
  padding: 9px 10px;
  border-bottom: 1px solid var(--line);
  text-align: right;
  font-size: 14px;
  transition: background 0.2s ease;
}
.qualified-row td {
  background: rgba(46, 125, 50, 0.08) !important;
  border-bottom-color: rgba(46, 125, 50, 0.2) !important;
}
.third-row td {
  background: rgba(43, 177, 255, 0.08) !important;
  border-bottom-color: rgba(43, 177, 255, 0.2) !important;
}
.eliminated-row td {
  background: rgba(220, 53, 69, 0.04) !important;
  color: var(--muted);
}

.tab-btn {
  transition: all 150ms ease-out;
}
.tab-btn:hover {
  color: var(--ink-1) !important;
}
.tab-btn.active {
  color: var(--ink-1) !important;
}

/* Bracket styling */
.bracket-col {
  display: flex;
  flex-direction: column;
  justify-content: space-around;
  min-width: 230px;
  flex-shrink: 0;
  gap: 20px;
  padding: 10px 0;
}
.bracket-col-title {
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--muted);
  border-bottom: 2px solid var(--ink);
  padding-bottom: 6px;
  margin-bottom: 12px;
  text-align: center;
}
.bracket-match {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  padding: 10px 12px;
  display: flex;
  flex-direction: column;
  gap: 6px;
  box-shadow: var(--sh-1);
  transition: all 140ms ease-out;
  position: relative;
  cursor: pointer;
  user-select: none;
}
.bracket-match:hover {
  border-color: var(--line-strong);
  box-shadow: var(--sh-2);
}
.bracket-match-header {
  font-family: var(--font-mono);
  font-size: 9px;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: .04em;
  border-bottom: 1px solid var(--line-soft);
  padding-bottom: 4px;
  margin-bottom: 2px;
}
.bracket-team {
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-size: 12.5px;
  color: var(--ink-2);
  height: 24px;
}
.bracket-team-left {
  display: flex;
  align-items: center;
  gap: 8px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 155px;
}
.bracket-team-slot {
  font-family: var(--font-mono);
  font-size: 9.5px;
  font-weight: 600;
  color: var(--muted);
  background: var(--panel-2);
  padding: 1px 4px;
  border-radius: var(--r-sm);
  border: 1px solid var(--line);
}
.bracket-team-name {
  font-weight: 500;
}
.bracket-team.winner .bracket-team-name {
  font-weight: 700;
  color: var(--ink-1);
}
.bracket-team-pct {
  font-family: var(--font-mono);
  font-size: 10.5px;
  font-weight: 700;
  color: var(--muted);
}
.bracket-team.winner .bracket-team-pct {
  color: var(--accent-strong);
}

/* Bracket Highlight styles */
.bracket-match.highlighted-match {
  border-color: var(--warn) !important;
  background: var(--warn-soft) !important;
  transform: translateY(-1px);
  box-shadow: var(--sh-2) !important;
}
.bracket-match.highlighted-match .bracket-team-slot {
  background: rgba(200, 133, 27, 0.15);
  border-color: rgba(200, 133, 27, 0.3);
  color: #9a6510;
}
.bracket-team.highlighted-team {
  color: #9a6510 !important;
}
.bracket-team.highlighted-team .bracket-team-name {
  font-weight: 800 !important;
}
.bracket-team.highlighted-team .bracket-team-pct {
  color: var(--warn) !important;
  font-weight: 800 !important;
}

/* Round Navigator for Mobile */
.mobile-round-nav .round-btn {
  font-family: var(--font-mono);
  font-size: 10.5px;
  font-weight: 700;
  text-transform: uppercase;
  cursor: pointer;
  padding: 6px 12px;
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: var(--r-sm);
  color: var(--muted);
  transition: all 120ms ease-out;
  letter-spacing: .02em;
}
.mobile-round-nav .round-btn:hover {
  border-color: var(--line-strong);
  color: var(--ink-1);
}
.mobile-round-nav .round-btn.active {
  background: var(--warn-soft);
  border-color: var(--warn);
  color: #9a6510;
}

/* Responsive Bracket display logic */
@media (max-width: 900px) {
  .mobile-round-nav {
    display: flex !important;
  }
  .bracket-scroll {
    overflow-x: hidden !important;
  }
  .bracket-col {
    display: none;
    width: 100%;
    min-width: 100% !important;
  }
  .bracket-col.active-round {
    display: flex !important;
  }
}

/* ==========================================================================
   PER-TEAM DOSSIER PREMIUM EDITORIAL LAYOUT
   ========================================================================== */

.fi { background-size: cover !important; background-position: center !important; }
.td-wrap { max-width: var(--maxw); margin: 0 auto; padding: 22px 22px 80px; }

/* ---- Hero ---- */
.td-hero { border-bottom: 2px solid var(--ink); padding-bottom: 22px; margin-bottom: 26px; }
.td-hero-top { display: flex; align-items: center; gap: 18px; flex-wrap: wrap; }
.td-flag { width: 54px; height: 54px; border-radius: 50%; box-shadow: inset 0 0 0 1px rgba(0,0,0,.12); flex: none; }
.td-name { font-family: var(--font-wide); font-weight: 800; font-size: clamp(38px, 6vw, 60px); line-height: .98; letter-spacing: -.02em; margin: 0; color: var(--ink); }
.td-dek { font-size: 18px; line-height: 1.5; color: var(--ink-2); max-width: 64ch; margin: 16px 0 0; }
.td-dek strong { color: var(--ink); }
.td-stats { display: grid; grid-template-columns: repeat(6, 1fr); gap: 0; margin-top: 22px; border: 1px solid var(--line); border-radius: var(--r-lg); overflow: hidden; background: var(--panel); }
.td-stat { padding: 14px 16px; border-right: 1px solid var(--line); }
.td-stat:last-child { border-right: 0; }
.td-stat .l { font-family: var(--font-mono); font-size: 10px; text-transform: uppercase; letter-spacing: .07em; color: var(--muted); display: block; margin-bottom: 6px; white-space: nowrap; }
.td-stat .v { font-family: var(--font-wide); font-weight: 800; font-size: 26px; line-height: 1; color: var(--ink); font-variant-numeric: tabular-nums; }
.td-stat .v.green { color: var(--accent-strong); }
.td-stat .v.gold { color: var(--warn); }
@media(max-width: 820px){ 
  .td-stats { grid-template-columns: repeat(3, 1fr); } 
  .td-stat:nth-child(3) { border-right: 0; } 
  .td-stat:nth-child(1), .td-stat:nth-child(2), .td-stat:nth-child(3) { border-bottom: 1px solid var(--line); } 
}

/* ---- Layout ---- */
.td-grid { display: grid; grid-template-columns: 1.6fr 1fr; gap: 22px; align-items: start; }
@media(max-width: 880px){ .td-grid { grid-template-columns: 1fr; } }
.col { display: flex; flex-direction: column; gap: 22px; }

.panel { background: var(--panel); border: 1px solid var(--line); border-radius: var(--r-lg); padding: 22px 24px; box-shadow: var(--sh-1); }
.panel h2.sec-t { font-family: var(--font-display); font-weight: 800; font-size: 20px; margin: 0 0 16px; padding-bottom: 10px; border-bottom: 2px solid var(--ink); text-transform: none; border-top: 0; }
.panel h3.sub-t { font-family: var(--font-mono); font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: .1em; color: var(--accent-strong); margin: 0 0 12px; }

/* ---- Storylines ---- */
.story { list-style: none; margin: 0; padding: 0; counter-reset: s; }
.story li { display: flex; gap: 14px; padding: 14px 0; border-bottom: 1px solid var(--line); }
.story li:last-child { border-bottom: 0; padding-bottom: 0; }
.story .n { counter-increment: s; font-family: var(--font-mono); font-size: 12px; font-weight: 700; color: var(--accent-strong); flex: none; width: 22px; padding-top: 2px; }
.story .n::before { content: counter(s, decimal-leading-zero); }
.story .b { font-size: 15px; line-height: 1.55; color: var(--ink-2); }
.story .b strong { color: var(--ink); }

/* ---- Tactical def list ---- */
.deflist > div { padding: 11px 0; border-bottom: 1px solid var(--line); font-size: 15px; line-height: 1.55; color: var(--ink-2); }
.deflist > div:first-child { padding-top: 0; }
.deflist > div:last-child { border-bottom: 0; }
.deflist .k { font-family: var(--font-mono); font-size: 10px; font-weight: 600; text-transform: uppercase; letter-spacing: .07em; color: var(--muted); display: block; margin-bottom: 4px; }
.deflist strong.lead { color: var(--ink); }
.tag { display: inline-block; font-family: var(--font-mono); font-size: 12px; font-weight: 700; color: var(--accent2-strong); background: rgba(47,111,179,.08); border: 1px solid rgba(47,111,179,.3); padding: 2px 9px; border-radius: var(--r-pill); }

.sw { display: grid; grid-template-columns: 1fr 1fr; gap: 22px; margin-top: 18px; padding-top: 16px; border-top: 1px solid var(--line); }
@media(max-width: 560px){ .sw { grid-template-columns: 1fr; } }
.sw ul { list-style: none; margin: 6px 0 0; padding: 0; }
.sw li { position: relative; padding-left: 18px; font-size: 13.5px; line-height: 1.5; color: var(--ink-2); margin-bottom: 8px; }
.sw li::before { content: ""; position: absolute; left: 0; top: 7px; width: 8px; height: 8px; border-radius: 2px; }
.sw.str li::before { background: var(--accent); }
.sw.weak li::before { background: var(--danger); }
.sw h4 { font-family: var(--font-mono); font-size: 10px; text-transform: uppercase; letter-spacing: .07em; margin: 0; }
.sw.str h4 { color: var(--accent-strong); } 
.sw.weak h4 { color: var(--danger); }

/* ---- Tactical pitch (coordinate-based, big, with movement) ---- */
.tp-pitch { margin: 8px auto 6px; max-width: 540px; }
.tp-pitch-head { display: flex; align-items: center; justify-content: space-between;
  gap: 12px; flex-wrap: wrap; margin: 0 0 10px; }
.tp-pitch-form { font-family: var(--font-display); font-weight: 800; font-size: 16px;
  letter-spacing: .02em; color: var(--ink); }
.tp-pitch-key { font-family: var(--font-display); font-size: 12px; color: var(--muted);
  display: inline-flex; align-items: center; gap: 2px; }
.tp-pitch-key .k-dot { display: inline-block; width: 10px; height: 10px; border-radius: 50%;
  margin: 0 3px 0 8px; vertical-align: middle; }
.tp-pitch-key .k-def { background: #2f6fb3; }
.tp-pitch-key .k-mid { background: #1a9d54; }
.tp-pitch-key .k-fwd { background: #cc3b3b; }
.tp-pitch-key .k-arr { display: inline-block; width: 16px; height: 0; vertical-align: middle;
  border-top: 3px solid #3a382f; opacity: .6; margin-right: 2px; position: relative; }
.tp-pitch-key .k-arr::after { content: ""; position: absolute; right: -1px; top: -4px;
  border-left: 6px solid #3a382f; border-top: 4px solid transparent; border-bottom: 4px solid transparent; }
.tp-pitch-svg { width: 100%; height: auto; display: block;
  border: 1px solid var(--line); border-radius: var(--r-lg); box-shadow: var(--sh-1); }
.tp-pitch-note { font-size: 13.5px; line-height: 1.55; color: var(--muted);
  margin: 12px 2px 0; font-style: italic; }

/* ---- legacy row-based pitch (kept for any old render path) ---- */
.pitch { position: relative; background:
    linear-gradient(0deg, rgba(26,157,84,.05), rgba(26,157,84,.05)),
    repeating-linear-gradient(0deg, transparent, transparent 13%, rgba(26,157,84,.04) 13%, rgba(26,157,84,.04) 26%);
  border: 1px solid var(--line); border-radius: var(--r-md); padding: 20px 12px; display: flex; flex-direction: column; gap: 6px; }
.pitch::before { content: ""; position: absolute; left: 8%; right: 8%; top: 50%; height: 1px; background: rgba(26,157,84,.18); }
.pitch::after { content: ""; position: absolute; left: 50%; top: 50%; width: 64px; height: 64px; transform: translate(-50%,-50%); border: 1px solid rgba(26,157,84,.18); border-radius: 50%; }
.prow { display: flex; justify-content: space-around; gap: 8px; position: relative; z-index: 1; }
.pnode { text-align: center; flex: 1; min-width: 0; }
.pdot { width: 30px; height: 30px; border-radius: 50%; margin: 0 auto 5px; display: flex; align-items: center; justify-content: center; font-family: var(--font-mono); font-size: 10px; font-weight: 800; color: #fff; background: var(--accent); border: 2px solid var(--panel); box-shadow: var(--sh-1); }
.pdot.doubt { background: var(--warn); }
.pname { font-size: 11px; font-family: var(--font-text); font-weight: 600; color: var(--ink); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

/* ---- Key players ---- */
.kp-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
@media(max-width: 680px){ .kp-grid { grid-template-columns: 1fr; } }
.kp { border: 1px solid var(--line); border-radius: var(--r-lg); padding: 16px 18px; background: var(--panel); box-shadow: var(--sh-1); transition: .13s; }
.kp:hover { border-color: var(--accent); box-shadow: var(--sh-2); }
.kp-top { display: flex; align-items: center; gap: 12px; }
.mono-av { width: 40px; height: 40px; border-radius: 50%; flex: none; background: var(--panel-2); border: 1px solid var(--line); display: flex; align-items: center; justify-content: center; font-family: var(--font-wide); font-weight: 800; font-size: 14px; color: var(--ink); }
.kp-id { flex: 1; min-width: 0; }
.kp-name { font-family: var(--font-wide); font-weight: 800; font-size: 17px; color: var(--ink); line-height: 1.1; display: block; }
.kp-arch { font-family: var(--font-mono); font-size: 9.5px; text-transform: uppercase; letter-spacing: .06em; color: var(--muted); margin-top: 4px; display: block; }
.kp-status { font-family: var(--font-mono); font-size: 9px; font-weight: 700; text-transform: uppercase; letter-spacing: .04em; padding: 3px 9px; border-radius: var(--r-pill); flex: none; }
.s-fit { color: var(--accent-strong); background: rgba(26,157,84,.1); border: 1px solid rgba(26,157,84,.3); }
.s-doubt { color: #9a6510; background: var(--warn-soft); border: 1px solid var(--warn); }
.s-out { color: var(--danger); background: rgba(204,59,59,.08); border: 1px solid rgba(204,59,59,.4); }
.kp-club { font-family: var(--font-mono); font-size: 10px; text-transform: uppercase; letter-spacing: .05em; color: var(--muted); margin: 12px 0 10px; padding-bottom: 10px; border-bottom: 1px solid var(--line); }
.kp-hook { font-size: 13.5px; line-height: 1.5; color: var(--ink); font-weight: 500; margin: 0 0 10px; padding-left: 12px; border-left: 2px solid var(--accent); }
.kp-led { font-size: 12px; line-height: 1.45; color: var(--muted); margin: 0; }
.kp-led b { font-family: var(--font-mono); font-size: 9px; text-transform: uppercase; letter-spacing: .05em; color: var(--accent-strong); display: block; margin-bottom: 3px; }
.s-break { color: var(--accent-strong); background: rgba(26,157,84,.07); border: 1px dashed rgba(26,157,84,.5); }
.kp-take { font-size: 13px; line-height: 1.55; color: var(--ink-2); margin: 0 0 10px; }
.kp-take b { font-family: var(--font-mono); font-size: 9px; text-transform: uppercase; letter-spacing: .05em; color: var(--accent-strong); display: block; margin-bottom: 3px; }
.kp-form { font-size: 12px; line-height: 1.5; color: var(--ink-2); margin: 0 0 10px; padding: 7px 10px; background: rgba(26,157,84,.05); border-radius: 7px; }
.kp-form b { font-family: var(--font-mono); font-size: 9px; text-transform: uppercase; letter-spacing: .05em; color: var(--accent-strong); display: block; margin-bottom: 2px; }

/* ---- Sidebar ---- */
.glance { list-style: none; margin: 0; padding: 0; }
.glance li { display: flex; justify-content: space-between; gap: 12px; align-items: baseline; padding: 9px 0; border-bottom: 1px solid var(--line); font-size: 14px; }
.glance li:last-child { border-bottom: 0; }
.glance .k { font-family: var(--font-mono); font-size: 10px; text-transform: uppercase; letter-spacing: .06em; color: var(--muted); }
.glance .v { font-weight: 700; color: var(--ink); text-align: right; }
.glance .v.tn { font-variant-numeric: tabular-nums; }

.watchrow { display: flex; align-items: center; gap: 11px; padding: 10px 0; border-bottom: 1px solid var(--line); }
.watchrow:last-child { border-bottom: 0; }
.wd { width: 9px; height: 9px; border-radius: 50%; flex: none; }
.watchrow .nm { font-weight: 700; font-size: 14px; flex: 1; }
.watchrow .why { display: block; font-weight: 400; font-size: 12px; color: var(--muted); }
.watchrow .tg { font-family: var(--font-mono); font-size: 9px; font-weight: 700; text-transform: uppercase; padding: 2px 7px; border-radius: var(--r-pill); }

.cf { border-radius: var(--r-md); border: 1px solid var(--line); padding: 14px 16px; }
.cf + .cf { margin-top: 12px; }
.cf.ceil { border-top: 3px solid var(--accent); }
.cf.floor { border-top: 3px solid var(--danger); }
.cf h4 { font-family: var(--font-wide); font-size: 14px; margin: 0 0 6px; }
.cf.ceil h4 { color: var(--accent-strong); } 
.cf.floor h4 { color: var(--danger); }
.cf p { margin: 0; font-size: 13px; line-height: 1.5; color: var(--ink-2); }

/* ---- Full squad ---- */
.squad-group { margin-bottom: 18px; }
.squad-group:last-child { margin-bottom: 0; }
.squad-group h4 { font-family: var(--font-mono); font-size: 10px; text-transform: uppercase; letter-spacing: .08em; color: var(--muted); margin: 0 0 10px; padding-bottom: 6px; border-bottom: 1px solid var(--line); }
.squad-pills { display: flex; flex-wrap: wrap; gap: 8px; }
.pill { display: inline-flex; align-items: baseline; gap: 7px; background: var(--panel-2); border: 1px solid var(--line); border-radius: var(--r-md); padding: 7px 11px; font-size: 13.5px; font-weight: 700; color: var(--ink); white-space: nowrap; }
.pill .cl { font-family: var(--font-mono); font-size: 10px; font-weight: 500; color: var(--muted); letter-spacing: .02em; }

/* ---- Sources ---- */
.sources { display: flex; flex-wrap: wrap; gap: 8px 18px; }
.sources a { font-family: var(--font-mono); font-size: 12px; color: var(--accent2-strong); }
.sources span { color: var(--muted); }

/* ---- Timeline ---- */
.timeline { list-style: none; margin: 0; padding: 0 0 0 4px; }
.timeline li { position: relative; display: flex; gap: 16px; padding: 0 0 16px 20px; border-left: 1.5px solid var(--line); }
.timeline li:last-child { padding-bottom: 0; }
.timeline li::before { content: ""; position: absolute; left: -5.5px; top: 4px; width: 9px; height: 9px; border-radius: 50%; background: var(--panel); border: 2px solid var(--muted); }
.timeline li.tl-key::before { background: var(--accent); border-color: var(--accent); }
.tl-date { font-family: var(--font-mono); font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .04em; color: var(--accent-strong); flex: none; width: 64px; padding-top: 1px; }
.tl-event { font-size: 14px; line-height: 1.5; color: var(--ink-2); }
.tl-key .tl-event { color: var(--ink); font-weight: 600; }

/* The manager & culture section (from the research dossiers) */
.cult-panel { margin-top: 22px; border-top: 3px solid var(--accent2); }
.cult-dek { margin: -2px 0 18px; font-size: 13.5px; color: var(--muted); line-height: 1.5; }
.cult-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 22px 28px; }
.cult-block.cult-lead { grid-column: 1 / -1; border-left: 3px solid var(--accent2); padding-left: 16px; }
.cult-block.cult-lead p { font-size: 15px; }
.cult-block { min-width: 0; }
.cult-block.cult-watch { grid-column: 1 / -1; border-top: 1px dashed var(--line); padding-top: 18px; margin-top: 2px; }
.cult-h { font-family: var(--font-display); font-weight: 800; font-size: 15px; margin: 0 0 8px; color: var(--ink); }
.cult-block p { margin: 0; font-size: 14px; line-height: 1.62; color: var(--ink-2); }
.cult-watch-list { margin: 0; padding-left: 1.1rem; display: grid; grid-template-columns: 1fr 1fr; gap: 6px 24px; }
.cult-watch-list li { font-size: 13.5px; line-height: 1.5; color: var(--ink-2); }
.cult-src { margin: 16px 0 0; font-family: var(--font-mono); font-size: 11px; color: var(--muted); letter-spacing: .01em; }
@media (max-width: 760px) {
  .cult-grid { grid-template-columns: 1fr; }
  .cult-watch-list { grid-template-columns: 1fr; }
}

/* The Newsroom agent's team-news brief */
.news-panel { margin-top: 22px; border-top: 3px solid var(--danger, #cc3b3b); }
.news-head { display: flex; align-items: baseline; justify-content: space-between; gap: 12px; }
.news-mood { font-family: var(--font-mono); font-size: 10px; font-weight: 700; text-transform: uppercase;
  letter-spacing: .05em; color: var(--muted); background: var(--line); padding: 4px 11px; border-radius: var(--r-pill); }
.news-lead { font-family: var(--font-display); font-weight: 800; font-size: 17px; line-height: 1.35; color: var(--ink); margin: 10px 0 8px; }
.news-body { font-size: 14px; line-height: 1.6; color: var(--ink-2); margin: 0 0 16px; }
.news-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }
.news-inj h4, .news-story h4 { font-family: var(--font-mono); font-size: 9.5px; text-transform: uppercase;
  letter-spacing: .06em; color: var(--accent-strong); margin: 0 0 8px; }
.news-inj-list { list-style: none; margin: 0; padding: 0; }
.news-inj-list li { display: grid; grid-template-columns: 1fr auto; align-items: center; gap: 4px 8px;
  padding: 7px 0; border-top: 1px solid var(--line); }
.news-inj-list li:first-child { border-top: none; }
.news-inj-name { font-family: var(--font-text); font-weight: 700; font-size: 13.5px; color: var(--ink); }
.news-inj-note { grid-column: 1; font-size: 12px; line-height: 1.4; color: var(--muted); }
.news-inj-list .kp-status { grid-column: 2; grid-row: 1 / span 2; }
.news-story-h { font-family: var(--font-display); font-weight: 800; font-size: 14px; color: var(--ink); margin: 0 0 5px; }
.news-story p:last-child { margin: 0; font-size: 13.5px; line-height: 1.55; color: var(--ink-2); }
@media (max-width: 760px) { .news-grid { grid-template-columns: 1fr; } }

/* The Tactics agent's team-shape read */
.tac-panel { margin-top: 22px; border-top: 3px solid var(--accent); }
.tac-head { display: flex; align-items: baseline; justify-content: space-between; gap: 12px; }
.tac-form { font-family: var(--font-mono); font-weight: 700; font-size: 15px; letter-spacing: .08em;
  color: var(--accent-strong); background: rgba(26,157,84,.08); padding: 4px 12px; border-radius: var(--r-pill); }
.tac-grid { display: grid; grid-template-columns: 220px 1fr; gap: 26px; margin-top: 14px; }
.tac-xi h4, .tac-read h4, .tac-sw h4, .tac-battle h4, .tac-phase h4 {
  font-family: var(--font-mono); font-size: 9.5px; text-transform: uppercase; letter-spacing: .06em;
  color: var(--accent-strong); margin: 0 0 7px; }
.txi-list { list-style: none; margin: 0; padding: 0; counter-reset: xi; }
.txi-list li { display: flex; align-items: baseline; gap: 8px; padding: 5px 0; border-top: 1px solid var(--line); counter-increment: xi; }
.txi-list li:first-child { border-top: none; }
.txi-list li::before { content: counter(xi); font-family: var(--font-mono); font-size: 10px; color: var(--muted); width: 16px; flex: none; }
.txi-name { font-family: var(--font-text); font-weight: 700; font-size: 13.5px; color: var(--ink); }
.txi-role { font-family: var(--font-mono); font-size: 9.5px; text-transform: uppercase; letter-spacing: .03em; color: var(--muted); margin-left: auto; text-align: right; }
.tac-phase { margin-bottom: 14px; }
.tac-phase p { margin: 0; font-size: 13.5px; line-height: 1.55; color: var(--ink-2); }
.tac-sw-row { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; margin: 16px 0; }
.tac-sw-list { margin: 0; padding-left: 1.05rem; }
.tac-sw-list li { font-size: 13px; line-height: 1.5; color: var(--ink-2); margin-bottom: 3px; }
.tac-str h4 { color: var(--accent-strong); }
.tac-wk h4 { color: #9a6510; }
.tac-battle { border-top: 1px dashed var(--line); padding-top: 12px; }
.tac-battle p { margin: 0; font-size: 13.5px; line-height: 1.55; color: var(--ink); }
.tac-aim { margin: 16px 0 0; font-size: 13.5px; line-height: 1.55; color: var(--ink-2); padding-top: 14px; border-top: 1px solid var(--line); }
.tac-aim b { font-family: var(--font-mono); font-size: 9px; text-transform: uppercase; letter-spacing: .05em; color: var(--accent-strong); display: block; margin-bottom: 3px; }
@media (max-width: 760px) {
  .tac-grid { grid-template-columns: 1fr; }
  .tac-sw-row { grid-template-columns: 1fr; }
}

/* Tournament-features (Players) page — nucleus views */
.features-index .feat-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 26px; margin-bottom: 36px; }
.feat-card { border: 1px solid var(--line); border-radius: 10px; padding: 20px 22px; background: var(--card, #fff); }
.feat-h { font-family: var(--font-display); font-weight: 800; font-size: 19px; margin: 0 0 4px; color: var(--ink); }
.feat-sub { font-size: 13px; line-height: 1.5; color: var(--muted); margin: 0 0 16px; }
.feat-list { list-style: none; margin: 0; padding: 0; }
.feat-list li { display: grid; grid-template-columns: 26px 22px 1fr auto; align-items: center;
  gap: 10px; padding: 8px 0; border-top: 1px solid var(--line); }
.feat-list li:first-child { border-top: none; }
.feat-rank { font-family: var(--font-mono); font-size: 12px; font-weight: 700; color: var(--accent-strong); text-align: right; }
.feat-name { font-family: var(--font-text); font-weight: 700; font-size: 14.5px; color: var(--ink); }
.feat-meta { grid-column: 3; font-family: var(--font-mono); font-size: 10.5px; color: var(--muted); }
.feat-list li { grid-template-rows: auto auto; }
.feat-name { grid-row: 1; }
.feat-meta { grid-row: 2; }
.feat-stat { grid-column: 4; grid-row: 1 / span 2; font-family: var(--font-display);
  font-weight: 800; font-size: 18px; color: var(--ink); text-align: right; }
.feat-unit { display: block; font-family: var(--font-mono); font-weight: 400; font-size: 9.5px;
  text-transform: uppercase; letter-spacing: .04em; color: var(--muted); }
.feat-section-h { font-family: var(--font-display); font-weight: 800; font-size: 21px; margin: 28px 0 2px; color: var(--ink); }
/* Best XI */
.feat-xi { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; margin-bottom: 8px; }
.feat-xi-player { display: grid; grid-template-columns: auto auto 1fr; align-items: center; column-gap: 8px;
  border: 1px solid var(--line); border-radius: 9px; padding: 11px 13px; background: var(--card, #fff); }
.feat-xi-slot { font-family: var(--font-mono); font-size: 10px; font-weight: 700; text-transform: uppercase;
  letter-spacing: .05em; color: var(--accent-strong); }
.feat-xi-name { font-family: var(--font-text); font-weight: 700; font-size: 13.5px; color: var(--ink); text-decoration: none; }
.feat-xi-val { grid-column: 1 / -1; font-family: var(--font-mono); font-size: 11px; color: var(--muted); margin-top: 4px; }
.feat-list-squads li { grid-template-columns: 26px 22px 1fr auto; }
/* Breakout board */
.feat-break-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; margin-bottom: 8px; }
.feat-break { border: 1px solid var(--line); border-left: 3px solid var(--accent); border-radius: 9px; padding: 13px 15px; background: var(--card, #fff); }
.feat-break-top { display: flex; align-items: center; gap: 8px; }
.feat-break-name { font-family: var(--font-text); font-weight: 700; font-size: 14.5px; color: var(--ink); text-decoration: none; }
.feat-break-val { margin-left: auto; font-family: var(--font-display); font-weight: 800; font-size: 14px; color: var(--accent-strong); }
.feat-break-arch { font-family: var(--font-mono); font-size: 9.5px; text-transform: uppercase; letter-spacing: .04em; color: var(--muted); margin: 6px 0 7px; }
.feat-break-hook { margin: 0; font-size: 12.5px; line-height: 1.45; color: var(--ink-2); }
.feat-watch-grid { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 20px 26px; }
.feat-watch-group { min-width: 0; }
.feat-watch-gh { font-family: var(--font-mono); font-size: 12px; font-weight: 700; text-transform: uppercase;
  letter-spacing: .05em; color: var(--accent-strong); margin: 0 0 8px; border-bottom: 1px solid var(--line); padding-bottom: 5px; }
.feat-watch-list { list-style: none; margin: 0; padding: 0; }
.feat-watch-list li { padding: 7px 0; border-top: 1px solid var(--line); }
.feat-watch-list li:first-child { border-top: none; }
.feat-watch-link { display: inline-flex; align-items: center; gap: 7px; text-decoration: none; }
.feat-watch-name { font-family: var(--font-text); font-weight: 700; font-size: 14px; color: var(--ink); }
.feat-watch-why { display: block; font-size: 12.5px; line-height: 1.45; color: var(--ink-2); margin-top: 2px; }
/* Faces of 2026 */
.faces-band { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; margin-bottom: 38px; }
.face-card { display: block; border: 1px solid var(--line); border-radius: 12px; padding: 15px 16px;
  background: var(--card, #fff); text-decoration: none; transition: .12s; }
.face-card:hover { border-color: var(--accent); box-shadow: var(--sh-2); text-decoration: none; }
.face-top { display: flex; align-items: center; justify-content: space-between; gap: 8px; margin-bottom: 9px; }
.face-pos { font-family: var(--font-mono); font-size: 9.5px; text-transform: uppercase; letter-spacing: .05em;
  color: var(--muted); border: 1px solid var(--line); border-radius: 999px; padding: 2px 7px; }
.face-name { font-family: var(--font-display); font-weight: 800; font-size: 17px; color: var(--ink); line-height: 1.15; }
.face-club { font-size: 11.5px; color: var(--muted); margin: 1px 0 8px; }
.face-line { margin: 0; font-size: 12.5px; line-height: 1.5; color: var(--ink-2); }
/* The races */
.races-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; margin-bottom: 10px; }
.race-card { border: 1px solid var(--line); border-radius: 11px; padding: 16px 18px; background: var(--card, #fff); }
.race-h { font-family: var(--font-display); font-weight: 800; font-size: 16px; margin: 0 0 6px; color: var(--ink); }
.race-empty { font-size: 11.5px; color: var(--accent-strong); font-weight: 700; margin: 0 0 12px;
  border: 1px dashed var(--line); border-radius: 7px; padding: 5px 9px; display: inline-block; }
.race-favs-h { font-family: var(--font-mono); font-size: 9.5px; text-transform: uppercase; letter-spacing: .05em;
  color: var(--muted); margin: 0 0 7px; }
.race-favs { display: flex; flex-direction: column; gap: 5px; }
.race-fav { display: inline-flex; align-items: center; gap: 7px; font-size: 13.5px; font-weight: 700;
  color: var(--ink); text-decoration: none; }
.race-fav:hover { color: var(--accent-strong); text-decoration: none; }
.rf-age { font-family: var(--font-mono); font-size: 10.5px; color: var(--muted); font-weight: 400; }
.race-marksmen { list-style: none; margin: 0; padding: 0; }
.race-marksmen li { display: flex; align-items: center; gap: 7px; font-size: 12.5px; padding: 3px 0; color: var(--ink-2); }
.rm-goals { margin-left: auto; font-family: var(--font-mono); font-size: 11px; color: var(--muted); }
/* Best in the world XI */
.xi-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; margin-bottom: 10px; }
.xi-card { border: 1px solid var(--line); border-radius: 9px; padding: 12px 14px; background: var(--card, #fff); }
.xi-card-top { display: flex; align-items: center; gap: 8px; }
.xi-slot { font-family: var(--font-mono); font-size: 10px; font-weight: 700; text-transform: uppercase;
  color: #fff; background: var(--accent); border-radius: 5px; padding: 2px 6px; }
.xi-name { font-family: var(--font-text); font-weight: 700; font-size: 14px; color: var(--ink); text-decoration: none; }
.xi-arch { font-family: var(--font-mono); font-size: 9.5px; text-transform: uppercase; letter-spacing: .04em;
  color: var(--muted); margin: 7px 0 6px; }
.xi-verdict { margin: 0; font-size: 12.5px; line-height: 1.45; color: var(--ink-2); }
/* Injury watch */
.injury-watch { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; margin-bottom: 10px; }
.injury-col { border: 1px solid var(--line); border-radius: 10px; padding: 14px 16px; background: var(--card, #fff); }
.injury-col-h { font-family: var(--font-display); font-weight: 800; font-size: 14px; margin-bottom: 10px;
  display: flex; align-items: center; gap: 7px; }
.injury-col-h.inj-out { color: var(--danger, #c0392b); }
.injury-col-h.inj-doubt { color: var(--warn, #e0a83a); }
.injury-col-h.inj-monitor { color: var(--muted); }
.inj-n { font-family: var(--font-mono); font-size: 11px; border: 1px solid var(--line); border-radius: 999px;
  padding: 1px 7px; color: var(--muted); font-weight: 600; }
.injury-list { list-style: none; margin: 0; padding: 0; }
.injury-row { padding: 7px 0; border-top: 1px solid var(--line); }
.injury-row:first-child { border-top: none; }
.injury-name { display: inline-flex; align-items: center; gap: 7px; font-weight: 700; font-size: 13.5px;
  color: var(--ink); text-decoration: none; }
.injury-issue { display: block; font-size: 12px; line-height: 1.4; color: var(--ink-2); margin-top: 2px; }
.injury-empty { font-size: 12.5px; color: var(--muted); margin: 0; }
/* Breakout details/expand */
.feat-break[open] { border-left-color: var(--accent-strong); box-shadow: var(--sh-2); }
.feat-break summary { list-style: none; cursor: pointer; }
.feat-break summary::-webkit-details-marker { display: none; }
.feat-break-age { margin-left: auto; font-family: var(--font-mono); font-size: 11px; color: var(--muted); }
.scout-more { margin-top: 11px; padding-top: 11px; border-top: 1px solid var(--line); }
.sm-row { margin-bottom: 8px; }
.sm-label { font-family: var(--font-mono); font-size: 9px; text-transform: uppercase; letter-spacing: .05em; font-weight: 700; }
.sm-up { color: var(--accent-strong); }
.sm-down { color: var(--warn, #e0a83a); }
.sm-list { margin: 4px 0 0; padding-left: 16px; font-size: 12px; line-height: 1.45; color: var(--ink-2); }
.sm-comp { font-size: 12px; color: var(--ink-2); margin: 8px 0 6px; }
.sm-link { font-size: 11.5px; font-weight: 700; color: var(--accent2); text-decoration: none; }
/* position chip + old guard */
.pos-chip { display: inline-block; font-family: var(--font-mono); font-size: 9px; text-transform: uppercase;
  letter-spacing: .04em; color: var(--muted); border: 1px solid var(--line); border-radius: 999px;
  padding: 1px 6px; margin-left: 4px; vertical-align: middle; }
.oldguard-strip { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
.vet-card { display: block; border: 1px solid var(--line); border-left: 3px solid var(--accent2); border-radius: 9px;
  padding: 13px 15px; background: var(--card, #fff); text-decoration: none; transition: .12s; }
.vet-card:hover { border-color: var(--accent); box-shadow: var(--sh-2); text-decoration: none; }
.vet-top { display: flex; align-items: center; gap: 8px; }
.vet-name { font-family: var(--font-display); font-weight: 800; font-size: 15px; color: var(--ink); }
.vet-meta { font-family: var(--font-mono); font-size: 11px; color: var(--muted); margin: 5px 0 7px; }
.vet-line { margin: 0; font-size: 12.5px; line-height: 1.45; color: var(--ink-2); }
@media (max-width: 860px) {
  .features-index .feat-grid { grid-template-columns: 1fr; }
  .feat-watch-grid { grid-template-columns: 1fr; }
  .feat-xi, .xi-grid { grid-template-columns: repeat(2, 1fr); }
  .feat-break-grid { grid-template-columns: 1fr; }
  .faces-band { grid-template-columns: repeat(2, 1fr); }
  .races-grid, .injury-watch, .oldguard-strip { grid-template-columns: 1fr; }
}

/* ============================================================= */
/*  Match preview — the analyst's read, styled like a feature     */
/* ============================================================= */
.mp { max-width: 760px; margin: 0 auto 28px; }
.mp-hero { padding-bottom: 22px; border-bottom: 1px solid var(--line); margin-bottom: 26px; }
.mp-kicker {
  font-family: var(--font-mono); font-size: 11px; font-weight: 700;
  text-transform: uppercase; letter-spacing: .08em; color: var(--accent-strong);
  margin-bottom: 16px;
}
.mp-teams {
  display: flex; align-items: center; gap: 14px; flex-wrap: wrap;
  font-family: var(--font-wide); font-weight: 800; font-size: 26px; color: var(--ink);
}
.mp-team { display: inline-flex; align-items: center; gap: 11px; }
.mp-vs { color: var(--muted); font-weight: 500; font-size: 18px; }
.mp-venue {
  font-family: var(--font-mono); font-size: 11.5px; color: var(--muted);
  text-transform: uppercase; letter-spacing: .04em; margin: 14px 0 0;
}
.mp-headline {
  font-family: var(--font-wide); font-weight: 800; font-size: 33px; line-height: 1.14;
  letter-spacing: -.01em; color: var(--ink); margin: 20px 0 0;
}
.mp-standfirst {
  font-size: 18px; line-height: 1.5; color: var(--ink-2); margin: 14px 0 0;
  font-weight: 500;
}
.mp-story { font-size: 17.5px; line-height: 1.72; color: var(--ink); }
.mp-story p:first-child::first-letter {
  font-family: var(--font-wide); font-weight: 800; float: left;
  font-size: 58px; line-height: .82; padding: 6px 12px 0 0; color: var(--accent-strong);
}
.mp-story p { margin: 0 0 16px; }

/* model strip — deliberately quiet, a sanity check not a centrepiece */
.mp-numbers {
  background: var(--panel-2); border: 1px solid var(--line); border-radius: var(--r-lg);
  padding: 16px 18px; margin: 8px 0 30px;
}
.mp-numbers-head {
  font: 700 9.5px var(--font-mono); text-transform: uppercase; letter-spacing: .07em;
  color: var(--muted); margin: 0 0 9px;
}
.mp-numbers-src {
  margin: 11px 0 0; padding-top: 11px; border-top: 1px dashed var(--line);
  font-size: 12px; line-height: 1.55; color: var(--muted);
}
.mp-numbers-bar {
  display: flex; height: 22px; border-radius: var(--r-sm); overflow: hidden;
  font: 800 10px/22px var(--font-mono); text-align: center;
}
.mp-numbers-bar .b-h { background: var(--h); color: #08130c; }
.mp-numbers-bar .b-d { background: var(--d); color: #fff; }
.mp-numbers-bar .b-a { background: var(--a); color: #08130c; }
.mp-numbers-legend {
  display: flex; justify-content: space-between; margin-top: 5px;
  font: 600 9.5px var(--font-mono); text-transform: uppercase;
  letter-spacing: .03em; color: var(--muted);
}
.mp-numbers-meta {
  display: flex; gap: 22px; margin-top: 12px; padding-top: 12px;
  border-top: 1px dashed var(--line); font-size: 12.5px; color: var(--ink-2);
}
.mp-numbers-meta strong { font-family: var(--font-mono); color: var(--ink); }
.mp-numbers-note {
  margin: 12px 0 0; font-size: 13px; line-height: 1.55; color: var(--muted);
  font-style: italic;
}

.mp-block { margin: 0 0 30px; }
.mp-section-h {
  font-family: var(--font-wide); font-weight: 800; font-size: 22px; line-height: 1.2;
  color: var(--ink); margin: 0 0 14px; padding-bottom: 0;
}
.mp-tactical { font-size: 16.5px; line-height: 1.7; color: var(--ink); }
.mp-tactical p { margin: 0 0 14px; }

/* duels */
.mp-duels { display: flex; flex-direction: column; gap: 14px; }
.mp-duel {
  background: var(--panel); border: 1px solid var(--line); border-left: 3px solid var(--accent);
  border-radius: var(--r-md); padding: 16px 18px; box-shadow: var(--sh-1);
}
.mp-duel-title {
  font-family: var(--font-wide); font-weight: 800; font-size: 16px; color: var(--ink);
  margin-bottom: 9px;
}
.mp-duel-players { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 10px; }
.mp-chip {
  display: inline-flex; align-items: center; font-family: var(--font-mono);
  font-size: 11px; font-weight: 700; color: var(--accent-strong);
  background: rgba(26,157,84,.08); border: 1px solid rgba(26,157,84,.25);
  border-radius: var(--r-pill); padding: 3px 11px;
}
.mp-duel-read { font-size: 15px; line-height: 1.62; color: var(--ink-2); margin: 0; }
/* form / coming-into-it chips */
.mp-form-chips { display: flex; flex-direction: column; gap: 6px; }
.mp-form-chip { font-size: 12.5px; line-height: 1.4; color: var(--ink-2); background: var(--panel-2);
  border: 1px solid var(--line); border-left: 3px solid var(--accent2); border-radius: 6px; padding: 5px 9px; }

/* team news + x-factor */
.mp-cols { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; margin: 0 0 30px; }
.mp-news, .mp-xfactor {
  background: var(--panel); border: 1px solid var(--line); border-radius: var(--r-md);
  padding: 16px 18px;
}
.mp-xfactor { background: var(--panel-2); border-color: var(--warn-soft); }
.mp-mini-h {
  font-family: var(--font-mono); font-size: 10px; font-weight: 700;
  text-transform: uppercase; letter-spacing: .08em; color: var(--muted); margin-bottom: 9px;
}
.mp-news p { font-size: 14.5px; line-height: 1.62; color: var(--ink-2); margin: 0; }
.mp-xfactor-head {
  font-family: var(--font-wide); font-weight: 800; font-size: 15px; color: var(--ink);
  margin-bottom: 7px;
}
.mp-xfactor p { font-size: 14px; line-height: 1.6; color: var(--ink-2); margin: 0; }

/* the verdict */
.mp-verdict {
  background: linear-gradient(180deg, rgba(26,157,84,.06), rgba(26,157,84,.02));
  border: 1px solid rgba(26,157,84,.25); border-top: 3px solid var(--accent);
  border-radius: var(--r-lg); padding: 20px 24px; margin: 0 0 8px;
}
.mp-verdict .prose { font-size: 16.5px; line-height: 1.7; color: var(--ink); }
.mp-verdict .prose p { margin: 0 0 12px; }
.mp-verdict .prose p:last-child { margin-bottom: 0; }

@media (max-width: 760px) {
  .mp-headline { font-size: 27px; }
  .mp-teams { font-size: 21px; }
  .mp-cols { grid-template-columns: 1fr; }
  .mp-story { font-size: 16.5px; }
}

/* ---- share row (match + team pages) ---- */
.share-row {
  display: flex; align-items: center; flex-wrap: wrap; gap: 10px;
  margin: 0 0 24px; padding: 14px 18px;
  background: var(--panel); border: 1px solid var(--line);
  border-radius: var(--r-lg); box-shadow: var(--sh-1);
}
.share-label {
  font-family: var(--font-mono); font-size: 11px; letter-spacing: .04em;
  text-transform: uppercase; color: var(--muted); margin-right: auto;
}
.share-btn {
  display: inline-flex; align-items: center; gap: 7px;
  border: 1px solid var(--line-strong); background: var(--bg-2);
  color: var(--ink); border-radius: var(--r-pill); padding: 8px 14px;
  font: 600 13px/1 var(--font-text); text-decoration: none; cursor: pointer;
  transition: border-color .15s, background .15s, color .15s;
}
.share-btn .share-ic { font-size: 14px; line-height: 1; }
.share-btn:hover { border-color: var(--ink); color: var(--ink); }
.share-x:hover { background: #1b1b18; border-color: #1b1b18; color: #fff; }
.share-wa:hover { background: #1faf54; border-color: #1faf54; color: #fff; }
.share-copy:hover { border-color: var(--accent2-strong); color: var(--accent2-strong); }
.share-copy.copied { background: var(--accent); border-color: var(--accent); color: #fff; }
@media (max-width: 560px) {
  .share-label { flex-basis: 100%; margin: 0 0 2px; }
  .share-btn { flex: 1; justify-content: center; }
}

/* ---- match fixture row (prominent TV/time in the hero) ---- */
.mp-fixture {
  display: flex; align-items: center; flex-wrap: wrap; gap: 10px 14px;
  margin: 4px 0 18px; font-size: 15px;
}
.mp-fx-when { font-weight: 700; color: var(--ink); }
.mp-fx-venue { color: var(--muted); font-size: 13.5px; }
.mp-tv-pill {
  display: inline-flex; align-items: center; gap: 6px;
  background: var(--accent2); color: #fff; font-weight: 700; font-size: 13px;
  padding: 4px 12px; border-radius: var(--r-pill); letter-spacing: .01em;
}

/* ---- the first-screen brief ---- */
.mp-brief {
  background: var(--panel); border: 1px solid var(--line);
  border-left: 3px solid var(--accent); border-radius: var(--r-lg);
  padding: 4px 22px 18px; margin: 0 0 22px; box-shadow: var(--sh-1);
}
.mp-brief-row { padding: 16px 0; border-bottom: 1px solid var(--line-soft); }
.mp-brief-row:last-of-type { border-bottom: 0; }
.mp-brief-label {
  font-family: var(--font-mono); font-size: 11px; letter-spacing: .06em;
  text-transform: uppercase; color: var(--accent-strong); margin-bottom: 8px;
}
.mp-brief-headline {
  font-family: var(--font-display); font-weight: 800; font-size: 19px;
  line-height: 1.32; color: var(--ink); margin: 0;
}
.mp-brief-body { font-size: 15px; line-height: 1.6; color: var(--ink-2); margin: 8px 0 0; }
.mp-quote { margin: 0 0 12px; padding: 0; }
.mp-quote:last-child { margin-bottom: 0; }
.mp-quote p {
  font-size: 16px; line-height: 1.6; font-style: italic; color: var(--ink);
  margin: 0 0 6px;
}
.mp-quote cite {
  display: flex; align-items: center; gap: 7px; font-style: normal;
  font-size: 12.5px; color: var(--muted);
}
.mp-quote cite a { font-weight: 700; color: var(--accent2-strong); text-decoration: underline; }
.mp-quote-lang {
  font-family: var(--font-mono); font-size: 10px; text-transform: uppercase;
  letter-spacing: .05em; color: var(--faint); border: 1px solid var(--line);
  border-radius: var(--r-sm); padding: 1px 5px;
}
.mp-news-list { list-style: none; margin: 0; padding: 0; }
.mp-news-list li {
  font-size: 14.5px; line-height: 1.5; color: var(--ink-2); margin: 0 0 7px;
}
.mp-status {
  display: inline-block; font-family: var(--font-mono); font-size: 10px;
  font-weight: 700; text-transform: uppercase; letter-spacing: .04em;
  padding: 1px 7px; border-radius: var(--r-sm); margin-right: 6px; vertical-align: 1px;
}
.mp-status-out { background: var(--danger); color: #fff; }
.mp-status-doubt, .mp-status-monitor { background: var(--warn-soft); color: #9a6510; }
.mp-status-fit_again { background: var(--accent); color: #fff; }
.mp-fresh {
  font-family: var(--font-mono); font-size: 11px; color: var(--muted);
  padding-top: 12px; letter-spacing: .02em;
}

/* ============================================================
   MATCH PAGE — editorial serif redesign (overrides earlier .mp-*)
   ============================================================ */
.mp-hero { margin: 8px 0 26px; }
.mp-eyebrow {
  font-family: var(--font-display); font-weight: 700; font-size: 12px;
  text-transform: uppercase; letter-spacing: .06em; color: var(--accent-strong);
  margin: 0 0 12px;
}
.mp-matchup { display: flex; align-items: center; flex-wrap: wrap; gap: 14px 22px; margin: 0 0 18px; }
.mp-side { display: flex; align-items: center; gap: 14px; }
.mp-flag {
  font-size: 2.7rem; border-radius: 4px;
  box-shadow: 0 1px 4px rgba(30, 28, 22, .18);
}
.mp-nation {
  font-family: var(--font-wide); font-weight: 800; font-size: 2.6rem; line-height: 1.02;
  letter-spacing: -.02em; color: var(--ink);
}
.mp-v { font-family: var(--font-wide); font-weight: 700; font-size: 1.3rem; color: var(--faint); }
.mp-meta {
  display: flex; align-items: center; flex-wrap: wrap; gap: 8px 14px;
  margin: 0 0 26px; font-family: var(--font-display); font-size: 15px;
}
.mp-meta-when { font-weight: 700; color: var(--ink); }
.mp-meta-venue { color: var(--muted); font-size: 13.5px; }

/* headline + standfirst — serif lead */
.mp-headline {
  font-family: var(--font-serif); font-weight: 700; font-size: 2.5rem; line-height: 1.16;
  letter-spacing: -.01em; color: var(--ink); margin: 6px 0 14px; max-width: 22ch;
}
.mp-standfirst {
  font-family: var(--font-serif); font-weight: 400; font-size: 1.32rem; line-height: 1.5;
  color: var(--ink-2); margin: 0; max-width: 62ch;
}

/* reading prose — the serif read */
.mp-story, .mp-tactical, .mp-verdict {
  font-family: var(--font-serif); font-size: 1.2rem; line-height: 1.75; color: var(--ink);
}
.mp-story p, .mp-tactical p, .mp-verdict p { margin: 0 0 1.15em; max-width: 66ch; }
.mp-story p:last-child, .mp-tactical p:last-child, .mp-verdict p:last-child { margin-bottom: 0; }
.mp-story p:first-child::first-letter {
  font-family: var(--font-serif); font-weight: 700; float: left; font-size: 3.4em;
  line-height: .78; padding: 7px 11px 0 0; color: var(--ink);
}

/* section headers — a rule + a green kicker, not a box */
.mp-section-h {
  font-family: var(--font-display); font-weight: 800; font-size: 13px;
  text-transform: uppercase; letter-spacing: .07em; color: var(--accent-strong);
  margin: 40px 0 14px; padding-top: 18px; border-top: 1px solid var(--line);
}

.mp-pullquote {
  font-family: var(--font-serif); font-style: italic; font-size: 1.25rem; line-height: 1.55;
  color: var(--ink-2); border-left: 3px solid var(--accent); padding: 2px 0 2px 18px;
  margin: 0; max-width: 60ch;
}

/* numbers strip — kept, just de-teched */
.mp-numbers {
  background: var(--bg-2); border: 1px solid var(--line); border-radius: var(--r-lg);
  padding: 18px 20px; margin: 28px 0;
}
.mp-numbers-head {
  font-family: var(--font-display); font-weight: 800; font-size: 13px;
  text-transform: uppercase; letter-spacing: .06em; color: var(--ink); margin: 0 0 12px;
}
.mp-numbers-bar { display: flex; height: 26px; border-radius: var(--r-sm); overflow: hidden; }
.mp-numbers-bar span {
  font-family: var(--font-display); font-weight: 800; font-size: 11px; line-height: 26px;
  text-align: center; color: #fff;
}
.mp-numbers-bar .b-h { background: var(--res-home); }
.mp-numbers-bar .b-d { background: var(--res-draw); color: var(--ink); }
.mp-numbers-bar .b-a { background: var(--res-away); }
.mp-numbers-legend {
  display: flex; justify-content: space-between; font-family: var(--font-display);
  font-size: 11.5px; color: var(--muted); margin-top: 6px;
}
.mp-numbers-note { font-size: 14px; color: var(--ink-2); margin: 12px 0 0; }

/* two-column factual blocks — clean, no panels */
.mp-twocol { display: grid; grid-template-columns: 1fr 1fr; gap: 28px; margin: 0 0 6px; }
.mp-twocol-item { min-width: 0; }
.mp-team-sub {
  display: flex; align-items: center; gap: 8px; font-family: var(--font-display);
  font-weight: 700; font-size: 15px; color: var(--ink); margin: 0 0 10px;
}
.mp-twocol-text { font-size: 15px; line-height: 1.55; color: var(--ink-2); margin: 0 0 10px; }
.mp-stat-row {
  display: flex; justify-content: space-between; gap: 12px; font-size: 14px;
  color: var(--ink-2); padding: 6px 0; border-bottom: 1px dashed var(--line);
}
.mp-stat-row strong { color: var(--ink); font-weight: 700; }
.mp-form-chips { display: flex; flex-wrap: wrap; gap: 5px; }
.mp-form-chip {
  display: inline-flex; align-items: center; justify-content: center; min-width: 22px;
  height: 22px; padding: 0 5px; border-radius: var(--r-sm); font-family: var(--font-display);
  font-weight: 700; font-size: 11px; background: var(--bg-2); border: 1px solid var(--line);
  color: var(--ink-2);
}

/* sources — quiet, collapsible */
.mp-sources { margin: 40px 0 0; border-top: 1px solid var(--line); }
.mp-sources summary {
  font-family: var(--font-display); font-size: 12px; font-weight: 700; text-transform: uppercase;
  letter-spacing: .06em; color: var(--muted); padding: 14px 0; cursor: pointer; user-select: none;
}
.mp-sources-body { padding: 4px 0 8px; }
.mp-sources-intro { font-size: 13px; line-height: 1.55; color: var(--ink-2); margin: 0 0 14px; max-width: 72ch; }
.mp-src-list { list-style: square; padding-left: 1.1rem; margin: 0; font-size: 13px; line-height: 1.5; color: var(--ink-2); }
.mp-src-list a { font-weight: 600; color: var(--accent2-strong); text-decoration: underline; }

.mp-fresh { font-family: var(--font-display); font-size: 12px; color: var(--muted); padding-top: 10px; letter-spacing: 0; }

@media (max-width: 760px) {
  .mp-nation { font-size: 1.85rem; }
  .mp-flag { font-size: 2.05rem; }
  .mp-headline { font-size: 1.9rem; max-width: none; }
  .mp-standfirst { font-size: 1.15rem; }
  .mp-story, .mp-tactical, .mp-verdict { font-size: 1.1rem; }
  .mp-twocol { grid-template-columns: 1fr; gap: 8px; }
  .mp-twocol-item + .mp-twocol-item { margin-top: 14px; }
}

/* ===== one shared reading column: hero + body align to the same edge ===== */
.mp-page { max-width: 800px; margin: 0 auto; }
.mp-page .mp { max-width: none; margin: 0 0 28px; }     /* fill the column, don't re-centre */
/* a confident, uniform serif read that fills the column (not a timid narrow strip) */
.mp-page .mp-story p, .mp-page .mp-tactical p, .mp-page .mp-verdict p {
  font-size: 1.18rem; line-height: 1.72; color: var(--ink-2); max-width: none;
}

/* ===== new editorial parts: what-to-watch / x-factor / verdict ===== */

/* what to watch — punchy sans bullets, not four-sentence dumps */
.mp-watch { list-style: none; margin: 0; padding: 0; }
.mp-watch li {
  position: relative; padding: 13px 0 13px 28px;
  border-bottom: 1px solid var(--line-soft);
  font-family: var(--font-text); font-size: 1.02rem; line-height: 1.5; color: var(--ink);
}
.mp-watch li:last-child { border-bottom: 0; }
.mp-watch li::before {
  content: ""; position: absolute; left: 3px; top: 20px;
  width: 9px; height: 9px; border-radius: 2px; background: var(--accent);
}

/* the x-factor — flows as part of the read; the headline is a serif lead-in, not a box */
.mp-xfactor-lead {
  font-family: var(--font-serif); font-weight: 700; font-style: italic;
  color: var(--ink); margin: 0 0 .55em !important;
}

/* the verdict — de-boxed: neutralise the old gradient panel, keep it as prose */
.mp-verdict {
  background: none !important; border: 0 !important; border-radius: 0 !important;
  padding: 0 !important; margin: 0 !important;
}

@media (max-width: 760px) {
  .mp-watch li { font-size: .98rem; }
}

/* ===================== editorial TEAM page ===================== */
.tp-hero { position: relative; }
.tp-chip {
  position: absolute; top: 0; right: 0; display: flex; flex-direction: column;
  gap: 3px; text-align: right; font-family: var(--font-display); font-size: 12px;
  color: var(--muted); background: var(--bg-2); border: 1px solid var(--line);
  border-radius: var(--r-md); padding: 8px 12px;
}
.tp-chip-rank { font-weight: 800; color: var(--ink); font-size: 13px; }
.tp-chip-item b { color: var(--accent-strong); font-weight: 800; }

.tp-name { display: flex; align-items: center; gap: 16px; margin: 6px 0 12px; }
.tp-flag { font-size: 2.8rem; line-height: 1; border-radius: 3px; box-shadow: var(--sh-1); }
.tp-nation {
  font-family: var(--font-display); font-weight: 800; font-size: 2.7rem;
  line-height: 1.02; letter-spacing: -.01em; color: var(--ink);
}
.tp-identity {
  font-family: var(--font-serif); font-size: 1.3rem; line-height: 1.5;
  color: var(--ink-2); max-width: 62ch; margin: 0 0 14px;
}
.tp-meta {
  display: flex; flex-wrap: wrap; gap: 6px 22px; margin: 0;
  font-family: var(--font-display); font-size: 13.5px; color: var(--muted);
}
.tp-meta b { color: var(--ink); font-weight: 700; }

.tp-lead { font-family: var(--font-display); font-weight: 800; color: var(--accent-strong); }

/* players — clean blocks, not the old archetype boxes */
.tp-players { display: flex; flex-direction: column; }
.tp-player { padding: 16px 0; border-bottom: 1px solid var(--line-soft); }
.tp-player:last-child { border-bottom: 0; }
.tp-player-head { display: flex; align-items: baseline; justify-content: space-between; gap: 12px; flex-wrap: wrap; }
.tp-player-name { font-family: var(--font-display); font-weight: 800; font-size: 1.28rem; color: var(--ink); }
.tp-player-gen {
  font-family: var(--font-display); font-size: 11.5px; font-weight: 700;
  text-transform: uppercase; letter-spacing: .05em; color: var(--accent2-strong);
}
.tp-player-role { font-family: var(--font-display); font-size: 13px; color: var(--muted); margin-top: 2px; }
.tp-player-form {
  font-family: var(--font-text); font-size: 13.5px; color: var(--ink-2);
  margin-top: 8px; padding-top: 7px; border-top: 1px dashed var(--line);
}
.tp-player-take { font-family: var(--font-serif); font-size: 1.1rem; line-height: 1.6; color: var(--ink); margin: 9px 0 0; max-width: 64ch; }
.tp-selection { margin-top: 20px; }

/* the group fixtures */
.tp-fixtures { list-style: none; margin: 0; padding: 0; }
.tp-fixtures li a {
  display: flex; align-items: center; gap: 14px; padding: 13px 6px;
  border-bottom: 1px solid var(--line-soft); text-decoration: none; color: var(--ink);
  border-radius: var(--r-sm);
}
.tp-fixtures li:last-child a { border-bottom: 0; }
.tp-fixtures li a:hover { background: var(--bg-2); }
.tp-fx-md { font-family: var(--font-display); font-weight: 800; font-size: 12px; color: var(--accent-strong); width: 40px; flex: none; }
.tp-fx-opp { font-family: var(--font-display); font-weight: 700; font-size: 1.05rem; display: flex; align-items: center; gap: 9px; flex: 1; }
.tp-fx-meta { font-family: var(--font-display); font-size: 12.5px; color: var(--muted); text-align: right; }

@media (max-width: 760px) {
  .tp-chip { position: static; flex-direction: row; flex-wrap: wrap; gap: 4px 14px;
    text-align: left; margin: 0 0 12px; }
  .tp-nation { font-size: 2rem; }
  .tp-flag { font-size: 2.1rem; }
  .tp-identity { font-size: 1.15rem; }
}


/* ---- Full squad (unified capsules) — structural defaults; restyle freely ---- */
.tp-squad{margin:0 0 1.25rem;}
.tp-squad-unit{margin:1.6rem 0;}
.tp-squad-unit-h{font-size:.78rem;letter-spacing:.09em;text-transform:uppercase;color:var(--muted,#777);border-bottom:1px solid rgba(0,0,0,.12);padding-bottom:.35rem;margin:0 0 .8rem;}
.tp-squad-player{padding:.7rem 0;border-bottom:1px solid rgba(0,0,0,.06);}
.tp-squad-player:last-child{border-bottom:0;}
.tp-sq-head{display:flex;align-items:baseline;gap:.5rem;flex-wrap:wrap;}
.tp-sq-num{display:inline-block;min-width:1.7em;text-align:center;font-variant-numeric:tabular-nums;font-size:.76rem;color:var(--muted,#777);border:1px solid rgba(0,0,0,.15);border-radius:4px;padding:.05rem .3rem;}
.tp-sq-name{font-size:1.05rem;font-weight:600;}
.tp-squad-player.is-xi .tp-sq-name{font-weight:700;}
.tp-sq-xi{font-size:.6rem;letter-spacing:.06em;font-weight:700;color:#fff;background:var(--accent,#1f7a4d);border-radius:3px;padding:.1rem .34rem;text-transform:uppercase;}
.tp-sq-meta{font-size:.8rem;color:var(--muted,#777);margin-left:auto;}
.tp-sq-blurb{margin:.4rem 0 0;line-height:1.55;max-width:64ch;}
