@font-face{font-family:Fredoka;font-style:normal;font-weight:300 700;font-display:swap;src:url(/assets/fonts/fredoka-latin.woff2) format("woff2");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+2000-206F,U+2122,U+2191,U+2193}:root{--bg:#0c2733;--bg2:#08171f;--card:#14394a;--card2:#0e2c3a;--ink:#fff;--muted:#8fb3c4;--teal:#4dd2c0;--coral:#ff7a5c;--sky:#4ec3ff;--gold:#ffd166;--blue:#5cb3ff;--pink:#ff8fc7;--green:#4dd2c0;--green2:#4dd2c0;--red:#ff6b6b;--purple:var(--sky);--teal-dk:#2a9e8e;--coral-dk:#d2563b;--ghost-dk:rgba(0,0,0,.35);--line:rgba(255,255,255,.14);--safe-t:env(safe-area-inset-top);--safe-b:env(safe-area-inset-bottom);--font:"Fredoka",ui-rounded,"SF Pro Rounded","Hiragino Maru Gothic ProN", "Segoe UI",system-ui,-apple-system,Roboto,sans-serif}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body{height:100%;margin:0;overflow:hidden;background:#06121a}body{font-family:var(--font);color:var(--ink);-webkit-user-select:none;user-select:none;-webkit-font-smoothing:antialiased}#app{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center}#game{position:absolute;top:0;right:0;bottom:0;left:0}#game canvas{display:block;margin:auto}#ui{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;display:flex;justify-content:center}.screen{position:absolute;top:0;right:0;bottom:0;left:0;display:none;flex-direction:column;width:100%;max-width:480px;pointer-events:auto}.screen.active{display:flex}.overlay{align-items:center;justify-content:center;padding:20px;overflow:hidden;background:radial-gradient(120% 80% at 18% 12%,rgba(78,195,255,.22),transparent 55%),radial-gradient(120% 80% at 85% 90%,rgba(77,210,192,.2),transparent 55%),linear-gradient(180deg,#06121aeb,#06121af5)}.overlay:before,.overlay:after{content:"";position:absolute;border-radius:50%;pointer-events:none;z-index:0;background:radial-gradient(circle at 32% 28%,#fff,rgba(255,255,255,.65) 18%,var(--sky) 60%,#1f6f9e 100%);opacity:.16;will-change:transform}.overlay:before{width:150px;height:150px;left:-40px;top:14%;animation:floatA 13s ease-in-out infinite}.overlay:after{width:200px;height:200px;right:-60px;bottom:8%;background:radial-gradient(circle at 32% 28%,#fff,rgba(255,255,255,.65) 18%,var(--teal) 60%,#2a9e8e 100%);animation:floatB 17s ease-in-out infinite}@keyframes floatA{0%,to{transform:translateY(0) rotate(0)}50%{transform:translateY(34px) rotate(18deg)}}@keyframes floatB{0%,to{transform:translateY(0) rotate(0)}50%{transform:translateY(-40px) rotate(-16deg)}}.muted{color:var(--muted);font-size:14px;margin:4px 0 14px;font-weight:500}.brand{font-size:34px;font-weight:700;letter-spacing:.01em;line-height:1.05;margin-bottom:6px;display:flex;align-items:center;justify-content:center;gap:8px}.brand span{background:linear-gradient(180deg,var(--pink),var(--sky));-webkit-background-clip:text;background-clip:text;color:transparent}.brand.sm{font-size:20px;margin:0;gap:6px}.brand-ball{width:1.05em;height:1.05em;flex:none;filter:drop-shadow(0 2px 3px rgba(0,0,0,.35))}.card{position:relative;z-index:1;background:linear-gradient(180deg,var(--card),var(--card2));border:1px solid var(--line);border-radius:28px;padding:28px 22px;width:min(88vw,380px);text-align:center;box-shadow:0 18px 0 -6px #00000038,0 26px 50px #00000073,inset 0 1px #ffffff1a}.pop{animation:pop .4s cubic-bezier(.2,1.4,.35,1)}@keyframes pop{0%{transform:scale(.8) translateY(8px);opacity:0}to{transform:scale(1) translateY(0);opacity:1}}.card h2{margin:2px 0;font-size:24px;font-weight:700;letter-spacing:.01em}.btn{position:relative;display:block;width:100%;border:none;border-radius:16px;padding:15px;font-family:var(--font);font-size:17px;font-weight:700;letter-spacing:.01em;color:#fff;cursor:pointer;margin-top:12px;transition:transform .06s ease,box-shadow .06s ease,filter .15s}.btn:active{transform:translateY(4px)}.btn:disabled{opacity:.5;cursor:default}.btn-primary{background:linear-gradient(180deg,#5fe0cd,#37b9a8);box-shadow:0 5px 0 var(--teal-dk),0 8px 14px #2a9e8e66}.btn-primary:active{box-shadow:0 1px 0 var(--teal-dk)}.btn-primary:hover:not(:disabled){filter:brightness(1.05)}.btn-ghost{background:#ffffff12;color:var(--muted);border:1px solid var(--line);box-shadow:0 4px 0 var(--ghost-dk)}.btn-ghost:active{box-shadow:0 1px 0 var(--ghost-dk)}.btn-ghost:hover:not(:disabled){filter:brightness(1.12)}.auth-buttons{margin-top:20px;display:flex;flex-direction:column;gap:12px}.text-input{width:100%;margin-top:18px;background:#00000047;border:2px solid var(--line);border-radius:14px;color:var(--ink);font-family:var(--font);font-size:18px;font-weight:600;text-align:center;padding:14px;outline:none;transition:border-color .15s}.text-input:focus{border-color:var(--teal)}.text-input::placeholder{color:#b3a6e08c;font-weight:500}.field-status{min-height:18px;font-size:13px;margin:8px 0 4px;color:var(--muted);font-weight:600}.field-status.good{color:var(--teal)}.field-status.bad{color:var(--red)}.form-err{min-height:16px;color:var(--red);font-size:13px;margin:8px 0 0;font-weight:600}#scr-lobby{background:radial-gradient(130% 70% at 12% 0%,rgba(78,195,255,.18),transparent 50%),radial-gradient(130% 70% at 90% 100%,rgba(77,210,192,.16),transparent 50%),linear-gradient(180deg,var(--bg) 0%,var(--bg2) 100%)}.lobby-head{position:relative;padding:calc(16px + var(--safe-t)) 18px 12px;border-bottom:1px solid var(--line)}.version-tag{position:absolute;top:calc(18px + var(--safe-t));right:18px;font-size:11px;font-weight:600;color:var(--muted);opacity:.55}.lobby-hero{display:flex;align-items:center;gap:12px;padding-right:44px}.lobby-hero-img{width:60px;height:60px;flex:none;filter:drop-shadow(0 3px 5px rgba(0,0,0,.4))}.lobby-hero-title{margin:0;font-size:28px;font-weight:700;letter-spacing:.01em;line-height:1.05}.lobby-hero-title span{background:linear-gradient(180deg,var(--pink),var(--sky));-webkit-background-clip:text;background-clip:text;color:transparent}.me-row{display:flex;justify-content:space-between;align-items:center;margin-top:10px}.me-name{font-weight:700;font-size:15px}.me-best{font-size:13px;color:var(--muted);font-weight:600}.me-best strong{color:var(--gold);font-size:16px;margin-left:5px}.lobby-body{flex:1;overflow-y:auto;padding:16px 16px calc(16px + var(--safe-b));display:flex;flex-direction:column;gap:18px}.lobby-actions{display:flex;flex-direction:column;gap:0}.section-title{display:flex;align-items:center;gap:8px;font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:10px}.pill{background:var(--sky);border:none;border-radius:20px;padding:2px 10px;font-size:12px;font-weight:700;color:#062231}.room-list{display:flex;flex-direction:column;gap:10px}.room{display:flex;align-items:center;justify-content:space-between;background:linear-gradient(180deg,var(--card),var(--card2));border:1px solid var(--line);border-radius:16px;padding:12px 14px;box-shadow:0 4px 0 -1px #00000038}.room-host{display:flex;align-items:center;gap:9px;font-weight:600;font-size:15px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.room-host .dot{width:9px;height:9px;border-radius:50%;background:var(--teal);box-shadow:0 0 10px var(--teal);flex:none;animation:blink 1.4s ease-in-out infinite}@keyframes blink{0%,to{opacity:1}50%{opacity:.35}}.btn-join{width:auto;margin:0;padding:9px 18px;font-size:14px;border-radius:12px;color:#fff;background:linear-gradient(180deg,#5fe0cd,#37b9a8);box-shadow:0 4px 0 var(--teal-dk);transition:transform .06s,box-shadow .06s,filter .15s}.btn-join:active{transform:translateY(3px);box-shadow:0 1px 0 var(--teal-dk)}.room-empty,.lb-empty{color:var(--muted);font-size:13px;font-weight:500;text-align:center;padding:18px 10px;background:#0000002e;border:1px dashed var(--line);border-radius:16px}.leaderboard{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.leaderboard li{display:flex;align-items:center;gap:10px;background:linear-gradient(180deg,var(--card),var(--card2));border:1px solid var(--line);border-radius:14px;padding:10px 14px;font-size:14px;font-weight:600}.leaderboard li.me{border-color:var(--gold);background:linear-gradient(180deg,#ffd16624,#ffd1660f)}.leaderboard .rank{width:22px;height:22px;line-height:22px;color:#062231;font-weight:700;text-align:center;border-radius:50%;background:var(--muted);flex:none}.leaderboard li:nth-child(1) .rank{background:var(--gold)}.leaderboard li:nth-child(2) .rank{background:#d8def0}.leaderboard li:nth-child(3) .rank{background:var(--coral)}.leaderboard .lb-name{flex:1;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.leaderboard .lb-score{font-weight:700;color:var(--gold)}.spinner{width:42px;height:42px;margin:0 auto 14px;border-radius:50%;border:4px solid var(--line);border-top-color:var(--teal);animation:spin .9s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.count-num{font-size:140px;font-weight:700;color:var(--gold);line-height:1;text-shadow:0 0 30px rgba(255,209,102,.5),0 8px 0 rgba(0,0,0,.25);animation:pulse .9s ease-in-out infinite}.count-foe{position:absolute;bottom:24%;font-size:19px;font-weight:700;color:#fff;text-shadow:0 2px 8px rgba(0,0,0,.5)}@keyframes pulse{0%,to{transform:scale(1);opacity:.9}50%{transform:scale(1.18);opacity:1}}#hud{position:absolute;top:0;left:50%;transform:translate(-50%);width:100%;max-width:480px;padding:calc(10px + var(--safe-t)) 14px 0;display:none;pointer-events:none;z-index:5}#hud.show{display:block}.hud-score{text-align:center;font-size:68px;font-weight:700;line-height:1;color:#fff;text-shadow:0 0 2px rgba(0,0,0,.4),0 4px 0 rgba(0,0,0,.35),0 6px 14px rgba(0,0,0,.45)}.hud-score.bump{animation:bump .18s ease-out}@keyframes bump{0%{transform:scale(1)}40%{transform:scale(1.3)}to{transform:scale(1)}}.hud-foe{position:absolute;top:calc(12px + var(--safe-t));right:16px;display:flex;align-items:center;gap:7px;font-size:13px;font-weight:600}.hud-foe-name{color:#fff;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-shadow:0 1px 3px rgba(0,0,0,.7)}.hud-foe-score{min-width:26px;text-align:center;background:var(--coral);border-radius:9px;padding:2px 9px;font-weight:700;color:#fff;box-shadow:0 2px 0 var(--coral-dk)}.hud-foe-score.out{background:#0006;box-shadow:none;opacity:.5;text-decoration:line-through}.tap-hint{position:absolute;left:50%;bottom:calc(30px + var(--safe-b));transform:translate(-50%);font-size:13px;font-weight:600;color:#fff;background:#0e2c3ab3;border:1px solid var(--line);padding:9px 20px;border-radius:30px;pointer-events:none;z-index:5;display:none;animation:hint 1.1s ease-in-out infinite;white-space:nowrap}.tap-hint.show{display:block}@keyframes hint{0%,to{opacity:.6}50%{opacity:1}}.card-badge{display:inline-block;font-weight:700;font-size:13px;letter-spacing:.14em;background:var(--teal);color:#13283a;padding:7px 18px;border-radius:30px;margin-bottom:12px;box-shadow:0 4px 0 var(--teal-dk)}.card-badge.win{background:var(--gold);color:#5a4500;box-shadow:0 4px #c79a1f}.card-badge.lose{background:var(--coral);color:#fff;box-shadow:0 4px 0 var(--coral-dk)}.card-badge.draw{background:var(--blue);color:#0a2d4a;box-shadow:0 4px #2f7fc2}.result-scores{display:flex;align-items:center;justify-content:center;gap:16px;margin:18px 0 8px}.rs-col{display:flex;flex-direction:column;gap:5px;opacity:.6;min-width:96px;padding:12px 8px;border-radius:16px}.rs-col.hi{opacity:1;background:linear-gradient(180deg,#ffd16629,#ffd1660a);border:1px solid rgba(255,209,102,.3)}.rs-label{font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--muted)}.rs-col.hi .rs-label{color:var(--gold)}.rs-val{font-size:42px;font-weight:700;line-height:1}.rs-sep{font-size:24px;color:var(--muted);font-weight:700}.btn-profile{transition:transform .08s,opacity .15s}.btn-profile:hover{transform:scale(1.02)}.btn-profile:active{transform:scale(.98)}.profile-dot{display:inline-block;box-shadow:0 0 8px currentColor}.btn-share{background:linear-gradient(180deg,#ffd875,var(--gold));color:#5a4500;border:none;border-radius:10px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;box-shadow:0 3px #c79a1f,0 4px 8px #0003;transition:transform .06s ease,box-shadow .06s ease,filter .15s,background .2s,color .2s;flex-shrink:0}.btn-share:active{transform:translateY(2px);box-shadow:0 1px #c79a1f}.btn-share:hover:not(:disabled){filter:brightness(1.08)}.btn-share svg{display:block}.profile-avatar-container{display:flex;justify-content:center;margin-bottom:16px}.profile-avatar{width:78px;height:78px;border-radius:50%;background:var(--card2);border:3px solid var(--line);box-shadow:0 6px 18px #0006;display:flex;align-items:center;justify-content:center;font-size:38px;line-height:1}.profile-avatar svg{width:64%;height:64%}.profile-info{display:flex;flex-direction:column;gap:16px;margin:18px 0;text-align:left}.profile-field{display:flex;flex-direction:column}.profile-field label{font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}.text-input.sm{margin-top:0;padding:11px 14px;font-size:16px;text-align:left;flex:1}.profile-stats{display:flex;gap:14px;margin:8px 0}.stat-box{flex:1;background:#0003;border:1px solid var(--line);border-radius:16px;padding:14px;text-align:center;display:flex;flex-direction:column;gap:4px}.stat-label{font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--muted)}.stat-val{font-size:26px;font-weight:700;color:var(--gold)}@media (max-height:680px){.brand{font-size:26px}.count-num{font-size:100px}.hud-score{font-size:54px}.card{padding:22px 20px}.lobby-hero-img{width:48px;height:48px}.lobby-hero-title{font-size:24px}}@media (prefers-reduced-motion:reduce){.pop,.overlay:before,.overlay:after,.count-num,.hud-score.bump,.tap-hint,.room-host .dot{animation:none!important}}.privacy-link-btn{background:none;border:none;color:var(--muted);text-decoration:underline;font-size:12px;cursor:pointer;margin-top:16px;font-family:var(--font);transition:color .15s}.privacy-link-btn:hover{color:var(--teal)}
