
:root{
  --night:#070b12; --sky:#0c1320; --panel:#101826; --panel2:#17202f;
  --line:#22304a; --chalk:#e9e4d8; --dim:#8d97a8;
  --led:#ffb000; --led-dim:#8a6510; --siren:#ff4530; --turf:#1db954;
  --turf-deep:#0e3d22; --ok:#37d68f;
}
*{box-sizing:border-box;margin:0;padding:0}
html{font-size:17px;scroll-behavior:smooth}
body{
  background:var(--night); color:var(--chalk);
  font-family:"Newsreader",Georgia,serif; line-height:1.65;
}
/* floodlight beams */
body::before{
  content:""; position:fixed; inset:0; z-index:-1; pointer-events:none;
  background:
    radial-gradient(ellipse 55% 38% at 8% -6%, rgba(255,214,120,.13), transparent 60%),
    radial-gradient(ellipse 55% 38% at 92% -6%, rgba(255,214,120,.13), transparent 60%),
    radial-gradient(ellipse 90% 55% at 50% 115%, rgba(14,61,34,.5), transparent 65%),
    linear-gradient(180deg, #0c1424 0%, var(--night) 45%);
}
body::after{ /* grain */
  content:""; position:fixed; inset:0; pointer-events:none; opacity:.05; z-index:50;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='160' height='160' filter='url(%23n)' opacity='0.6'/%3E%3C/svg%3E");
}
a{color:var(--led);text-decoration:none}
a:hover{text-decoration:underline}
.wrap{max-width:880px;margin:0 auto;padding:0 22px}

/* ------------------------------------------------------------ header */
header.site{
  position:sticky; top:0; z-index:40;
  background:rgba(7,11,18,.82); backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line);
}
.topbar{display:flex;align-items:center;gap:18px;padding:14px 0}
.brand{font-family:"Bricolage Grotesque",sans-serif;font-weight:800;font-size:1.45rem;
  letter-spacing:-.02em;white-space:nowrap}
.brand a{color:var(--chalk)} .brand a:hover{text-decoration:none}
.brand .digits{font-variant-numeric:tabular-nums;color:var(--led);text-shadow:0 0 16px rgba(255,176,0,.5)}
.brand .colon{animation:blink 1.6s steps(1) infinite}
@keyframes blink{50%{opacity:.15}}
nav.site{display:flex;gap:20px;margin-left:auto;font-family:"Bricolage Grotesque",sans-serif;
  font-size:.74rem;letter-spacing:.13em;text-transform:uppercase}
nav.site a{color:var(--dim);padding:6px 2px;border-bottom:2px solid transparent}
nav.site a:hover{color:var(--chalk);text-decoration:none;border-bottom-color:var(--led)}
.sgclock{font-family:"Bricolage Grotesque",sans-serif;font-weight:700;font-variant-numeric:tabular-nums;
  font-size:.8rem;color:var(--led);border:1px solid var(--led-dim);border-radius:7px;
  padding:5px 10px;white-space:nowrap;background:rgba(255,176,0,.06);
  box-shadow:inset 0 0 12px rgba(255,176,0,.06)}
.sgclock small{color:var(--dim);letter-spacing:.1em;margin-right:6px}

/* ------------------------------------------------------------ ticker */
.ticker{border-bottom:1px solid var(--line);background:var(--sky);overflow:hidden;white-space:nowrap}
.ticker-track{display:inline-block;padding:8px 0;animation:tick 36s linear infinite}
.ticker:hover .ticker-track{animation-play-state:paused}
.ticker-track span{font-family:"Bricolage Grotesque",sans-serif;font-size:.74rem;
  letter-spacing:.1em;text-transform:uppercase;color:var(--dim);margin:0 26px}
