:root{
  --bg:#0a0a12;
  --bg2:#0d0d18;
  --panel:#12121f;
  --panel2:#171728;
  --line:#23233a;
  --txt:#e9e9f2;
  --muted:#8a8aa3;
  --accent:#ff2d78;     /* magenta */
  --accent2:#7c3aed;    /* violet */
  --gold:#ffd24a;
  --green:#0b8f4f;
  --green2:#0a6e3e;
  --good:#2ee06a;
  --bad:#ff5470;
  --radius:14px;
  --shadow:0 10px 40px rgba(0,0,0,.45);
}
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:'Inter',system-ui,sans-serif;
  background:
    radial-gradient(1100px 600px at 80% -10%, #1a1030 0%, transparent 60%),
    radial-gradient(900px 500px at 0% 110%, #10182e 0%, transparent 55%),
    var(--bg);
  color:var(--txt);
  -webkit-font-smoothing:antialiased;
}
.hidden{display:none !important}

/* ---------- App-download banner (website only) ---------- */
.appbanner{
  display:flex;align-items:center;gap:12px;
  padding:9px 14px;border-bottom:1px solid var(--line);
  background:linear-gradient(90deg,var(--panel2),var(--panel));
}
.appbanner.hidden{display:none}
.appbanner-x{
  flex:0 0 auto;width:26px;height:26px;border:0;border-radius:50%;
  background:var(--panel);color:var(--muted);font-size:18px;line-height:1;
  cursor:pointer;display:flex;align-items:center;justify-content:center;
}
.appbanner-x:hover{color:var(--txt)}
.appbanner-icon{
  flex:0 0 auto;width:40px;height:40px;border-radius:9px;object-fit:cover;
  box-shadow:0 2px 8px rgba(0,0,0,.4);
}
.appbanner-txt{display:flex;flex-direction:column;line-height:1.25;min-width:0;flex:1 1 auto}
.appbanner-txt strong{font-size:14px;color:var(--txt)}
.appbanner-txt span{font-size:12px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.appbanner-cta{
  flex:0 0 auto;padding:7px 18px;border-radius:999px;
  background:var(--accent);color:#fff;font-weight:800;font-size:13px;
  letter-spacing:.04em;text-transform:uppercase;text-decoration:none;
}
.appbanner-cta:hover{filter:brightness(1.08)}

/* ---------- Nations Cup cross-promo (non-iOS web only) ---------- */
.nc-promo{
  display:flex;align-items:center;gap:8px;width:fit-content;max-width:100%;
  margin:2px auto 10px;padding:9px 18px;border-radius:999px;
  border:1px solid var(--line);
  background:linear-gradient(90deg,var(--panel2),var(--panel));
  color:var(--txt);font-weight:600;font-size:14px;text-decoration:none;
  box-shadow:0 2px 10px rgba(0,0,0,.25);
  transition:filter .15s,transform .15s,border-color .15s;
}
.nc-promo b{color:var(--accent);font-weight:800}
.nc-promo:hover{filter:brightness(1.1);transform:translateY(-1px);border-color:var(--accent)}

/* ---------- Game chooser (native app only) ---------- */
/* Lock the page behind the chooser so scrolling moves the overlay, not the page under it. */
html.chooser-open, body.chooser-open{overflow:hidden !important;height:100%}
.mode-chooser{position:fixed;inset:0;z-index:100;display:flex;overflow-y:auto;overscroll-behavior:contain;
  -webkit-overflow-scrolling:touch;
  background:radial-gradient(900px 500px at 80% -10%,#1a1030 0%,transparent 60%),var(--bg)}
.mc-inner{margin:auto;padding:40px 24px;width:100%;max-width:560px;text-align:center}
.mc-logo{width:118px;height:auto;margin:0 auto 10px;display:block;filter:drop-shadow(0 6px 18px rgba(0,0,0,.5))}
.mc-title{font-size:24px;font-weight:900;margin:0 0 24px}
.mc-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.mc-card{display:flex;flex-direction:column;align-items:center;gap:8px;padding:30px 16px;border-radius:18px;cursor:pointer;
  border:2px solid var(--line);color:var(--txt);transition:.15s;background:var(--panel)}
.mc-card:hover{transform:translateY(-3px)}
.mc-epl{background:linear-gradient(160deg,rgba(255,45,120,.20),rgba(124,58,237,.12))}
.mc-epl:hover{border-color:var(--accent)}
.mc-wc{background:linear-gradient(160deg,rgba(255,46,126,.16),rgba(19,212,196,.16))}
.mc-wc:hover{border-color:#13d4c4}
.mc-ec{background:linear-gradient(160deg,rgba(62,155,255,.20),rgba(27,58,143,.16))}
.mc-ec:hover{border-color:#3e9bff}
.mc-flag{font-size:46px;line-height:1}
.mc-name{font-weight:900;font-size:22px;letter-spacing:.5px}
.mc-desc{font-size:12.5px;color:var(--muted);font-weight:500;line-height:1.4}
@media(max-width:520px){.mc-grid{grid-template-columns:1fr}.mc-flag{font-size:40px}}

/* ---------- Setup screen (mode + formation) ---------- */
.setup{min-height:calc(100vh - 67px);display:flex;align-items:flex-start;justify-content:center;padding:42px 20px 80px}
.setup-inner{width:100%;max-width:640px;text-align:center}
.setup-logo{width:120px;height:auto;margin:0 auto 6px;display:block;filter:drop-shadow(0 6px 18px rgba(0,0,0,.5))}
.setup-title{font-size:26px;font-weight:900;margin:0 0 6px}
.setup-sub{color:var(--muted);font-size:14px;margin:0 0 30px}
.setup-step{margin-bottom:26px}
.setup-step-label{font-size:12px;letter-spacing:2px;color:var(--gold);font-weight:800;margin-bottom:14px;text-transform:uppercase}
.mode-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.mode-card{
  text-align:left;padding:18px;border-radius:14px;cursor:pointer;
  background:var(--panel);border:2px solid var(--line);color:var(--txt);transition:.15s;
  display:flex;flex-direction:column;gap:8px;
}
.mode-card:hover{border-color:var(--accent2);transform:translateY(-2px)}
.mode-card.selected{border-color:var(--accent);box-shadow:0 0 0 3px rgba(255,45,120,.22),var(--shadow);background:var(--panel2)}
.mode-name{font-weight:900;font-size:18px}
.mode-desc{font-size:12.5px;color:var(--muted);line-height:1.5;font-weight:500}
.formation-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.formation-card{
  padding:18px 8px;border-radius:12px;cursor:pointer;
  background:var(--panel);border:2px solid var(--line);color:var(--txt);transition:.15s;
  font-weight:900;font-size:17px;letter-spacing:1px;
}
.formation-card:hover{border-color:var(--accent2);transform:translateY(-2px)}
.formation-card.selected{border-color:var(--accent);box-shadow:0 0 0 3px rgba(255,45,120,.22);background:var(--panel2)}
.setup-start{
  margin-top:8px;padding:15px 48px;border:none;border-radius:12px;cursor:pointer;
  font-weight:900;font-size:17px;letter-spacing:.5px;color:#fff;
  background:linear-gradient(135deg,var(--accent),var(--accent2));
  box-shadow:0 10px 30px rgba(255,45,120,.4);transition:.15s;
}
.setup-start:hover{transform:translateY(-2px)}

/* Expert mode — hide ratings & stats DURING the draft only; revealed on results. */
body.mode-expert #gameScreen .prow-stats,
body.mode-expert #gameScreen .prow-ov,
body.mode-expert #gameScreen .draft-cols,
body.mode-expert #gameScreen .slot-ov{display:none !important}

/* ---------- Top bar ---------- */
.topbar{
  display:flex;align-items:center;gap:18px;
  padding:14px 22px;border-bottom:1px solid var(--line);
  background:rgba(10,10,18,.7);backdrop-filter:blur(8px);
  position:sticky;top:0;z-index:30;
}
.brand{display:flex;align-items:center;gap:12px}
.brand-logo{height:44px;width:auto;display:block;filter:drop-shadow(0 2px 6px rgba(0,0,0,.4))}
.brand-sub{color:var(--muted);font-size:13px;font-weight:600}
.round-pill{
  margin-left:auto;font-weight:800;font-size:14px;letter-spacing:.3px;
  padding:8px 16px;border-radius:999px;
  background:linear-gradient(135deg,rgba(255,45,120,.18),rgba(124,58,237,.18));
  border:1px solid var(--line);
}
.icon-btn{
  width:38px;height:38px;border-radius:10px;border:1px solid var(--line);
  background:var(--panel2);color:var(--txt);font-size:18px;cursor:pointer;
  transition:.15s;
}
.icon-btn:hover{background:#222238;transform:rotate(-90deg)}

/* ---------- Game layout ---------- */
.game{
  display:grid;grid-template-columns:minmax(380px,1fr) minmax(420px,1.05fr);
  gap:28px;max-width:1280px;margin:0 auto;padding:34px 24px 60px;
  min-height:calc(100vh - 67px);align-items:start;
}
.left-col{min-height:520px}

/* ---------- Spin pane ---------- */
.spin-pane{display:flex;flex-direction:column;align-items:center;padding-top:40px}
.reels{display:flex;gap:18px}
.reel{
  width:150px;height:108px;border-radius:16px;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;
  background:linear-gradient(180deg,#161626,#0e0e1a);
  position:relative;overflow:hidden;
}
.reel-team{border:3px solid var(--accent);box-shadow:0 0 28px rgba(255,45,120,.35)}
.reel-year{border:3px solid var(--accent2);box-shadow:0 0 28px rgba(124,58,237,.35)}
.reel-label{font-size:11px;font-weight:800;letter-spacing:2px;color:var(--accent)}
.reel-year .reel-label{color:var(--accent2)}
.reel-value{font-size:38px;font-weight:900;letter-spacing:-1px;line-height:1}
.reel.spinning .reel-value{filter:blur(.4px);opacity:.85}
.reel-captions{display:flex;gap:18px;margin-top:8px}
.reel-captions span{width:150px;text-align:center;color:var(--muted);font-size:12px;font-weight:600}
.spin-btn{
  margin-top:26px;padding:14px 56px;border:none;border-radius:12px;cursor:pointer;
  font-weight:900;font-size:18px;letter-spacing:1px;color:#fff;
  background:linear-gradient(135deg,var(--accent),#ff6a3d);
  box-shadow:0 10px 30px rgba(255,45,120,.4);transition:.15s;
}
.spin-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 14px 36px rgba(255,45,120,.5)}
.spin-btn:disabled{opacity:.55;cursor:default}
.spin-hint{color:var(--muted);font-size:13px;margin-top:20px;text-align:center;max-width:280px}

/* ---------- Draft pane ---------- */
.draft-pane{
  background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow);overflow:hidden;
}
.draft-head{display:flex;align-items:center;gap:12px;padding:14px 16px;border-bottom:1px solid var(--line);background:var(--panel2)}
.draft-badge{width:34px;height:34px;object-fit:contain}
.draft-title{display:flex;flex-direction:column;line-height:1.15}
.draft-title>span:first-child{font-weight:800;font-size:16px}
.draft-year{color:var(--accent);font-size:12px;font-weight:700}
.draft-search{
  margin-left:auto;width:150px;padding:8px 12px;border-radius:9px;
  border:1px solid var(--line);background:#0d0d18;color:var(--txt);font-size:13px;
}
.draft-search:focus{outline:none;border-color:var(--accent2)}
.draft-subhead{display:flex;align-items:center;justify-content:space-between;padding:8px 16px;border-bottom:1px solid var(--line)}
.draft-instruct{font-size:12px;font-weight:700;color:var(--gold);letter-spacing:.3px}
.draft-cols{display:flex;gap:0}
.draft-cols i{width:34px;text-align:center;font-style:normal;font-size:10px;font-weight:700;color:var(--muted)}
.draft-cols i.ov{color:var(--txt)}
.respin-btn{display:block;width:calc(100% - 32px);margin:10px 16px;padding:13px;
  border:none;border-radius:10px;cursor:pointer;
  background:linear-gradient(90deg,#ffd24a,#ffb300);color:#1a1205;font-weight:900;font-size:14px;
  box-shadow:0 4px 14px rgba(255,200,40,.40);transition:.15s}
.respin-btn:hover{transform:translateY(-1px);box-shadow:0 6px 20px rgba(255,200,40,.55)}
.respin-btn:disabled{opacity:.6;cursor:default}
.player-list{max-height:560px;overflow-y:auto}
.player-list::-webkit-scrollbar{width:8px}
.player-list::-webkit-scrollbar-thumb{background:#2a2a42;border-radius:8px}

.prow{
  display:flex;align-items:center;gap:12px;padding:9px 16px;cursor:pointer;
  border-bottom:1px solid rgba(35,35,58,.55);transition:background .12s;
}
.prow:hover{background:var(--panel2)}
.prow.selected{background:rgba(255,45,120,.14);box-shadow:inset 3px 0 0 var(--accent)}
.prow.drafted{opacity:.32;pointer-events:none}
.prow-face{
  width:40px;height:40px;flex:none;
  display:flex;align-items:center;justify-content:center;
}
.prow-face svg{width:40px;height:40px;display:block}
.prow.ineligible{opacity:.34;pointer-events:none}
.prow.ineligible .prow-pos{background:#3a2030;color:#ff8aa6}
.prow-id{flex:1;min-width:0}
.prow-name{font-weight:700;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.prow-meta{font-size:11px;color:var(--muted);margin-top:1px}
.prow-pos{display:inline-block;padding:1px 6px;border-radius:5px;background:#232338;color:#c9c9e0;font-weight:700;font-size:10px;margin-right:6px}
.prow-stats{display:flex;gap:0}
.prow-stats b{width:34px;text-align:center;font-weight:700;font-size:13px;color:#d5d5e8}
.prow-ov{
  width:34px;text-align:center;font-weight:900;font-size:15px;
}
.ov-90{color:#3ddc84}.ov-80{color:#7ce08a}.ov-75{color:#e9e9f2}.ov-70{color:#c2c2d6}.ov-low{color:#9a9ab0}

/* ---------- Pitch ---------- */
.pitch-col{position:relative;display:flex;flex-direction:column;align-items:center}
.pitch{
  position:relative;width:100%;max-width:520px;aspect-ratio:3/4;border-radius:18px;
  background:
    repeating-linear-gradient(0deg,#0c7a45 0 11.1%, #0a6e3e 11.1% 22.2%);
  border:2px solid rgba(255,255,255,.14);box-shadow:var(--shadow);overflow:hidden;
}
.pitch-lines{position:absolute;inset:0;pointer-events:none}
.pl-box{position:absolute;left:25%;width:50%;height:14%;border:2px solid rgba(255,255,255,.32)}
.pl-box-top{top:0;border-top:none}
.pl-box-bottom{bottom:0;border-bottom:none}
.pl-circle{position:absolute;top:50%;left:50%;width:26%;aspect-ratio:1;border:2px solid rgba(255,255,255,.28);border-radius:50%;transform:translate(-50%,-50%)}
.pl-halfway{position:absolute;top:50%;left:0;width:100%;height:0;border-top:2px solid rgba(255,255,255,.28)}
.pl-spot{position:absolute;left:50%;width:5px;height:5px;background:rgba(255,255,255,.5);border-radius:50%;transform:translateX(-50%)}
.pl-spot-top{top:10%}.pl-spot-bottom{bottom:10%}

.slot{
  position:absolute;transform:translate(-50%,-50%);
  width:64px;display:flex;flex-direction:column;align-items:center;gap:4px;
  cursor:default;
}
.slot-node{
  width:54px;height:54px;border-radius:14px;display:flex;align-items:center;justify-content:center;
  border:2px dashed rgba(255,255,255,.4);background:rgba(0,0,0,.22);
  font-weight:800;font-size:13px;color:rgba(255,255,255,.85);transition:.15s;
  overflow:hidden;position:relative;
}
.slot-label{font-size:10px;font-weight:800;color:rgba(255,255,255,.7);letter-spacing:.5px}
.slot.open.armed .slot-node{
  border-color:var(--gold);border-style:solid;cursor:pointer;
  box-shadow:0 0 0 3px rgba(255,210,74,.25),0 0 22px rgba(255,210,74,.5);
  animation:pulse 1.1s infinite;
}
.slot.open.armed{cursor:pointer}
@keyframes pulse{0%,100%{transform:translate(-50%,-50%) scale(1)}50%{transform:translate(-50%,-50%) scale(1.08)}}
.slot.filled .slot-node{
  border:none;background:transparent;width:62px;height:62px;overflow:visible;
  color:#fff;cursor:default;
}
.slot.filled .slot-node svg{width:58px;height:58px;display:block;filter:drop-shadow(0 4px 8px rgba(0,0,0,.5))}
.slot-ov{
  position:absolute;top:-4px;right:-2px;width:22px;height:22px;border-radius:50%;
  background:var(--gold);color:#1a1a1a;font-weight:900;font-size:11px;
  display:flex;align-items:center;justify-content:center;border:2px solid #0a0a12;z-index:2;
}
.slot-name{font-size:11px;font-weight:700;max-width:78px;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  text-shadow:0 1px 3px rgba(0,0,0,.8)}
.formation-tag{
  margin-top:14px;font-weight:800;letter-spacing:2px;color:var(--muted);font-size:13px;
  padding:6px 16px;border:1px solid var(--line);border-radius:999px;
}

/* ---------- Results ---------- */
.results{min-height:100vh;display:flex;align-items:flex-start;justify-content:center;padding:50px 20px 80px}
.results-inner{width:100%;max-width:560px;text-align:center}
.results-logo-img{width:140px;height:auto;display:block;margin:0 auto 2px;
  filter:drop-shadow(0 6px 18px rgba(0,0,0,.5))}
.results-q{font-size:24px;font-weight:800;margin:6px 0 26px}
.record-block{background:var(--panel);border:1px solid var(--line);border-radius:18px;padding:26px;box-shadow:var(--shadow)}
.record-label{font-size:12px;letter-spacing:2px;color:var(--muted);font-weight:700}
.record-line{display:flex;align-items:baseline;justify-content:center;gap:10px;margin:8px 0 4px;font-weight:900;font-size:58px;letter-spacing:-2px}
.rec-w{color:var(--good)}.rec-l{color:var(--bad)}.rec-d{color:var(--muted)}.rec-sep{color:#3a3a55;font-size:40px}
.record-key{color:var(--muted);font-size:13px;font-weight:600}
.record-key b{color:var(--txt)}
.tier-badge{
  display:inline-block;margin-top:16px;padding:8px 22px;border-radius:999px;font-weight:900;letter-spacing:1.5px;font-size:14px;
  background:linear-gradient(135deg,var(--gold),#ff9d3d);color:#1a1200;
}
.results-actions{display:flex;gap:12px;justify-content:center;margin:24px 0 30px}
.btn-primary{padding:13px 26px;border:none;border-radius:11px;font-weight:800;font-size:15px;cursor:pointer;color:#fff;
  background:linear-gradient(135deg,var(--accent),var(--accent2));box-shadow:0 8px 24px rgba(255,45,120,.35)}
.btn-ghost{padding:13px 26px;border:1px solid var(--line);border-radius:11px;font-weight:800;font-size:15px;cursor:pointer;color:var(--txt);background:var(--panel2)}
.btn-primary:hover,.btn-ghost:hover{transform:translateY(-2px)}

.results-ad{width:100%;max-width:560px;margin:6px auto 24px;min-height:90px;overflow:hidden}
.iap-row{display:flex;flex-direction:column;align-items:center;gap:8px;margin:-12px 0 26px}
.btn-noads{padding:11px 22px;border:1px solid var(--gold);border-radius:11px;cursor:pointer;
  font-weight:800;font-size:14px;color:var(--gold);background:rgba(255,210,74,.10);transition:.15s}
.btn-noads:hover:not(:disabled){background:rgba(255,210,74,.20);transform:translateY(-1px)}
.btn-noads:disabled{opacity:.6;cursor:default}
.iap-restore{background:none;border:none;color:var(--muted);font-size:12px;font-weight:600;
  cursor:pointer;text-decoration:underline}
.iap-restore:hover{color:var(--txt)}

.xi-list{margin-top:8px;text-align:left}
.xirow{display:flex;align-items:center;gap:12px;padding:11px 14px;border-bottom:1px solid var(--line);background:var(--panel);border-radius:10px;margin-bottom:6px}
.xirow-pos{width:38px;font-weight:800;font-size:12px;color:var(--accent);text-align:center}
.xirow-face{width:34px;height:34px;border-radius:50%;object-fit:cover;background:#1c1c2e;border:1px solid var(--line);flex:none}
.xirow-id{flex:1;min-width:0}
.xirow-name{font-weight:700;font-size:14px}
.xirow-meta{font-size:11px;color:var(--muted)}
.xirow-ov{font-weight:900;font-size:18px;width:40px;text-align:center}
.fit-warn{color:var(--bad);font-size:10px;font-weight:700;margin-left:6px}

/* ---------- Responsive ---------- */
@media(max-width:900px){
  .game{grid-template-columns:1fr;gap:20px}
  .pitch{max-width:420px}
}

/* ---- Phones ---- */
@media(max-width:620px){
  .topbar{padding:11px 14px;gap:10px}
  .brand-sub{display:none}
  .round-pill{font-size:13px;padding:7px 13px}
  .game{padding:16px 10px 48px;gap:14px}
  .pitch{max-width:340px}
  .spin-pane{padding-top:18px}
  .reel{width:132px;height:96px}
  .reel-value{font-size:32px}
  .reel-captions span{width:132px}

  .draft-pane{box-shadow:none}
  .draft-head{padding:11px 13px;gap:10px}
  .draft-search{width:104px}
  .draft-cols{display:none}            /* per-row labels replace the header on mobile */
  .draft-subhead{padding:8px 13px}
  .player-list{max-height:none;overflow:visible}

  .prow{flex-wrap:wrap;padding:11px 13px;gap:10px}
  .prow-face{order:1}
  .prow-id{order:2;flex:1 1 0;min-width:0}
  .prow-ov{order:3;width:auto;min-width:32px;font-size:20px}
  .prow-stats{order:4;flex-basis:100%;justify-content:space-between;gap:0;margin-top:2px;padding-left:50px}
  .prow-stats b{
    width:auto;display:flex;flex-direction:column;align-items:center;
    font-size:13px;line-height:1.1;color:#d5d5e8;
  }
  .prow-stats b::before{
    content:attr(data-k);font-size:8px;font-weight:800;letter-spacing:.4px;
    color:var(--muted);margin-bottom:1px;
  }
}
@media(max-width:620px){
  .setup{padding:24px 12px 60px}
  .setup-title{font-size:22px}
  .mode-grid{grid-template-columns:1fr}
  .formation-grid{grid-template-columns:repeat(3,1fr)}
  .formation-card{padding:16px 6px;font-size:16px}
  .setup-start{width:100%}
}
.confetti-canvas{position:fixed;inset:0;z-index:90;pointer-events:none}

.consent-banner{
  position:fixed;left:50%;bottom:16px;transform:translateX(-50%);z-index:95;
  width:min(94vw,720px);display:flex;align-items:center;gap:16px;flex-wrap:wrap;
  background:var(--panel);border:1px solid var(--line);border-radius:14px;
  padding:14px 18px;box-shadow:var(--shadow);
}
.consent-text{flex:1;min-width:220px;color:#c8c8d8;font-size:13px;line-height:1.5}
.consent-text a{color:var(--accent);font-weight:600}
.consent-actions{display:flex;gap:10px;flex:0 0 auto}
.consent-reject{padding:10px 14px;border:1px solid var(--line);border-radius:10px;cursor:pointer;
  font-weight:700;font-size:13px;color:var(--txt);background:var(--panel2)}
.consent-reject:hover{background:#23233a}
.consent-accept{padding:10px 18px;border:none;border-radius:10px;cursor:pointer;
  font-weight:800;font-size:13px;color:#fff;background:linear-gradient(135deg,var(--accent),var(--accent2))}
.consent-accept:hover{transform:translateY(-1px)}
@media(max-width:560px){
  .consent-banner{bottom:0;left:0;transform:none;width:100%;border-radius:14px 14px 0 0}
  .consent-actions{flex:1}
  .consent-reject,.consent-accept{flex:1}
}

.modal-overlay{position:fixed;inset:0;z-index:85;display:flex;align-items:center;justify-content:center;
  background:rgba(5,5,10,.72);backdrop-filter:blur(4px)}
.donate-card{position:relative;width:min(92vw,440px);background:var(--panel);border:1px solid var(--line);
  border-radius:16px;padding:26px 26px 24px;box-shadow:var(--shadow)}
.donate-x{position:absolute;top:12px;right:14px;width:28px;height:28px;border:none;background:transparent;
  color:var(--muted);font-size:22px;cursor:pointer;line-height:1}
.donate-x:hover{color:var(--txt)}
.donate-title{font-weight:900;font-size:20px;color:var(--gold);margin-bottom:12px}
.donate-body{color:#c8c8d8;font-size:14px;line-height:1.55;margin:0 0 20px}
.donate-actions{display:flex;gap:12px}
.donate-support{flex:1;text-align:center;padding:13px;border-radius:11px;text-decoration:none;
  font-weight:800;font-size:15px;color:#1a1200;background:linear-gradient(135deg,#ffd24a,#ff9d3d);
  box-shadow:0 8px 22px rgba(255,160,60,.35);transition:.15s}
.donate-support:hover{transform:translateY(-2px)}
.donate-later{padding:13px 18px;border:1px solid var(--line);border-radius:11px;cursor:pointer;
  font-weight:800;font-size:15px;color:var(--txt);background:var(--panel2)}
.donate-later:hover{background:#23233a}
.social-btn{flex:1;text-align:center;padding:13px;border-radius:11px;text-decoration:none;
  font-weight:800;font-size:15px;color:#fff;transition:.15s}
.social-btn.x{background:#0a0a0a;border:1px solid #333}
.social-btn.ig{background:linear-gradient(135deg,#feda75,#fa7e1e,#d62976,#962fbf)}
.social-btn:hover{transform:translateY(-2px)}
.social-later{margin-top:14px;width:100%}

.share-menu{position:fixed;inset:0;z-index:80;display:flex;align-items:center;justify-content:center;
  background:rgba(5,5,10,.7);backdrop-filter:blur(4px)}
.share-menu-inner{width:min(92vw,420px);background:var(--panel);border:1px solid var(--line);
  border-radius:16px;padding:24px;box-shadow:var(--shadow);text-align:center}
.share-menu-title{font-weight:900;font-size:20px;margin-bottom:6px}
.share-menu-note{color:var(--muted);font-size:13px;margin:0 0 18px}
.share-menu-links{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.share-menu-links a{padding:13px;border-radius:11px;background:var(--panel2);border:1px solid var(--line);
  color:var(--txt);font-weight:700;font-size:14px;text-decoration:none;transition:.15s}
.share-menu-links a:hover{background:#23233a;transform:translateY(-2px)}
.share-menu-close{margin-top:16px;width:100%;padding:12px;border:none;border-radius:11px;cursor:pointer;
  font-weight:800;color:#fff;background:linear-gradient(135deg,var(--accent),var(--accent2))}
.site-footer{
  text-align:center;padding:18px 16px 26px;color:var(--muted);font-size:12px;
  border-top:1px solid var(--line);
}
.site-footer a{color:var(--accent);text-decoration:none;font-weight:600}
.site-footer a:hover{text-decoration:underline}
.footer-disclaimer{max-width:560px;margin:10px auto 0;font-size:11px;line-height:1.5;color:var(--muted);opacity:.85}

/* ---------- About / How it works / FAQ ---------- */
.about{max-width:760px;margin:0 auto;padding:8px 22px 50px}
.about-inner{background:var(--panel);border:1px solid var(--line);border-radius:18px;
  padding:30px 30px 34px;box-shadow:var(--shadow)}
.about h2{font-size:24px;font-weight:900;margin:0 0 12px}
.about h3{font-size:16px;font-weight:800;margin:24px 0 10px;color:var(--gold)}
.about p{color:#c8c8d8;font-size:14.5px;line-height:1.65;margin:0 0 12px}
.about ol,.about ul{color:#c8c8d8;font-size:14.5px;line-height:1.7;margin:0 0 12px;padding-left:22px}
.about li{margin-bottom:6px}
.about strong{color:var(--txt)}
.faq-q{font-weight:800;font-size:14.5px;color:var(--txt);margin-top:14px}
.faq-a{color:#c8c8d8;font-size:14px;line-height:1.6;margin-top:4px}
@media(max-width:620px){
  .about{padding:6px 12px 40px}
  .about-inner{padding:22px 18px 26px}
  .about h2{font-size:21px}
}
.toast{
  position:fixed;left:50%;bottom:28px;transform:translateX(-50%);
  background:#1d1d30;border:1px solid var(--line);color:var(--txt);
  padding:12px 20px;border-radius:10px;font-weight:600;font-size:14px;
  box-shadow:var(--shadow);z-index:60;animation:toastin .25s;
}
@keyframes toastin{from{opacity:0;transform:translate(-50%,10px)}to{opacity:1;transform:translate(-50%,0)}}

/* ===== Results: "Show more" full-season breakdown ===== */
.btn-showmore{display:inline-block;margin:6px auto 0;padding:11px 22px;border:1px solid var(--line);
  border-radius:11px;background:var(--panel2);color:var(--txt);font-weight:800;font-size:14px;
  cursor:pointer;transition:.15s}
.btn-showmore:hover{border-color:var(--accent2);color:#fff}
.breakdown{margin-top:16px;text-align:left}
.bd-grid{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:16px}
.bd-card{flex:1 1 150px;min-width:140px;background:var(--panel);border:1px solid var(--line);
  border-radius:14px;padding:14px 16px}
.bd-label{font-size:10.5px;letter-spacing:1.1px;text-transform:uppercase;color:var(--muted);font-weight:800}
.bd-value{font-size:26px;font-weight:900;line-height:1.15;margin-top:6px;color:var(--good)}
.bd-value.bd-sm{font-size:17px;color:var(--txt)}
.bd-sub{font-size:12px;color:var(--muted);margin-top:3px}
.bd-honours{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:14px 16px;margin-bottom:18px}
.bd-honours-label{font-size:10.5px;letter-spacing:1.1px;text-transform:uppercase;color:var(--muted);font-weight:800}
.bd-cups{display:flex;gap:10px;flex-wrap:wrap;margin-top:10px}
.bd-cup{display:flex;align-items:center;gap:7px;padding:8px 13px;border-radius:10px;font-weight:800;font-size:13px;border:1px solid var(--line)}
.bd-cup.won{background:linear-gradient(135deg,rgba(255,210,74,.18),rgba(255,45,120,.14));border-color:rgba(255,210,74,.5);color:#ffd24a}
.bd-cup.lost{background:var(--panel2);color:var(--muted);opacity:.75}
.bd-cup .bd-cup-ico{font-size:15px}
.bd-players-label{font-size:10.5px;letter-spacing:1.1px;text-transform:uppercase;color:var(--muted);font-weight:800;margin:0 0 8px 2px}

/* ===== THE QUADRUPLE celebration banner ===== */
.quad-banner{display:flex;flex-direction:column;align-items:center;gap:4px;margin:14px auto 4px;
  max-width:420px;padding:16px 20px;border-radius:16px;text-align:center;
  background:linear-gradient(135deg,#ffd24a,#ff2d78 48%,#7c3aed);
  box-shadow:0 0 32px rgba(255,45,120,.45);animation:quadPulse 1.6s ease-in-out infinite}
.quad-title{font-size:22px;font-weight:900;letter-spacing:1px;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.35)}
.quad-sub{font-size:12.5px;font-weight:700;color:rgba(255,255,255,.92)}
@keyframes quadPulse{0%,100%{transform:scale(1);box-shadow:0 0 28px rgba(255,45,120,.40)}
  50%{transform:scale(1.025);box-shadow:0 0 40px rgba(255,45,120,.6)}}

/* Season recap (verdict + correspondent summary + key men) */
.recap{max-width:560px;margin:14px auto 4px;padding:18px 20px;border:1px solid var(--line);
  border-radius:14px;background:linear-gradient(180deg,var(--panel2),var(--panel));text-align:left}
.recap.hidden{display:none}
.recap-verdict{display:inline-block;font-weight:900;font-size:13px;letter-spacing:.09em;
  padding:6px 14px;border-radius:999px;margin-bottom:12px}
.recap-verdict.over{background:rgba(46,224,106,.16);color:#7af0a0;border:1px solid rgba(46,224,106,.4)}
.recap-verdict.met{background:rgba(124,47,247,.18);color:#c4a7ff;border:1px solid rgba(124,47,247,.45)}
.recap-verdict.under{background:rgba(255,84,112,.16);color:#ff90a3;border:1px solid rgba(255,84,112,.4)}
.recap-text{color:var(--txt);font-size:15px;line-height:1.62;margin-bottom:14px}
.recap-grid{display:flex;flex-direction:column;gap:7px}
.recap-item{display:flex;justify-content:space-between;align-items:center;gap:10px;
  padding:8px 12px;border-radius:10px;background:rgba(255,255,255,.04)}
.recap-k{color:var(--muted);font-size:13px;font-weight:600}
.recap-v{color:var(--txt);font-size:15px;font-weight:800;text-align:right}

