/* ============================================================
   PICK·A·GAME — arcade / neon-CRT aesthetic
   ============================================================ */
:root{
  --bg:#07060d;
  --bg2:#0d0a1a;
  --ink:#f4f0ff;
  --mute:#8a83b8;
  --mag:#ff2e88;     /* hot magenta */
  --cyan:#19f0ff;    /* electric cyan */
  --lime:#c6ff00;    /* acid lime */
  --gold:#ffb300;
  --line:rgba(255,255,255,.10);
  --card:rgba(255,255,255,.035);
  --glow-m:0 0 4px var(--mag),0 0 16px rgba(255,46,136,.55);
  --glow-c:0 0 4px var(--cyan),0 0 16px rgba(25,240,255,.5);
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  background:
    radial-gradient(120% 90% at 50% -10%,#1a1140 0%,transparent 55%),
    radial-gradient(80% 70% at 110% 110%,#23104a 0%,transparent 60%),
    var(--bg);
  color:var(--ink);
  font-family:"DM Mono",ui-monospace,monospace;
  overflow-x:hidden;
  -webkit-tap-highlight-color:transparent;
}
/* CRT scanlines + vignette */
.crt{
  position:fixed;inset:0;pointer-events:none;z-index:9000;
  background:repeating-linear-gradient(0deg,rgba(0,0,0,.16) 0 1px,transparent 1px 3px);
  mix-blend-mode:multiply;
}
.crt::after{
  content:"";position:absolute;inset:0;
  box-shadow:inset 0 0 220px 40px rgba(0,0,0,.75);
}
.grain{
  position:fixed;inset:-50%;pointer-events:none;z-index:9001;opacity:.05;
  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='.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  animation:grain .9s steps(3) infinite;
}
@keyframes grain{0%{transform:translate(0,0)}33%{transform:translate(-6%,3%)}66%{transform:translate(4%,-5%)}100%{transform:translate(0,0)}}

#app{position:relative;z-index:1;min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:clamp(14px,3vw,40px)}
.screen{display:none;width:min(960px,100%);flex-direction:column;align-items:center;gap:22px;animation:in .45s cubic-bezier(.2,1,.3,1)}
.screen.active{display:flex}
@keyframes in{from{opacity:0;transform:translateY(14px) scale(.99)}to{opacity:1;transform:none}}

/* ---------- typographic marquee ---------- */
.marquee{font-family:"Bungee",sans-serif;line-height:.92;text-align:center;
  font-size:clamp(44px,11vw,118px);letter-spacing:.01em;display:flex;flex-wrap:wrap;justify-content:center;gap:.06em}
.marquee .m1{color:var(--mag);text-shadow:var(--glow-m)}
.marquee .m2{color:var(--lime);text-shadow:0 0 16px rgba(198,255,0,.55)}
.marquee .m3{color:var(--cyan);text-shadow:var(--glow-c)}
.marquee .dot{color:var(--ink);opacity:.4}
.tag{color:var(--mute);letter-spacing:.32em;font-size:clamp(10px,1.5vw,13px);text-align:center}

/* ---------- panels / cards ---------- */
.panel,.card-box{
  width:100%;background:var(--card);border:1px solid var(--line);
  border-radius:18px;padding:clamp(18px,3vw,30px);
  backdrop-filter:blur(6px);box-shadow:0 24px 60px rgba(0,0,0,.5),inset 0 1px 0 rgba(255,255,255,.05);
}
.panel{max-width:480px;display:flex;flex-direction:column;gap:14px}
.fld{display:flex;flex-direction:column;gap:7px}
.fld span{font-size:11px;letter-spacing:.22em;color:var(--mute)}
input{
  font-family:inherit;font-size:16px;color:var(--ink);
  background:#06040e;border:1px solid var(--line);border-radius:11px;
  padding:13px 15px;outline:none;transition:border-color .15s,box-shadow .15s;width:100%;
}
input:focus{border-color:var(--cyan);box-shadow:var(--glow-c)}
.code-inp{text-transform:uppercase;letter-spacing:.5em;text-align:center;font-family:"Bungee";font-size:22px}

/* ---------- buttons ---------- */
.btn{
  font-family:"Bungee",sans-serif;font-size:15px;letter-spacing:.04em;
  color:var(--bg);background:var(--cyan);border:none;border-radius:12px;
  padding:15px 22px;cursor:pointer;position:relative;
  box-shadow:0 0 0 1px rgba(255,255,255,.15),0 10px 0 -2px #0a3d44,var(--glow-c);
  transition:transform .08s,box-shadow .12s,filter .12s;
}
.btn:hover{filter:brightness(1.08)}
.btn:active{transform:translateY(3px);box-shadow:0 0 0 1px rgba(255,255,255,.15),0 5px 0 -2px #0a3d44,var(--glow-c)}
.btn.big{background:var(--mag);color:#fff;box-shadow:0 0 0 1px rgba(255,255,255,.18),0 10px 0 -2px #6e0a36,var(--glow-m);width:100%}
.btn.big:active{box-shadow:0 0 0 1px rgba(255,255,255,.18),0 5px 0 -2px #6e0a36,var(--glow-m)}
.btn.ghost{background:transparent;color:var(--ink);box-shadow:0 0 0 1px var(--line)}
.btn:disabled{filter:grayscale(.7) brightness(.6);cursor:not-allowed;box-shadow:0 0 0 1px var(--line)}
.btn[disabled]:active{transform:none}
.link{background:none;border:none;color:var(--mute);font-family:inherit;font-size:12px;
  letter-spacing:.16em;cursor:pointer;text-decoration:none;padding:6px}
.link:hover{color:var(--cyan)}
.link.danger:hover{color:var(--mag)}
.or{text-align:center;color:var(--mute);font-size:11px;letter-spacing:.3em}
.join-row{display:flex;gap:10px}
.join-row .code-inp{flex:1;font-size:18px;padding:13px}
.err{color:var(--mag);font-size:12px;min-height:1em;text-align:center;letter-spacing:.06em}
.hist-open{margin-top:6px}

/* ---------- lobby ---------- */
.bar{width:100%;display:flex;justify-content:space-between;align-items:center;
  gap:14px;flex-wrap:wrap;border-bottom:1px solid var(--line);padding-bottom:14px}
.bar.mini{font-size:12px;letter-spacing:.14em;color:var(--mute)}
.room{font-size:12px;letter-spacing:.2em;color:var(--mute);display:flex;align-items:center;gap:12px}
.room b{font-family:"Bungee";font-size:26px;color:var(--lime);letter-spacing:.14em;text-shadow:0 0 14px rgba(198,255,0,.5)}
.chip-btn{font-family:inherit;font-size:11px;letter-spacing:.12em;color:var(--cyan);
  background:rgba(25,240,255,.08);border:1px solid rgba(25,240,255,.3);border-radius:8px;padding:6px 10px;cursor:pointer}
.slots{display:flex;align-items:stretch;gap:8px;flex-wrap:wrap}
.slot{display:flex;flex-direction:column;align-items:center;min-width:78px;
  padding:8px 12px;border:1px solid var(--line);border-radius:11px;background:#0c0a18;opacity:.4;transition:.25s}
.slot.live{opacity:1;border-color:var(--cyan);box-shadow:var(--glow-c)}
.slot.me{border-color:var(--lime);box-shadow:0 0 12px rgba(198,255,0,.4)}
.slot i{font-style:normal;font-family:"Bungee";font-size:12px;color:var(--mute)}
.slot.live i{color:var(--cyan)}
.slot.me i{color:var(--lime)}
.slot span{font-size:12px;max-width:90px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

.lobby-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;width:100%}
@media(max-width:720px){.lobby-grid{grid-template-columns:1fr}}
.card-box h2{font-family:"Bungee";font-size:15px;letter-spacing:.1em;color:var(--ink);margin-bottom:16px}
.seg{display:flex;gap:6px;margin-bottom:12px;flex-wrap:wrap}
.seg button,.chips button{
  font-family:inherit;font-size:12px;letter-spacing:.05em;color:var(--mute);
  background:#0c0a18;border:1px solid var(--line);border-radius:9px;padding:9px 12px;cursor:pointer;transition:.15s}
.seg button.on{color:var(--bg);background:var(--cyan);border-color:var(--cyan);box-shadow:var(--glow-c)}
.chips{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:14px}
.chips button.on{color:var(--bg);background:var(--lime);border-color:var(--lime)}
.poolc{font-size:12px;letter-spacing:.16em;color:var(--mute)}
.poolc b{font-family:"Bungee";color:var(--lime);font-size:20px}
.modes{display:flex;flex-direction:column;gap:12px;margin-bottom:16px}
.mode{text-align:left;font-family:inherit;color:var(--ink);background:#0c0a18;
  border:1px solid var(--line);border-radius:13px;padding:15px 16px;cursor:pointer;
  display:grid;grid-template-columns:auto 1fr;gap:4px 14px;align-items:center;transition:.18s}
.mode .mi{grid-row:span 2;font-size:30px}
.mode b{font-family:"Bungee";font-size:14px;letter-spacing:.05em}
.mode small{color:var(--mute);font-size:11px;grid-column:2}
.mode.on{border-color:var(--mag);box-shadow:var(--glow-m);background:rgba(255,46,136,.07)}
.hint{color:var(--mute);font-size:11px;letter-spacing:.1em;text-align:center}

/* ---------- tinder deck ---------- */
.deck{position:relative;width:min(420px,92vw);height:min(560px,62dvh)}
.gcard{
  position:absolute;inset:0;border-radius:22px;padding:26px;
  display:flex;flex-direction:column;justify-content:space-between;
  border:1px solid rgba(255,255,255,.16);overflow:hidden;
  box-shadow:0 30px 70px rgba(0,0,0,.6);cursor:grab;
  transition:transform .35s cubic-bezier(.2,1,.3,1),opacity .35s;
  will-change:transform;
}
.gcard::after{content:"";position:absolute;inset:0;
  background:repeating-linear-gradient(135deg,rgba(255,255,255,.05) 0 2px,transparent 2px 9px);mix-blend-mode:overlay}
.gcard .cat{font-size:11px;letter-spacing:.24em;opacity:.85;font-family:"Bungee"}
.gcard h3{font-family:"Bungee";font-size:clamp(26px,7vw,42px);line-height:1.02;
  text-shadow:0 4px 20px rgba(0,0,0,.55);word-break:break-word}
.gcard .meta{display:flex;flex-wrap:wrap;gap:8px}
.badge{font-size:11px;letter-spacing:.1em;background:rgba(0,0,0,.4);
  border:1px solid rgba(255,255,255,.3);border-radius:999px;padding:6px 12px;backdrop-filter:blur(2px)}
.gcard .note{font-size:13px;opacity:.92;background:rgba(0,0,0,.34);
  padding:10px 13px;border-radius:11px;border:1px solid rgba(255,255,255,.14)}
.gcard .cover{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.gcard .shade{position:absolute;inset:0;z-index:0;
  background:linear-gradient(180deg,rgba(8,4,16,.25) 0%,rgba(8,4,16,.55) 45%,rgba(8,4,16,.93) 100%)}
.gcard>.cat,.gcard>h3,.gcard>div,.gcard>.steam-link,.gcard>.stamp{position:relative;z-index:1}
.steam-link{display:inline-flex;align-items:center;gap:7px;align-self:flex-start;
  font-family:"DM Mono";font-size:12px;letter-spacing:.08em;text-decoration:none;
  color:var(--cyan);background:rgba(8,12,24,.7);border:1px solid rgba(25,240,255,.4);
  border-radius:999px;padding:7px 14px;margin-top:10px;backdrop-filter:blur(3px);transition:.15s}
.steam-link:hover{background:var(--cyan);color:#06121a}
.winner .wcover{display:block;width:min(220px,55vw);aspect-ratio:600/900;object-fit:cover;
  border-radius:14px;border:1px solid var(--line);box-shadow:0 18px 50px rgba(0,0,0,.6),var(--glow-c);margin:0 auto 18px}
.stamp{position:absolute;top:34px;font-family:"Bungee";font-size:34px;
  padding:6px 16px;border:4px solid;border-radius:12px;opacity:0;transform:rotate(-14deg);transition:opacity .1s}
.stamp.yes{right:24px;color:var(--lime);border-color:var(--lime);text-shadow:0 0 12px var(--lime)}
.stamp.no{left:24px;color:var(--mag);border-color:var(--mag);transform:rotate(14deg)}
.gcard.gone-r{transform:translateX(140%) rotate(22deg);opacity:0}
.gcard.gone-l{transform:translateX(-140%) rotate(-22deg);opacity:0}
.deck-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;
  height:100%;gap:12px;color:var(--mute);text-align:center}
.deck-empty b{font-family:"Bungee";color:var(--cyan);font-size:20px}

.swipe-ctl{display:flex;gap:22px;align-items:center}
.rnd{width:66px;height:66px;border-radius:50%;font-size:26px;cursor:pointer;
  border:2px solid;background:#0c0a18;transition:transform .1s,box-shadow .15s}
.rnd:active{transform:scale(.9)}
.rnd.yep{color:var(--lime);border-color:var(--lime);box-shadow:0 0 16px rgba(198,255,0,.4)}
.rnd.nope{color:var(--mag);border-color:var(--mag);box-shadow:var(--glow-m)}
.rnd.none{width:52px;height:52px;font-size:18px;color:var(--gold);border-color:var(--gold)}
.prog b{color:var(--ink)}

/* ---------- roulette ---------- */
.wheel{position:relative;width:100%;max-width:680px}
.pointer{position:absolute;top:-14px;left:50%;transform:translateX(-50%);
  color:var(--mag);font-size:26px;z-index:3;filter:drop-shadow(0 0 8px var(--mag))}
.reel-mask{overflow:hidden;border:1px solid var(--line);border-radius:16px;
  background:#06040e;box-shadow:inset 0 0 60px rgba(0,0,0,.7);
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent)}
.reel{display:flex;will-change:transform}
.cell{flex:0 0 220px;height:150px;margin:14px 7px;border-radius:14px;
  display:flex;align-items:center;justify-content:center;text-align:center;
  font-family:"Bungee";font-size:17px;padding:14px;line-height:1.1;
  border:1px solid rgba(255,255,255,.14);color:#fff;text-shadow:0 2px 10px rgba(0,0,0,.6)}
.reel.spin{transition:transform 4.4s cubic-bezier(.12,.62,.12,1)}

/* ---------- result ---------- */
#screen-result{text-align:center}
.verdict{font-family:"Bungee";letter-spacing:.3em;color:var(--mute);font-size:14px}
.winner{font-family:"Bungee";font-size:clamp(30px,8vw,64px);line-height:1.04;
  color:var(--lime);text-shadow:0 0 28px rgba(198,255,0,.55);max-width:14ch;
  padding:18px 4px;animation:pop .6s cubic-bezier(.2,1.4,.3,1)}
@keyframes pop{0%{transform:scale(.6);opacity:0}100%{transform:scale(1);opacity:1}}
.winner .wmeta{display:flex;gap:8px;justify-content:center;flex-wrap:wrap;margin-top:14px}
.winner .wmeta .badge{font-family:"DM Mono";color:var(--ink)}
.result-actions{display:flex;gap:12px;flex-wrap:wrap;justify-content:center;max-width:520px}
.result-actions .btn{width:auto}
.shortlist{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;max-width:600px;margin-top:8px}
.shortlist .badge{cursor:default}
.shortlist .h{width:100%;color:var(--mute);font-size:11px;letter-spacing:.22em}
.burst{position:fixed;inset:0;pointer-events:none;z-index:50;overflow:hidden}
.spark{position:absolute;width:10px;height:10px;border-radius:2px;animation:fly 1.1s ease-out forwards}
@keyframes fly{to{transform:translate(var(--dx),var(--dy)) rotate(540deg);opacity:0}}

/* ---------- history drawer ---------- */
.drawer{position:fixed;top:0;right:0;height:100dvh;width:min(360px,86vw);
  background:var(--bg2);border-left:1px solid var(--line);z-index:9100;
  transform:translateX(105%);transition:transform .3s cubic-bezier(.2,1,.3,1);
  display:flex;flex-direction:column;gap:10px;padding:20px}
.drawer.open{transform:none}
.drawer-head{display:flex;justify-content:space-between;align-items:center}
.drawer-head b{font-family:"Bungee";color:var(--cyan);letter-spacing:.1em}
.hist-list{flex:1;overflow:auto;display:flex;flex-direction:column;gap:8px}
.hrow{display:flex;justify-content:space-between;gap:10px;font-size:12px;
  background:var(--card);border:1px solid var(--line);border-radius:9px;padding:10px 12px}
.hrow span{color:var(--mute);font-size:10px}
.empty-h{color:var(--mute);font-size:12px;text-align:center;margin-top:30px}

/* ---------- toast ---------- */
.toast{position:fixed;left:50%;bottom:26px;transform:translate(-50%,140%);
  background:#120c24;border:1px solid var(--mag);color:var(--ink);
  padding:13px 20px;border-radius:11px;font-size:13px;z-index:9200;
  box-shadow:var(--glow-m);transition:transform .35s cubic-bezier(.2,1.4,.3,1);max-width:88vw;text-align:center}
.toast.show{transform:translate(-50%,0)}
