/* ============================================================
   TOPO KAMPIOEN — "MATCHDAY"
   Voetbal-zine / Panini-album / broadcast-graphics look.
   Condensed display (Anton) + grotesk (Archivo), platte
   kleurvlakken, halftoon-textuur, harde offset-schaduwen,
   schuine snedes en grote rugnummers. Bewust níét generiek.
   ============================================================ */
:root{
  --ink:#0a1410;          /* bijna-zwart groen */
  --pitch:#0c2a1c;
  --pitch-2:#103826;
  --chalk:#f3efe2;        /* warm krijtwit (papier) */
  --chalk-2:#e6dfc9;
  --oranje:#ff5a1f;
  --oranje-ink:#7a2503;
  --lime:#c8ff3d;         /* broadcast-accent */
  --sky:#86d8f5;          /* water */
  --sky-2:#5fc0e6;
  --gold:#ffc83d;
  --red:#ff3b3b;
  --green:#27d36a;
  --blue:#2f6bff;
  --purple:#8b3cff;
  --muted:#8aa093;
  --hard:4px 4px 0 var(--ink);
  --hard-lg:6px 6px 0 var(--ink);
  --bord:2.5px solid var(--ink);
  --safe-b:env(safe-area-inset-bottom,0px);
  --safe-t:env(safe-area-inset-top,0px);
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
svg.ic{stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;display:inline-block;vertical-align:middle;flex:none}
svg.ic.fill{fill:currentColor;stroke:none}
html,body{margin:0;padding:0;height:100%}
body{
  font-family:'Archivo',system-ui,-apple-system,'Segoe UI',sans-serif;
  font-weight:600;
  color:var(--chalk);
  background:var(--pitch);
  background-image:
    radial-gradient(120% 80% at 50% -20%, var(--pitch-2), transparent 55%),
    radial-gradient(rgba(255,255,255,.045) 1px, transparent 1.6px); /* halftoon */
  background-size:auto, 16px 16px;
  background-attachment:fixed;
  overscroll-behavior:none;
  -webkit-user-select:none;user-select:none;
  text-rendering:optimizeLegibility;
}
/* filmkorrel-overlay */
.grain{
  position:fixed;inset:0;z-index:1;pointer-events:none;opacity:.5;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.35'/%3E%3C/svg%3E");
}
#app{
  position:relative;z-index:2;
  max-width:540px;margin:0 auto;min-height:100%;
  display:flex;flex-direction:column;padding-top:var(--safe-t);
}
.disp{font-family:'Anton',Impact,sans-serif;font-weight:400;letter-spacing:.4px;text-transform:uppercase}

