/* ============================================================
   FlashScore TV V2 — THEME ENGINE (base.css)
   Token-driven structural layer shared by all skins.
   A skin file (theme-<slug>.css) loads AFTER this and overrides
   the --tokens (and a few structural rules) to create a fully
   distinct identity. No app logic, hooks or class names change.
   ============================================================ */

:root{
  /* surfaces */
  --bg:#0c111d;
  --bg-2:#0f1626;
  --panel:rgba(20,28,44,.86);
  --card-bg:linear-gradient(180deg,rgba(26,35,54,.92),rgba(15,22,36,.92));
  --header-bg:rgba(12,17,29,.82);
  --line:rgba(130,150,190,.16);
  --line-2:rgba(130,150,190,.32);
  /* ink */
  --text:#eef2fb;
  --muted:#93a3c2;
  --muted-2:#6b7a99;
  /* brand */
  --accent:#5b8cff;
  --accent-2:#8a6bff;
  --accent-ink:#06112a;
  --live:#ff3b5c;
  --ok:#2bd28a;
  --gold:#ffc24a;
  --grad-accent:linear-gradient(135deg,var(--accent),var(--accent-2));
  /* type */
  --font:system-ui,-apple-system,"Segoe UI",Tahoma,Arial,sans-serif;
  --font-head:var(--font);
  --fw-body:500;
  --fw-head:800;
  --tracking:.1px;
  --tracking-head:-.3px;
  --uppercase:none;
  /* shape */
  --r-sm:10px;
  --r:16px;
  --r-lg:22px;
  --r-pill:999px;
  --card-radius:var(--r);
  --border-w:1px;
  --shadow:0 18px 40px -18px rgba(0,0,0,.7);
  --ease:cubic-bezier(.22,.61,.36,1);
  --fast:.18s var(--ease);
  --med:.32s var(--ease);
  /* layout */
  --maxw:1480px;
  --gap:14px;
  /* component hooks (skins override) */
  --card-accent:var(--grad-accent);
  --status-live-bg:rgba(255,59,92,.16);
  --topline:1px;
}

*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0;
  color:var(--text);
  font-family:var(--font);
  font-weight:var(--fw-body);
  letter-spacing:var(--tracking);
  line-height:1.65;
  background:var(--bg);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  min-height:100vh;
}
a{text-decoration:none;color:inherit;transition:color var(--fast)}
img{max-width:100%}

.wrap{position:relative;z-index:1;width:min(var(--maxw),calc(100% - 30px));margin-inline:auto}

