:root{
  /* FIFA World Cup 26 host-nation trio */
  --can-red:#e0473c;
  --mex-green:#2fae6e;
  --usa-blue:#3f7ad8;
  --gold:#f0c75e;

  --bg:#0a0f1e;            /* deep night-sky navy */
  --panel:rgba(20,28,48,.72);
  --panel-solid:#141c30;
  --line:rgba(120,150,210,.18);
  --ink:#eef2fb;
  --muted:#9aa8c7;
  --bad:#e0635c;
  --radius:14px;
  font-size:16px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--bg);color:var(--ink);
  font-family:Inter,system-ui,sans-serif;line-height:1.5;min-height:100vh;position:relative}

/* ---- WC26 animated backdrop: tri-colour aurora + pitch lines ---- */
body::before{content:"";position:fixed;inset:0;z-index:-2;
  background:
    radial-gradient(640px 420px at 12% -6%, rgba(224,71,60,.32), transparent 65%),
    radial-gradient(720px 480px at 88% 4%,  rgba(63,122,216,.34), transparent 65%),
    radial-gradient(820px 560px at 50% 108%, rgba(47,174,110,.30), transparent 65%);
  animation:aurora 18s ease-in-out infinite alternate}
body::after{content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;
  background:
    repeating-linear-gradient(90deg, rgba(255,255,255,.022) 0 1px, transparent 1px 120px),
    radial-gradient(circle at 50% 42%, transparent 0 218px, rgba(255,255,255,.05) 219px 220px, transparent 221px);}
@keyframes aurora{
  0%{filter:hue-rotate(0deg) saturate(1);transform:translateY(0)}
  100%{filter:hue-rotate(-14deg) saturate(1.15);transform:translateY(-26px)}}