/* ---------- HUD: scorebord-strip ---------- */
.hud{
  position:sticky;top:0;z-index:30;
  display:flex;align-items:center;gap:8px;
  padding:9px 10px;
  background:var(--ink);
  border-bottom:3px solid var(--oranje);
}
.hud-btn{
  width:42px;height:42px;border:2px solid rgba(255,255,255,.18);border-radius:8px;
  background:#142a20;color:var(--chalk);font-size:19px;cursor:pointer;
  display:grid;place-items:center;transition:transform .1s, background .15s;
}
.hud-btn:active{transform:translate(1px,1px)}
.hud-stats{flex:1;display:flex;gap:7px;justify-content:center;flex-wrap:wrap}
.hud-chip{
  display:flex;align-items:center;gap:6px;
  background:#142a20;color:var(--chalk);
  padding:6px 12px;border-radius:6px;font-size:15px;white-space:nowrap;
  border:2px solid rgba(255,255,255,.1);
}
.hud-chip span{font-family:'Anton',sans-serif;font-size:18px;line-height:1;letter-spacing:.5px;color:var(--lime)}
.hud-streak{background:var(--oranje);border-color:#fff;}
.hud-streak span{color:#fff}
.pop{animation:pop .35s}
@keyframes pop{0%{transform:scale(1)}40%{transform:scale(1.4)}100%{transform:scale(1)}}

/* ---------- Views ---------- */
#view{flex:1;padding:16px 14px 24px;display:flex;flex-direction:column;gap:16px}
.fade{animation:fade .3s ease}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

/* ---------- Home hero: banner met schuine snede ---------- */
.hero{
  position:relative;background:var(--oranje);color:var(--ink);
  border:var(--bord);box-shadow:var(--hard-lg);
  padding:18px 16px 22px;overflow:hidden;
  clip-path:polygon(0 0,100% 0,100% calc(100% - 16px),0 100%);
}
.hero::before{ /* halftoon op banner */
  content:"";position:absolute;inset:0;opacity:.18;
  background-image:radial-gradient(var(--ink) 1.2px, transparent 1.4px);background-size:10px 10px;
}
.hero-badge{
  position:relative;font-family:'Archivo',sans-serif;font-weight:900;font-size:11px;letter-spacing:2.5px;
  text-transform:uppercase;color:var(--oranje);background:var(--ink);
  display:inline-block;padding:5px 10px;border-radius:3px;
}
.hero h1{
  position:relative;font-family:'Anton',sans-serif;font-weight:400;letter-spacing:.5px;text-transform:uppercase;
  font-size:46px;line-height:.92;margin:10px 0 6px;color:var(--ink);
  text-shadow:3px 3px 0 var(--chalk);
}
.hero h1 .ball{display:inline-block;font-size:34px;animation:spin 5s linear infinite;text-shadow:none;vertical-align:6px}
@keyframes spin{to{transform:rotate(360deg)}}
.hero p{position:relative;margin:0;font-weight:800;text-transform:uppercase;letter-spacing:1.5px;font-size:12.5px;color:var(--oranje-ink)}

/* ---------- Spelerspas (greet) ---------- */
.greet{
  display:flex;align-items:center;gap:12px;
  background:var(--chalk);color:var(--ink);
  border:var(--bord);box-shadow:var(--hard);padding:12px;
  position:relative;
}
.greet::after{ /* perforatie-rand links als 'ticket' */
  content:"";position:absolute;left:64px;top:8px;bottom:8px;width:2px;
  background-image:linear-gradient(var(--ink) 50%, transparent 0);background-size:2px 7px;
}
.greet .ava{
  width:52px;height:52px;border-radius:6px;flex:none;display:grid;place-items:center;
  font-family:'Anton',sans-serif;font-size:28px;letter-spacing:.5px;
  background:var(--ink);color:var(--lime);cursor:pointer;border:2px solid var(--ink);
}
.greet .who{flex:1;min-width:0;padding-left:6px}
.greet .who b{font-family:'Anton',sans-serif;font-weight:400;font-size:20px;letter-spacing:.4px;display:block;text-transform:uppercase}
.greet .who small{color:#5e7468;font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:1px}
.rankbar{height:10px;border-radius:0;background:#d8d0ba;margin-top:7px;overflow:hidden;border:1.5px solid var(--ink)}
.rankbar i{display:block;height:100%;background:var(--oranje);
  background-image:repeating-linear-gradient(45deg,rgba(0,0,0,.18) 0 5px,transparent 5px 10px);
  transition:width .6s}

/* ---------- Section koppen ---------- */
.section-title{
  font-family:'Anton',sans-serif;font-weight:400;font-size:17px;letter-spacing:.8px;text-transform:uppercase;
  color:var(--chalk);margin:8px 2px -4px;display:flex;align-items:center;gap:8px;
}
.section-title::after{content:"";flex:1;height:3px;background:var(--lime);margin-left:4px}

/* ---------- Mode-kaarten: wedstrijdtickets met rugnummer ---------- */
.modes{display:grid;grid-template-columns:1fr 1fr;gap:13px}
.mode{
  position:relative;border:var(--bord);text-align:left;cursor:pointer;color:var(--chalk);
  box-shadow:var(--hard);padding:14px 14px 12px;min-height:128px;
  display:flex;flex-direction:column;justify-content:flex-end;gap:3px;overflow:hidden;
  transition:transform .1s, box-shadow .1s;
  clip-path:polygon(0 0,100% 0,100% 100%,14px 100%,0 calc(100% - 14px));
}
.mode:active{transform:translate(3px,3px);box-shadow:1px 1px 0 var(--ink)}
.mode .ic{font-size:30px;position:relative;z-index:2;filter:drop-shadow(2px 2px 0 rgba(0,0,0,.35))}
.mode b{font-family:'Anton',sans-serif;font-weight:400;font-size:20px;letter-spacing:.5px;text-transform:uppercase;position:relative;z-index:2}
.mode small{font-size:11.5px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;opacity:.92;line-height:1.25;position:relative;z-index:2}
.mode::before{ /* groot rugnummer */
  position:absolute;right:-6px;top:-18px;font-family:'Anton',sans-serif;font-size:96px;line-height:1;
  color:rgba(255,255,255,.16);z-index:1;
}
.mode.m1::before{content:"01"} .mode.m2::before{content:"02"}
.mode.m3::before{content:"03"} .mode.m4::before{content:"04"}
.mode .best{position:absolute;top:9px;left:9px;z-index:3;font-family:'Anton',sans-serif;font-size:13px;letter-spacing:.5px;
  background:var(--gold);color:var(--ink);padding:2px 7px;border:2px solid var(--ink)}
.mode .best:empty{display:none}
.mode.m1{background:var(--blue)} .mode.m2{background:var(--oranje)}
.mode.m3{background:#10a3a3} .mode.m4{background:var(--ink)}
.mode.m4{border-color:var(--lime)}
.mode.m4 b,.mode.m4 .ic{color:var(--lime)}
.mode.m4::before{color:rgba(200,255,61,.14)}
.mode.wide{grid-column:1 / -1;flex-direction:row;align-items:center;min-height:auto;gap:12px}
.mode.exam{background:var(--lime);color:var(--ink);border-color:var(--ink);clip-path:none}
.mode.exam::before{content:none}
.mode.exam .ic{font-size:30px}
.mode.exam b{font-family:'Anton',sans-serif;font-weight:400;font-size:20px;letter-spacing:.4px;text-transform:uppercase;display:block}
.mode.exam small{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;opacity:.85}
.mode.exam .exam-go{font-size:20px;background:var(--ink);color:var(--lime);width:38px;height:38px;display:grid;place-items:center;flex:none;border:2px solid var(--ink)}

/* ---------- Extra-tegels ---------- */
.tiles{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.tile{
  border:var(--bord);cursor:pointer;background:var(--chalk);color:var(--ink);text-align:left;
  box-shadow:var(--hard);padding:12px;display:flex;align-items:center;gap:11px;
  transition:transform .1s, box-shadow .1s;
}
.tile:active{transform:translate(3px,3px);box-shadow:1px 1px 0 var(--ink)}
.tile .ic{font-size:24px}
.tile b{font-family:'Anton',sans-serif;font-weight:400;font-size:16px;letter-spacing:.4px;text-transform:uppercase;display:block}
.tile small{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;color:#5e7468}

/* ---------- Play: vraagpaneel ---------- */
.q-head{
  background:var(--chalk);color:var(--ink);border:var(--bord);box-shadow:var(--hard);padding:12px 14px;
}
.q-progress{display:flex;align-items:center;gap:8px;margin-bottom:9px}
.q-dots{flex:1;display:flex;gap:4px}
.q-dot{flex:1;height:8px;background:#d8d0ba;border:1.5px solid var(--ink)}
.q-dot.ok{background:var(--green)}
.q-dot.no{background:var(--red)}
.q-dot.cur{background:var(--oranje)}
.q-count{font-family:'Anton',sans-serif;font-size:15px;letter-spacing:.5px;color:var(--ink);white-space:nowrap}
.q-prompt{font-family:'Anton',sans-serif;font-weight:400;font-size:24px;line-height:1.05;letter-spacing:.3px;text-transform:uppercase}
.q-prompt .tgt{color:var(--oranje)}
.q-sub{color:#5e7468;font-size:12.5px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;margin-top:5px}

/* ---------- Spelregels ---------- */
.rules{display:flex;flex-direction:column}
.rule{display:flex;gap:12px;align-items:flex-start;padding:12px 2px;border-bottom:2px solid rgba(10,20,16,.1)}
.rule:last-child{border-bottom:0}
.rtag{flex:none;width:32px;height:32px;display:grid;place-items:center;font-family:'Anton',sans-serif;font-size:18px;color:#fff;border:2.5px solid var(--ink)}
.rtag.t1{background:var(--blue)} .rtag.t2{background:var(--oranje)} .rtag.t3{background:#10a3a3} .rtag.t4{background:var(--ink);color:var(--lime)}
.rule b{font-family:'Anton',sans-serif;font-weight:400;font-size:17px;letter-spacing:.3px;text-transform:uppercase;display:block;color:var(--ink)}
.rule p{margin:2px 0 0;color:#5e7468;font-weight:600;font-size:13.5px;line-height:1.3}
.rules-note{margin-top:12px;padding-top:12px;border-top:2.5px solid var(--ink)}
.rules-note p{margin:0 0 8px;color:var(--ink);font-weight:600;font-size:13.5px;line-height:1.4}
.rules-note p:last-child{margin-bottom:0}
.rules-note b{font-family:'Anton',sans-serif;font-weight:400;letter-spacing:.3px;text-transform:uppercase;font-size:14px}

/* ---------- Kaart ---------- */
.map-wrap{
  background:var(--sky);
  background-image:radial-gradient(rgba(255,255,255,.5) 1px, transparent 1.5px);background-size:13px 13px;
  border:var(--bord);box-shadow:var(--hard);padding:8px;position:relative;overflow:hidden;
}
.map-wrap::after{ /* hoek-tick zoals tv-graphic */
  content:"● LIVE";position:absolute;top:8px;right:10px;font-family:'Archivo',sans-serif;font-weight:900;
  font-size:10px;letter-spacing:1.5px;color:var(--red);background:var(--ink);padding:3px 7px;z-index:3;
}
.map-wrap svg{display:block;width:100%;height:clamp(240px,52vh,560px);touch-action:manipulation;position:relative;z-index:2}
.prov{fill:var(--chalk);stroke:var(--ink);stroke-width:1.6;cursor:pointer;transition:fill .12s, transform .12s;transform-origin:center}
.prov.clickable:active{fill:#ffd9b0}
.prov.dim{fill:#cfd8cf;opacity:.7}
.prov.hi{fill:var(--oranje)}
.prov.ok{fill:var(--green)}
.prov.no{fill:var(--red)}
.prov.reveal{fill:var(--lime)}
.prov.locked{cursor:default}
.dot{cursor:pointer}
.dot circle{stroke:var(--ink);stroke-width:2.5;transition:r .12s}
.dot.cap circle{fill:var(--red)}
.dot.water circle{fill:var(--blue)}
.dot.pulse circle{animation:pulse 1.1s infinite}
@keyframes pulse{0%{transform:scale(1)}50%{transform:scale(1.4)}100%{transform:scale(1)}}
.dot.ok circle{fill:var(--green)}
.dot.no circle{fill:var(--red)}
.dot.reveal circle{fill:var(--green);animation:none}
.dot text{font-family:'Archivo',sans-serif;font-weight:900;paint-order:stroke;stroke:var(--chalk);stroke-width:3.5px;font-size:14px;fill:var(--ink);pointer-events:none}
.plabel{font-family:'Archivo Narrow',sans-serif;font-weight:700;text-transform:uppercase;letter-spacing:.3px;font-size:13px;fill:var(--ink);paint-order:stroke;stroke:var(--chalk);stroke-width:3px;pointer-events:none;opacity:0}
.plabel.show{opacity:1}
.water-lab{font-family:'Archivo Narrow',sans-serif;font-weight:700;font-style:italic;text-transform:uppercase;letter-spacing:.3px;font-size:13px;fill:#0c4866;paint-order:stroke;stroke:#fff;stroke-width:3px;pointer-events:none}
/* ingetekende rivieren */
.river{fill:none;stroke:#1d6fd6;stroke-width:4.5;stroke-linecap:round;stroke-linejoin:round;opacity:.92;pointer-events:none}
.river.faint{opacity:.35}
.river.hot{stroke:#ff2fb0;stroke-width:9;filter:drop-shadow(0 0 6px rgba(255,47,176,.9));animation:hotpulse 1.1s ease-in-out infinite}
@keyframes hotpulse{0%,100%{opacity:.85;stroke-width:8}50%{opacity:1;stroke-width:11}}
.dot.rivdot circle{fill:#1d6fd6}
/* sterke markering: radar-ping + pijl */
.wmark .wcore{fill:#ff2fb0;stroke:#fff;stroke-width:3}
.wmark .ping{fill:none;stroke:#ff2fb0;stroke-width:3;transform-box:fill-box;transform-origin:center;opacity:0;animation:ping 1.8s ease-out infinite}
.wmark .ping.p2{animation-delay:.9s}
@keyframes ping{0%{transform:scale(.5);opacity:.95}100%{transform:scale(3.4);opacity:0}}
.wmark .warrow{fill:var(--oranje);stroke:var(--ink);stroke-width:2;animation:wbounce 1s ease-in-out infinite}
@keyframes wbounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}

/* ---------- Meerkeuze ---------- */
.choices{display:grid;grid-template-columns:1fr 1fr;gap:11px}
.choice{
  border:var(--bord);cursor:pointer;background:var(--chalk);color:var(--ink);
  font-family:'Anton',sans-serif;font-weight:400;font-size:18px;letter-spacing:.3px;text-transform:uppercase;
  padding:16px 12px;box-shadow:var(--hard);transition:transform .08s, box-shadow .08s, background .15s;
  min-height:58px;line-height:1.05;
}
.choice:active{transform:translate(3px,3px);box-shadow:1px 1px 0 var(--ink)}
.choice.ok{background:var(--green);color:#04210f}
.choice.no{background:var(--red);color:#fff}
.choice.dis{opacity:.5;pointer-events:none}

.feedback{text-align:center;font-family:'Anton',sans-serif;font-weight:400;font-size:18px;letter-spacing:.4px;text-transform:uppercase;min-height:24px;color:var(--chalk)}
.toast{
  position:fixed;left:50%;bottom:calc(78px + var(--safe-b));transform:translateX(-50%);
  background:var(--ink);color:var(--lime);padding:10px 16px;border:2px solid var(--lime);
  font-family:'Anton',sans-serif;letter-spacing:.5px;text-transform:uppercase;z-index:40;animation:toastin .25s;
}
@keyframes toastin{from{opacity:0;transform:translate(-50%,12px)}to{opacity:1;transform:translateX(-50%)}}

/* ---------- Resultaat ---------- */
.result{
  background:var(--chalk);color:var(--ink);border:var(--bord);box-shadow:var(--hard-lg);padding:22px 18px;text-align:center;
}
.result .big{font-size:62px;line-height:1}
.result .big svg.ic{display:block;margin:0 auto}
.result h2{font-family:'Anton',sans-serif;font-weight:400;font-size:26px;letter-spacing:.4px;text-transform:uppercase;margin:8px 0 2px}
.result .score{font-family:'Anton',sans-serif;font-size:42px;color:var(--oranje);letter-spacing:.5px;text-transform:uppercase}
.result .row{display:flex;gap:10px;justify-content:center;margin:14px 0;flex-wrap:wrap}
.kpi{background:var(--ink);color:var(--chalk);padding:10px 14px;min-width:92px;border:2px solid var(--ink)}
.kpi b{display:block;font-family:'Anton',sans-serif;font-size:24px;letter-spacing:.5px;color:var(--lime)}
.kpi small{color:#9fb6a8;font-weight:800;text-transform:uppercase;font-size:10px;letter-spacing:1px}
.stars{font-size:32px;letter-spacing:6px;color:var(--oranje)}
.result p{font-weight:600}

/* ---------- Knoppen ---------- */
.btn{
  border:var(--bord);cursor:pointer;font-family:'Anton',sans-serif;font-weight:400;font-size:19px;letter-spacing:.6px;text-transform:uppercase;
  padding:15px 18px;width:100%;background:var(--oranje);color:var(--ink);box-shadow:var(--hard);
  transition:transform .08s, box-shadow .08s;
}
.btn:active{transform:translate(3px,3px);box-shadow:1px 1px 0 var(--ink)}
.btn.alt{background:var(--blue);color:#fff}
.btn.ghost{background:var(--chalk);color:var(--ink)}
.btn.green{background:var(--lime);color:var(--ink)}
.btn:disabled{opacity:.5}
.btn-row{display:flex;gap:10px}
.btn-row .btn{width:auto;flex:1;min-width:0;padding-left:10px;padding-right:10px}

/* ---------- Album / kaarten (Panini-stickers) ---------- */
.album-head{text-align:center}
.album-head h2{font-family:'Anton',sans-serif;font-weight:400;font-size:30px;letter-spacing:.5px;text-transform:uppercase;margin:0 0 4px;color:var(--chalk)}
.cardgrid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.card{
  position:relative;padding:12px;min-height:152px;color:#fff;border:2.5px solid var(--ink);
  display:flex;flex-direction:column;justify-content:space-between;box-shadow:var(--hard);
  overflow:hidden;isolation:isolate;
}
.card::before{content:"";position:absolute;inset:0;z-index:0;opacity:.16;
  background-image:radial-gradient(#000 1.1px, transparent 1.3px);background-size:9px 9px}
.card .shine{position:absolute;inset:0;background:linear-gradient(115deg,transparent 42%,rgba(255,255,255,.55) 50%,transparent 58%);transform:translateX(-130%);z-index:3}
.card.gold .shine{animation:shine 2.8s infinite}
@keyframes shine{0%{transform:translateX(-130%)}55%,100%{transform:translateX(130%)}}
.card .em{font-size:40px;position:relative;z-index:2;filter:drop-shadow(2px 2px 0 rgba(0,0,0,.35))}
.card b{font-family:'Anton',sans-serif;font-weight:400;font-size:17px;letter-spacing:.4px;text-transform:uppercase;line-height:1;position:relative;z-index:2}
.card small{font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;opacity:.92;position:relative;z-index:2}
.card .rar{position:absolute;top:7px;right:7px;z-index:4;font-family:'Archivo',sans-serif;font-size:9px;font-weight:900;letter-spacing:1px;text-transform:uppercase;background:var(--ink);color:#fff;padding:3px 6px}
.card.locked{background:#1a2c23 !important;color:#5e7468;border-color:#2a4034}
.card.locked::before{display:none}
.card.locked .em{filter:grayscale(1);opacity:.45}
.card.locked .shine{display:none}
.rarity-brons .rar{background:#7b4f29}
.rarity-zilver .rar{background:#5f6d77}
.rarity-goud .rar{background:#b07d00}
.rarity-special .rar{background:var(--purple)}

/* ---------- Shop / pakjes ---------- */
.shop-card{background:var(--chalk);color:var(--ink);border:var(--bord);box-shadow:var(--hard);padding:18px;text-align:center}
.shop-card p{font-weight:700}
.pack{
  width:140px;height:182px;margin:4px auto 14px;position:relative;cursor:pointer;
  background:var(--oranje);border:3px solid var(--ink);box-shadow:var(--hard);
  display:grid;place-items:center;overflow:hidden;transition:transform .1s, box-shadow .1s;
}
.pack::before{content:"";position:absolute;inset:0;opacity:.2;background-image:radial-gradient(#000 1.2px,transparent 1.4px);background-size:11px 11px}
.pack::after{content:"";position:absolute;top:0;bottom:0;left:50%;width:0;border-left:2px dashed rgba(0,0,0,.3)} /* foil-naad */
.pack:active{transform:translate(3px,3px);box-shadow:1px 1px 0 var(--ink)}
.pack .pemoji{font-size:66px;position:relative;z-index:2;color:var(--ink);filter:drop-shadow(2px 2px 0 rgba(255,255,255,.3))}
.pack .pemoji svg.ic{stroke-width:1.8}
.pack .ptag{position:absolute;bottom:0;left:0;right:0;background:var(--ink);color:var(--lime);
  font-family:'Anton',sans-serif;letter-spacing:1px;text-transform:uppercase;padding:6px;font-size:14px;z-index:2}

/* ---------- Overlay ---------- */
.overlay{
  position:fixed;inset:0;z-index:60;display:grid;place-items:center;padding:24px;
  background:rgba(8,18,13,.88);animation:fade .2s;
}
.overlay-inner{text-align:center;color:var(--chalk);max-width:330px;width:100%}
.overlay-inner h3{font-family:'Anton',sans-serif;font-weight:400;font-size:24px;letter-spacing:.5px;text-transform:uppercase;margin:14px 0 6px}
.overlay-inner p{font-weight:700}
.overlay .reveal-card{transform:scale(.4) rotate(-6deg);animation:cardin .55s cubic-bezier(.2,1.4,.4,1) forwards}
@keyframes cardin{to{transform:scale(1) rotate(-2deg)}}
.overlay .card{margin:0 auto;width:200px;min-height:242px}
.overlay .card .em{font-size:60px}
.overlay .card b{font-size:21px}

/* confetti */
.confetti{position:fixed;inset:0;pointer-events:none;z-index:70;overflow:hidden}
.confetti i{position:absolute;top:-14px;width:10px;height:14px;animation:fall linear forwards}
@keyframes fall{to{transform:translateY(112vh) rotate(720deg);opacity:.9}}

/* ---------- Ticker: broadcast lower-third ---------- */
.ticker{
  position:sticky;bottom:0;z-index:20;display:flex;align-items:stretch;
  background:var(--ink);border-top:3px solid var(--oranje);padding-bottom:var(--safe-b);
}
.ticker-tag{background:var(--oranje);color:var(--ink);font-family:'Anton',sans-serif;letter-spacing:1px;text-transform:uppercase;font-size:12px;padding:9px 11px;white-space:nowrap;display:flex;align-items:center}
.ticker-track{overflow:hidden;flex:1;display:flex;align-items:center}
.ticker-content{display:inline-block;white-space:nowrap;color:var(--chalk);font-size:13.5px;font-weight:700;padding:9px 0;animation:scroll 90s linear infinite}
@keyframes scroll{from{transform:translateX(20%)}to{transform:translateX(-100%)}}

/* ---------- Toets: naam-invoer ---------- */
.nlabel{display:block;font-family:'Anton',sans-serif;font-weight:400;text-transform:uppercase;font-size:13px;letter-spacing:.6px;margin:12px 0 6px;color:var(--ink)}
.ninput{width:100%;font-family:'Archivo',sans-serif;font-weight:800;font-size:16px;padding:13px;border:2.5px solid var(--ink);background:#fff;color:var(--ink);outline:none}
.ninput:focus{box-shadow:var(--hard)}

/* ---------- Ranglijst ---------- */
.rank-list{display:flex;flex-direction:column;gap:9px}
.rrow{display:grid;grid-template-columns:38px 1fr auto;grid-template-areas:"pos name cij" "pos meta meta";align-items:center;gap:1px 10px;
  background:var(--chalk);color:var(--ink);border:2.5px solid var(--ink);box-shadow:var(--hard);padding:10px 12px}
.rrow.me{background:var(--lime)}
.rpos{grid-area:pos;font-family:'Anton',sans-serif;font-size:20px;text-align:center;line-height:1}
.rpos.p1{color:var(--gold)} .rpos.p2{color:#8a97a1} .rpos.p3{color:#b5743b}
.rmeta svg.ic{width:13px;height:13px;margin-bottom:-1px}
.rname{grid-area:name;font-family:'Anton',sans-serif;font-weight:400;font-size:17px;letter-spacing:.3px;text-transform:uppercase;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.rcij{grid-area:cij;font-family:'Anton',sans-serif;font-size:24px;color:var(--oranje);line-height:1}
.rmeta{grid-area:meta;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;color:#5e7468}

/* ---------- helpers ---------- */
.center{display:flex;flex-direction:column;align-items:center;gap:10px}
.spacer{flex:1}
.hidden,[hidden]{display:none !important}
.mut{color:#5e7468;font-size:12.5px;font-weight:700}
.footnote{color:#6f8a7c;font-size:10.5px;font-weight:800;text-transform:uppercase;letter-spacing:1px;text-align:center;padding:4px}

/* reduced motion */
@media(prefers-reduced-motion:reduce){
  .ticker-content,.hero h1 .ball,.card.gold .shine,.dot.pulse circle{animation:none !important}
}

/* tablet / desktop */
@media(min-width:600px){
  #app{max-width:840px}
  .hero h1{font-size:60px}
  .modes{grid-template-columns:repeat(4,1fr)}
  .mode{min-height:150px}
  .cardgrid{grid-template-columns:repeat(4,1fr)}
  .choices{grid-template-columns:repeat(4,1fr)}
}
@media(min-width:900px){#app{max-width:920px}}