.ticker-track b{color:var(--chalk);font-weight:700}
.ticker-track .t{color:var(--led);font-variant-numeric:tabular-nums}
@keyframes tick{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* -------------------------------------------------------------- hero */
.hero{
  position:relative; overflow:hidden; margin:30px 0 36px;
  border:1px solid var(--line); border-radius:16px;
  background:linear-gradient(160deg, #11203a 0%, #0b1626 45%, var(--turf-deep) 130%);
  padding:40px 36px 34px;
}
.hero .pitch{position:absolute;inset:0;opacity:.16;pointer-events:none}
.hero .glow{position:absolute;width:420px;height:420px;border-radius:50%;
  background:radial-gradient(circle, rgba(255,176,0,.16), transparent 65%);
  top:-210px;right:-110px;pointer-events:none}
.hero .kicker{margin-bottom:14px}
.kicker{font-family:"Bricolage Grotesque",sans-serif;font-size:.72rem;letter-spacing:.2em;
  text-transform:uppercase;color:var(--led);display:flex;align-items:center;gap:10px}
.kicker::before{content:"";width:26px;height:2px;background:var(--led);display:inline-block}
.hero .teams{font-family:"Bricolage Grotesque",sans-serif;font-weight:800;
  font-size:clamp(1.9rem,5.4vw,3.1rem);line-height:1.04;letter-spacing:-.025em;margin:0 0 6px}
.hero .teams .vs{color:var(--turf);font-size:.5em;vertical-align:middle;margin:0 12px;
  font-style:italic;font-weight:700}
.hero .sub{color:var(--dim);font-size:.95rem;margin-bottom:22px}
.hero .row{display:flex;flex-wrap:wrap;align-items:center;gap:26px}
.countdown{display:flex;gap:10px}
.countdown .cell{background:rgba(7,11,18,.7);border:1px solid var(--led-dim);border-radius:10px;
  padding:10px 0;text-align:center;min-width:74px;
  box-shadow:inset 0 0 16px rgba(255,176,0,.05)}
.countdown .num{font-family:"Bricolage Grotesque",sans-serif;font-weight:800;font-size:1.7rem;
  color:var(--led);font-variant-numeric:tabular-nums;text-shadow:0 0 14px rgba(255,176,0,.45);line-height:1}
.countdown .lab{font-size:.6rem;letter-spacing:.18em;text-transform:uppercase;color:var(--dim);margin-top:5px;
  font-family:"Bricolage Grotesque",sans-serif}
.hero .cta{font-family:"Bricolage Grotesque",sans-serif;font-weight:700;font-size:.85rem;
  letter-spacing:.06em;background:var(--led);color:#190f00;padding:12px 22px;border-radius:9px;
  box-shadow:0 0 26px rgba(255,176,0,.35);transition:transform .15s}
.hero .cta:hover{transform:translateY(-2px);text-decoration:none}

/* ------------------------------------------------------------- cards */
h1{font-family:"Bricolage Grotesque",sans-serif;font-weight:800;font-size:2rem;
  line-height:1.12;letter-spacing:-.02em;margin:0 0 18px}
h2{font-family:"Bricolage Grotesque",sans-serif;font-weight:700;font-size:1.2rem;margin:38px 0 14px}
.section-kicker{margin:34px 0 14px}
.card{
  position:relative;background:var(--panel);border:1px solid var(--line);border-radius:12px;
  padding:18px 22px 18px 30px;margin-bottom:14px;display:flex;gap:18px;align-items:center;
  transition:border-color .2s, transform .2s, box-shadow .2s; overflow:hidden;
}
.card::before{ /* ticket perforation */
  content:""; position:absolute; left:9px; top:6px; bottom:6px; width:0;
  border-left:2px dashed var(--line);
}
.card:hover{border-color:var(--led-dim);transform:translateY(-2px);box-shadow:0 8px 30px rgba(0,0,0,.45)}
.card .ko{font-variant-numeric:tabular-nums;font-family:"Bricolage Grotesque",sans-serif;
  font-weight:800;font-size:1.45rem;color:var(--led);min-width:104px;
  text-shadow:0 0 14px rgba(255,176,0,.35);line-height:1.1}
.card .ko small{display:block;color:var(--dim);font-size:.62rem;letter-spacing:.14em;
  text-transform:uppercase;text-shadow:none;margin-top:3px}
.card .fixture{flex:1}
.card .teams{font-family:"Bricolage Grotesque",sans-serif;font-weight:700;font-size:1.06rem}
.card .why{color:var(--dim);font-size:.88rem;margin-top:3px}
.chip{display:inline-block;font-family:"Bricolage Grotesque",sans-serif;font-size:.62rem;
  letter-spacing:.12em;text-transform:uppercase;color:var(--turf);border:1px solid var(--turf-deep);
  background:rgba(29,185,84,.07);border-radius:5px;padding:2px 7px;margin-top:7px}
.badge{font-family:"Bricolage Grotesque",sans-serif;font-weight:800;border-radius:9px;
  padding:8px 13px;font-size:.95rem;white-space:nowrap}
.badge.s5{background:var(--siren);color:#fff;box-shadow:0 0 22px rgba(255,69,48,.55);animation:pulse 1.4s ease-in-out infinite}
.badge.s4{background:var(--led);color:#1a1205;box-shadow:0 0 18px rgba(255,176,0,.35)}
.badge.s3{background:var(--panel2);color:var(--led);border:1px solid var(--led-dim)}
.badge.s2,.badge.s1{background:var(--panel2);color:var(--dim);border:1px solid var(--line)}
@keyframes pulse{50%{box-shadow:0 0 36px rgba(255,69,48,.9)}}

/* ----------------------------------------------------------- article */
.match-strip{
  border:1px solid var(--line);border-radius:14px;margin:28px 0;
  background:linear-gradient(150deg,#11203a, #0b1626 70%);
  padding:24px 28px;position:relative;overflow:hidden;
}
.match-strip .pitch{position:absolute;inset:0;opacity:.13;pointer-events:none}
.match-strip .teams{font-family:"Bricolage Grotesque",sans-serif;font-weight:800;
  font-size:1.5rem;letter-spacing:-.02em}
.match-strip .teams .vs{color:var(--turf);font-style:italic;font-size:.75em;margin:0 8px}
.match-strip .sub{color:var(--dim);font-size:.9rem;margin-top:4px;font-variant-numeric:tabular-nums}
article{max-width:680px}
article p{margin:0 0 18px}
article ul{margin:0 0 18px 22px}
article li{margin-bottom:8px}
article strong{color:#fff}
article h2{display:flex;align-items:center;gap:10px}
article h2::before{content:"";width:8px;height:8px;border-radius:50%;
  background:var(--turf);box-shadow:0 0 10px rgba(29,185,84,.7);flex:none}
article blockquote{
  background:var(--panel);border:1px solid var(--led-dim);border-radius:12px;
  padding:18px 22px;margin:0 0 22px;
  box-shadow:0 0 30px rgba(255,176,0,.08), inset 0 0 18px rgba(255,176,0,.04);
}
article blockquote p{margin:0 0 6px} article blockquote p:last-child{margin:0}
article table{width:100%;border-collapse:collapse;font-size:.92rem;margin:0 0 22px}
.meta{color:var(--dim);font-size:.9rem;margin-bottom:26px}

/* ------------------------------------------------------- scoreboard */
.scoreboard{
  display:inline-flex;align-items:baseline;gap:14px;border:1px solid var(--led-dim);
  background:#0a0f08;border-radius:14px;padding:18px 28px;margin:6px 0 10px;
  box-shadow:inset 0 0 30px rgba(255,176,0,.06), 0 0 36px rgba(255,176,0,.08);
}
.scoreboard .digits{font-family:"Bricolage Grotesque",sans-serif;font-weight:800;
  font-size:3.2rem;color:var(--led);font-variant-numeric:tabular-nums;
  text-shadow:0 0 26px rgba(255,176,0,.55);line-height:1}
.scoreboard .label{font-family:"Bricolage Grotesque",sans-serif;font-size:.68rem;
  letter-spacing:.18em;text-transform:uppercase;color:var(--dim)}
table{width:100%;border-collapse:collapse;font-size:.92rem;margin:18px 0 22px}
th{font-family:"Bricolage Grotesque",sans-serif;font-size:.68rem;letter-spacing:.14em;
  text-transform:uppercase;color:var(--dim);text-align:left;padding:8px 10px;border-bottom:1px solid var(--line)}
td{padding:11px 10px;border-bottom:1px solid var(--line);vertical-align:top}
tr:hover td{background:rgba(255,176,0,.025)}
.v-ok{color:var(--ok);font-weight:700} .v-no{color:var(--siren);font-weight:700}

/* -------------------------------------------------------------- list */
.list a{display:flex;gap:14px;padding:14px 4px;border-bottom:1px solid var(--line);color:var(--chalk);
  align-items:baseline;transition:background .15s}
.list a:hover{color:var(--led);text-decoration:none;background:rgba(255,176,0,.03)}
.list .d{color:var(--dim);font-size:.82rem;font-variant-numeric:tabular-nums;flex:none;
  font-family:"Bricolage Grotesque",sans-serif}

/* ------------------------------------------------------------ footer */
footer.site{border-top:1px solid var(--line);margin-top:70px;background:var(--sky)}
.footgrid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:34px;padding:38px 0 30px}
@media(max-width:640px){.footgrid{grid-template-columns:1fr}}
footer .fbrand{font-family:"Bricolage Grotesque",sans-serif;font-weight:800;font-size:1.2rem;margin-bottom:10px}
footer p, footer a{color:var(--dim);font-size:.86rem}
footer h4{font-family:"Bricolage Grotesque",sans-serif;font-size:.7rem;letter-spacing:.16em;
  text-transform:uppercase;color:var(--chalk);margin-bottom:12px}
footer ul{list-style:none}
footer li{margin-bottom:8px}
footer a:hover{color:var(--led)}
.footbottom{border-top:1px solid var(--line);padding:16px 0 26px;display:flex;
  justify-content:space-between;flex-wrap:wrap;gap:10px;color:var(--dim);font-size:.78rem}
.footbottom .pitchline{color:var(--turf)}

/* ------------------------------------------------------ mobile pass */
@media(max-width:720px){
  html{font-size:15.5px}
  .wrap{padding:0 14px}
  /* header: tighter, clock moves to its own row edge */
  .topbar{flex-wrap:wrap;gap:8px 12px;padding:10px 0}
  .brand{font-size:1.1rem;gap:8px}
  .logo{width:30px;height:30px}
  nav.site{gap:12px;font-size:.64rem;margin-left:0;order:3;width:100%;justify-content:space-between}
  .sgclock{margin-left:auto;font-size:.7rem;padding:4px 8px}
  /* hero: tighter, countdown spans the width, CTA full width */
  .hero{padding:22px 16px;margin:18px 0 26px;border-radius:12px}
  .hero .sub{font-size:.88rem;margin-bottom:16px}
  .hero .row{gap:12px}
  .countdown{width:100%;gap:6px}
  .countdown .cell{min-width:0;flex:1;padding:8px 0}
  .countdown .num{font-size:1.35rem}
  .hero .cta{width:100%;text-align:center;padding:13px 0}
  .badge{margin-left:auto}
  .teambar{width:120px;margin-bottom:14px}
  /* cards: kickoff + badge on top row, fixture text below full-width */
  .card{flex-wrap:wrap;gap:8px 14px;padding:14px 14px 14px 24px}
  .card .ko{min-width:0;font-size:1.15rem;order:1}
  .card .badge{order:2}
  .card .fixture{flex:1 1 100%;order:3}
  .card .why{font-size:.84rem}
  /* tables scroll sideways instead of crushing */
  .tablewrap{overflow-x:auto;-webkit-overflow-scrolling:touch;margin:0 -14px;padding:0 14px}
  .tablewrap table{min-width:560px}
  .scoreboard{padding:14px 18px;gap:10px}
  .scoreboard .digits{font-size:2.2rem}
  .match-strip{padding:16px 16px 16px 20px;margin:18px 0}
  .match-strip .teams{font-size:1.15rem}
  h1{font-size:1.5rem}
  article h2{font-size:1.08rem}
  .siren-banner{font-size:.66rem;letter-spacing:.08em;padding:8px 10px}
  .watermark-ball{width:220px;height:220px;right:-90px;bottom:-90px}
  .footgrid{gap:22px;padding:28px 0 22px}
  .footbottom{flex-direction:column;gap:6px}
}

.fadein{animation:rise .5s ease both}
@keyframes rise{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
.fadein.d1{animation-delay:.08s}.fadein.d2{animation-delay:.16s}.fadein.d3{animation-delay:.24s}

/* --------------------------------------------------- football imagery */
.logo{width:40px;height:40px;flex:none;filter:drop-shadow(0 0 10px rgba(255,176,0,.35))}
.brand{display:flex;align-items:center;gap:11px}
.ball-ico{width:15px;height:15px;vertical-align:-2px;color:var(--led)}
.kicker .ball-ico{width:14px;height:14px}
/* goal-net texture on panels */
.card,.match-strip,article blockquote{
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='26' height='26'%3E%3Cg fill='none' stroke='%23e9e4d8' stroke-opacity='0.045'%3E%3Cpath d='M13 0 L26 13 L13 26 L0 13 Z'/%3E%3C/g%3E%3C/svg%3E");
}
/* big watermark ball, slowly rolling */
.watermark-ball{position:fixed;right:-130px;bottom:-130px;width:380px;height:380px;
  opacity:.05;z-index:-1;pointer-events:none;color:#e9e4d8;animation:roll 80s linear infinite}
@keyframes roll{to{transform:rotate(360deg)}}
.ticker-track .sep{color:var(--led-dim);margin:0 2px}
footer .fbrand{display:flex;align-items:center;gap:9px}
footer .logo{width:26px;height:26px}

/* ------------------------------------------------- team colour theming */
.card,.match-strip,.hero{--c1:var(--led);--c2:var(--turf)}
.card::after{content:"";position:absolute;left:0;top:0;right:0;height:4px;
  background:linear-gradient(90deg,var(--c1) 0%,var(--c1) 46%,var(--c2) 54%,var(--c2) 100%)}
.card .dot{display:inline-block;width:9px;height:9px;border-radius:50%;margin-right:7px;
  vertical-align:1px;box-shadow:0 0 8px rgba(255,255,255,.15)}
.teambar{height:5px;width:170px;border-radius:3px;margin:4px 0 18px;
  background:linear-gradient(90deg,var(--c1) 0%,var(--c1) 46%,var(--c2) 54%,var(--c2) 100%);
  box-shadow:0 0 14px rgba(255,255,255,.12)}
.match-strip::after{content:"";position:absolute;left:0;top:0;bottom:0;width:5px;
  background:linear-gradient(180deg,var(--c1),var(--c2))}

/* --------------------------------------------------------- confetti */
.confetti{position:fixed;inset:0;pointer-events:none;z-index:60;overflow:hidden}
.confetti span{position:absolute;top:-16px;width:9px;height:15px;opacity:.95;
  animation:cfall linear forwards;border-radius:2px}
@keyframes cfall{to{transform:translateY(108vh) rotate(740deg);opacity:.65}}
.scoreboard{cursor:pointer}

/* ------------------------------------------------- 5/5 siren takeover */
.siren-banner{
  background:repeating-linear-gradient(135deg,#7a130a 0 26px,#56524d00 26px 52px),#2a0a06;
  border-bottom:1px solid var(--siren);color:#ffd9d4;
  font-family:"Bricolage Grotesque",sans-serif;font-weight:700;font-size:.8rem;
  letter-spacing:.12em;text-transform:uppercase;text-align:center;padding:9px 14px;
  animation:siren-glow 1.6s ease-in-out infinite}
.siren-banner b{color:#fff}
.siren-banner .t{color:var(--led);font-variant-numeric:tabular-nums}
@keyframes siren-glow{50%{box-shadow:inset 0 0 34px rgba(255,69,48,.5)}}
body.siren-day .hero{border-color:rgba(255,69,48,.55);
  box-shadow:0 0 56px rgba(255,69,48,.18), inset 0 0 40px rgba(255,69,48,.05)}
body.siren-day .hero .kicker{color:var(--siren)}
body.siren-day .hero .kicker::before{background:var(--siren)}
body.siren-day .hero .cta{background:var(--siren);color:#fff;box-shadow:0 0 30px rgba(255,69,48,.5)}
body.siren-day .countdown .cell{border-color:rgba(255,69,48,.5)}
body.siren-day .countdown .num{color:#ff6f5e;text-shadow:0 0 16px rgba(255,69,48,.6)}
