/* =====================================================================
   FIFA WORLD CUP 2026 — DESIGN SYSTEM
   A premium, dark, glassmorphic theme with a green-pitch + gold accent.
   ===================================================================== */
:root{
  --bg:#05070d;
  --bg-2:#0a0f1c;
  --surface:#0e1422;
  --surface-2:#131b2e;
  --card:rgba(255,255,255,.04);
  --card-border:rgba(255,255,255,.08);
  --text:#eef2f8;
  --muted:#93a0b8;
  --faint:#5c677d;

  --green:#00c46a;
  --green-deep:#009b54;
  --gold:#ffd24c;
  --gold-deep:#e8b51c;
  --red:#ff4d5e;
  --blue:#4da3ff;
  --purple:#9b6cff;

  --grad-hero:linear-gradient(135deg,#00c46a 0%,#0a8bd6 50%,#9b6cff 100%);
  --grad-gold:linear-gradient(135deg,#ffd24c,#ff9d2f);
  --grad-pitch:linear-gradient(160deg,#0a3d23 0%,#062818 100%);

  --radius:18px;
  --radius-sm:12px;
  --shadow:0 18px 50px -18px rgba(0,0,0,.65);
  --shadow-glow:0 0 40px -8px rgba(0,196,106,.35);
  --maxw:1240px;
  --header-h:68px;
  font-synthesis:none;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Inter','Segoe UI',system-ui,-apple-system,sans-serif;
  background:
    radial-gradient(1200px 600px at 80% -10%, rgba(0,196,106,.14), transparent 60%),
    radial-gradient(1000px 500px at -10% 10%, rgba(75,163,255,.12), transparent 55%),
    var(--bg);
  color:var(--text);
  line-height:1.6;
  min-height:100vh;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.display{font-family:'Oswald','Inter',sans-serif;font-weight:700;letter-spacing:-.5px;text-transform:uppercase}

/* ---------- layout helpers ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}
.section{padding:70px 0}
.section-tight{padding:42px 0}
.grid{display:grid;gap:22px}
.center{text-align:center}
.muted{color:var(--muted)}
.pill{display:inline-flex;align-items:center;gap:7px;padding:5px 13px;border-radius:999px;font-size:.72rem;font-weight:700;letter-spacing:1.4px;text-transform:uppercase}
.pill-green{background:rgba(0,196,106,.14);color:var(--green);border:1px solid rgba(0,196,106,.3)}
.pill-gold{background:rgba(255,210,76,.13);color:var(--gold);border:1px solid rgba(255,210,76,.3)}
.pill-red{background:rgba(255,77,94,.14);color:var(--red);border:1px solid rgba(255,77,94,.35)}

.section-head{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;margin-bottom:30px;flex-wrap:wrap}
.section-head h2{font-size:clamp(1.6rem,3vw,2.4rem);line-height:1.05}
.section-head .display{background:var(--grad-gold);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.eyebrow{color:var(--green);font-weight:800;letter-spacing:3px;text-transform:uppercase;font-size:.74rem;margin-bottom:8px}
.link-more{color:var(--green);font-weight:700;font-size:.9rem;display:inline-flex;gap:6px;align-items:center;transition:gap .2s}
.link-more:hover{gap:11px}

/* ---------- HEADER / NAV ---------- */
.site-header{
  position:sticky;top:0;z-index:50;height:var(--header-h);
  backdrop-filter:blur(18px);
  background:rgba(7,10,18,.72);
  border-bottom:1px solid var(--card-border);
}
.nav{height:100%;display:flex;align-items:center;justify-content:space-between;gap:18px}
.brand{display:flex;align-items:center;gap:11px;font-weight:800;font-size:1.05rem}
.brand .logo{
  width:38px;height:38px;border-radius:11px;display:grid;place-items:center;
  background:var(--grad-hero);font-size:1.2rem;box-shadow:var(--shadow-glow);
}
.brand b{background:var(--grad-gold);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.brand small{display:block;font-size:.62rem;letter-spacing:2px;color:var(--muted);font-weight:600}
.nav-links{display:flex;align-items:center;gap:4px}
.nav-links a{
  padding:9px 14px;border-radius:10px;font-size:.9rem;font-weight:600;color:var(--muted);
  transition:.18s;position:relative;
}
.nav-links a:hover{color:var(--text);background:rgba(255,255,255,.05)}
.nav-links a.active{color:var(--text);background:rgba(0,196,106,.12)}
.nav-links a.live-link{color:var(--red)}
.nav-links a.live-link::before{content:'';width:7px;height:7px;border-radius:50%;background:var(--red);display:inline-block;margin-right:6px;animation:blink 1.2s infinite}
.nav-right{display:flex;align-items:center;gap:12px}
.tz-badge{font-size:.74rem;color:var(--muted);background:var(--card);border:1px solid var(--card-border);padding:6px 11px;border-radius:9px;white-space:nowrap}
.tz-badge b{color:var(--green)}
.burger{display:none;background:none;border:1px solid var(--card-border);color:var(--text);width:42px;height:42px;border-radius:10px;font-size:1.2rem;cursor:pointer}
.notif-bell{background:none;border:1px solid var(--card-border);color:var(--muted);width:40px;height:40px;border-radius:10px;font-size:1.05rem;cursor:pointer;transition:.18s;flex:0 0 auto}
.notif-bell:hover{color:var(--text);border-color:rgba(0,196,106,.4)}
.notif-bell.on{color:var(--gold);border-color:rgba(255,210,76,.5);background:rgba(255,210,76,.1);animation:bellPulse 2s infinite}
@keyframes bellPulse{0%,100%{box-shadow:0 0 0 0 rgba(255,210,76,.4)}50%{box-shadow:0 0 0 6px rgba(255,210,76,0)}}
.avatar.has-photo{background-size:cover !important;background-position:center top;text-shadow:none;border-color:rgba(255,255,255,.25)}

@keyframes blink{0%,100%{opacity:1}50%{opacity:.25}}

/* ---------- HERO ---------- */
.hero{position:relative;overflow:hidden;padding:64px 0 40px}
.hero-glow{position:absolute;inset:0;z-index:-1;
  background:
    radial-gradient(700px 360px at 75% 20%, rgba(0,196,106,.25), transparent 60%),
    radial-gradient(600px 360px at 15% 80%, rgba(155,108,255,.2), transparent 60%);
  filter:saturate(1.2);
}
.hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:40px;align-items:center}
.hero h1{font-size:clamp(2.4rem,5.6vw,4.6rem);line-height:.94;margin:16px 0 14px}
.hero h1 .g{background:var(--grad-hero);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.hero p.lead{font-size:1.12rem;color:var(--muted);max-width:540px}
.hero-cta{display:flex;gap:14px;margin-top:28px;flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;gap:9px;padding:13px 24px;border-radius:12px;font-weight:700;font-size:.95rem;cursor:pointer;border:1px solid transparent;transition:.2s;white-space:nowrap}
.btn-primary{background:var(--grad-hero);color:#04130c;box-shadow:var(--shadow-glow)}
.btn-primary:hover{transform:translateY(-2px)}
.btn-ghost{background:var(--card);border-color:var(--card-border);color:var(--text)}
.btn-ghost:hover{background:rgba(255,255,255,.08)}
.btn-gold{background:var(--grad-gold);color:#1a1200}
.btn-gold:hover{transform:translateY(-2px)}

.hero-stats{display:flex;gap:26px;margin-top:34px;flex-wrap:wrap}
.hero-stats .s b{font-family:'Oswald',sans-serif;font-size:1.9rem;display:block;line-height:1;background:var(--grad-gold);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.hero-stats .s span{font-size:.74rem;color:var(--muted);text-transform:uppercase;letter-spacing:1.5px}

/* trophy / countdown card */
.hero-card{
  background:linear-gradient(165deg,rgba(255,255,255,.07),rgba(255,255,255,.02));
  border:1px solid var(--card-border);border-radius:24px;padding:30px;box-shadow:var(--shadow);
  position:relative;overflow:hidden;
}
.hero-card::before{content:'';position:absolute;top:-60px;right:-60px;width:200px;height:200px;border-radius:50%;background:var(--grad-gold);filter:blur(70px);opacity:.35}
.hero-card .trophy{font-size:2.6rem;text-align:center;margin-bottom:6px}
.hero-card h3{text-align:center;font-size:1.05rem;margin-bottom:4px}
.hero-card .sub{text-align:center;color:var(--muted);font-size:.84rem;margin-bottom:22px}
.countdown{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.cd-box{background:rgba(0,0,0,.35);border:1px solid var(--card-border);border-radius:14px;padding:14px 6px;text-align:center}
.cd-box b{font-family:'Oswald',sans-serif;font-size:2rem;display:block;line-height:1;color:var(--gold)}
.cd-box span{font-size:.64rem;text-transform:uppercase;letter-spacing:1.5px;color:var(--muted)}

/* ---------- CARDS / GENERIC ---------- */
.card{background:var(--card);border:1px solid var(--card-border);border-radius:var(--radius);overflow:hidden;transition:.22s;backdrop-filter:blur(6px)}
.card:hover{border-color:rgba(0,196,106,.4);transform:translateY(-4px);box-shadow:var(--shadow)}

/* ---------- MATCH CARD ---------- */
.match-card{padding:18px 20px;display:flex;flex-direction:column;gap:14px}
.match-top{display:flex;justify-content:space-between;align-items:center;font-size:.74rem;color:var(--muted)}
.match-stage{font-weight:700;letter-spacing:.5px;color:var(--green)}
.match-teams{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:8px}
.mt-side{display:flex;align-items:center;gap:11px}
.mt-side.away{flex-direction:row-reverse;text-align:right}
.mt-side .flag{width:40px;height:27px;border-radius:5px;object-fit:cover;box-shadow:0 2px 8px rgba(0,0,0,.5)}
.mt-side .tn{font-weight:700;font-size:.98rem}
.mt-side .tc{font-size:.7rem;color:var(--muted);letter-spacing:1px}
.match-score{font-family:'Oswald',sans-serif;font-size:1.7rem;font-weight:700;min-width:74px;text-align:center}
.match-score .vs{font-size:.8rem;color:var(--faint);font-weight:400}
.match-score .ko{font-size:.95rem;color:var(--green);font-weight:600;line-height:1.1}
.match-score .ko small{display:block;color:var(--muted);font-size:.68rem;font-weight:400}
.match-foot{display:flex;justify-content:space-between;align-items:center;font-size:.76rem;color:var(--muted);border-top:1px solid var(--card-border);padding-top:11px}
.match-foot a{color:var(--green);font-weight:700}
.live-badge{background:var(--red);color:#fff;padding:2px 9px;border-radius:6px;font-size:.66rem;font-weight:800;letter-spacing:.8px;display:inline-flex;align-items:center;gap:5px}
.live-badge::before{content:'';width:6px;height:6px;border-radius:50%;background:#fff;animation:blink 1s infinite}

/* ---------- TEAM CARD / GROUPS ---------- */
.groups-grid{grid-template-columns:repeat(auto-fill,minmax(330px,1fr))}
.group-card{padding:0}
.group-head{display:flex;align-items:center;gap:10px;padding:15px 18px;background:linear-gradient(90deg,rgba(0,196,106,.12),transparent);border-bottom:1px solid var(--card-border)}
.group-head .gl{width:34px;height:34px;border-radius:9px;background:var(--grad-hero);display:grid;place-items:center;font-family:'Oswald';font-weight:700;color:#04130c}
.group-head h3{font-size:1rem}
.standings{width:100%;border-collapse:collapse;font-size:.85rem}
.standings th{text-align:center;font-size:.66rem;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);padding:9px 4px;font-weight:600}
.standings th.tname,.standings td.tname{text-align:left;padding-left:16px}
.standings td{padding:9px 4px;text-align:center;border-top:1px solid var(--card-border)}
.standings tr:hover{background:rgba(255,255,255,.03)}
.standings .tname{display:flex;align-items:center;gap:9px;font-weight:600}
.standings .tname img{width:24px;height:16px;border-radius:3px;object-fit:cover}
.standings .pts{font-weight:800;color:var(--gold)}
.standings .qual{box-shadow:inset 3px 0 0 var(--green)}

/* ---------- TEAM TILE (teams page) ---------- */
.teams-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}
.team-tile{padding:20px 16px;text-align:center;cursor:pointer;position:relative}
.team-tile .flag{width:74px;height:50px;border-radius:8px;object-fit:cover;margin:0 auto 13px;box-shadow:0 6px 18px rgba(0,0,0,.5);transition:.25s}
.team-tile:hover .flag{transform:scale(1.08) rotate(-2deg)}
.team-tile h4{font-size:1rem}
.team-tile .meta{font-size:.74rem;color:var(--muted);margin-top:3px}
.team-tile .grp{position:absolute;top:12px;right:12px;font-size:.66rem;font-weight:800;color:var(--green);background:rgba(0,196,106,.12);padding:2px 8px;border-radius:6px}
.team-tile .rk{position:absolute;top:12px;left:12px;font-size:.66rem;color:var(--gold);font-weight:700}
.fav-btn{position:absolute;bottom:10px;right:10px;background:none;border:none;color:var(--gold);font-size:1.2rem;cursor:pointer;line-height:1;padding:2px;transition:transform .15s;z-index:2}
.fav-btn:hover{transform:scale(1.25)}
.fav-btn.on{filter:drop-shadow(0 0 6px rgba(255,210,76,.7))}

/* ---------- PLAYER CARD ---------- */
.players-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}
.player-card{padding:0;text-align:center}
.player-top{position:relative;padding:26px 16px 16px;background:linear-gradient(160deg,rgba(255,255,255,.06),transparent)}
.avatar{width:96px;height:96px;border-radius:50%;margin:0 auto;display:grid;place-items:center;font-family:'Oswald';font-weight:700;font-size:2rem;border:3px solid rgba(255,255,255,.15);position:relative}
.player-num{position:absolute;top:14px;right:16px;font-family:'Oswald';font-size:1.5rem;color:rgba(255,255,255,.25);font-weight:700}
.player-flag{position:absolute;top:16px;left:16px;width:30px;height:20px;border-radius:4px;object-fit:cover;box-shadow:0 2px 6px rgba(0,0,0,.5)}
.player-body{padding:14px 16px 20px}
.player-body h4{font-size:1.02rem}
.player-body .club{font-size:.76rem;color:var(--muted);margin-bottom:12px}
.player-stats{display:flex;justify-content:space-around;border-top:1px solid var(--card-border);padding-top:12px}
.player-stats .ps b{display:block;font-family:'Oswald';font-size:1.15rem;color:var(--gold);line-height:1}
.player-stats .ps span{font-size:.62rem;text-transform:uppercase;letter-spacing:.8px;color:var(--muted)}
.pos-badge{display:inline-block;font-size:.64rem;font-weight:800;letter-spacing:1px;padding:2px 8px;border-radius:5px;margin-bottom:6px}
.pos-GK{background:rgba(255,210,76,.16);color:var(--gold)}
.pos-DF{background:rgba(75,163,255,.16);color:var(--blue)}
.pos-MF{background:rgba(0,196,106,.16);color:var(--green)}
.pos-FW{background:rgba(255,77,94,.16);color:var(--red)}

/* ---------- FILTER BAR ---------- */
.filterbar{display:flex;gap:9px;flex-wrap:wrap;margin-bottom:26px;align-items:center}
.chip{padding:8px 16px;border-radius:999px;font-size:.84rem;font-weight:600;background:var(--card);border:1px solid var(--card-border);color:var(--muted);cursor:pointer;transition:.16s}
.chip:hover{color:var(--text);border-color:rgba(0,196,106,.4)}
.chip.active{background:var(--grad-hero);color:#04130c;border-color:transparent}
.search-input{flex:1;min-width:180px;max-width:300px;padding:10px 16px;border-radius:11px;background:var(--card);border:1px solid var(--card-border);color:var(--text);font-size:.9rem;outline:none}
.search-input:focus{border-color:var(--green)}

/* ---------- STADIUM CARD ---------- */
.stadiums-grid{grid-template-columns:repeat(auto-fill,minmax(340px,1fr))}
.stadium-card{padding:0;display:flex;flex-direction:column}
.stadium-hero{height:170px;position:relative;overflow:hidden;display:grid;place-items:center}
.stadium-hero .sh-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:.4s}
.stadium-card:hover .sh-img{transform:scale(1.07)}
.stadium-hero::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(5,7,13,.95),transparent 60%)}
.stadium-hero .sh-cap{position:absolute;top:12px;right:12px;z-index:2;background:rgba(0,0,0,.55);backdrop-filter:blur(4px);padding:4px 10px;border-radius:8px;font-size:.74rem;font-weight:700}
.stadium-hero .sh-city{position:absolute;bottom:12px;left:16px;z-index:2;display:flex;align-items:center;gap:8px}
.stadium-hero .sh-city img{width:26px;height:18px;border-radius:3px}
.stadium-hero .sh-city b{font-size:1.05rem}
.stadium-body{padding:16px 18px;flex:1;display:flex;flex-direction:column;gap:8px}
.stadium-body h3{font-size:1.15rem}
.stadium-body .note{font-size:.82rem;color:var(--muted);flex:1}
.stadium-map{height:200px;border-top:1px solid var(--card-border);background:#0a0f1c}
.stadium-meta{display:flex;gap:14px;font-size:.76rem;color:var(--muted);flex-wrap:wrap}
.stadium-meta b{color:var(--text)}

/* ---------- LIVE CENTER ---------- */
.live-wrap{display:grid;grid-template-columns:1fr 360px;gap:24px;align-items:start}
.live-main{display:flex;flex-direction:column;gap:22px}
.live-scoreboard{
  background:var(--grad-pitch);border:1px solid rgba(0,196,106,.25);border-radius:22px;padding:30px;position:relative;overflow:hidden;
  box-shadow:var(--shadow);
}
.live-scoreboard::before{content:'';position:absolute;inset:0;background-image:repeating-linear-gradient(90deg,transparent,transparent 60px,rgba(255,255,255,.025) 60px,rgba(255,255,255,.025) 120px)}
.lsb-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:22px;position:relative}
.lsb-clock{font-family:'Oswald';font-size:1.1rem;color:var(--red);font-weight:700;display:flex;align-items:center;gap:8px}
.lsb-clock .dot{width:9px;height:9px;border-radius:50%;background:var(--red);animation:blink 1s infinite}
.lsb-grid{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:18px;position:relative}
.lsb-team{text-align:center}
.lsb-team img{width:84px;height:56px;border-radius:8px;object-fit:cover;margin:0 auto 12px;box-shadow:0 6px 20px rgba(0,0,0,.6)}
.lsb-team h3{font-size:1.3rem}
.lsb-team .rank{font-size:.72rem;color:var(--muted)}
.lsb-score{font-family:'Oswald';font-size:4rem;font-weight:700;line-height:1;letter-spacing:2px}
.lsb-score small{display:block;font-size:.8rem;color:var(--green);letter-spacing:2px;font-weight:600;margin-top:6px}

.stat-row{margin-bottom:16px}
.stat-row .sr-label{display:flex;justify-content:space-between;font-size:.82rem;margin-bottom:6px}
.stat-row .sr-label b{font-weight:700}
.sr-bar{height:9px;border-radius:6px;background:rgba(255,255,255,.08);overflow:hidden;display:flex}
.sr-bar .h{background:var(--green);transition:width .8s}
.sr-bar .a{background:var(--gold);transition:width .8s}

.commentary{max-height:520px;overflow-y:auto;display:flex;flex-direction:column;gap:2px}
.comm-item{display:flex;gap:12px;padding:12px 4px;border-bottom:1px solid var(--card-border);animation:fadeIn .4s}
.comm-min{font-family:'Oswald';font-size:.95rem;color:var(--green);min-width:38px;font-weight:700}
.comm-icon{font-size:1.1rem}
.comm-text{font-size:.86rem;color:var(--text)}
.comm-text.goal{font-weight:700;color:var(--gold)}
@keyframes fadeIn{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:none}}

.live-side .card{padding:18px}
.lineup-row{display:flex;align-items:center;gap:9px;padding:7px 0;font-size:.85rem;border-bottom:1px solid var(--card-border)}
.lineup-row .ln{width:24px;font-family:'Oswald';color:var(--muted);text-align:center}

/* ---------- TACTICAL PITCH ---------- */
.pitch-wrap{width:100%;border-radius:14px;overflow:hidden;background:#073f23;border:1px solid rgba(255,255,255,.1);box-shadow:inset 0 0 40px rgba(0,0,0,.35);line-height:0}
.pitch-wrap canvas{display:block;width:100%}
.pitch-caption{font-size:.72rem;color:var(--muted);margin-top:8px;line-height:1.4}
.pitch-replay{padding:8px 14px;font-size:.82rem}
.pitch-head{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:8px;margin-bottom:10px}
.form-badges{display:flex;gap:7px;flex-wrap:wrap}
.fbadge{display:inline-flex;align-items:center;gap:5px;background:var(--card);border:1px solid var(--card-border);border-radius:8px;padding:4px 9px;font-size:.74rem;font-weight:700}
.fbadge img{width:18px;height:12px;border-radius:2px}
.fbadge b{color:var(--green)}
.fbadge i{font-style:normal;font-size:.6rem;color:var(--muted);background:rgba(255,255,255,.06);padding:1px 5px;border-radius:5px}
/* possession meter */
.poss-meter{margin-bottom:12px}
.poss-row{display:flex;justify-content:space-between;align-items:center;font-size:.76rem;margin-bottom:5px}
.poss-bar{height:9px;border-radius:6px;background:var(--gold);overflow:hidden}
.poss-bar span{display:block;height:100%;width:50%;background:var(--green);transition:width .6s ease}
/* controls */
.pitch-controls{margin-top:12px;display:flex;flex-direction:column;gap:10px}
.pitch-toggles{display:flex;gap:7px;flex-wrap:wrap}
.chip.mini{padding:6px 12px;font-size:.76rem;opacity:.5}
.chip.mini.on{opacity:1;background:rgba(0,196,106,.14);border-color:rgba(0,196,106,.4);color:var(--green)}
.goal-timeline{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.tl-btn{background:var(--card);border:1px solid var(--card-border);color:var(--text);border-radius:8px;width:34px;height:30px;cursor:pointer;font-size:.8rem;flex:0 0 auto}
.tl-btn:hover{border-color:var(--green)}
.goal-timeline .pins{display:flex;gap:6px;flex-wrap:wrap;flex:1}
.goal-pin{display:inline-flex;align-items:center;gap:4px;background:var(--card);border:1px solid var(--card-border);border-radius:999px;padding:3px 9px;cursor:pointer;font-size:.74rem}
.goal-pin img{width:16px;height:11px;border-radius:2px}
.goal-pin .gm{font-family:Oswald;font-weight:700;color:var(--gold)}
.goal-pin.on{border-color:var(--gold);background:rgba(255,210,76,.12)}

/* ---------- NEWS ---------- */
.news-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}
.news-card{display:flex;flex-direction:column;cursor:pointer}
.news-img{height:170px;position:relative;overflow:hidden}
.news-img img{width:100%;height:100%;object-fit:cover;transition:.4s}
.news-card:hover .news-img img{transform:scale(1.07)}
.news-img .cat{position:absolute;top:12px;left:12px;background:var(--grad-gold);color:#1a1200;padding:4px 11px;border-radius:7px;font-size:.68rem;font-weight:800;letter-spacing:.6px;text-transform:uppercase}
.news-body{padding:16px 18px 20px;flex:1;display:flex;flex-direction:column;gap:9px}
.news-body h3{font-size:1.08rem;line-height:1.25}
.news-body .blurb{font-size:.86rem;color:var(--muted);flex:1}
.news-body .date{font-size:.74rem;color:var(--faint)}
.news-feature{grid-column:span 2;flex-direction:row}
.news-feature .news-img{height:auto;flex:1.1}
.news-feature .news-body{flex:1;justify-content:center}
.news-feature .news-body h3{font-size:1.5rem}

/* ---------- MODAL ---------- */
.modal-overlay{position:fixed;inset:0;background:rgba(3,5,10,.8);backdrop-filter:blur(8px);z-index:100;display:none;align-items:center;justify-content:center;padding:20px;animation:fadeIn .25s}
.modal-overlay.open{display:flex}
.modal{background:var(--surface);border:1px solid var(--card-border);border-radius:22px;max-width:560px;width:100%;max-height:88vh;overflow-y:auto;box-shadow:var(--shadow);animation:popIn .3s}
@keyframes popIn{from{transform:scale(.94);opacity:0}to{transform:scale(1);opacity:1}}
.modal-hero{height:130px;background:var(--grad-hero);position:relative;display:grid;place-items:center}
.modal-hero img{width:90px;height:60px;border-radius:8px;object-fit:cover;box-shadow:0 8px 24px rgba(0,0,0,.6)}
.modal-close{position:absolute;top:14px;right:14px;width:36px;height:36px;border-radius:50%;background:rgba(0,0,0,.4);border:none;color:#fff;font-size:1.3rem;cursor:pointer;display:grid;place-items:center}
.modal-body{padding:24px}
.modal-body h2{font-size:1.6rem}
.modal-body .sub{color:var(--muted);margin-bottom:18px}
.kv-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:18px}
.kv{background:var(--card);border:1px solid var(--card-border);border-radius:12px;padding:12px 14px}
.kv span{font-size:.7rem;text-transform:uppercase;letter-spacing:1px;color:var(--muted)}
.kv b{display:block;font-size:1.1rem;margin-top:2px}

/* ---------- FOOTER ---------- */
.site-footer{border-top:1px solid var(--card-border);background:var(--bg-2);padding:50px 0 30px;margin-top:60px}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:30px;margin-bottom:34px}
.footer-grid h5{font-size:.78rem;text-transform:uppercase;letter-spacing:1.5px;color:var(--muted);margin-bottom:14px}
.footer-grid a{display:block;color:var(--muted);font-size:.9rem;padding:5px 0;transition:.15s}
.footer-grid a:hover{color:var(--green)}
.footer-grid p{color:var(--muted);font-size:.9rem;max-width:280px}
.footer-bottom{border-top:1px solid var(--card-border);padding-top:22px;display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;font-size:.82rem;color:var(--faint)}

/* ---------- PAGE HEADER (inner pages) ---------- */
.page-hero{padding:48px 0 14px;position:relative}
.page-hero h1{font-size:clamp(2rem,4.4vw,3.2rem);line-height:1}
.page-hero p{color:var(--muted);font-size:1.05rem;max-width:620px;margin-top:12px}
.breadcrumb{font-size:.8rem;color:var(--muted);margin-bottom:14px}
.breadcrumb a:hover{color:var(--green)}

/* ---------- UTILITY ---------- */
.flag-sm{width:28px;height:19px;border-radius:3px;object-fit:cover}
.empty{padding:50px;text-align:center;color:var(--muted)}
.scroll-x{display:flex;gap:18px;overflow-x:auto;padding-bottom:12px;scroll-snap-type:x mandatory}
.scroll-x>*{flex:0 0 320px;scroll-snap-align:start}
.scroll-x::-webkit-scrollbar{height:8px}
.scroll-x::-webkit-scrollbar-thumb{background:rgba(255,255,255,.12);border-radius:4px}
::-webkit-scrollbar{width:11px;height:11px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:rgba(255,255,255,.1);border-radius:6px}
::-webkit-scrollbar-thumb:hover{background:rgba(255,255,255,.18)}

.reveal{opacity:0;transform:translateY(24px);transition:.7s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}

/* ---------- RESPONSIVE ---------- */
@media(max-width:980px){
  .hero-grid{grid-template-columns:1fr}
  .live-wrap{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .news-feature{grid-column:span 1;flex-direction:column}
  .news-feature .news-img{height:170px}
}
@media(max-width:720px){
  .nav-links{
    position:fixed;top:var(--header-h);left:0;right:0;flex-direction:column;align-items:stretch;
    background:rgba(7,10,18,.97);backdrop-filter:blur(20px);padding:14px;gap:4px;
    border-bottom:1px solid var(--card-border);transform:translateY(-150%);transition:.3s;z-index:49;
  }
  .nav-links.open{transform:none}
  .burger{display:grid;place-items:center}
  .tz-badge{display:none}
  .footer-grid{grid-template-columns:1fr 1fr}
  .section{padding:48px 0}
  .lsb-score{font-size:2.8rem}
  .lsb-team img{width:60px;height:40px}
}
@media(max-width:460px){
  .footer-grid{grid-template-columns:1fr}
  .hero-stats{gap:18px}
}

/* ============ MOBILE POLISH ============ */
@media(max-width:720px){
  .wrap{padding:0 16px}
  .page-hero{padding:32px 0 8px}
  .section-head{margin-bottom:22px}
  .hero{padding:36px 0 20px}
  .hero-card{padding:22px}
  .countdown{gap:7px}
  .cd-box b{font-size:1.6rem}
  /* match cards */
  .mt-side .flag{width:34px;height:23px}
  .mt-side .tn{font-size:.86rem}
  .match-score{font-size:1.4rem;min-width:60px}
  /* tap targets */
  .chip{padding:9px 15px}
  .btn{padding:12px 18px}
  .nav-links a{padding:13px 14px;font-size:1rem}
  /* modals fill screen */
  .modal{max-height:92vh;border-radius:18px}
  .modal-body{padding:18px}
  .kv-grid{grid-template-columns:1fr 1fr;gap:9px}
  /* standings stay readable */
  .standings{font-size:.78rem}
  .standings th,.standings td{padding:8px 2px}
  .standings .tname,.standings th.tname{padding-left:10px}
  .standings .tname img{width:20px;height:13px}
  /* leaderboards / pulse */
  .player-stats .ps b{font-size:1rem}
  .scroll-x>*{flex-basis:78vw}
}
@media(max-width:420px){
  .hero h1{font-size:2.2rem}
  .match-teams{gap:5px}
  .mt-side{gap:7px}
  .mt-side .tc{display:none}
  .lsb-score{font-size:2.3rem}
  .section-head h2{font-size:1.5rem}
  .round-col{flex-basis:84vw;min-width:84vw}
}
/* nicer focus + tap highlight */
a,button,input{-webkit-tap-highlight-color:rgba(0,196,106,.25)}
:focus-visible{outline:2px solid var(--green);outline-offset:2px}
@media(hover:none){ .card:hover{transform:none} }