/* ---------- Header ---------- */
.topbar{position:sticky;top:0;z-index:40;background:var(--header-bg);backdrop-filter:blur(16px) saturate(140%);-webkit-backdrop-filter:blur(16px) saturate(140%);border-bottom:var(--border-w) solid var(--line)}
.nav{display:flex;justify-content:space-between;align-items:center;gap:14px;padding:13px 0}
.brand{display:flex;align-items:center;gap:11px;font-family:var(--font-head);font-weight:900;font-size:1.22rem;color:#fff;white-space:nowrap}
.brand-mark{display:grid;place-items:center;width:40px;height:40px;border-radius:13px;font-size:1.15rem;color:var(--accent-ink);background:var(--grad-accent);box-shadow:inset 0 0 0 1px rgba(255,255,255,.22)}
.menu{display:flex;gap:6px;flex-wrap:wrap}
.menu a,.pill{padding:9px 13px;border-radius:var(--r-pill);background:rgba(255,255,255,.04);border:1px solid var(--line);color:var(--muted);font-weight:700;font-size:.92rem;transition:color var(--fast),background var(--fast),border-color var(--fast),transform var(--fast)}
.menu a:hover,.pill:hover{color:#fff;border-color:var(--line-2);transform:translateY(-1px)}
.menu a.active{color:var(--accent-ink);background:var(--grad-accent);border-color:transparent}
.pill{color:var(--accent);font-weight:800}
.pill:hover{color:var(--accent-ink);background:var(--grad-accent);border-color:transparent}

/* ---------- Panels ---------- */
.panel{position:relative;background:var(--panel);border:1px solid var(--line);border-radius:var(--r);padding:18px;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);box-shadow:var(--shadow)}
a.panel{display:block;transition:transform var(--fast),border-color var(--fast),box-shadow var(--fast)}
a.panel:hover{transform:translateY(-3px);border-color:var(--line-2)}

/* ---------- Hero / headings ---------- */
.hero{padding:26px 0}
.eyebrow{display:inline-flex;align-items:center;gap:7px;font-size:.78rem;font-weight:800;letter-spacing:1.4px;text-transform:uppercase;color:var(--accent)}
.headline,.hero h1{font-family:var(--font-head);font-size:clamp(1.7rem,4vw,3rem);font-weight:var(--fw-head);line-height:1.12;margin:0 0 12px;letter-spacing:var(--tracking-head);color:#fff;text-transform:var(--uppercase)}
.sub{color:var(--muted);margin:.2rem 0}
h2{font-family:var(--font-head);font-weight:var(--fw-head);letter-spacing:var(--tracking-head)}
.section-title{display:flex;align-items:center;justify-content:space-between;gap:14px;margin:30px 0 14px}
.section-title h2{margin:0;font-size:1.3rem;position:relative;padding-inline-start:15px;text-transform:var(--uppercase)}
.section-title h2::before{content:"";position:absolute;inset-inline-start:0;top:50%;transform:translateY(-50%);width:5px;height:1.05em;border-radius:var(--r-pill);background:var(--card-accent)}

/* ---------- Match grid + cards ---------- */
.match-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:var(--gap)}
.match-card{position:relative;display:block;overflow:hidden;background:var(--card-bg);border:var(--border-w) solid var(--line);border-radius:var(--card-radius);padding:14px 15px 15px;transition:transform var(--fast),border-color var(--fast),box-shadow var(--fast)}
.match-card::before{content:"";position:absolute;inset:0 0 auto;height:var(--topline);background:var(--card-accent);opacity:0;transition:opacity var(--med)}
.match-card:hover{transform:translateY(-4px);border-color:var(--line-2);box-shadow:0 26px 50px -26px rgba(0,0,0,.85)}
.match-card:hover::before{opacity:1}
.match-card.live{border-color:var(--live)}
.match-card.live::before{background:var(--live);opacity:1}
.meta{display:flex;align-items:center;justify-content:space-between;gap:10px;color:var(--muted);font-size:.78rem;font-weight:700}
.meta span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:62%;text-transform:uppercase;letter-spacing:.5px}
.meta time{color:var(--muted-2);font-variant-numeric:tabular-nums;white-space:nowrap}
.teams{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:8px;margin:14px 0 12px}
.team{display:grid;justify-items:center;gap:9px;text-align:center;font-weight:800;font-size:.96rem;line-height:1.25}
.logo{width:54px;height:54px;border-radius:50%;object-fit:contain;background:radial-gradient(circle at 50% 35%,#fff,#e8eefc);padding:7px;box-shadow:0 6px 16px -6px rgba(0,0,0,.6),0 0 0 1px var(--line);transition:transform var(--med)}
.match-card:hover .logo{transform:scale(1.07) translateY(-1px)}
.score{font-size:1.55rem;font-weight:900;font-variant-numeric:tabular-nums;min-width:64px;text-align:center;padding:5px 10px;border-radius:var(--r-sm);background:rgba(255,255,255,.05);border:1px solid var(--line);color:#fff}
.match-card.live .score{background:var(--status-live-bg);border-color:var(--live)}

/* ---------- Status pills ---------- */
.status{display:inline-flex;align-items:center;gap:6px;border-radius:var(--r-pill);padding:5px 12px;background:rgba(255,255,255,.06);border:1px solid var(--line);color:var(--muted);font-weight:800;font-size:.76rem;letter-spacing:.3px}
.match-card>.status{margin-top:2px}
.status.live{background:var(--status-live-bg);border-color:var(--live);color:#ff97ab}
.status.live::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--live);animation:livePulse 1.4s infinite}
.status.finished{background:rgba(43,210,138,.12);border-color:rgba(43,210,138,.32);color:var(--ok)}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:0;border-radius:var(--r-sm);padding:11px 18px;background:var(--grad-accent);color:var(--accent-ink);font-family:var(--font-head);font-weight:900;font-size:.98rem;cursor:pointer;position:relative;overflow:hidden;transition:transform var(--fast),box-shadow var(--fast),filter var(--fast)}
.btn:hover{transform:translateY(-2px);filter:brightness(1.05)}
.btn:active{transform:translateY(0)}
.btn.ghost{background:transparent;color:var(--text);border:1px solid var(--line-2)}
.btn.ghost:hover{border-color:var(--accent);color:#fff}

/* ---------- Inputs ---------- */
.input,textarea,select.input{width:100%;border:1px solid var(--line-2);background:rgba(0,0,0,.28);color:var(--text);border-radius:var(--r-sm);padding:12px 14px;font:inherit;font-weight:600;transition:border-color var(--fast),box-shadow var(--fast)}
.input::placeholder,textarea::placeholder{color:var(--muted-2)}
.input:focus,textarea:focus,select.input:focus{outline:0;border-color:var(--accent-2);box-shadow:0 0 0 4px color-mix(in srgb,var(--accent-2) 22%,transparent)}
textarea{min-height:130px;resize:vertical}
label{display:block;color:var(--muted);font-weight:700;font-size:.9rem}
label .input,label textarea,label select{margin-top:6px}

/* ---------- Ticker ---------- */
.ticker{position:relative;overflow:hidden;margin-top:1px;background:var(--bg-2);border-block:1px solid var(--line)}
.ticker-track{display:flex;gap:10px;width:max-content;padding:9px 0;padding-inline-end:96px;animation:ticker 60s linear infinite}
.ticker:hover .ticker-track{animation-play-state:paused}
.ticker-item{display:flex;align-items:center;gap:8px;white-space:nowrap;color:#d7e2f5;font-weight:700;font-size:.86rem;padding:4px 12px;border-radius:var(--r-pill);border:1px solid var(--line);background:rgba(255,255,255,.04)}
.ticker-item b{color:#fff}
.ticker-item .status{padding:2px 9px;font-size:.7rem}
.ticker-live-dot{position:absolute;inset-inline-end:14px;top:50%;transform:translateY(-50%);display:flex;align-items:center;gap:7px;padding:4px 12px;border-radius:var(--r-pill);background:var(--status-live-bg);border:1px solid var(--live);color:#ff8197;font-weight:900;font-size:.74rem;letter-spacing:1px}
.ticker-live-dot::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--live);box-shadow:0 0 12px var(--live);animation:livePulse 1.4s infinite}

/* ---------- Live center ---------- */
.live-center{padding:18px 0 24px;display:grid;gap:14px}
.live-stat-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}
.live-stat{position:relative;overflow:hidden;display:grid;align-content:center;gap:2px;min-height:104px;padding:16px;text-align:center;border:1px solid var(--line);border-radius:var(--r);background:var(--card-bg)}
.live-stat::after{content:"";position:absolute;inset:auto 16px 0;height:3px;border-radius:var(--r-pill);background:var(--card-accent)}
.live-stat span{font-size:.72rem;font-weight:900;letter-spacing:1.5px;text-transform:uppercase;color:var(--accent)}
.live-stat b{font-size:2rem;line-height:1.15;font-weight:900;color:#fff;font-variant-numeric:tabular-nums}
.live-stat small{color:var(--muted);font-weight:700}
.live-control-grid{display:grid;grid-template-columns:170px minmax(320px,.95fr) 1.05fr;gap:12px}
.live-clock,.live-tabs,.live-title{border:1px solid var(--line);border-radius:var(--r);background:var(--panel);padding:16px}
.live-clock{text-align:center;display:grid;align-content:center;gap:3px}
.live-clock span,.live-clock small{color:var(--muted);font-weight:700;font-size:.82rem}
.live-clock b{font-size:2.1rem;line-height:1.15;color:var(--accent);font-weight:900;font-variant-numeric:tabular-nums;letter-spacing:1px}
.live-tabs{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;padding:10px}
.live-tabs a{display:grid;place-items:center;min-height:80px;border-radius:var(--r-sm);border:1px solid var(--line);background:rgba(255,255,255,.03);color:var(--muted);font-weight:800;font-size:.92rem;transition:transform var(--fast),color var(--fast),border-color var(--fast)}
.live-tabs a:hover{transform:translateY(-2px);color:#fff;border-color:var(--line-2)}
.live-tabs a.active{color:var(--accent-ink);background:var(--grad-accent);border-color:transparent}
.live-title{display:grid;align-content:center;gap:4px}
.live-title strong{color:var(--accent);font-weight:900;font-size:.78rem;letter-spacing:1.4px;text-transform:uppercase}
.live-title h1{margin:2px 0;font-size:1.8rem;font-weight:900;color:#fff}
.live-title p{margin:0;color:var(--muted)}
.live-focus{position:relative;overflow:hidden;border:1px solid var(--line);border-radius:var(--r);padding:16px;background:var(--panel)}
.live-focus-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}
.live-focus-head b{color:#fff;font-weight:900;font-size:1.05rem;padding-inline-start:12px;border-inline-start:4px solid var(--accent)}
.live-focus-head small{color:var(--muted);font-weight:700}
.focus-grid{grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}
.focus-grid .match-card:only-child{grid-column:1/-1}
.focus-grid .match-card:nth-child(3):last-child{grid-column:1/-1}

/* ---------- World cup hero ---------- */
.world-hero{position:relative;overflow:hidden}
.world-hero .panel{text-align:center}
.world-hero h2{font-size:1.8rem;color:#fff;margin:.2rem 0 0}
.world-hero span{color:var(--accent);font-weight:800;letter-spacing:1px;text-transform:uppercase;font-size:.8rem}

/* ---------- Match page ---------- */
.match-layout{display:grid;grid-template-columns:minmax(0,1fr) 340px;gap:16px;align-items:start}
.match-layout>div{display:grid;gap:16px}
.match-layout .teams .score{font-size:2.1rem;min-width:96px}
.match-layout .team span{font-size:1.05rem}
.match-layout .logo{width:72px;height:72px}
.player{position:relative;min-height:clamp(280px,46vw,460px);background:radial-gradient(circle at 50% 40%,var(--bg-2),#02050c);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;display:grid;place-items:center}
.server-tabs{display:flex;gap:9px;flex-wrap:wrap;margin:12px 0 16px}
.server-btn{border:1px solid var(--line-2);background:rgba(255,255,255,.05);color:var(--text);border-radius:var(--r-sm);padding:9px 15px;font-weight:800;cursor:pointer;transition:transform var(--fast),background var(--fast),color var(--fast),border-color var(--fast)}
.server-btn:hover{transform:translateY(-2px);border-color:var(--accent-2)}
.server-btn.active{background:var(--grad-accent);color:var(--accent-ink);border-color:transparent}
.article h2{margin:20px 0 9px;color:#fff;font-size:1.25rem}
.article p,.article li{color:color-mix(in srgb,var(--text) 82%,transparent)}
.article ul{margin:9px 0 16px;padding-inline-start:22px;display:grid;gap:6px}
.article a{color:var(--accent);font-weight:800}

/* ---------- Empty / footer ---------- */
.empty{text-align:center;color:var(--muted);padding:34px 22px;border:1px dashed var(--line-2);border-radius:var(--r);background:rgba(255,255,255,.015);font-weight:600}
.footer{position:relative;z-index:1;margin-top:46px;padding:30px 0;border-top:1px solid var(--line);color:var(--muted)}
.footer a{color:var(--muted);font-weight:700}
.footer a:hover{color:var(--accent)}

/* ---------- Contact ---------- */
.contact-page{min-height:clamp(520px,calc(100vh - 230px),760px);display:grid;place-items:center;padding:30px 0}
.contact-shell{width:min(1000px,100%);display:grid;grid-template-columns:minmax(240px,.86fr) minmax(280px,1.14fr);gap:16px;align-items:stretch}
.contact-copy,.contact-card{border:1px solid var(--line);border-radius:var(--r-lg);background:var(--panel);box-shadow:var(--shadow)}
.contact-copy{display:grid;align-content:center;gap:14px;padding:26px}
.contact-copy h1{margin:0;color:#fff;font-weight:900;font-size:2rem}
.contact-mini-grid{display:grid;gap:9px}
.contact-mini-grid span{min-height:42px;display:flex;align-items:center;border:1px solid var(--line);border-radius:var(--r-sm);background:rgba(0,0,0,.25);padding:9px 13px;color:var(--muted);font-weight:600}
.contact-form{display:grid;gap:11px;padding:22px;max-width:none}

/* ---------- Language switch ---------- */
.lang-switch{display:flex;gap:5px;align-items:center;flex-wrap:wrap}
.lang-switch a{border:1px solid var(--line);border-radius:var(--r-sm);padding:7px 10px;color:var(--muted);font-size:.76rem;font-weight:900;letter-spacing:.5px;transition:color var(--fast),background var(--fast),border-color var(--fast)}
.lang-switch a:hover{color:#fff;border-color:var(--line-2)}
.lang-switch a.active{background:var(--grad-accent);color:var(--accent-ink);border-color:transparent}

/* ---------- Flags ---------- */
.flag{font-size:1.05em;filter:saturate(1.2) drop-shadow(0 1px 2px rgba(0,0,0,.4))}

/* ---------- Mobile menu ---------- */
.menu-toggle{display:none;width:44px;height:44px;border:1px solid var(--line-2);border-radius:13px;background:rgba(255,255,255,.04);color:#eaf2ff;place-items:center;gap:4px;padding:11px;cursor:pointer}
.menu-toggle:hover{border-color:var(--accent-2)}
.menu-toggle span{display:block;width:18px;height:2px;border-radius:var(--r-pill);background:currentColor;transition:transform .2s var(--ease),opacity .2s var(--ease)}
.topbar.menu-open .menu-toggle span:nth-child(1){transform:translateY(6px) rotate(45deg)}
.topbar.menu-open .menu-toggle span:nth-child(2){opacity:0}
.topbar.menu-open .menu-toggle span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}
.mobile-menu-panel{display:flex;align-items:center;gap:8px;flex-wrap:wrap}

/* ============================================================
   NOTIFICATIONS (shared structure; skins recolor)
   ============================================================ */
.event-alerts{position:fixed;inset-inline-start:16px;bottom:16px;z-index:90;display:grid;gap:11px;width:min(380px,calc(100vw - 32px));pointer-events:none}
.event-alert{pointer-events:auto;position:relative;overflow:hidden;display:grid;grid-template-columns:46px 1fr;gap:12px;padding:13px 40px 13px 13px;border-radius:var(--r);border:1px solid var(--line-2);background:var(--card-bg);box-shadow:0 22px 50px -20px rgba(0,0,0,.7);color:var(--text);backdrop-filter:blur(14px);animation:alertIn .42s var(--ease) both}
[dir="rtl"] .event-alert{padding:13px 13px 13px 40px}
.event-alert .ev-bar{position:absolute;inset:0 auto 0 0;width:4px;background:var(--accent-2)}
[dir="rtl"] .event-alert .ev-bar{inset:0 0 0 auto}
.event-alert .ev-ico{grid-row:1/3;align-self:start;display:grid;place-items:center;width:46px;height:46px;border-radius:13px;font-size:1.4rem;background:color-mix(in srgb,var(--accent-2) 16%,transparent);border:1px solid color-mix(in srgb,var(--accent-2) 40%,transparent)}
.event-alert strong{display:block;color:#fff;font-size:1.02rem;font-weight:900;line-height:1.25}
.event-alert .ev-sub{margin:1px 0 7px;color:var(--muted);font-size:.86rem;font-weight:600}
.event-alert .ev-meta{display:flex;align-items:center;gap:9px;flex-wrap:wrap;color:var(--muted)}
.event-alert .ev-min{background:rgba(255,255,255,.08);color:#fff;font-weight:900;border-radius:var(--r-pill);padding:2px 9px;font-size:.78rem;font-variant-numeric:tabular-nums}
.event-alert .ev-score{color:#fff;font-weight:900;font-size:1rem;font-variant-numeric:tabular-nums}
.event-alert .ev-actor{color:var(--muted);font-weight:700;font-size:.84rem}
.event-alert .ev-close{position:absolute;top:8px;inset-inline-end:8px;width:26px;height:26px;border:0;border-radius:8px;background:rgba(255,255,255,.08);color:#fff;cursor:pointer;font-size:1rem;line-height:1;transition:background var(--fast),transform var(--fast)}
.event-alert .ev-close:hover{background:rgba(255,255,255,.2);transform:rotate(90deg)}
.event-alert.soft{opacity:.7}
.event-alert::after{content:"";position:absolute;inset:0 0 auto;height:2px;background:linear-gradient(90deg,transparent,var(--accent-2),transparent);transform:translateX(-100%);animation:sweep 2.4s var(--ease) infinite}
.event-alert.goal{border-color:var(--live)}
.event-alert.goal .ev-bar{background:var(--live)}
.event-alert.goal .ev-ico{background:var(--status-live-bg);border-color:var(--live);animation:goalKick .6s var(--ease)}
.event-alert.goal::after{background:linear-gradient(90deg,transparent,var(--live),var(--gold),transparent)}
.event-alert.redcard .ev-bar{background:linear-gradient(180deg,#ff2e57,#b3001e)}
.event-alert.redcard .ev-ico{background:linear-gradient(160deg,#ff3d5e,#c20021);border-color:rgba(255,80,110,.6);color:#fff;animation:cardFlip .6s var(--ease)}
.event-alert.penalty .ev-bar{background:linear-gradient(180deg,var(--gold),#ff8a00)}
.event-alert.penalty .ev-ico{background:color-mix(in srgb,var(--gold) 18%,transparent);border-color:var(--gold);color:var(--gold)}
.event-alert.kickoff .ev-bar{background:var(--grad-accent)}
.event-alert.kickoff .ev-ico{background:color-mix(in srgb,var(--accent) 16%,transparent);border-color:var(--accent);color:var(--accent)}
.event-alert.halftime .ev-bar{background:linear-gradient(180deg,#5ad0ff,#23e0c8)}
.event-alert.halftime .ev-ico{background:rgba(35,224,200,.16);border-color:rgba(35,224,200,.45);color:#23e0c8}
.event-alert.fulltime .ev-bar{background:linear-gradient(180deg,var(--ok),#0fb36b)}
.event-alert.fulltime .ev-ico{background:color-mix(in srgb,var(--ok) 16%,transparent);border-color:var(--ok);color:var(--ok)}

/* ---------- Goal celebration ---------- */
.goal-burst{position:fixed;inset:0;z-index:120;pointer-events:none;display:grid;place-items:center;animation:burstFade 2.1s var(--ease) forwards}
.goal-burst::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 50% 50%,color-mix(in srgb,var(--live) 28%,transparent),transparent 55%);animation:flashPulse .8s var(--ease) 2}
.goal-burst .goal-word{position:relative;font-family:var(--font-head);font-size:clamp(3rem,13vw,9rem);font-weight:900;letter-spacing:-2px;color:#fff;text-shadow:0 0 40px color-mix(in srgb,var(--live) 80%,transparent),0 0 14px rgba(255,255,255,.5);animation:goalPop .7s var(--ease) both}
.goal-burst .spark{position:absolute;top:50%;left:50%;width:11px;height:11px;border-radius:2px;background:var(--accent);transform:translate(-50%,-50%);animation:spark 1.1s var(--ease) forwards}

/* ---------- Skeleton ---------- */
.logo:not([src]),.logo[src=""]{background:linear-gradient(100deg,rgba(255,255,255,.06) 30%,rgba(255,255,255,.16) 50%,rgba(255,255,255,.06) 70%);background-size:200% 100%;animation:shimmer 1.3s linear infinite}

/* ---------- Entrance ---------- */
.match-grid>*,.hero,.section-title{animation:fadeUp .5s var(--ease) both}
.match-grid>*:nth-child(2){animation-delay:.04s}
.match-grid>*:nth-child(3){animation-delay:.08s}
.match-grid>*:nth-child(4){animation-delay:.12s}
.match-grid>*:nth-child(n+5){animation-delay:.16s}

/* ---------- Keyframes ---------- */
@keyframes ticker{to{transform:translateX(-50%)}}
@keyframes livePulse{0%{box-shadow:0 0 0 0 color-mix(in srgb,var(--live) 55%,transparent)}70%{box-shadow:0 0 0 7px transparent}100%{box-shadow:0 0 0 0 transparent}}
@keyframes fadeUp{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
@keyframes alertIn{from{opacity:0;transform:translateY(16px) scale(.96)}to{opacity:1;transform:none}}
@keyframes sweep{0%{transform:translateX(-100%)}60%,100%{transform:translateX(100%)}}
@keyframes goalKick{0%{transform:scale(.6) rotate(-25deg)}55%{transform:scale(1.18) rotate(8deg)}100%{transform:none}}
@keyframes cardFlip{0%{transform:rotateY(90deg) scale(.7)}100%{transform:none}}
@keyframes burstFade{0%{opacity:1}80%{opacity:1}100%{opacity:0;visibility:hidden}}
@keyframes flashPulse{0%{opacity:0}30%{opacity:1}100%{opacity:0}}
@keyframes goalPop{0%{opacity:0;transform:scale(.4) translateY(20px)}55%{opacity:1;transform:scale(1.12)}100%{transform:scale(1)}}
@keyframes spark{0%{opacity:0;transform:translate(-50%,-50%) scale(.4) rotate(0)}20%{opacity:1}100%{opacity:0;transform:translate(calc(-50% + var(--dx,0px)),calc(-50% + var(--dy,0px))) scale(.5) rotate(160deg)}}
@keyframes shimmer{to{background-position:-200% 0}}

/* ---------- Responsive ---------- */
@media(max-width:900px){
  .match-layout{grid-template-columns:1fr}
  .live-stat-grid{grid-template-columns:repeat(2,1fr)}
  .live-control-grid{grid-template-columns:1fr}
  .live-tabs{grid-template-columns:repeat(4,minmax(78px,1fr))}
  .contact-shell{grid-template-columns:1fr}
  .contact-page{min-height:auto;padding:16px 0 26px}
}
@media(max-width:850px){
  .nav{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px}
  .menu-toggle{display:grid}
  .mobile-menu-panel{display:none;grid-column:1/-1}
  .topbar.menu-open .mobile-menu-panel{display:grid;gap:10px;animation:fadeUp .3s var(--ease) both}
  .mobile-menu-panel .menu{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;width:100%}
  .mobile-menu-panel .menu a{justify-content:center;text-align:center;white-space:normal}
  .mobile-menu-panel .lang-switch{justify-content:center}
  .ticker-live-dot{display:none}
  .live-focus-head{flex-direction:column;align-items:flex-start;gap:4px}
}
@media(max-width:560px){
  .wrap{width:calc(100% - 22px)}
  .match-grid{grid-template-columns:1fr;gap:12px}
  .logo{width:48px;height:48px}
  .score{font-size:1.4rem}
  .event-alerts{inset-inline:10px;bottom:10px;width:auto}
  .focus-grid .match-card:nth-child(3):last-child{grid-column:auto}
}
@media(max-width:520px){.mobile-menu-panel .menu{grid-template-columns:1fr}}
@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.001s!important;animation-iteration-count:1!important;transition-duration:.001s!important}.ticker-track{animation:none}}
