@font-face{font-family:Fredoka;src:url(/fonts/fredoka-400.ttf)format("truetype");font-weight:400;font-display:swap}@font-face{font-family:Fredoka;src:url(/fonts/fredoka-600.ttf)format("truetype");font-weight:600;font-display:swap}@font-face{font-family:Fredoka;src:url(/fonts/fredoka-700.ttf)format("truetype");font-weight:700;font-display:swap}:root{--felt-a:#f2ead9;--felt-b:#e6dbc4;--surface:#fffdf8;--surface-2:#f4eedd;--text:#2b2418;--muted:#8a7d63;--border:#e3d8bf;--board-bg:#2d2a26;--cell:#efe9dd;--accent:#2563eb;--accent-deep:#1d4ed8;--ok:#16a34a;--bad:#dc2626;--gold:#d97706;--shadow-card:0 1px 2px #3c2d1414, 0 6px 18px #3c2d141a;--shadow-pop:0 2px 6px #3c2d141f, 0 16px 40px #3c2d142e;--hi:inset 0 1.5px 0 #ffffffa6;--font-display:"Fredoka", system-ui, sans-serif;font-family:system-ui,-apple-system,sans-serif}:root[data-theme=dark]{--felt-a:#1b1712;--felt-b:#131009;--surface:#241f17;--surface-2:#2e2820;--text:#f0e9da;--muted:#a3977f;--border:#3b3426;--board-bg:#0c0b09;--cell:#3a352e;--shadow-card:0 1px 2px #0006, 0 8px 22px #00000073;--shadow-pop:0 2px 6px #00000080, 0 18px 44px #0009;--hi:inset 0 1.5px 0 #ffffff12}[data-skin=gs]{--accent:#16a34a;--accent-deep:#15803d}[data-skin=star]{--accent:#d97706;--accent-deep:#b45309}[data-skin=sudoku]{--accent:#2563eb;--accent-deep:#1d4ed8}[data-skin=kenken]{--accent:#7c3aed;--accent-deep:#6d28d9}[data-skin=boggle]{--accent:#ea580c;--accent-deep:#c2410c}[data-skin=pipes]{--accent:#0891b2;--accent-deep:#0e7490}[data-skin=nonogram]{--accent:#db2777;--accent-deep:#be185d}[data-skin=lightsout]{--accent:#ca8a04;--accent-deep:#a16207}[data-skin=mines]{--accent:#57534e;--accent-deep:#44403c}[data-skin=wordsearch]{--accent:#0d9488;--accent-deep:#0f766e}[data-skin=memory]{--accent:#e11d48;--accent-deep:#be123c}[data-skin=trio]{--accent:#9333ea;--accent-deep:#7e22ce}[data-skin=g2048]{--accent:#f59e0b;--accent-deep:#d97706}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}html{background:var(--felt-b)}body{color:var(--text);background:radial-gradient(1200px 700px at 25% -10%, var(--felt-a), transparent 70%), radial-gradient(1000px 800px at 110% 30%, var(--felt-a), transparent 60%), url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3CfeColorMatrix values='0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 .04 0'/%3E%3C/filter%3E%3Crect width='180' height='180' filter='url(%23n)'/%3E%3C/svg%3E"), var(--felt-b);margin:0}[hidden]{display:none!important}h1,h2,h3,.display{font-family:var(--font-display);letter-spacing:.01em}h2{margin:0 0 .6rem;font-size:1.05rem;font-weight:600}.muted{color:var(--muted);font-size:.85rem}.header{z-index:5;background:color-mix(in srgb, var(--surface) 80%, transparent);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border-bottom:1px solid var(--border);align-items:center;gap:.6rem;padding:.55rem .9rem;display:flex;position:sticky;top:0}.header .logo{width:32px;height:32px;box-shadow:var(--shadow-card);border-radius:9px}.header h1{flex:1;margin:0;font-size:1.15rem;font-weight:700}.header h1 em{color:var(--accent);font-style:normal}.who{color:var(--muted);align-items:center;gap:.4rem;font-size:.8rem;display:flex}main{flex-direction:column;gap:.9rem;max-width:480px;margin:0 auto;padding:.9rem;display:flex}.panel{background:var(--surface);box-shadow:var(--shadow-card), var(--hi);border:1px solid var(--border);border-radius:18px;padding:.9rem}button,.btn,select,input,textarea{font:inherit;color:var(--text);border:1px solid var(--border);background:var(--surface);border-radius:12px}input,textarea,select{background:var(--surface-2);padding:.5rem .8rem}input:focus-visible,textarea:focus-visible,select:focus-visible,button:focus-visible{outline:2px solid var(--accent);outline-offset:1px}button{cursor:pointer;background:linear-gradient(180deg, var(--surface), var(--surface-2));box-shadow:0 2px 0 var(--border), 0 3px 6px #3c2d1414, var(--hi);padding:.5rem .9rem;font-weight:600;transition:transform 60ms,box-shadow 60ms,filter .15s}button:hover{filter:brightness(1.03)}button:active{box-shadow:0 0 0 var(--border), inset 0 2px 4px #00000014;transform:translateY(2px)}button.primary{color:#fff;border-color:var(--accent-deep);background:linear-gradient(180deg, color-mix(in srgb, var(--accent) 88%, #fff), var(--accent));box-shadow:0 3px 0 var(--accent-deep), 0 5px 12px color-mix(in srgb, var(--accent) 45%, transparent), inset 0 1.5px 0 #ffffff59;text-shadow:0 1px 1px #00000026}button.primary:active{box-shadow:0 0 0 var(--accent-deep), inset 0 2px 5px #0003;transform:translateY(3px)}button.big{width:100%;font-size:1.15rem;font-family:var(--font-display);border-radius:16px;padding:.8rem 1.6rem}button.ghost{box-shadow:none;color:var(--muted);background:0 0;border-color:#0000}button.danger{color:var(--bad)}.landing{text-align:center}.landing .hero{width:100%;box-shadow:var(--shadow-pop);border-radius:16px}.landing h2{margin:.9rem 0 .3rem;font-size:1.5rem;font-weight:700}.join-row{justify-content:center;gap:.45rem;margin-top:.6rem;display:flex}.join-row input{text-transform:uppercase;text-align:center;letter-spacing:.15em;width:11em;font-weight:700}.landing h3{font-family:var(--font-display);color:var(--muted);margin:1.3rem 0 .45rem;font-size:.95rem}.party-list{flex-direction:column;gap:.45rem;display:flex}.party-card{text-align:left;flex-direction:column;align-items:flex-start;gap:.15rem;width:100%;padding:.6rem .85rem;display:flex;position:relative}.party-card b{letter-spacing:.07em;font-family:var(--font-display)}.party-card small{color:var(--muted)}.party-card .x{color:var(--muted);font-size:.8rem;position:absolute;top:8px;right:12px}.strip{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.strip .code{font-family:var(--font-display);letter-spacing:.1em;flex:1;font-size:1.05rem;font-weight:700}.strip .code span{color:var(--accent)}.banner{text-align:center;font-weight:700;font-family:var(--font-display);color:#422006;box-shadow:0 3px 0 #b45309, var(--shadow-card), inset 0 2px 0 #ffffff80;background:linear-gradient(#fcd34d,#f59e0b);border-radius:18px;padding:.8rem 1rem;animation:.45s cubic-bezier(.34,1.56,.64,1) banner-in}@keyframes banner-in{0%{opacity:0;transform:scale(.92)}}.shelf{grid-template-columns:repeat(3,1fr);gap:.55rem;display:grid}.game-card{text-align:center;border:2px solid var(--border);border-radius:14px;flex-direction:column;align-items:center;gap:.25rem;padding:.7rem .35rem .6rem;display:flex;position:relative;overflow:hidden}.game-card:before{content:"";background:linear-gradient(180deg, color-mix(in srgb, var(--accent) 18%, transparent), transparent);pointer-events:none;height:42px;position:absolute;inset:0 0 auto}.game-card .gc-icon{background:radial-gradient(circle at 35% 30%, color-mix(in srgb, var(--accent) 30%, var(--surface)), color-mix(in srgb, var(--accent) 12%, var(--surface)));width:46px;height:46px;box-shadow:0 2px 5px color-mix(in srgb, var(--accent) 35%, transparent), inset 0 1.5px 0 #ffffff80;border-radius:50%;place-items:center;font-size:1.7rem;display:grid}.game-card b{font-size:.82rem;font-family:var(--font-display);font-weight:600}.game-card small{color:var(--muted);font-size:.67rem;line-height:1.3}.game-card.picked{border-color:var(--accent);box-shadow:0 0 0 3px color-mix(in srgb, var(--accent) 22%, transparent), var(--shadow-card)}.game-card.locked{opacity:.42}.game-card .gc-lock{opacity:.35;font-size:.8rem;position:absolute;top:5px;right:7px}.game-card .gc-lock:hover,.game-card.locked .gc-lock{opacity:1}.card-panel{background:var(--surface-2);border:2px solid var(--accent);border-radius:14px;grid-column:1/-1;margin:-.05rem 0 .2rem;padding:.65rem .75rem;box-shadow:inset 0 2px 6px #3c2d140f}.card-panel .opts{flex-direction:column;gap:.45rem;margin-bottom:.65rem;font-size:.9rem;display:flex}.card-panel .row{gap:.5rem;display:flex}.playlist{flex-direction:column;gap:.3rem;display:flex}.pl-item{align-items:center;gap:.5rem;font-size:.88rem;display:flex}.pl-item.done{opacity:.45}.pl-item.next .pl-label{font-weight:700}.pl-mark{text-align:center;width:1.4em;color:var(--accent);font-weight:700;font-family:var(--font-display)}.pl-label{flex:1}.pl-item button{padding:.1rem .45rem;font-size:.65rem}.next-up{border:2px solid var(--accent);background:var(--surface);box-shadow:0 0 0 4px color-mix(in srgb, var(--accent) 14%, transparent), var(--shadow-card);border-radius:16px;flex-wrap:wrap;align-items:center;gap:.6rem;padding:.65rem .85rem;display:flex}.next-up b{font-family:var(--font-display);flex:1}.play{flex-direction:column;align-items:center;gap:.75rem;display:flex}.game-frame{background:linear-gradient(180deg, color-mix(in srgb, var(--accent) 10%, var(--surface)), var(--surface)), var(--surface);border:1px solid color-mix(in srgb, var(--accent) 25%, var(--border));width:100%;box-shadow:var(--shadow-card), inset 0 1.5px 0 #ffffff59;border-radius:22px;justify-content:center;padding:.9rem;display:flex}:root[data-theme=dark] .game-frame{box-shadow:var(--shadow-card), inset 0 1.5px 0 #ffffff0d}.statusbar{flex-wrap:wrap;justify-content:center;align-items:center;gap:.9rem;min-height:1.4em;font-size:.95rem;display:flex}.statusbar .timer{font-variant-numeric:tabular-nums;font-weight:700;font-family:var(--font-display);background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow-card);border-radius:99px;padding:.15rem .8rem}.status.ok{color:var(--ok);font-weight:600}.status.bad{color:var(--bad);font-weight:700}.status.won{color:var(--gold);font-weight:800}.round-label{text-align:center;margin:0}.help{text-align:center;max-width:470px;margin:0;font-size:.82rem}.help summary{cursor:pointer;color:var(--accent);font-weight:600;list-style:none}.help[open] summary{margin-bottom:.25rem}.score-head{justify-content:space-between;align-items:baseline;display:flex}.player{border-bottom:1px solid var(--border);align-items:center;gap:.6rem;padding:.5rem .35rem;display:flex}.player:last-child{border-bottom:none}.player .pname{text-overflow:ellipsis;flex:1;font-size:.9rem;font-weight:600;overflow:hidden}.player .pts{font-variant-numeric:tabular-nums;font-weight:700;font-family:var(--font-display);text-align:center;background:var(--surface-2);border-radius:10px;min-width:2em;padding:.05rem .45rem;box-shadow:inset 0 1px 3px #3c2d141f}.player .ptime{color:var(--gold);font-variant-numeric:tabular-nums;white-space:nowrap;font-size:.8rem}.player .pmini{justify-content:center;min-width:64px;display:flex}.player .stuck-badge{color:var(--bad);font-size:.72rem;font-weight:700}.player.stuck .pmini{outline:2px solid var(--bad);border-radius:5px}.player .boot{color:var(--bad);padding:.1rem .4rem;font-size:.65rem}.mini-board{background:var(--board-bg);border-radius:4px;grid-template-rows:repeat(6,9px);grid-template-columns:repeat(6,9px);gap:1px;padding:2px;display:grid}.mini-board .mc{background:var(--cell);border-radius:1px}.settings{flex-direction:column;gap:.45rem;margin-top:.7rem;font-size:.85rem;display:flex}.admin-row{flex-wrap:wrap;gap:.4rem;margin-top:.6rem;display:flex}.admin-row button{padding:.3rem .6rem;font-size:.8rem}.chat-log{flex-direction:column;gap:.3rem;max-height:170px;margin-bottom:.55rem;font-size:.85rem;display:flex;overflow-y:auto}.chat-msg{line-height:1.35}.chat-msg b{color:var(--accent);font-weight:700}.chat-msg.mine b{color:var(--gold)}.chat-msg a{color:var(--accent);word-break:break-all}.chat-row{gap:.45rem;display:flex}.chat-row input{border-radius:99px;flex:1;min-width:0}.toasts{z-index:70;pointer-events:none;flex-direction:column;gap:.4rem;display:flex;position:fixed;top:60px;left:50%;transform:translate(-50%)}.toast{background:var(--text);color:var(--surface);font-size:.85rem;font-weight:600;font-family:var(--font-display);box-shadow:var(--shadow-pop);border-radius:99px;padding:.5rem 1rem;animation:.3s cubic-bezier(.34,1.56,.64,1) toast-in}@keyframes toast-in{0%{opacity:0;transform:translateY(-10px)scale(.95)}}dialog{border:1px solid var(--border);background:var(--surface);color:var(--text);text-align:center;max-width:92vw;box-shadow:var(--shadow-pop);border-radius:22px;padding:1.3rem}dialog::backdrop{-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);background:#140e0580}dialog h2{font-size:1.2rem}dialog input,dialog textarea{width:100%;margin:.8rem 0;display:block}.google-btn{justify-content:center;align-items:center;gap:.5rem;width:100%;padding:.6rem .8rem;display:inline-flex}.qr-box svg{border-radius:10px;width:min(70vw,280px);height:auto}.fb-shot{object-fit:contain;border:1px solid var(--border);border-radius:10px;width:100%;max-height:180px}.fb-row{justify-content:center;gap:.5rem;display:flex}.board-pop{animation:.55s board-pop}@keyframes board-pop{0%{transform:scale(1)}35%{transform:scale(1.05)rotate(1deg)}70%{transform:scale(.99)rotate(-.5deg)}to{transform:scale(1)}}#confetti{pointer-events:none;z-index:60;position:fixed;inset:0;overflow:hidden}#confetti i{width:9px;height:14px;animation:confetti var(--t) cubic-bezier(.2, .55, .45, 1) forwards;opacity:0;border-radius:2px;position:absolute;top:55%}@keyframes confetti{0%{opacity:1;transform:translate(0)rotate(0)}30%{transform:translate(calc(var(--dx) * .55), calc(var(--up) * -1)) rotate(calc(var(--rot) * .4));opacity:1}to{transform:translate(var(--dx), 60vh) rotate(var(--rot));opacity:0}}.panel .shelf+*,.panel .playlist+*,.panel .shelf,.panel .playlist{margin-top:.65rem}.proposal{border:2px solid var(--accent);background:var(--surface);box-shadow:0 0 0 4px color-mix(in srgb, var(--accent) 14%, transparent), var(--shadow-card);border-radius:16px;flex-direction:column;gap:.5rem;padding:.65rem .85rem;display:flex}.proposal b{font-family:var(--font-display)}.proposal .row{gap:.5rem;display:flex}.fade-in{animation:.3s fade-in}@keyframes fade-in{0%{opacity:0;transform:translateY(6px)}}@media (width>=760px){main{grid-template-rows:auto auto auto auto 1fr;grid-template-columns:minmax(0,1fr) 360px;align-items:start;gap:.9rem;max-width:1100px;display:grid}.span-all{grid-column:1/-1}.col-main{grid-area:3/1/span 3}.col-side-1{grid-area:3/2}.col-side-2{grid-area:4/2}.chat-log{max-height:44vh}.player .pmini{min-width:84px}}
