/* ============================================================
   LFH — shared stylesheet (index + club pages)
   ============================================================ */
:root{
  --ink:#150d2e; --ink-2:#241548; --purple:#37003c;
  --cobalt:#00209F; --cobalt-br:#1b5cff;
  --vermilion:#D21034; --vermilion-br:#ff2244;
  --gold:#F2C14E; --mint:#00e5a0;
  --paper:#f6f7fb; --card:#fff; --text:#1a1330; --muted:#6b6685; --line:#e7e6ef;
  --line-dk:rgba(255,255,255,.12);
  /* club-themed vars, overridden per club page */
  --club:#1b5cff; --club2:#0a2e8a;
}
/* ---------- DARK MODE ---------- */
[data-theme="dark"]{
  --paper:#0c0a18; --card:#16132b; --text:#eceaf6; --muted:#9b95bd; --line:#2a2546;
}
[data-theme="dark"] body{background:var(--paper)}
[data-theme="dark"] table.standings th{background:#1c1838}
[data-theme="dark"] table.standings tbody tr:hover{background:#1f1b3d}
[data-theme="dark"] .mc-time,[data-theme="dark"] .mc-ft,[data-theme="dark"] .fr-res.up{background:#221d40}
[data-theme="dark"] .tl-item::before{border-color:var(--card)}
html{transition:none}
body,.mcard,.club-card,.news-card,.stat-card,.info-card,.player-card,.fr-row,.tcard,.vcard{transition:background .25s,border-color .25s,color .25s}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Inter',system-ui,sans-serif;background:var(--paper);color:var(--text);-webkit-font-smoothing:antialiased}
a{text-decoration:none;color:inherit}
::selection{background:var(--gold);color:var(--ink)}
.wrap{max-width:1200px;margin:0 auto;padding:0 24px}
img{max-width:100%}

/* ---------- TOP BAR ---------- */
.topbar{background:var(--ink);color:#fff}
.topbar .wrap{display:flex;align-items:center;justify-content:space-between;height:42px;font-size:12px}
.topbar .tb-left{display:flex;gap:20px;color:rgba(255,255,255,.6)}
.topbar a{color:rgba(255,255,255,.6);transition:.15s}
.topbar a:hover{color:#fff}
.topbar .tb-right{display:flex;gap:14px;align-items:center}
.lang{border:1px solid rgba(255,255,255,.2);border-radius:4px;padding:3px 9px;font-weight:600}
@media(max-width:760px){.topbar .tb-left{display:none}}

/* ---------- MAIN NAV ---------- */
header.main{background:linear-gradient(90deg,var(--purple),var(--ink) 70%);position:sticky;top:0;z-index:60}
header.main .wrap{display:flex;align-items:center;height:72px;gap:8px}
.logo{display:flex;align-items:center;gap:13px;margin-right:18px;flex-shrink:0}
.logo .crest{width:44px;height:50px;position:relative;flex-shrink:0;
  background:linear-gradient(160deg,var(--cobalt) 0 50%,var(--vermilion) 50% 100%);
  clip-path:polygon(50% 0,100% 20%,100% 72%,50% 100%,0 72%,0 20%);
  display:grid;place-items:center;box-shadow:0 0 0 2px var(--gold)}
.logo .crest b{font-family:'Archivo';font-weight:900;font-size:17px;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.5)}
.logo .lt b{font-family:'Archivo';font-weight:800;font-size:16px;color:#fff;display:block;line-height:1.05}
.logo .lt span{font-family:'Barlow Condensed';font-size:11px;letter-spacing:2.5px;color:var(--gold);text-transform:uppercase}
nav.primary{display:flex;gap:2px;height:100%;align-items:stretch;flex:1 1 auto;min-width:0}
nav.primary a{display:flex;align-items:center;padding:0 11px;color:rgba(255,255,255,.78);font-weight:600;font-size:13.5px;position:relative;transition:.15s}
nav.primary a:hover,nav.primary a.active{color:#fff}
nav.primary a.active::after{content:"";position:absolute;left:11px;right:11px;bottom:0;height:3px;background:var(--gold)}
.nav-more{position:relative;display:flex;align-items:stretch}
.nav-more-btn{display:flex;align-items:center;padding:0 11px;color:rgba(255,255,255,.78);font-weight:600;font-size:13.5px;background:none;border:none;cursor:pointer;font-family:inherit;height:100%;white-space:nowrap}
.nav-more:hover .nav-more-btn,.nav-more.active .nav-more-btn{color:#fff}
.nav-more.active .nav-more-btn::after{content:"";position:absolute;left:11px;right:11px;bottom:0;height:3px;background:var(--gold)}
.nav-more-menu{position:absolute;top:100%;right:0;background:var(--ink,#140d2e);border:1px solid rgba(255,255,255,.12);border-radius:10px;padding:6px;min-width:200px;box-shadow:0 18px 40px rgba(0,0,0,.4);opacity:0;visibility:hidden;transform:translateY(6px);transition:.16s;z-index:120;flex-direction:column}
.nav-more.open .nav-more-menu,.nav-more:hover .nav-more-menu{opacity:1;visibility:visible;transform:translateY(0)}
.nav-more-menu a{display:block;padding:10px 13px;color:rgba(255,255,255,.82);font-weight:600;font-size:13.5px;border-radius:7px;white-space:nowrap}
.nav-more-menu a:hover{background:rgba(255,255,255,.08);color:#fff}
.nav-more-menu a.active{color:var(--gold)}
.nav-cta{margin-left:18px;padding-left:16px;border-left:1px solid rgba(255,255,255,.12);display:flex;align-items:center;gap:10px;flex:0 0 auto}
.btn{font-weight:700;font-size:13px;padding:10px 18px;border-radius:6px;cursor:pointer;border:none;transition:.16s;
  display:inline-flex;align-items:center;gap:7px;font-family:inherit}
.btn-gold{background:var(--gold);color:var(--ink)}.btn-gold:hover{background:#ffd061}
.btn-line{background:transparent;border:1px solid rgba(255,255,255,.25);color:#fff}
.btn-line:hover{border-color:var(--gold);color:var(--gold)}
.burger{display:none;flex-direction:column;gap:4px;cursor:pointer;padding:8px}
.burger span{width:22px;height:2px;background:#fff;border-radius:2px}
@media(max-width:900px){nav.primary{display:none}.burger{display:flex}.nav-cta .btn-line{display:none}}

/* ---------- GENERIC SECTION ---------- */
section{padding:56px 0}
.sec-head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:26px;flex-wrap:wrap;gap:12px}
.sec-head h2{font-family:'Archivo';font-weight:900;font-size:clamp(24px,3.4vw,34px);letter-spacing:-.5px;display:flex;align-items:center;gap:14px}
.sec-head h2::before{content:"";width:6px;height:30px;background:var(--vermilion);border-radius:3px}
.sec-head .more{font-weight:700;font-size:14px;color:var(--cobalt-br);display:flex;align-items:center;gap:6px;transition:.15s}
.sec-head .more:hover{gap:10px}

/* tabs */
.tabs{display:flex;gap:6px;margin-bottom:22px;border-bottom:2px solid var(--line);flex-wrap:wrap}
.tab{font-weight:700;font-size:14px;padding:12px 18px;cursor:pointer;color:var(--muted);position:relative;border:none;background:none;transition:.15s;font-family:inherit}
.tab:hover{color:var(--text)}.tab.on{color:var(--text)}
.tab.on::after{content:"";position:absolute;left:0;right:0;bottom:-2px;height:3px;background:var(--vermilion)}

/* ---------- HERO HUB (index) ---------- */
.hero{background:linear-gradient(120deg,var(--purple),var(--ink) 55%,#1a0e3a);color:#fff;position:relative;overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;opacity:.5;
  background:radial-gradient(60% 90% at 85% 0%,rgba(27,92,255,.35),transparent 60%),
            radial-gradient(50% 80% at 10% 100%,rgba(210,16,52,.28),transparent 60%)}
.hero .wrap{position:relative;z-index:2;padding:36px 24px 48px}
.hero-top{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:24px;flex-wrap:wrap;gap:10px}
.hero-top h1{font-family:'Archivo';font-weight:900;font-size:clamp(26px,4vw,40px);letter-spacing:-.5px}
.hero-top .gw{font-family:'Barlow Condensed';font-weight:700;font-size:15px;letter-spacing:2px;text-transform:uppercase;
  color:var(--gold);display:flex;align-items:center;gap:8px}
.hero-top .gw .dot{width:8px;height:8px;border-radius:50%;background:var(--mint);box-shadow:0 0 10px var(--mint)}
.hero-grid{display:grid;grid-template-columns:1.6fr 1fr;gap:22px}
@media(max-width:880px){.hero-grid{grid-template-columns:1fr}}

.feature{background:rgba(255,255,255,.06);border:1px solid var(--line-dk);border-radius:16px;overflow:hidden;backdrop-filter:blur(4px)}
.feature .fh{display:flex;justify-content:space-between;align-items:center;padding:14px 20px;background:rgba(0,0,0,.2);
  border-bottom:1px solid var(--line-dk);font-size:12px;font-weight:600;color:rgba(255,255,255,.7)}
.feature .fh .live{background:var(--vermilion);color:#fff;padding:3px 10px;border-radius:4px;font-weight:800;letter-spacing:1px;display:flex;align-items:center;gap:6px}
.feature .fh .live::before{content:"";width:7px;height:7px;border-radius:50%;background:#fff;animation:pulse 1.2s infinite}
@keyframes pulse{50%{opacity:.3}}
.feature .fbody{display:flex;align-items:center;justify-content:center;gap:18px;padding:34px 20px}
.fteam{display:flex;flex-direction:column;align-items:center;gap:12px;flex:1;max-width:180px}
.badge{width:64px;height:64px;border-radius:14px;display:grid;place-items:center;font-family:'Archivo';font-weight:900;font-size:22px;color:#fff;box-shadow:0 8px 20px rgba(0,0,0,.3)}
.fteam b{font-weight:700;font-size:16px;text-align:center}.fteam small{color:rgba(255,255,255,.55);font-size:12px}
.fscore{text-align:center}
.fscore .sc{font-family:'Archivo';font-weight:900;font-size:54px;line-height:1;letter-spacing:2px}
.fscore .min{font-family:'Barlow Condensed';font-size:14px;color:var(--mint);font-weight:700;margin-top:6px}
.feature .ff{padding:14px 20px;border-top:1px solid var(--line-dk);display:flex;justify-content:space-between;align-items:center;font-size:13px;color:rgba(255,255,255,.6)}
.feature .ff .scorers{display:flex;flex-direction:column;gap:2px;font-size:12px}
.feature .ff .scorers span{color:rgba(255,255,255,.8)}

.mini-standings{background:rgba(255,255,255,.06);border:1px solid var(--line-dk);border-radius:16px;overflow:hidden}
.mini-standings .mh{padding:14px 18px;font-weight:700;font-size:14px;border-bottom:1px solid var(--line-dk);display:flex;justify-content:space-between;align-items:center}
.mini-standings .mh a{color:var(--gold);font-size:12px;font-weight:600}
.mini-row{display:flex;align-items:center;gap:10px;padding:9px 18px;font-size:13px;border-bottom:1px solid rgba(255,255,255,.05);transition:.12s}
.mini-row:last-child{border:none}.mini-row:hover{background:rgba(255,255,255,.05)}
.mini-row .pos{width:18px;font-weight:700;color:rgba(255,255,255,.6);font-size:12px}
.mini-row .md{width:18px;height:18px;border-radius:5px;flex-shrink:0}
.mini-row .nm{flex:1;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:#fff}
.mini-row .pl{color:rgba(255,255,255,.5);font-size:12px;width:24px;text-align:center}
.mini-row .pt{font-weight:800;width:26px;text-align:right;color:var(--gold)}
.mini-row.cl{box-shadow:inset 3px 0 0 var(--mint)}

/* sponsor strip */
.strip{background:var(--ink);color:rgba(255,255,255,.4)}
.strip .wrap{display:flex;align-items:center;justify-content:center;gap:48px;padding:26px 24px;flex-wrap:wrap;
  font-family:'Barlow Condensed';font-weight:700;font-size:18px;letter-spacing:2px;text-transform:uppercase}
.strip span{opacity:.6;transition:.15s}.strip span:hover{opacity:1;color:var(--gold)}

/* ---------- MATCH CARDS ---------- */
.match-day{margin-bottom:26px}
.md-label{font-family:'Barlow Condensed';font-weight:700;font-size:15px;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);margin-bottom:12px;display:flex;align-items:center;gap:10px}
.md-label::after{content:"";flex:1;height:1px;background:var(--line)}
.matches{display:grid;grid-template-columns:repeat(auto-fill,minmax(330px,1fr));gap:14px}
.mcard{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:16px 18px;transition:.16s;cursor:pointer;display:block}
.mcard:hover{border-color:var(--cobalt-br);box-shadow:0 8px 24px rgba(27,92,255,.1);transform:translateY(-2px)}
.mcard .mc-top{display:flex;justify-content:space-between;font-size:11px;color:var(--muted);margin-bottom:14px;font-weight:600}
.mc-team{display:flex;align-items:center;gap:11px;margin:7px 0}
.mc-team .mb{width:30px;height:30px;border-radius:7px;flex-shrink:0;display:grid;place-items:center;font-family:'Archivo';font-weight:800;font-size:12px;color:#fff}
.mc-team .mn{flex:1;font-weight:600;font-size:15px}
.mc-team .mg{font-family:'Archivo';font-weight:900;font-size:20px;width:30px;text-align:center}
.mc-team.win .mn{font-weight:800}.mc-team.lose{opacity:.5}
.mc-time{text-align:center;padding:6px 0;margin:4px 0;border-radius:8px;background:var(--paper);font-family:'Barlow Condensed';font-weight:700;font-size:18px;letter-spacing:1px}
.mc-ft{display:inline-block;font-size:10px;font-weight:800;color:var(--muted);background:var(--paper);padding:2px 8px;border-radius:4px;letter-spacing:1px;margin-top:6px}

/* ---------- STANDINGS ---------- */
.stand-wrap{background:var(--card);border:1px solid var(--line);border-radius:14px;overflow:hidden;overflow-x:auto}
table.standings{width:100%;border-collapse:collapse;min-width:680px}
table.standings th{font-family:'Barlow Condensed';font-weight:700;font-size:13px;letter-spacing:1px;text-transform:uppercase;color:var(--muted);padding:14px 10px;text-align:center;border-bottom:2px solid var(--line);background:#fafaff}
table.standings th.l,table.standings td.l{text-align:left}
table.standings td{padding:13px 10px;text-align:center;font-size:14px;border-bottom:1px solid var(--line);font-weight:500}
table.standings tr:last-child td{border-bottom:none}
table.standings tbody tr{transition:.12s;cursor:pointer}
table.standings tbody tr:hover{background:#f7f8ff}
.st-pos{font-family:'Archivo';font-weight:800;width:40px;position:relative}
.st-team{display:flex;align-items:center;gap:12px;font-weight:700;min-width:200px}
.st-team .md2{width:26px;height:26px;border-radius:7px;flex-shrink:0;display:grid;place-items:center;color:#fff;font-family:'Archivo';font-weight:800;font-size:10px}
.st-pts{font-family:'Archivo';font-weight:900;font-size:16px}
.st-form{display:flex;gap:4px;justify-content:center}
.fp{width:20px;height:20px;border-radius:5px;font-size:10px;font-weight:900;display:grid;place-items:center;color:#fff}
.fp.W{background:#16a34a}.fp.D{background:#94a3b8}.fp.L{background:var(--vermilion)}
.zone{position:absolute;left:0;top:0;bottom:0;width:4px}
.z-champ{background:var(--mint)}.z-play{background:var(--cobalt-br)}.z-rel{background:var(--vermilion)}
.legend{display:flex;gap:20px;margin-top:14px;flex-wrap:wrap;font-size:12px;color:var(--muted)}
.legend span{display:flex;align-items:center;gap:7px}
.legend i{width:12px;height:12px;border-radius:3px;display:inline-block}

/* ---------- STATS LEADERS ---------- */
.stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:18px}
.stat-card{background:var(--card);border:1px solid var(--line);border-radius:14px;overflow:hidden}
.stat-card .sch{padding:16px 20px;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:10px;background:linear-gradient(90deg,var(--purple),var(--ink));color:#fff}
.stat-card .sch .ico{font-size:20px}.stat-card .sch b{font-weight:800;font-size:15px}
.stat-card .sch span{margin-left:auto;font-family:'Barlow Condensed';font-size:12px;letter-spacing:1px;color:var(--gold);text-transform:uppercase}
.lead-row{display:flex;align-items:center;gap:12px;padding:13px 20px;border-bottom:1px solid var(--line)}
.lead-row:last-child{border:none}
.lead-row .rk{font-family:'Archivo';font-weight:900;width:22px;color:var(--muted);font-size:14px}
.lead-row .rk.one{color:var(--gold)}
.lead-row .pa{width:36px;height:36px;border-radius:9px;flex-shrink:0;display:grid;place-items:center;color:#fff;font-family:'Archivo';font-weight:800;font-size:13px}
.lead-row .pi{flex:1;min-width:0}
.lead-row .pi b{font-size:14px;font-weight:700;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.lead-row .pi span{font-size:12px;color:var(--muted)}
.lead-row .val{font-family:'Archivo';font-weight:900;font-size:22px;color:var(--vermilion)}
.lead-row.one{background:linear-gradient(90deg,rgba(242,193,78,.1),transparent)}

/* ---------- NEWS ---------- */
.news-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:18px}
.news-card{background:var(--card);border:1px solid var(--line);border-radius:14px;overflow:hidden;transition:.16s;cursor:pointer}
.news-card:hover{transform:translateY(-3px);box-shadow:0 14px 34px rgba(20,13,46,.12)}
.news-img{height:160px;position:relative;display:grid;place-items:center;overflow:hidden}
.news-img .tag{position:absolute;top:12px;left:12px;font-size:11px;font-weight:800;letter-spacing:1px;text-transform:uppercase;background:var(--gold);color:var(--ink);padding:4px 10px;border-radius:5px}
.news-img .ico{font-size:46px;opacity:.85}
.news-body{padding:16px 18px}
.news-body .nt{font-weight:800;font-size:16px;line-height:1.3;margin-bottom:8px}
.news-body .nd{font-size:13px;color:var(--muted);line-height:1.5}
.news-body .nm{margin-top:12px;font-size:11px;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.5px}
.news-lead{grid-column:span 2;display:grid;grid-template-columns:1fr 1fr}
.news-lead .news-img{height:100%}
@media(max-width:760px){.news-lead{grid-column:span 1;grid-template-columns:1fr}.news-lead .news-img{height:160px}}

/* ---------- CLUBS GRID ---------- */
.clubs-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:14px}
.club-card{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:22px 18px;text-align:center;transition:.18s;cursor:pointer;position:relative;overflow:hidden;display:block;color:inherit}
.club-card::before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--cc,#888)}
.club-card:hover{transform:translateY(-4px);box-shadow:0 16px 34px rgba(20,13,46,.14)}
.club-card .cb{width:60px;height:60px;border-radius:16px;margin:0 auto 14px;display:grid;place-items:center;color:#fff;font-family:'Archivo';font-weight:900;font-size:20px}
.club-card b{font-size:15px;display:block;margin-bottom:3px}
.club-card small{color:var(--muted);font-size:12px;display:block}
.club-card .meta{margin-top:12px;padding-top:12px;border-top:1px solid var(--line);font-size:11px;color:var(--muted);display:flex;justify-content:space-between}
.club-card .meta b{font-size:14px;color:var(--text);display:inline}

/* ---------- FOOTER ---------- */
footer{background:linear-gradient(160deg,var(--purple),var(--ink));color:#fff;padding:54px 0 28px}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:36px;margin-bottom:40px}
@media(max-width:760px){.foot-grid{grid-template-columns:1fr 1fr}}
.foot-grid p{color:rgba(255,255,255,.6);font-size:14px;line-height:1.6;margin-top:14px;max-width:300px}
.foot-col h4{font-family:'Barlow Condensed';font-weight:700;font-size:13px;letter-spacing:2px;text-transform:uppercase;color:var(--gold);margin-bottom:14px}
.foot-col a{display:block;color:rgba(255,255,255,.6);font-size:14px;padding:5px 0;transition:.15s}
.foot-col a:hover{color:#fff;padding-left:4px}
.foot-base{border-top:1px solid rgba(255,255,255,.12);padding-top:22px;display:flex;justify-content:space-between;color:rgba(255,255,255,.5);font-size:13px;flex-wrap:wrap;gap:10px}
.socials{display:flex;gap:10px}
.socials a{width:36px;height:36px;border-radius:9px;background:rgba(255,255,255,.08);display:grid;place-items:center;transition:.15s}
.socials a:hover{background:var(--gold);color:var(--ink)}

/* ============================================================
   CLUB PAGE specific
   ============================================================ */
.club-hero{background:linear-gradient(120deg,var(--club2),var(--ink) 75%);color:#fff;position:relative;overflow:hidden}
.club-hero::before{content:"";position:absolute;inset:0;opacity:.55;background:radial-gradient(50% 90% at 90% 10%,var(--club),transparent 60%)}
.club-hero::after{content:"";position:absolute;right:-60px;top:-40px;font-size:380px;font-family:'Archivo';font-weight:900;
  opacity:.06;line-height:1;content:attr(data-mono)}
.club-hero .wrap{position:relative;z-index:2;padding:30px 24px 40px}
.breadcrumb{font-size:13px;color:rgba(255,255,255,.6);margin-bottom:24px;display:flex;gap:8px;align-items:center}
.breadcrumb a:hover{color:var(--gold)}
.ch-main{display:flex;align-items:center;gap:26px;flex-wrap:wrap}
.ch-crest{width:108px;height:108px;border-radius:26px;display:grid;place-items:center;color:#fff;font-family:'Archivo';font-weight:900;font-size:40px;
  box-shadow:0 16px 40px rgba(0,0,0,.4);flex-shrink:0;border:3px solid rgba(255,255,255,.15)}
.ch-info h1{font-family:'Archivo';font-weight:900;font-size:clamp(30px,5vw,52px);letter-spacing:-1px;line-height:1}
.ch-info .nick{font-family:'Barlow Condensed';font-size:18px;letter-spacing:2px;text-transform:uppercase;color:var(--gold);margin-top:6px}
.ch-info .sub{color:rgba(255,255,255,.7);margin-top:10px;font-size:15px;display:flex;gap:18px;flex-wrap:wrap}
.ch-info .sub span{display:flex;align-items:center;gap:6px}
.ch-stats{display:flex;gap:14px;margin-top:30px;flex-wrap:wrap}
.ch-stat{background:rgba(255,255,255,.08);border:1px solid var(--line-dk);border-radius:12px;padding:16px 22px;min-width:110px}
.ch-stat b{font-family:'Archivo';font-weight:900;font-size:30px;display:block;line-height:1}
.ch-stat small{font-family:'Barlow Condensed';font-size:12px;letter-spacing:1.5px;text-transform:uppercase;color:rgba(255,255,255,.6)}

/* club sub-nav */
.club-subnav{background:#fff;border-bottom:1px solid var(--line);position:sticky;top:72px;z-index:50}
.club-subnav .wrap{display:flex;gap:4px;overflow-x:auto}
.club-subnav a{padding:16px 18px;font-weight:700;font-size:14px;color:var(--muted);white-space:nowrap;border-bottom:3px solid transparent;transition:.15s}
.club-subnav a:hover{color:var(--text)}
.club-subnav a.on{color:var(--text);border-bottom-color:var(--club)}

/* squad */
.pos-group{margin-bottom:30px}
.pos-title{font-family:'Barlow Condensed';font-weight:700;font-size:16px;letter-spacing:2px;text-transform:uppercase;color:var(--club);margin-bottom:14px;display:flex;align-items:center;gap:10px}
.pos-title::after{content:"";flex:1;height:2px;background:var(--line)}
.squad-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:14px}
.player-card{background:var(--card);border:1px solid var(--line);border-radius:14px;overflow:hidden;transition:.16s;cursor:pointer}
.player-card:hover{transform:translateY(-3px);box-shadow:0 12px 28px rgba(20,13,46,.12);border-color:var(--club)}
.pc-top{height:84px;background:linear-gradient(135deg,var(--club),var(--club2));position:relative;display:flex;align-items:flex-end;justify-content:space-between;padding:12px 16px}
.pc-top .num{font-family:'Archivo';font-weight:900;font-size:44px;color:rgba(255,255,255,.85);line-height:.8}
.pc-top .cap{position:absolute;top:12px;right:14px;background:var(--gold);color:var(--ink);font-size:10px;font-weight:900;padding:3px 7px;border-radius:4px;letter-spacing:.5px}
.pc-top .flag{font-size:22px}
.pc-body{padding:14px 16px}
.pc-body .pn{font-weight:800;font-size:15px;line-height:1.2}
.pc-body .pmeta{display:flex;justify-content:space-between;margin-top:8px;font-size:12px;color:var(--muted)}
.pc-body .pmeta b{color:var(--club);font-weight:700}

/* club fixtures/results list */
.fr-list{display:flex;flex-direction:column;gap:10px}
.fr-row{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:14px 18px;display:grid;
  grid-template-columns:90px 1fr auto;align-items:center;gap:16px;transition:.14s}
.fr-row:hover{border-color:var(--club)}
.fr-date{font-size:12px;color:var(--muted);font-weight:600;line-height:1.4}
.fr-date b{display:block;color:var(--text);font-size:13px}
.fr-match{display:flex;align-items:center;gap:12px}
.fr-match .ha{font-weight:700;font-size:15px}
.fr-match .vs{font-family:'Barlow Condensed';font-weight:700;color:var(--muted);font-size:13px;padding:0 4px}
.fr-match .opp-badge{width:26px;height:26px;border-radius:7px;display:grid;place-items:center;color:#fff;font-family:'Archivo';font-weight:800;font-size:10px}
.fr-res{font-family:'Archivo';font-weight:900;font-size:18px;padding:6px 14px;border-radius:8px;color:#fff;min-width:64px;text-align:center}
.fr-res.win{background:#16a34a}.fr-res.draw{background:#94a3b8}.fr-res.loss{background:var(--vermilion)}
.fr-res.up{background:var(--paper);color:var(--text);font-family:'Barlow Condensed';font-size:16px}
.fr-tag{font-size:11px;font-weight:700;color:var(--muted)}
@media(max-width:560px){.fr-row{grid-template-columns:1fr auto}.fr-date{display:none}}

/* stadium / about cards */
.info-grid{display:grid;grid-template-columns:1.3fr 1fr;gap:20px}
@media(max-width:760px){.info-grid{grid-template-columns:1fr}}
.info-card{background:var(--card);border:1px solid var(--line);border-radius:14px;overflow:hidden}
.info-card .ich{height:160px;background:linear-gradient(135deg,var(--club),var(--club2));display:grid;place-items:center;color:rgba(255,255,255,.9);font-size:60px;position:relative}
.info-card .ich .pitch-ico{font-size:64px}
.info-card .icb{padding:22px}
.info-card .icb h3{font-family:'Archivo';font-weight:800;font-size:20px;margin-bottom:6px}
.info-card .icb p{color:var(--muted);font-size:14px;line-height:1.6}
.spec-list{list-style:none;margin-top:16px}
.spec-list li{display:flex;justify-content:space-between;padding:11px 0;border-bottom:1px solid var(--line);font-size:14px}
.spec-list li:last-child{border:none}
.spec-list li span{color:var(--muted)}.spec-list li b{font-weight:700}

/* history timeline */
.timeline{position:relative;padding-left:28px}
.timeline::before{content:"";position:absolute;left:7px;top:6px;bottom:6px;width:2px;background:var(--line)}
.tl-item{position:relative;padding-bottom:22px}
.tl-item::before{content:"";position:absolute;left:-26px;top:4px;width:14px;height:14px;border-radius:50%;background:var(--club);border:3px solid #fff;box-shadow:0 0 0 2px var(--line)}
.tl-item .yr{font-family:'Archivo';font-weight:900;font-size:15px;color:var(--club)}
.tl-item .tx{font-size:14px;color:var(--text);margin-top:2px}

.section-pad-sm{padding:40px 0}
.muted-note{font-size:12px;color:var(--muted);margin-top:16px;font-style:italic}
.hidden{display:none}

/* ============================================================
   PL-STYLE ADDITIONS: theme toggle, magazine, sponsors, players,
   transfers, video, mobile drawer
   ============================================================ */

/* theme toggle */
.theme-toggle{width:38px;height:38px;border-radius:10px;border:1px solid rgba(255,255,255,.2);background:transparent;
  color:#fff;cursor:pointer;display:grid;place-items:center;font-size:17px;transition:.15s;flex-shrink:0}
.theme-toggle:hover{border-color:var(--gold);color:var(--gold)}

/* full nav: allow more items, scroll on mobile */
nav.primary{overflow-x:auto;scrollbar-width:none}
nav.primary::-webkit-scrollbar{display:none}
nav.primary a{white-space:nowrap}

/* mobile drawer */
.drawer{position:fixed;inset:0;z-index:200;background:var(--ink);transform:translateX(100%);transition:transform .28s;
  display:flex;flex-direction:column;padding:24px;overflow-y:auto}
.drawer.open{transform:none}
.drawer .dx{align-self:flex-end;font-size:30px;color:#fff;background:none;border:none;cursor:pointer;line-height:1}
.drawer a{color:#fff;font-family:'Archivo';font-weight:800;font-size:22px;padding:14px 0;border-bottom:1px solid rgba(255,255,255,.08)}
.drawer a:hover{color:var(--gold)}

/* generic page header (non-home pages) */
.page-head{background:linear-gradient(120deg,var(--purple),var(--ink) 60%);color:#fff;padding:40px 0;position:relative;overflow:hidden}
.page-head::before{content:"";position:absolute;inset:0;opacity:.4;background:radial-gradient(60% 100% at 90% 0%,rgba(27,92,255,.4),transparent 60%)}
.page-head .wrap{position:relative;z-index:2}
.page-head h1{font-family:'Archivo';font-weight:900;font-size:clamp(28px,5vw,46px);letter-spacing:-1px}
.page-head p{color:rgba(255,255,255,.7);margin-top:8px;font-size:16px;max-width:560px}
.page-head .breadcrumb{margin-bottom:18px}

/* ---------- TIERED SPONSOR RAIL ---------- */
.sponsor-rail{background:var(--card);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.sponsor-rail .wrap{display:flex;gap:14px;padding:26px 24px;flex-wrap:wrap;justify-content:center}
.sponsor-tier{text-align:center;min-width:130px;flex:1;max-width:180px}
.sponsor-tier .tlbl{font-family:'Barlow Condensed';font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);margin-bottom:8px}
.sponsor-tier .tname{font-family:'Archivo';font-weight:900;font-size:20px;letter-spacing:-.5px;color:var(--text);
  padding:10px;border-radius:10px;background:var(--paper);transition:.15s}
.sponsor-tier:hover .tname{color:var(--cobalt-br)}

/* ---------- MAGAZINE GRID ---------- */
.mag-grid{display:grid;grid-template-columns:2fr 1fr 1fr;grid-auto-rows:1fr;gap:18px}
.mag{position:relative;border-radius:16px;overflow:hidden;color:#fff;min-height:200px;display:flex;flex-direction:column;
  justify-content:flex-end;padding:24px;cursor:pointer;transition:.18s}
.mag:hover{transform:translateY(-3px);box-shadow:0 18px 40px rgba(20,13,46,.2)}
.mag.big{grid-row:span 2;grid-column:span 1;min-height:420px}
.mag .mag-bg{position:absolute;inset:0;z-index:0}
.mag .mag-ico{position:absolute;top:20px;right:22px;font-size:38px;opacity:.85;z-index:1}
.mag .mag-c{position:relative;z-index:2}
.mag .mk{font-family:'Barlow Condensed';font-weight:700;font-size:12px;letter-spacing:2px;text-transform:uppercase;
  color:var(--gold);margin-bottom:8px}
.mag .mt{font-family:'Archivo';font-weight:900;line-height:1.05;letter-spacing:-.5px;font-size:20px}
.mag.big .mt{font-size:34px}
.mag .md2{color:rgba(255,255,255,.85);font-size:14px;margin-top:10px;line-height:1.45}
.mag.big .md2{font-size:16px}
@media(max-width:880px){.mag-grid{grid-template-columns:1fr 1fr}.mag.big{grid-column:span 2;grid-row:auto;min-height:300px}}
@media(max-width:560px){.mag-grid{grid-template-columns:1fr}.mag.big{grid-column:span 1}}

/* row of section blocks on home */
.home-section{padding:46px 0}
.home-section.alt{background:var(--card);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}

/* ---------- PLAYERS PAGE ---------- */
.filters{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:24px;align-items:center}
.filters input,.filters select{font-family:inherit;font-size:14px;padding:11px 14px;border-radius:10px;border:1px solid var(--line);
  background:var(--card);color:var(--text);outline:none;transition:.15s}
.filters input{flex:1;min-width:200px}
.filters input:focus,.filters select:focus{border-color:var(--cobalt-br)}
.filters .count{margin-left:auto;font-size:13px;color:var(--muted);font-weight:600}
.players-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px}
.pl-card{background:var(--card);border:1px solid var(--line);border-radius:14px;overflow:hidden;cursor:pointer;transition:.16s;display:flex;align-items:center;gap:14px;padding:14px}
.pl-card:hover{transform:translateY(-2px);box-shadow:0 10px 24px rgba(20,13,46,.1);border-color:var(--cc,var(--cobalt-br))}
.pl-card .plnum{width:46px;height:46px;border-radius:12px;flex-shrink:0;display:grid;place-items:center;color:#fff;font-family:'Archivo';font-weight:900;font-size:18px}
.pl-card .plinfo{flex:1;min-width:0}
.pl-card .plinfo b{font-size:15px;font-weight:700;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.pl-card .plinfo span{font-size:12px;color:var(--muted)}
.pl-card .plpos{font-family:'Barlow Condensed';font-weight:700;font-size:12px;letter-spacing:1px;color:var(--cc,var(--cobalt-br));text-transform:uppercase}

/* ---------- TRANSFERS PAGE ---------- */
.transfers-list{display:flex;flex-direction:column;gap:10px}
.tcard{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:16px 18px;display:grid;
  grid-template-columns:auto 1fr auto;gap:16px;align-items:center;transition:.14s}
.tcard:hover{border-color:var(--cobalt-br)}
.tcard .tin{width:30px;height:30px;border-radius:8px;display:grid;place-items:center;font-size:15px;flex-shrink:0;
  background:rgba(0,229,160,.15);color:#0a8a4a;font-weight:900}
[data-theme="dark"] .tcard .tin{color:var(--mint)}
.tcard .tbody{min-width:0}
.tcard .tname{font-weight:800;font-size:16px}
.tcard .tmove{display:flex;align-items:center;gap:8px;margin-top:5px;font-size:13px;color:var(--muted);flex-wrap:wrap}
.tcard .tclub{display:inline-flex;align-items:center;gap:6px;font-weight:600;color:var(--text)}
.tcard .tclub .tb{width:18px;height:18px;border-radius:5px;display:inline-grid;place-items:center;color:#fff;font-size:8px;font-family:'Archivo';font-weight:800}
.tcard .arrow{color:var(--cobalt-br);font-weight:900}
.tcard .tmeta{text-align:right;flex-shrink:0}
.tcard .tfee{font-family:'Archivo';font-weight:900;font-size:14px;color:var(--text)}
.tcard .tdate{font-size:12px;color:var(--muted);margin-top:3px}
@media(max-width:560px){.tcard{grid-template-columns:auto 1fr}.tcard .tmeta{grid-column:2;text-align:left}}

/* ---------- VIDEO PAGE ---------- */
.video-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:18px}
.vcard{background:var(--card);border:1px solid var(--line);border-radius:14px;overflow:hidden;cursor:pointer;transition:.16s}
.vcard:hover{transform:translateY(-3px);box-shadow:0 14px 34px rgba(20,13,46,.14)}
.vcard.feat{grid-column:span 2}
.vthumb{position:relative;aspect-ratio:16/9;display:grid;place-items:center;overflow:hidden}
.vcard.feat .vthumb{aspect-ratio:21/9}
.vthumb .vplay{width:56px;height:56px;border-radius:50%;background:rgba(255,255,255,.9);display:grid;place-items:center;
  color:var(--ink);font-size:22px;padding-left:4px;transition:.15s;box-shadow:0 6px 18px rgba(0,0,0,.3)}
.vcard:hover .vplay{transform:scale(1.1);background:var(--gold)}
.vthumb .vdur{position:absolute;bottom:10px;right:10px;background:rgba(0,0,0,.8);color:#fff;font-size:12px;font-weight:700;padding:3px 8px;border-radius:5px}
.vthumb .vcat{position:absolute;top:10px;left:10px;background:var(--gold);color:var(--ink);font-size:10px;font-weight:800;letter-spacing:1px;text-transform:uppercase;padding:4px 9px;border-radius:5px}
.vbody{padding:14px 16px}
.vbody .vt{font-weight:800;font-size:15px;line-height:1.3}
.vcard.feat .vbody .vt{font-size:19px}
.vbody .vm{margin-top:8px;font-size:12px;color:var(--muted);display:flex;gap:12px}
@media(max-width:760px){.vcard.feat{grid-column:span 1}.vcard.feat .vthumb{aspect-ratio:16/9}}

/* compact-preview "see all" link under homepage standings */
.see-all-link{display:inline-flex;align-items:center;gap:8px;margin-top:16px;font-weight:700;font-size:14px;
  color:var(--cobalt-br);transition:.15s}
.see-all-link:hover{gap:12px}

/* ============================================================
   PLAYER PROFILE PAGE
   ============================================================ */
.player-hero{background:linear-gradient(120deg,var(--club2),var(--ink) 75%);color:#fff;position:relative;overflow:hidden}
.player-hero::before{content:"";position:absolute;inset:0;opacity:.5;background:radial-gradient(50% 90% at 88% 8%,var(--club),transparent 60%)}
.player-hero::after{content:attr(data-num);position:absolute;right:-30px;top:-70px;font-family:'Archivo';font-weight:900;
  font-size:340px;line-height:1;opacity:.07;color:#fff}
.player-hero .wrap{position:relative;z-index:2;padding:30px 24px 40px}
.ph-main{display:flex;align-items:flex-end;gap:28px;flex-wrap:wrap}
.ph-shirt{width:120px;height:120px;border-radius:24px;flex-shrink:0;display:grid;place-items:center;color:#fff;
  font-family:'Archivo';font-weight:900;font-size:54px;box-shadow:0 16px 40px rgba(0,0,0,.4);border:3px solid rgba(255,255,255,.15)}
.ph-info .ph-club{display:inline-flex;align-items:center;gap:8px;font-weight:600;font-size:14px;color:rgba(255,255,255,.8);margin-bottom:8px}
.ph-info .ph-club .pcb{width:22px;height:22px;border-radius:6px;display:grid;place-items:center;color:#fff;font-size:9px;font-family:'Archivo';font-weight:800}
.ph-info h1{font-family:'Archivo';font-weight:900;font-size:clamp(30px,5vw,52px);letter-spacing:-1px;line-height:1}
.ph-info .ph-sub{color:rgba(255,255,255,.7);margin-top:10px;font-size:15px;display:flex;gap:18px;flex-wrap:wrap}
.ph-info .ph-sub span{display:flex;align-items:center;gap:6px}
.ph-info .ph-cap{display:inline-block;margin-left:10px;background:var(--gold);color:var(--ink);font-size:12px;font-weight:900;padding:3px 9px;border-radius:5px;vertical-align:middle}
.ph-stats{display:flex;gap:14px;margin-top:30px;flex-wrap:wrap}
.ph-stat{background:rgba(255,255,255,.08);border:1px solid var(--line-dk);border-radius:12px;padding:16px 22px;min-width:96px}
.ph-stat b{font-family:'Archivo';font-weight:900;font-size:30px;display:block;line-height:1}
.ph-stat small{font-family:'Barlow Condensed';font-size:12px;letter-spacing:1.5px;text-transform:uppercase;color:rgba(255,255,255,.6)}
.bio-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}
@media(max-width:760px){.bio-grid{grid-template-columns:1fr}}
.teammates{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px}

/* ============================================================
   HOMEPAGE FEATURE BLOCKS: ticker, countdown, spotlight, TOTW, marquee
   ============================================================ */

/* --- transfers ticker --- */
.ticker{background:var(--ink);color:#fff;overflow:hidden;position:relative;border-bottom:1px solid var(--line-dk)}
.ticker .tk-label{position:absolute;left:0;top:0;bottom:0;z-index:3;display:flex;align-items:center;gap:8px;
  background:var(--vermilion);padding:0 18px;font-family:'Barlow Condensed';font-weight:700;font-size:14px;
  letter-spacing:1.5px;text-transform:uppercase;white-space:nowrap}
.ticker .tk-label::before{content:"";width:8px;height:8px;border-radius:50%;background:#fff;animation:pulse 1.2s infinite}
.ticker .tk-track{display:flex;gap:34px;white-space:nowrap;padding:12px 0 12px 160px;animation:scroll-x 38s linear infinite;width:max-content}
.ticker:hover .tk-track{animation-play-state:paused}
.ticker .tk-item{display:inline-flex;align-items:center;gap:9px;font-size:14px}
.ticker .tk-item .tkb{width:20px;height:20px;border-radius:5px;display:grid;place-items:center;color:#fff;font-size:9px;font-family:'Archivo';font-weight:800}
.ticker .tk-item b{font-weight:700}
.ticker .tk-item .tkar{color:var(--mint);font-weight:900}
.ticker .tk-item .tko{color:rgba(255,255,255,.55)}
@keyframes scroll-x{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* --- countdown --- */
.countdown{display:flex;align-items:center;justify-content:center;gap:22px;flex-wrap:wrap;
  background:linear-gradient(120deg,var(--purple),var(--ink));color:#fff;border-radius:16px;padding:24px 28px;margin-bottom:8px}
.countdown .cd-l{font-family:'Barlow Condensed';font-weight:700;letter-spacing:1.5px;text-transform:uppercase;font-size:14px;color:var(--gold)}
.countdown .cd-l b{display:block;font-family:'Archivo';font-weight:900;font-size:22px;color:#fff;letter-spacing:0;text-transform:none}
.cd-clock{display:flex;gap:12px}
.cd-unit{background:rgba(255,255,255,.08);border:1px solid var(--line-dk);border-radius:10px;padding:12px 16px;min-width:72px;text-align:center}
.cd-unit b{font-family:'Archivo';font-weight:900;font-size:30px;display:block;line-height:1;font-variant-numeric:tabular-nums}
.cd-unit small{font-family:'Barlow Condensed';font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:rgba(255,255,255,.6)}
.cd-cta{margin-left:auto}
@media(max-width:680px){.cd-cta{margin:0}.countdown{gap:16px}}

/* --- player spotlight --- */
.spotlight{display:grid;grid-template-columns:300px 1fr;gap:0;border-radius:18px;overflow:hidden;border:1px solid var(--line);background:var(--card)}
.spotlight .sp-vis{position:relative;background:linear-gradient(150deg,var(--club),var(--club2));display:flex;align-items:flex-end;justify-content:center;min-height:260px;overflow:hidden}
.spotlight .sp-vis .sp-num{position:absolute;top:-30px;right:-10px;font-family:'Archivo';font-weight:900;font-size:220px;line-height:1;color:rgba(255,255,255,.13)}
.spotlight .sp-vis .sp-shirt{width:120px;height:120px;border-radius:24px;background:rgba(255,255,255,.12);border:2px solid rgba(255,255,255,.25);
  display:grid;place-items:center;font-family:'Archivo';font-weight:900;font-size:52px;color:#fff;margin-bottom:30px;backdrop-filter:blur(4px)}
.spotlight .sp-body{padding:30px 32px;display:flex;flex-direction:column;justify-content:center}
.spotlight .sp-tag{display:inline-flex;align-items:center;gap:8px;align-self:flex-start;background:var(--gold);color:var(--ink);
  font-family:'Barlow Condensed';font-weight:700;font-size:12px;letter-spacing:2px;text-transform:uppercase;padding:5px 12px;border-radius:6px;margin-bottom:14px}
.spotlight .sp-name{font-family:'Archivo';font-weight:900;font-size:32px;letter-spacing:-.5px;line-height:1}
.spotlight .sp-club{color:var(--muted);font-weight:600;margin-top:6px;font-size:14px}
.spotlight .sp-quote{color:var(--text);font-size:15px;line-height:1.55;margin:16px 0 20px;border-left:3px solid var(--club);padding-left:14px}
.spotlight .sp-stats{display:flex;gap:26px;margin-bottom:22px}
.spotlight .sp-stat b{font-family:'Archivo';font-weight:900;font-size:28px;display:block;line-height:1;color:var(--club)}
.spotlight .sp-stat small{font-family:'Barlow Condensed';font-size:12px;letter-spacing:1px;text-transform:uppercase;color:var(--muted)}
@media(max-width:680px){.spotlight{grid-template-columns:1fr}.spotlight .sp-vis{min-height:200px}}

/* --- Team of the Week mini-pitch --- */
.totw-wrap{display:grid;grid-template-columns:1.3fr 1fr;gap:22px;align-items:stretch}
@media(max-width:820px){.totw-wrap{grid-template-columns:1fr}}
.totw-pitch{position:relative;border-radius:16px;overflow:hidden;min-height:440px;
  background:repeating-linear-gradient(#0a5c3a 0 38px,#0c6a43 38px 76px);border:1px solid var(--line)}
.totw-pitch .pl-lines{position:absolute;inset:14px;border:2px solid rgba(255,255,255,.3);border-radius:6px;pointer-events:none}
.totw-pitch .pl-lines::before{content:"";position:absolute;left:0;right:0;top:50%;height:2px;background:rgba(255,255,255,.3)}
.totw-pitch .pl-lines::after{content:"";position:absolute;left:50%;top:50%;width:84px;height:84px;border:2px solid rgba(255,255,255,.3);border-radius:50%;transform:translate(-50%,-50%)}
.totw-tok{position:absolute;transform:translate(-50%,-50%);width:66px;text-align:center;cursor:pointer;transition:transform .14s;z-index:2}
.totw-tok:hover{transform:translate(-50%,-50%) scale(1.08);z-index:4}
.totw-tok .tk-shirt{width:42px;height:42px;border-radius:11px;margin:0 auto;display:grid;place-items:center;color:#fff;
  font-family:'Archivo';font-weight:900;font-size:16px;box-shadow:0 5px 12px rgba(0,0,0,.4);border:2px solid rgba(255,255,255,.25)}
.totw-tok .tk-nm{font-size:11px;font-weight:700;color:#fff;margin-top:4px;text-shadow:0 1px 3px rgba(0,0,0,.8);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.totw-side{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:24px;display:flex;flex-direction:column}
.totw-side h3{font-family:'Archivo';font-weight:900;font-size:22px;line-height:1.05;margin-bottom:6px}
.totw-side .ts-sub{color:var(--muted);font-size:14px;margin-bottom:18px}
.totw-side .ts-form{display:inline-flex;align-self:flex-start;background:var(--vermilion);color:#fff;font-family:'Barlow Condensed';
  font-weight:700;letter-spacing:1px;padding:5px 12px;border-radius:6px;font-size:14px;margin-bottom:18px}
.totw-side .ts-list{display:flex;flex-direction:column;gap:7px;margin-bottom:20px}
.totw-side .ts-row{display:flex;align-items:center;gap:10px;font-size:13px;padding:6px 0;border-bottom:1px solid var(--line)}
.totw-side .ts-row:last-child{border:none}
.totw-side .ts-row .tsb{width:22px;height:22px;border-radius:6px;display:grid;place-items:center;color:#fff;font-size:9px;font-family:'Archivo';font-weight:800;flex-shrink:0}
.totw-side .ts-row .tsp{font-family:'Barlow Condensed';font-weight:700;color:var(--muted);width:32px;font-size:12px}
.totw-side .ts-row b{flex:1;font-weight:600}
.totw-side .ts-cta{margin-top:auto}

/* --- marquee fixture --- */
.marquee-fx{border-radius:18px;overflow:hidden;border:1px solid var(--line);background:var(--card)}
.marquee-fx .mf-head{background:linear-gradient(120deg,var(--purple),var(--ink));color:#fff;padding:14px 22px;
  display:flex;justify-content:space-between;align-items:center;font-family:'Barlow Condensed';font-weight:700;letter-spacing:1.5px;text-transform:uppercase;font-size:13px}
.marquee-fx .mf-head .mf-tag{color:var(--gold)}
.marquee-fx .mf-body{display:flex;align-items:center;justify-content:center;gap:26px;padding:34px 24px}
.marquee-fx .mf-team{display:flex;flex-direction:column;align-items:center;gap:12px;flex:1;max-width:200px;text-decoration:none;color:var(--text)}
.marquee-fx .mf-badge{width:72px;height:72px;border-radius:18px;display:grid;place-items:center;color:#fff;font-family:'Archivo';font-weight:900;font-size:24px;box-shadow:0 10px 24px rgba(0,0,0,.18)}
.marquee-fx .mf-team b{font-weight:800;font-size:17px;text-align:center}
.marquee-fx .mf-team .mf-form{display:flex;gap:4px}
.marquee-fx .mf-vs{text-align:center}
.marquee-fx .mf-vs .mf-v{font-family:'Archivo';font-weight:900;font-size:30px;color:var(--muted)}
.marquee-fx .mf-vs .mf-when{font-size:12px;color:var(--muted);margin-top:6px;line-height:1.5}
.marquee-fx .mf-foot{padding:16px 22px;border-top:1px solid var(--line);color:var(--muted);font-size:14px;text-align:center;font-style:italic}
@media(max-width:560px){.marquee-fx .mf-body{gap:12px}.marquee-fx .mf-badge{width:56px;height:56px;font-size:18px}.marquee-fx .mf-team .crest-img{--cs:56px !important}}

/* ============================================================
   MATCH CENTRE
   ============================================================ */
.match-hero{background:linear-gradient(120deg,var(--purple),var(--ink) 60%);color:#fff;position:relative;overflow:hidden}
.match-hero::before{content:"";position:absolute;inset:0;opacity:.4;background:radial-gradient(60% 100% at 50% 0%,rgba(27,92,255,.35),transparent 60%)}
.match-hero .wrap{position:relative;z-index:2;padding:24px 24px 36px}
.mh-meta{display:flex;justify-content:center;gap:14px;align-items:center;font-size:13px;color:rgba(255,255,255,.7);margin-bottom:20px;flex-wrap:wrap}
.mh-meta .ft{background:var(--vermilion);color:#fff;font-weight:800;padding:3px 10px;border-radius:5px;letter-spacing:1px;font-size:11px}
.mh-meta .up{background:rgba(255,255,255,.12);color:#fff;font-weight:700;padding:3px 10px;border-radius:5px;font-size:11px}
.mh-score{display:flex;align-items:center;justify-content:center;gap:30px;flex-wrap:wrap}
.mh-team{display:flex;flex-direction:column;align-items:center;gap:14px;flex:1;max-width:240px;color:#fff}
.mh-badge{width:84px;height:84px;border-radius:20px;display:grid;place-items:center;color:#fff;font-family:'Archivo';font-weight:900;font-size:28px;box-shadow:0 12px 28px rgba(0,0,0,.35)}
.mh-team b{font-weight:800;font-size:19px;text-align:center}
.mh-team small{color:rgba(255,255,255,.6);font-size:12px}
.mh-sc{font-family:'Archivo';font-weight:900;font-size:64px;line-height:1;letter-spacing:3px;text-align:center}
.mh-sc .vs-time{font-size:22px;font-family:'Barlow Condensed';color:var(--gold);letter-spacing:1px}
.mh-meta .live-tag{background:var(--vermilion);color:#fff;font-weight:800;padding:3px 11px;border-radius:5px;letter-spacing:1px;font-size:11px;display:inline-flex;align-items:center;gap:7px;animation:livePulse 1.6s infinite}
@keyframes livePulse{0%,100%{box-shadow:0 0 0 0 rgba(210,16,52,.5)}50%{box-shadow:0 0 0 6px rgba(210,16,52,0)}}
.mh-sc .mh-clock{display:block;font-size:16px;font-family:'Barlow Condensed';color:var(--gold);letter-spacing:1px;margin-top:6px;font-weight:600}
.tl-live-banner{text-align:center;max-width:560px;margin:0 auto 18px;background:var(--vermilion);color:#fff;font-weight:800;letter-spacing:1px;font-size:12px;padding:8px;border-radius:8px}
.tl-ev.card .tl-ic{background:transparent}

.mc-tabs{display:flex;gap:6px;border-bottom:2px solid var(--line);margin-bottom:24px;flex-wrap:wrap}
.mc-tab{font-weight:700;font-size:14px;padding:13px 20px;cursor:pointer;color:var(--muted);border:none;background:none;position:relative;font-family:inherit}
.mc-tab.on{color:var(--text)}
.mc-tab.on::after{content:"";position:absolute;left:0;right:0;bottom:-2px;height:3px;background:var(--vermilion)}

/* timeline */
.timeline-mc{max-width:560px;margin:0 auto}
.tl-ev{display:flex;align-items:center;gap:14px;padding:12px 0}
.tl-ev.home{flex-direction:row}
.tl-ev.away{flex-direction:row-reverse;text-align:right}
.tl-ev .tl-min{font-family:'Archivo';font-weight:900;font-size:15px;width:46px;text-align:center;color:var(--muted);flex-shrink:0}
.tl-ev .tl-ic{width:34px;height:34px;border-radius:50%;display:grid;place-items:center;font-size:16px;background:var(--paper);flex-shrink:0}
.tl-ev .tl-tx{flex:1}
.tl-ev .tl-tx b{font-weight:700;font-size:15px}
.tl-ev .tl-tx span{display:block;font-size:12px;color:var(--muted)}
.tl-center{text-align:center;color:var(--muted);font-size:13px;padding:20px;font-style:italic}

/* match stats bars */
.mc-stats{max-width:620px;margin:0 auto;display:flex;flex-direction:column;gap:18px}
.mc-stat .mc-stat-top{display:flex;justify-content:space-between;font-weight:700;font-size:14px;margin-bottom:6px}
.mc-stat .mc-stat-top span:nth-child(2){color:var(--muted);font-weight:600;font-size:13px}
.mc-bar{height:8px;border-radius:5px;background:var(--paper);overflow:hidden;display:flex}
.mc-bar .mc-bh{height:100%;background:var(--mh-h,#1b5cff)}
.mc-bar .mc-ba{height:100%;background:var(--mh-a,#d21034);margin-left:auto}

/* lineups */
.lineup-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
@media(max-width:680px){.lineup-grid{grid-template-columns:1fr}}
.lineup-col h4{font-family:'Archivo';font-weight:800;font-size:17px;margin-bottom:14px;display:flex;align-items:center;gap:10px}
.lineup-col h4 .lcb{width:26px;height:26px;border-radius:7px;display:grid;place-items:center;color:#fff;font-size:10px;font-family:'Archivo';font-weight:800}
.lineup-row{display:flex;align-items:center;gap:12px;padding:9px 12px;border-radius:9px;transition:.12s;cursor:pointer}
.lineup-row:hover{background:var(--paper)}
.lineup-row .ln{font-family:'Archivo';font-weight:900;width:26px;text-align:center;color:var(--muted);font-size:14px}
.lineup-row b{flex:1;font-weight:600;font-size:14px}
.lineup-row .lpos{font-family:'Barlow Condensed';font-weight:700;font-size:11px;letter-spacing:1px;color:var(--muted)}

/* h2h */
.h2h-list{max-width:560px;margin:0 auto;display:flex;flex-direction:column;gap:10px}
.h2h-row{display:grid;grid-template-columns:1fr auto 1fr;gap:14px;align-items:center;background:var(--card);border:1px solid var(--line);border-radius:10px;padding:12px 18px}
.h2h-row .h2h-s{font-family:'Archivo';font-weight:900;font-size:18px;padding:4px 14px;border-radius:8px;background:var(--paper);text-align:center;white-space:nowrap}
.h2h-row .h2h-yr{font-size:12px;color:var(--muted);text-align:center;grid-column:1/-1;margin-bottom:-4px}
.h2h-team{display:flex;align-items:center;gap:8px;font-weight:600;font-size:14px}
.h2h-team.r{justify-content:flex-end}
.h2h-team .h2hb{width:22px;height:22px;border-radius:6px;display:grid;place-items:center;color:#fff;font-size:9px;font-family:'Archivo';font-weight:800}

/* ============================================================
   FANTASY
   ============================================================ */
.fantasy-grid{display:grid;grid-template-columns:1fr 380px;gap:24px}
@media(max-width:980px){.fantasy-grid{grid-template-columns:1fr}}
.fan-pitch{position:relative;border-radius:16px;overflow:hidden;min-height:560px;
  background:repeating-linear-gradient(#0a5c3a 0 46px,#0c6a43 46px 92px);border:1px solid var(--line)}
.fan-pitch .pl-lines{position:absolute;inset:16px;border:2px solid rgba(255,255,255,.3);border-radius:6px;pointer-events:none}
.fan-pitch .pl-lines::before{content:"";position:absolute;left:0;right:0;top:50%;height:2px;background:rgba(255,255,255,.3)}
.fan-slot{position:absolute;transform:translate(-50%,-50%);width:78px;text-align:center;cursor:pointer;z-index:2;transition:transform .14s}
.fan-slot:hover{transform:translate(-50%,-50%) scale(1.07);z-index:4}
.fan-slot .fs-shirt{width:48px;height:48px;border-radius:12px;margin:0 auto;display:grid;place-items:center;color:#fff;
  font-family:'Archivo';font-weight:900;font-size:17px;box-shadow:0 6px 14px rgba(0,0,0,.4);border:2px solid rgba(255,255,255,.25)}
.fan-slot.empty .fs-shirt{background:rgba(255,255,255,.12);border:2px dashed rgba(255,255,255,.5);color:rgba(255,255,255,.8)}
.fan-slot .fs-nm{font-size:11px;font-weight:700;color:#fff;margin-top:4px;text-shadow:0 1px 3px rgba(0,0,0,.8);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.fan-slot .fs-pr{font-family:'Barlow Condensed';font-weight:700;font-size:11px;color:var(--gold);text-shadow:0 1px 3px rgba(0,0,0,.8)}
.fan-side{display:flex;flex-direction:column;gap:16px}
.fan-budget{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:18px 20px}
.fan-budget .fb-top{display:flex;justify-content:space-between;margin-bottom:12px}
.fan-budget .fb-top .fbn{font-family:'Barlow Condensed';font-size:13px;letter-spacing:1px;text-transform:uppercase;color:var(--muted)}
.fan-budget .fb-top b{font-family:'Archivo';font-weight:900;font-size:18px}
.fan-budget .fb-bar{height:8px;border-radius:5px;background:var(--paper);overflow:hidden}
.fan-budget .fb-fill{height:100%;background:linear-gradient(90deg,var(--mint),var(--gold));transition:width .3s}
.fan-budget .fb-fill.over{background:var(--vermilion)}
.fan-budget .fb-meta{display:flex;justify-content:space-between;margin-top:12px;font-size:13px;color:var(--muted)}
.fan-budget .fb-meta b{color:var(--text)}
.fan-pool{background:var(--card);border:1px solid var(--line);border-radius:14px;overflow:hidden;display:flex;flex-direction:column;flex:1}
.fan-pool .fp-head{padding:14px 18px;border-bottom:1px solid var(--line);font-weight:800;font-size:15px;display:flex;justify-content:space-between;align-items:center}
.fan-pool .fp-filters{display:flex;gap:6px;padding:12px 16px;border-bottom:1px solid var(--line);flex-wrap:wrap}
.fan-pool .fpf{font-size:11px;font-weight:700;padding:5px 11px;border-radius:6px;border:1px solid var(--line);background:transparent;color:var(--muted);cursor:pointer}
.fan-pool .fpf.on{background:var(--cobalt-br);color:#fff;border-color:var(--cobalt-br)}
.fan-pool .fp-list{overflow-y:auto;max-height:380px;padding:8px}
.fan-pool .fpp{display:flex;align-items:center;gap:11px;padding:9px 10px;border-radius:8px;cursor:pointer;transition:.12s}
.fan-pool .fpp:hover{background:var(--paper)}
.fan-pool .fpp.picked{opacity:.4;pointer-events:none}
.fan-pool .fpp .fppb{width:30px;height:30px;border-radius:7px;flex-shrink:0;display:grid;place-items:center;color:#fff;font-family:'Archivo';font-weight:800;font-size:11px}
.fan-pool .fpp .fppi{flex:1;min-width:0}
.fan-pool .fpp .fppi b{font-size:13px;font-weight:700;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.fan-pool .fpp .fppi span{font-size:11px;color:var(--muted)}
.fan-pool .fpp .fppr{font-family:'Archivo';font-weight:900;font-size:14px;color:var(--mint)}
.fan-actions{display:flex;gap:10px}
.fan-actions .btn{flex:1;justify-content:center}

/* ============================================================
   GLOBAL SEARCH
   ============================================================ */
.search-btn{width:38px;height:38px;border-radius:10px;border:1px solid rgba(255,255,255,.2);background:transparent;
  color:#fff;cursor:pointer;display:grid;place-items:center;font-size:16px;transition:.15s;flex-shrink:0}
.search-btn:hover{border-color:var(--gold);color:var(--gold)}
.search-overlay{position:fixed;inset:0;z-index:300;background:rgba(10,8,24,.7);backdrop-filter:blur(4px);
  display:none;align-items:flex-start;justify-content:center;padding:80px 20px}
.search-overlay.open{display:flex}
.search-box{background:var(--card);border-radius:16px;width:100%;max-width:620px;overflow:hidden;box-shadow:0 30px 80px rgba(0,0,0,.4);position:relative}
.search-box input{width:100%;border:none;outline:none;padding:24px 60px 24px 26px;font-size:19px;font-family:inherit;background:var(--card);color:var(--text)}
.search-close{position:absolute;top:16px;right:18px;background:none;border:none;font-size:30px;color:var(--muted);cursor:pointer;line-height:1}
.search-close:hover{color:var(--text)}
.search-results{max-height:50vh;overflow-y:auto;border-top:1px solid var(--line)}
.search-results:empty{display:none}
.sr-row{display:flex;align-items:center;gap:14px;padding:13px 22px;border-bottom:1px solid var(--line);transition:.12s}
.sr-row:hover{background:var(--paper)}
.sr-row:last-child{border:none}
.sr-badge{width:36px;height:36px;border-radius:9px;flex-shrink:0;display:grid;place-items:center;color:#fff;font-family:'Archivo';font-weight:800;font-size:13px}
.sr-info{flex:1;min-width:0}
.sr-info b{font-size:15px;font-weight:700;display:block}
.sr-info span{font-size:12px;color:var(--muted)}
.sr-type{font-family:'Barlow Condensed';font-size:12px;letter-spacing:1px;text-transform:uppercase;color:var(--muted);
  background:var(--paper);padding:4px 10px;border-radius:5px;flex-shrink:0}
.sr-empty{padding:24px 22px;color:var(--muted);text-align:center}
.sr-group{padding:10px 22px 6px;font-family:'Barlow Condensed';font-size:12px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--cobalt-br);background:var(--paper);border-bottom:1px solid var(--line)}
.sr-row.sr-active{background:var(--paper);box-shadow:inset 3px 0 0 var(--gold)}

/* ---- live event toasts ---- */
.lfh-toasts{position:fixed;right:18px;bottom:18px;z-index:400;display:flex;flex-direction:column;gap:10px;max-width:340px;pointer-events:none}
.lfh-toast{pointer-events:auto;display:flex;align-items:flex-start;gap:12px;background:var(--card);border:1px solid var(--line);border-left:5px solid var(--cobalt-br);border-radius:12px;padding:13px 14px;box-shadow:0 14px 40px rgba(20,13,46,.28);text-decoration:none;color:var(--text);transform:translateX(120%);opacity:0;transition:transform .35s cubic-bezier(.2,.9,.3,1.2),opacity .35s}
.lfh-toast.in{transform:translateX(0);opacity:1}
.lfh-toast.out{transform:translateX(120%);opacity:0}
.lfh-toast.goal{border-left-color:var(--mint)}
.lfh-toast.yellow{border-left-color:#f2c14e}
.lfh-toast.red{border-left-color:var(--vermilion)}
.lfh-toast .lt-ic{font-size:22px;line-height:1;margin-top:1px;flex-shrink:0}
.lfh-toast .lt-body{display:flex;flex-direction:column;gap:2px;min-width:0;flex:1}
.lfh-toast .lt-body b{font-size:14px;font-weight:800;display:flex;align-items:center;gap:6px}
.lfh-toast .lt-min{font-family:'Archivo';font-size:12px;color:var(--vermilion);font-weight:900}
.lfh-toast .lt-meta{font-size:12.5px;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.lfh-toast .lt-score{font-family:'Archivo';font-weight:800;font-size:12px;color:var(--cobalt-br);margin-top:1px}
.lfh-toast .lt-x{color:var(--muted);font-size:18px;line-height:1;flex-shrink:0;padding:0 2px}
.lfh-toast .lt-x:hover{color:var(--text)}
@media(max-width:560px){.lfh-toasts{left:12px;right:12px;bottom:12px;max-width:none}}

/* ============================================================
   IMAGE WRAPPERS — real logo/photo with colored-block fallback
   ============================================================ */
.crest-img{position:relative;display:inline-grid;place-items:center;flex-shrink:0;
  width:var(--cs,44px);height:var(--cs,44px);border-radius:22%;overflow:hidden}
.crest-img img{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;padding:8%;z-index:2;background:inherit}
.crest-img img.img-missing{display:none}
.crest-fallback{font-family:'Archivo';font-weight:900;color:#fff;z-index:1;
  font-size:calc(var(--cs,44px)*0.32);letter-spacing:.5px;text-shadow:0 1px 2px rgba(0,0,0,.3)}

.photo-img{position:relative;display:inline-grid;place-items:center;flex-shrink:0;
  width:var(--ps,48px);height:var(--ps,48px);border-radius:24%;overflow:hidden}
.photo-img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:top center;z-index:2}
.photo-img img.img-missing{display:none}
.photo-fallback{font-family:'Archivo';font-weight:900;color:#fff;z-index:1;
  font-size:calc(var(--ps,48px)*0.4);text-shadow:0 1px 2px rgba(0,0,0,.4)}
/* round variants */
.crest-img.round,.photo-img.round{border-radius:50%}

/* ---- club hero crest as image ---- */
.ch-crest{overflow:hidden;position:relative}
.ch-crest-img{width:100%;height:100%;object-fit:contain;padding:14px;display:block}
.ch-crest-fb{font-family:'Archivo';font-weight:900;font-size:40px;color:#fff;place-items:center;width:100%;height:100%}

/* ---- squad card photo fills colored header, number as corner badge ---- */
.pc-top{height:120px}
.pc-photo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:top center;z-index:1}
.pc-top .num{position:absolute;top:10px;left:14px;font-size:20px;z-index:3;
  background:rgba(8,11,26,.55);border-radius:7px;padding:2px 9px;line-height:1.1}
.pc-top .flag,.pc-top .cap{position:relative;z-index:3}
.pc-top::after{content:"";position:absolute;inset:0;z-index:2;
  background:linear-gradient(to top,rgba(0,0,0,.45),transparent 55%);pointer-events:none}

/* center crest image inside club cards (replaces old .cb block) */
.club-card .crest-img{margin:0 auto 14px;display:grid}
