:root{--bg:#16123a;--ink:#0b0926;--panel:#201b4ce8;--panel-solid:#251f56;--line:#4a3f96;--line-bright:#7466e0;--text:#fff3e0;--dim:#b7aee0;--accent:#4de3c2;--coral:#ff5d7e;--coral-deep:#d63a60;--accent-dark:#2bb89a;--danger:#ff6a5b;--gold:#ffcf4d;--shadow:0 12px 34px #0006, 0 2px 8px #00000045;--sticker:4px 4px 0 var(--ink);font-size:16px}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}::selection{background:#ff5d7e66}html,body{background:var(--bg);height:100dvh;color:var(--text);overscroll-behavior:none;margin:0;font-family:ui-rounded,SF Pro Rounded,Hiragino Maru Gothic ProN,Avenir Next,Segoe UI,system-ui,-apple-system,sans-serif;overflow:hidden}#game{touch-action:none;width:100%;height:100%;display:block;position:fixed;inset:0}#ui{pointer-events:none;padding:env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left);position:fixed;inset:0}#ui>*{pointer-events:auto}button{font:inherit;color:var(--text);cursor:pointer;background:var(--panel-solid);border:2px solid var(--ink);box-shadow:var(--sticker);border-radius:14px;padding:.65em 1.1em;font-weight:700;transition:transform 80ms,box-shadow 80ms,filter .15s}@media (hover:hover){button:hover:not(:disabled){box-shadow:5px 5px 0 var(--ink);filter:brightness(1.12);transform:translate(-1px,-1px)}}button:active:not(:disabled){box-shadow:1px 1px 0 var(--ink);transform:translate(3px,3px)}button:focus-visible{outline:2px solid var(--accent);outline-offset:2px}button.primary{background:linear-gradient(180deg, #ff7d96, var(--coral) 55%, var(--coral-deep));color:#2a0716;text-shadow:0 1px #ffffff4d;font-weight:800}button.danger{color:#ffb3a8;background:#3a1530}button:disabled{opacity:.45;cursor:default;box-shadow:2px 2px 0 var(--ink)}input,select{font:inherit;color:var(--text);background:var(--ink);border:2px solid var(--line);border-radius:12px;outline:none;width:100%;padding:.55em .8em}input:focus,select:focus{border-color:var(--accent);box-shadow:0 0 0 3px #4de3c233}.screen{background:radial-gradient(circle at 2px 2px,#ffffff0a 1px,#0000 1.6px) 0 0/26px 26px,radial-gradient(900px 520px at 15% -12%,#ff5d7e2b,#0000),radial-gradient(1100px 620px at 88% 112%,#4de3c226,#0000),linear-gradient(168deg,#1d1747,#110d30 70%);justify-content:center;align-items:center;animation:.28s screenIn;display:flex;position:absolute;inset:0;overflow-y:auto}@keyframes screenIn{0%{opacity:0;transform:translateY(10px)scale(.995)}to{opacity:1;transform:none}}.screen.overlay{-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:#0a0822d6;animation:.18s overlayIn}@keyframes overlayIn{0%{opacity:0}to{opacity:1}}.card{background:var(--panel);border:1px solid var(--line);border-color:var(--ink);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);width:min(430px,100vw - 32px);box-shadow:var(--shadow);border-radius:24px;flex-direction:column;gap:14px;margin:16px 0;padding:24px;display:flex}.card.wide{width:min(580px,100vw - 32px)}.logo{text-align:center;letter-spacing:1px;background:linear-gradient(#ffe9a8,#ff8d6e 45%,#ff5d7e);-webkit-text-fill-color:transparent;filter:drop-shadow(0 4px 10px #ff5d7e4d);-webkit-background-clip:text;background-clip:text;margin:0 0 4px;font-size:2.5rem;font-weight:900}.logo .flag{-webkit-text-fill-color:initial;animation:2.4s ease-in-out infinite flagBounce;display:inline-block}@keyframes flagBounce{0%,to{transform:translateY(0)rotate(-4deg)}50%{transform:translateY(-7px)rotate(7deg)}}.logo small{color:var(--dim);letter-spacing:.3px;-webkit-text-fill-color:var(--dim);filter:none;margin-top:6px;font-size:.85rem;font-weight:600;display:block}.row{align-items:center;gap:10px;display:flex}.row>*{flex:1}.field{flex-direction:column;gap:6px;display:flex}.field label{color:var(--dim);font-size:.8rem}.muted{color:var(--dim);font-size:.85rem}.error-text{color:#ffb6ae;text-align:center;min-height:1.2em;font-size:.9rem}.code-chip{justify-content:center;align-items:center;gap:10px;display:flex}.code-chip b{letter-spacing:.35em;font-family:ui-monospace,monospace;font-size:1.9rem}.roster{grid-template-columns:1fr 1fr;gap:8px;display:grid}.player-chip{border:1px solid var(--line);background:#16113ab8;border-radius:14px;align-items:center;gap:9px;min-height:46px;padding:7px 10px;font-size:.92rem;display:flex}.player-chip .avatar{width:30px;height:30px;color:var(--ink);border-radius:50%;flex:none;justify-content:center;align-items:center;font-size:.95rem;font-weight:900;display:flex;box-shadow:inset 0 -3px #0003,0 1px 4px #0004}.player-chip .crown{filter:drop-shadow(0 1px 3px #ffd34d66);margin-left:auto}.player-chip.empty{opacity:.3;border-style:dashed;justify-content:center;animation:2.6s ease-in-out infinite slotPulse}@keyframes slotPulse{0%,to{opacity:.22}50%{opacity:.4}}.player-chip.off{opacity:.55}.player-chip .who{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.settings-grid{grid-template-columns:1fr 1fr;gap:10px;display:grid}.room-list{flex-direction:column;gap:8px;max-height:50dvh;display:flex;overflow-y:auto}.room-line{border:1px solid var(--line);background:#16113aa0;border-radius:12px;align-items:center;gap:10px;padding:10px 12px;display:flex}.room-line .grow{flex:1;min-width:0}.room-line .grow b{text-overflow:ellipsis;white-space:nowrap;display:block;overflow:hidden}.hud-top{top:max(10px, env(safe-area-inset-top));background:var(--panel);border:1px solid var(--line);border-color:var(--ink);white-space:nowrap;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);box-shadow:var(--shadow);border-radius:999px;align-items:center;gap:12px;padding:7px 18px;font-size:.92rem;display:flex;position:absolute;left:50%;transform:translate(-50%)}.hud-strokes{top:max(10px, env(safe-area-inset-top));right:max(10px, env(safe-area-inset-right));background:var(--panel);border:1px solid var(--line);text-align:right;border-radius:14px;padding:6px 12px;font-size:.85rem;line-height:1.3;position:absolute}.hud-strokes b{font-size:1.1rem}.turn-banner{top:calc(max(10px, env(safe-area-inset-top)) + 46px);background:var(--panel);border:1px solid var(--accent);border-radius:999px;padding:5px 14px;font-size:.9rem;position:absolute;left:50%;transform:translate(-50%)}.turn-banner.me{background:var(--accent-dark)}.hud-corner{bottom:max(12px, env(safe-area-inset-bottom));gap:8px;display:flex;position:absolute}.hud-corner.left{left:max(12px, env(safe-area-inset-left))}.hud-corner.right{right:max(12px, env(safe-area-inset-right))}.hud-corner button{border-radius:50%;justify-content:center;align-items:center;width:46px;height:46px;padding:0;font-size:1.25rem;display:flex}.power-wrap{bottom:calc(max(12px, env(safe-area-inset-bottom)) + 60px);border:1px solid var(--line);opacity:0;background:#100d2cc0;border-radius:999px;width:min(260px,60vw);height:10px;transition:opacity .15s;position:absolute;left:50%;overflow:hidden;transform:translate(-50%)}.power-wrap.show{opacity:1}.power-bar{background:linear-gradient(90deg,#4de3c2,#ffcf4d 55%,#ff5d7e);border-radius:999px;width:0%;height:100%;box-shadow:0 0 10px #ffcf4d99,0 0 22px #ff5d7e55}.emote-wheel{bottom:calc(max(12px, env(safe-area-inset-bottom)) + 58px);left:max(12px, env(safe-area-inset-left));flex-direction:column;gap:6px;display:flex;position:absolute}.emote-wheel button{border-radius:50%;width:46px;height:46px;padding:0;font-size:1.35rem}.hud-corner .ability-btn{white-space:nowrap;border-radius:999px;width:auto;padding:0 16px;font-size:.95rem}.ability-btn.armed{border-color:var(--gold);background:#44360e;animation:1.6s ease-in-out infinite abilityGlow}@keyframes abilityGlow{0%,to{box-shadow:0 0 4px #ffd34d55}50%{box-shadow:0 0 16px #ffd34daa}}.banner{letter-spacing:.12em;text-shadow:0 4px 24px #000c;opacity:0;pointer-events:none;white-space:nowrap;font-size:clamp(1.6rem,6vw,2.6rem);font-weight:800;position:absolute;top:26%;left:50%;transform:translate(-50%,-50%)scale(.9)}.banner.show{animation:2.2s forwards bannerPop}@keyframes bannerPop{0%{opacity:0;transform:translate(-50%,-50%)scale(.7)}12%{opacity:1;transform:translate(-50%,-50%)scale(1.06)}20%{transform:translate(-50%,-50%)scale(1)}80%{opacity:1}to{opacity:0;transform:translate(-50%,-56%)scale(1)}}.score-table{border-collapse:collapse;width:100%;font-size:.85rem}.score-table th,.score-table td{border-bottom:1px solid var(--line);text-align:center;padding:6px}.score-table td:first-child,.score-table th:first-child{text-align:left;text-overflow:ellipsis;white-space:nowrap;max-width:110px;overflow:hidden}.score-table tr.me{background:#4de3c21f}.score-table .tot{font-weight:700}.podium{justify-content:center;align-items:flex-end;gap:10px;margin:8px 0;display:flex}.podium .step{background:var(--panel-solid);border:1px solid var(--line);text-align:center;border-radius:12px 12px 0 0;width:90px;padding:8px 4px;overflow:hidden}.podium .step .who{text-overflow:ellipsis;white-space:nowrap;font-size:.9rem;font-weight:700;overflow:hidden}.podium .step .pts{color:var(--dim);font-size:.8rem}.podium .p1{border-color:var(--gold);background:linear-gradient(180deg, #46380f, var(--panel-solid) 60%);height:110px;box-shadow:0 0 24px #ffd34d33}.podium .p2{height:86px}.podium .p3{height:68px}.medal{font-size:1.5rem}.confetti-rain{pointer-events:none;position:absolute;inset:0;overflow:hidden}.confetti-rain span{top:-8%;left:calc(var(--i) * 12.5% + 4%);animation:3.4s linear infinite confettiFall;animation-delay:calc(var(--i) * -.45s);filter:drop-shadow(0 2px 4px #0005);font-size:1.4rem;position:absolute}@keyframes confettiFall{0%{opacity:1;transform:translateY(0)rotate(0)}90%{opacity:1}to{opacity:.2;transform:translateY(115vh)rotate(340deg)}}.editor-top{top:max(10px, env(safe-area-inset-top));left:max(10px, env(safe-area-inset-left));right:max(10px, env(safe-area-inset-right));flex-wrap:wrap;align-items:center;gap:8px;display:flex;position:absolute}.editor-top button{padding:.45em .8em}.editor-top input{flex:0 10em;width:auto}.editor-tabs{top:calc(max(10px, env(safe-area-inset-top)) + 54px);left:max(10px, env(safe-area-inset-left));flex-wrap:wrap;align-items:center;gap:6px;max-width:70vw;display:flex;position:absolute}.editor-tabs button,.editor-tabs select{padding:.35em .7em;font-size:.85rem}.palette{right:max(10px, env(safe-area-inset-right));top:calc(max(10px, env(safe-area-inset-top)) + 54px);bottom:calc(max(10px, env(safe-area-inset-bottom)) + 120px);flex-direction:column;gap:6px;width:132px;display:flex;position:absolute;overflow-y:auto}.palette button{text-align:left;white-space:nowrap;padding:.45em .6em;font-size:.8rem}.props{bottom:max(10px, env(safe-area-inset-bottom));left:max(10px, env(safe-area-inset-left));right:max(10px, env(safe-area-inset-right));background:var(--panel);border:1px solid var(--line);border-radius:14px;flex-wrap:wrap;align-items:center;gap:12px;padding:10px 14px;display:flex;position:absolute}.prop-row{align-items:center;gap:6px;font-size:.8rem;display:flex}.prop-row input[type=range]{width:110px;padding:0}.prop-row span:last-child{text-align:right;min-width:2.5em}#toasts{top:calc(max(10px, env(safe-area-inset-top)) + 50px);z-index:50;pointer-events:none;flex-direction:column;align-items:center;gap:8px;display:flex;position:fixed;left:50%;transform:translate(-50%)}.toast{border:1px solid var(--line);text-align:center;background:#1d1747f2;border-radius:12px;max-width:86vw;padding:10px 16px;font-size:.92rem;animation:.2s toastIn}.toast.error{border-color:var(--danger)}@keyframes toastIn{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.spin{border:2px solid var(--dim);border-top-color:var(--accent);border-radius:50%;width:1em;height:1em;animation:.8s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.spin-wrap{bottom:calc(max(12px, env(safe-area-inset-bottom)) + 64px);right:max(12px, env(safe-area-inset-right));flex-direction:column;align-items:center;gap:4px;display:flex;position:absolute}.spin-label{letter-spacing:.12em;color:var(--dim);text-shadow:0 1px 3px #0008;font-size:.62rem;font-weight:800}.spin-pad{border:2px solid var(--ink);width:76px;height:76px;box-shadow:var(--sticker);touch-action:none;cursor:crosshair;background:radial-gradient(circle at 34% 30%,#fff3e018,#0000 60%),#1d1747e0;border-radius:50%;position:relative}.spin-pad.active{border-color:var(--accent);box-shadow:4px 4px 0 var(--ink), 0 0 14px #4de3c266}.spin-cross{pointer-events:none;background:linear-gradient(#fff2,#fff2) 50% 0/1px 100% no-repeat,linear-gradient(#fff2,#fff2) 0/100% 1px no-repeat;border-radius:50%;position:absolute;inset:0}.spin-dot{border:2px solid var(--ink);pointer-events:none;background:radial-gradient(circle at 35% 30%,#fff,#ffcf4d 60%,#d6952a);border-radius:50%;width:16px;height:16px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);box-shadow:0 0 8px #ffcf4d77}