h1,h2,h3,.brand-text,.stat-num{font-family:"Saira Condensed",Inter,sans-serif;letter-spacing:.02em;text-transform:uppercase}
a{color:#7fd2a4;text-decoration:none}
main{max-width:1080px;margin:0 auto;padding:24px 20px 64px}

/* ---------------- top bar ---------------- */
.topbar{display:flex;flex-wrap:wrap;gap:14px;align-items:center;justify-content:space-between;
  padding:12px 20px;border-bottom:1px solid var(--line);
  background:rgba(8,12,24,.66);backdrop-filter:blur(10px);position:sticky;top:0;z-index:5}
.topbar::after{content:"";position:absolute;left:0;right:0;bottom:-1px;height:2px;
  background:linear-gradient(90deg,var(--can-red),var(--gold),var(--mex-green),var(--usa-blue));
  background-size:300% 100%;animation:ribbon 9s linear infinite}
@keyframes ribbon{to{background-position:300% 0}}
.brand{display:flex;align-items:center;gap:10px;color:var(--ink)}
.brand-badge{background:linear-gradient(135deg,var(--can-red),var(--usa-blue));color:#fff;
  font-weight:800;font-family:"Saira Condensed";padding:4px 9px;border-radius:8px;letter-spacing:.05em}
.brand-text{font-weight:800;font-size:1.02rem;line-height:1.1}
.brand-text small{display:block;font-family:Inter;font-weight:500;font-size:.62rem;
  color:var(--muted);text-transform:none;letter-spacing:.03em}
.topbar nav{display:flex;gap:18px;flex-wrap:wrap}
.topbar nav a{color:var(--muted);font-weight:500;position:relative;padding:2px 0}
.topbar nav a::after{content:"";position:absolute;left:0;bottom:-3px;height:2px;width:0;
  background:var(--mex-green);transition:width .25s}
.topbar nav a:hover{color:var(--ink)}
.topbar nav a:hover::after{width:100%}
.auth{display:flex;align-items:center;gap:12px}
.who{color:var(--muted);font-size:.9rem}
.cta{background:var(--mex-green);color:#06281a;padding:6px 12px;border-radius:8px;font-weight:700}
.link-btn{background:none;border:none;color:#7fd2a4;cursor:pointer;font:inherit;padding:0}
.inline{display:inline}

/* ---------------- messages ---------------- */
.messages{max-width:1080px;margin:14px auto 0;padding:0 20px}
.msg{padding:10px 14px;border-radius:10px;margin-bottom:8px;border:1px solid var(--line);
  background:var(--panel);backdrop-filter:blur(8px);animation:fadeUp .4s ease both}
.msg-success{border-color:var(--mex-green)}
.msg-warning,.msg-error{border-color:var(--bad)}

/* ---------------- hero / dashboard ---------------- */
.hero{display:flex;flex-wrap:wrap;gap:24px;align-items:flex-end;justify-content:space-between;
  margin:30px 0 34px;animation:fadeUp .5s ease both}
.hero .kicker{color:var(--gold);font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  font-size:.78rem;margin-bottom:6px}
.hero h1{font-size:clamp(2.1rem,5.4vw,3.6rem);margin:0;line-height:1.02;
  background:linear-gradient(92deg,#fff 20%,var(--gold) 50%,var(--mex-green) 80%);
  -webkit-background-clip:text;background-clip:text;color:transparent}
.hero .sub{color:var(--muted);max-width:52ch;margin-top:10px}
.pool{background:linear-gradient(160deg,rgba(63,122,216,.18),var(--panel));
  border:1px solid var(--line);border-radius:var(--radius);padding:18px 24px;text-align:right;
  min-width:230px;backdrop-filter:blur(8px);box-shadow:0 12px 40px rgba(0,0,0,.35)}
.pool .stat-num{font-size:2.9rem;font-weight:800;color:var(--gold);line-height:1}
.pool .lbl{color:var(--muted);font-size:.85rem}

.grid{display:grid;gap:18px}
.grid.cols-2{grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);
  padding:20px;backdrop-filter:blur(8px);animation:fadeUp .5s ease both;
  transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease}
.card:hover{transform:translateY(-4px);box-shadow:0 18px 44px rgba(0,0,0,.4);border-color:rgba(150,180,240,.35)}
.card:nth-child(2){animation-delay:.08s}
.card:nth-child(3){animation-delay:.16s}
.card h3{margin:0 0 4px;font-size:1.45rem}
.card.phase-GROUP h3{color:var(--mex-green)}
.card.phase-KO h3{color:var(--can-red)}
.card .meta{color:var(--muted);font-size:.85rem;margin-bottom:10px}
.pool-tag{float:right;font-size:.72rem;font-weight:700;padding:2px 9px;border-radius:99px;
  border:1px solid var(--line);color:var(--gold)}
.progress{height:6px;border-radius:99px;background:rgba(255,255,255,.08);overflow:hidden;margin:10px 0 14px}
.progress i{display:block;height:100%;border-radius:99px;
  background:linear-gradient(90deg,var(--mex-green),var(--usa-blue));
  transition:width 1s cubic-bezier(.2,.8,.2,1)}
.prize-row{display:flex;justify-content:space-between;border-top:1px dashed var(--line);
  padding:7px 0;font-size:.95rem}
.prize-row .amt{color:var(--gold);font-weight:700;font-family:"Saira Condensed";font-size:1.1rem}
.card .actions{margin-top:14px;display:flex;gap:10px}
.btn{display:inline-block;background:var(--mex-green);color:#06281a;font-weight:700;
  padding:9px 16px;border-radius:9px;border:none;cursor:pointer;font:inherit;font-weight:700;
  transition:transform .15s ease, filter .15s ease}
.btn:hover{filter:brightness(1.1);transform:translateY(-1px)}
.btn:active{transform:translateY(0) scale(.98)}
.btn.ghost{background:transparent;color:#7fd2a4;border:1px solid var(--mex-green)}
.btn.danger{background:transparent;color:var(--bad);border:1px solid var(--bad)}
.btn.blue{background:var(--usa-blue);color:#fff}

/* ---------------- fixtures ---------------- */
.round-block{margin:28px 0;animation:fadeUp .45s ease both}
.round-block h2{font-size:1.45rem;border-left:4px solid var(--gold);padding-left:10px;margin-bottom:12px}
.fixture{display:grid;grid-template-columns:1fr auto;gap:10px;align-items:center;
  background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);
  padding:13px 16px;margin-bottom:10px;backdrop-filter:blur(8px);
  transition:transform .2s ease, border-color .2s ease}
.fixture:hover{transform:translateX(4px);border-color:rgba(150,180,240,.35)}
.fixture.locked{opacity:.7}
.fixture.locked:hover{transform:none}
.f-teams{display:flex;flex-direction:column;gap:2px}
.f-line{display:flex;gap:10px;align-items:baseline;flex-wrap:wrap}
.f-name{font-weight:600}
.f-meta{color:var(--muted);font-size:.8rem}
.deadline{color:var(--gold)}
.result-tag{font-size:.75rem;border:1px solid var(--line);border-radius:6px;padding:1px 7px;color:var(--muted)}
.result-tag.win{border-color:var(--mex-green);color:#7fd2a4}
.result-tag.lose{border-color:var(--bad);color:var(--bad)}
.score{font-family:"Saira Condensed";font-weight:800;font-size:1.1rem;color:var(--gold)}
.live-tag{color:var(--can-red);font-size:.75rem;font-weight:700;animation:pulse 1.6s infinite}
.hidden{display:none}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.45}}

/* 1 X 2 picker */
.pick{display:flex;border:1px solid var(--line);border-radius:10px;overflow:hidden;background:rgba(0,0,0,.25)}
.pick input{position:absolute;opacity:0;pointer-events:none}
.pick label{padding:9px 0;width:54px;text-align:center;cursor:pointer;color:var(--muted);
  font-family:"Saira Condensed";font-weight:800;font-size:1.08rem;
  border-left:1px solid var(--line);user-select:none;transition:background .18s, color .18s, transform .12s}
.pick label:first-of-type{border-left:none}
.pick label:hover{background:rgba(255,255,255,.07);color:var(--ink)}
.pick label:active{transform:scale(.94)}
.pick input:checked + label{background:linear-gradient(135deg,var(--mex-green),#1d8a52);color:#06281a}
.pick.disabled label{cursor:not-allowed;opacity:.45}
.savebar{position:sticky;bottom:0;background:rgba(8,12,24,.92);backdrop-filter:blur(10px);
  border-top:1px solid var(--line);padding:12px 0;margin-top:20px;display:flex;justify-content:flex-end}

/* ---------------- tables ---------------- */
table{width:100%;border-collapse:collapse;background:var(--panel);border:1px solid var(--line);
  border-radius:var(--radius);overflow:hidden;backdrop-filter:blur(8px)}
th,td{padding:11px 14px;text-align:left;border-bottom:1px solid var(--line)}
th{color:var(--muted);font-size:.78rem;text-transform:uppercase;letter-spacing:.07em}
tbody tr{transition:background .15s}
tbody tr:hover{background:rgba(255,255,255,.04)}
tr:last-child td{border-bottom:none}
tr.podium-1 td:first-child{box-shadow:inset 4px 0 var(--gold)}
tr.podium-2 td:first-child{box-shadow:inset 4px 0 #c8ccd2}
tr.podium-3 td:first-child{box-shadow:inset 4px 0 #c98a4b}
tr.me{background:rgba(63,122,216,.14)}
.num{text-align:right}
.paid-yes{color:#7fd2a4;font-weight:700}
.paid-no{color:var(--bad);font-weight:700}

/* ---------------- forms / auth ---------------- */
.auth-card{max-width:440px;margin:48px auto;background:var(--panel);border:1px solid var(--line);
  border-radius:var(--radius);padding:28px;backdrop-filter:blur(10px);animation:fadeUp .5s ease both}
.auth-card h1{margin-top:0}
label{display:block;margin:12px 0 4px;color:var(--muted);font-size:.9rem}
input[type=text],input[type=password],input[type=email]{width:100%;padding:11px;border-radius:9px;
  border:1px solid var(--line);background:rgba(0,0,0,.3);color:var(--ink);font:inherit;
  transition:border-color .2s, box-shadow .2s}
input:focus{outline:none;border-color:var(--usa-blue);box-shadow:0 0 0 3px rgba(63,122,216,.25)}
.auth-card .btn{margin-top:18px;width:100%}
.errors{color:var(--bad);font-size:.85rem}
.helptext{color:var(--muted);font-size:.8rem}

/* ---------------- organiser panel ---------------- */
.cred-box{background:linear-gradient(135deg,rgba(240,199,94,.12),var(--panel));
  border:1px solid var(--gold);border-radius:var(--radius);padding:18px;margin:18px 0;animation:fadeUp .4s both}
.cred-row{display:flex;gap:10px;align-items:center;margin:8px 0;flex-wrap:wrap}
.cred-row .lbl{width:90px;color:var(--muted);font-size:.85rem}
.cred-value{font-family:ui-monospace,Menlo,Consolas,monospace;background:rgba(0,0,0,.35);
  border:1px solid var(--line);border-radius:8px;padding:7px 12px;letter-spacing:.03em}
.copy-btn{border:1px solid var(--line);background:rgba(255,255,255,.06);color:var(--ink);
  border-radius:8px;padding:7px 12px;cursor:pointer;font:inherit;font-size:.82rem;transition:all .15s}
.copy-btn:hover{border-color:var(--mex-green);color:#7fd2a4}
.copy-btn.copied{background:var(--mex-green);color:#06281a;border-color:var(--mex-green)}
.manage-grid{display:grid;grid-template-columns:340px 1fr;gap:20px;align-items:start}
.mini-btn{font-size:.78rem;padding:4px 10px;border-radius:7px;cursor:pointer;font:inherit;border:1px solid var(--line);background:transparent;color:var(--muted);transition:all .15s}
.mini-btn:hover{color:var(--ink);border-color:var(--ink)}

.foot{color:var(--muted);text-align:center;padding:28px 16px;border-top:1px solid var(--line);font-size:.85rem}

@keyframes fadeUp{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation:none!important;transition:none!important}}
@media (max-width:760px){
  .manage-grid{grid-template-columns:1fr}
  .fixture{grid-template-columns:1fr}
  .pick{justify-content:stretch}
  .pick label{flex:1}}

/* ---- decorative footballs in the backdrop ---- */
.bg-ball{position:fixed;z-index:-1;pointer-events:none}
.bg-ball svg{display:block;width:100%;height:100%}
.ball-1{right:-120px;bottom:-120px;width:460px;height:460px;color:#9db4e8;opacity:.09;
  animation:spin 150s linear infinite}
.ball-2{left:-70px;top:90px;width:240px;height:240px;color:var(--mex-green);opacity:.07;
  animation:spin 200s linear infinite reverse}
@keyframes spin{to{transform:rotate(360deg)}}
@media (max-width:760px){.ball-2{display:none}.ball-1{width:300px;height:300px;right:-100px;bottom:-100px}}

/* ---- live ticker (goal.com style) ---- */
.ticker{display:flex;gap:10px;overflow-x:auto;padding:9px 16px;border-bottom:1px solid var(--line);
  background:rgba(8,12,24,.8);backdrop-filter:blur(10px);scrollbar-width:thin;scroll-snap-type:x proximity}
.ticker.hidden{display:none}
.t-card{flex:0 0 auto;display:flex;align-items:center;gap:8px;padding:6px 12px;border-radius:10px;
  border:1px solid var(--line);background:var(--panel);font-size:.85rem;scroll-snap-align:start;
  transition:border-color .2s}
.t-card:hover{border-color:rgba(150,180,240,.4)}
.t-card.is-live{border-color:var(--can-red)}
.t-team{font-family:"Saira Condensed";font-weight:800;letter-spacing:.04em}
.t-card b{color:var(--gold);font-family:"Saira Condensed";font-size:1rem}
.t-vs{color:var(--muted);font-size:.75rem}
.t-live{color:var(--can-red);font-size:.72rem;font-weight:700;animation:pulse 1.6s infinite}
.t-ft{color:var(--muted);font-size:.7rem;font-weight:700;border:1px solid var(--line);border-radius:5px;padding:0 5px}
.t-time{color:var(--usa-blue);font-size:.75rem;font-weight:700}

/* ---- community pick split bars ---- */
.split{display:flex;height:20px;border-radius:7px;overflow:hidden;margin-top:8px;max-width:440px;
  font-size:.68rem;font-weight:700;line-height:20px}
.split i{font-style:normal;padding-left:7px;white-space:nowrap;overflow:hidden;min-width:0}
.s-home{background:rgba(47,174,110,.45)}
.s-draw{background:rgba(240,199,94,.35)}
.s-away{background:rgba(63,122,216,.45)}
.scorers{color:var(--gold);opacity:.85}

/* ---- prediction progress + results strip ---- */
.pick-progress{display:inline-block;border:1px solid var(--mex-green);border-radius:99px;
  padding:6px 16px;font-size:.9rem;margin:6px 0 4px;background:rgba(47,174,110,.1)}
.pick-progress.warn{border-color:var(--gold);background:rgba(240,199,94,.08)}
.results-strip{display:flex;gap:10px;flex-wrap:wrap}
.r-chip{display:flex;flex-direction:column;gap:2px;border:1px solid var(--line);border-radius:10px;
  padding:9px 14px;background:var(--panel);font-size:.85rem;animation:fadeUp .4s both}
.r-chip.hit{border-color:var(--mex-green)}
.r-chip.miss{border-color:var(--bad);opacity:.85}
.r-teams{font-family:"Saira Condensed";font-weight:800;font-size:1rem}
.r-chip .r-mark{font-size:.75rem;color:var(--muted)}
.r-chip.hit .r-mark{color:#7fd2a4;font-weight:700}
.r-chip.miss .r-mark{color:var(--bad)}
