*{box-sizing:border-box;margin:0;padding:0}:root{--sky: #0ea5e9;--ink: #0f172a;--muted: #64748b;--card: #ffffff;--line: #e2e8f0}html,body,#root{height:100%}body{font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;color:var(--ink);background:linear-gradient(160deg,#e0f2fe,#f0fdf4);-webkit-tap-highlight-color:transparent}.loading{display:grid;place-items:center;height:100vh;color:var(--muted)}.muted{color:var(--muted);font-size:13px}.auth-wrap{min-height:100vh;display:grid;place-items:center;padding:20px}.auth-card{width:100%;max-width:380px;background:var(--card);border-radius:22px;padding:30px 26px;box-shadow:0 20px 50px #0284c72e;text-align:center}.auth-logo{font-size:56px}.auth-card h1{font-size:30px;margin:6px 0 2px;color:var(--sky)}.auth-sub{color:var(--muted);font-size:14px;margin-bottom:18px}.auth-tabs{display:flex;gap:6px;background:#f1f5f9;border-radius:12px;padding:4px;margin-bottom:16px}.auth-tabs button{flex:1;border:0;background:transparent;padding:10px;border-radius:9px;font-weight:600;color:var(--muted);cursor:pointer}.auth-tabs button.on{background:#fff;color:var(--sky);box-shadow:0 2px 6px #00000014}form{display:grid;gap:10px}input,.sens input{font-size:15px}.auth-card input{padding:13px 14px;border:1.5px solid var(--line);border-radius:12px;outline:none}.auth-card input:focus{border-color:var(--sky)}.btn-primary{background:var(--sky);color:#fff;border:0;padding:13px;border-radius:12px;font-weight:700;font-size:15px;cursor:pointer}.btn-primary:disabled{opacity:.6}.auth-err{background:#fef2f2;color:#dc2626;padding:9px 12px;border-radius:9px;font-size:13px}.auth-info{background:#f0fdf4;color:#16a34a;padding:9px 12px;border-radius:9px;font-size:13px}.auth-note{color:var(--muted);font-size:12px;margin-top:14px}.app{min-height:100vh;display:flex;flex-direction:column}.topbar{display:flex;align-items:center;gap:12px;padding:10px 16px;background:#fff;border-bottom:1px solid var(--line);position:sticky;top:0;z-index:20;flex-wrap:wrap}.brand{font-weight:800;color:var(--sky);font-size:18px;display:flex;align-items:center;gap:6px}.brand-ico{font-size:22px}.tabs{display:flex;gap:4px;margin:0 auto}.tabs button{border:0;background:transparent;padding:8px 14px;border-radius:10px;font-weight:600;color:var(--muted);cursor:pointer}.tabs button.on{background:#e0f2fe;color:var(--sky)}.user{display:flex;align-items:center;gap:8px}.uname{font-size:13px;font-weight:600}.admin-badge{font-style:normal;background:#fde68a;color:#92400e;font-size:10px;padding:1px 6px;border-radius:6px;margin-left:5px}.btn-ghost{border:1px solid var(--line);background:#fff;padding:7px 12px;border-radius:9px;font-weight:600;cursor:pointer;color:var(--ink);font-size:13px}.main{flex:1;padding:16px;max-width:900px;width:100%;margin:0 auto}.play-wrap{display:grid;gap:14px}.stage-frame{position:relative;width:100%;max-width:480px;margin:0 auto;border-radius:18px;overflow:hidden;box-shadow:0 12px 36px #0284c738;background:#bae6fd;aspect-ratio:480 / 640}.game-canvas{display:block}.overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:24px;gap:10px}.start-ov,.end-ov{background:#ffffffd1;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.big-bird{font-size:64px}.overlay h2{font-size:24px}.ov-desc{color:#334155;font-size:14px;line-height:1.6}.btn-start{background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff;border:0;padding:14px 28px;border-radius:14px;font-size:18px;font-weight:800;cursor:pointer;box-shadow:0 8px 20px #16a34a66}.count-ov{background:#0ea5e92e}.count-num{font-size:96px;font-weight:900;color:#fff;text-shadow:0 6px 0 rgba(2,132,199,.6);animation:pop .5s ease}@keyframes pop{0%{transform:scale(.4);opacity:0}to{transform:scale(1);opacity:1}}.hud{position:absolute;top:10px;left:10px;right:10px;pointer-events:none}.hud-row{display:flex;gap:6px;flex-wrap:wrap}.hud-chip{background:#0f172ab3;color:#fff;padding:4px 10px;border-radius:20px;font-size:12px;font-weight:700}.hud-stagebar{position:relative;margin-top:8px;height:18px;background:#0f172a73;border-radius:10px;overflow:hidden}.hud-stagefill{height:100%;background:linear-gradient(90deg,#fde047,#f59e0b);transition:width .12s linear}.hud-stagetxt{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;color:#fff;font-size:11px;font-weight:700}.hud-rest{margin-top:8px;background:#16a34ad9;color:#fff;padding:6px;border-radius:10px;text-align:center;font-weight:700;font-size:13px}.end-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;width:100%;max-width:280px}.end-stats>div{background:#fff;border:1px solid var(--line);border-radius:12px;padding:8px;display:flex;flex-direction:column}.end-stats span{font-size:11px;color:var(--muted)}.end-stats b{font-size:20px}.end-stats>div:first-child{grid-column:1 / -1;background:#ecfdf5}.saved-msg{font-weight:700;color:#16a34a}.end-actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:center}.controls{display:flex;align-items:center;gap:14px;flex-wrap:wrap;background:#fff;border:1px solid var(--line);border-radius:14px;padding:12px 14px;max-width:480px;margin:0 auto;width:100%}.mic-meter{display:flex;align-items:center;gap:8px;flex:1;min-width:160px}.mic-track{position:relative;flex:1;height:14px;background:#f1f5f9;border-radius:8px;overflow:hidden}.mic-fill{height:100%;width:0;background:#94a3b8;transition:width .05s linear}.mic-mark{position:absolute;top:-2px;width:2px;height:18px;background:#ef4444}.sens{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600}.howto{background:#fff;border:1px solid var(--line);border-radius:14px;padding:16px;max-width:480px;margin:0 auto;width:100%}.howto h3{margin-bottom:8px;font-size:15px}.howto ul{list-style:none;display:grid;gap:7px}.howto li{font-size:13px;color:#334155;line-height:1.5}.panel{background:#fff;border:1px solid var(--line);border-radius:16px;padding:16px;max-width:640px;margin:0 auto}.panel-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.panel-head h2{font-size:18px}.lb-list{display:grid;gap:6px}.lb-row{display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:12px;background:#f8fafc}.lb-row.me{background:#ecfeff;outline:2px solid #67e8f9}.lb-rank{width:30px;text-align:center;font-weight:800;font-size:16px}.lb-name{flex:1;display:flex;flex-direction:column}.lb-meta{font-size:11px;color:var(--muted)}.lb-score{font-weight:800;font-size:18px;color:var(--sky)}.lb-del{border:0;background:#fee2e2;color:#dc2626;border-radius:8px;width:26px;height:26px;cursor:pointer}.chat-panel{display:flex;flex-direction:column;height:calc(100vh - 120px)}.chat-list{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:8px;padding:4px}.chat-msg{display:flex}.chat-msg.mine{justify-content:flex-end}.chat-bubble{max-width:78%;background:#f1f5f9;border-radius:14px;padding:8px 12px}.chat-msg.mine .chat-bubble{background:#dbeafe}.chat-name{font-size:11px;font-weight:700;color:var(--sky)}.chat-body{font-size:14px;word-break:break-word;white-space:pre-wrap}.chat-time{font-size:10px;color:var(--muted);margin-top:3px;display:flex;gap:8px;align-items:center}.chat-del{border:0;background:transparent;color:#ef4444;cursor:pointer;font-size:10px}.chat-input{display:flex;gap:8px;margin-top:10px}.chat-input input{flex:1;padding:11px 14px;border:1.5px solid var(--line);border-radius:12px;outline:none}.chat-input input:focus{border-color:var(--sky)}@media (max-width: 520px){.tabs{order:3;width:100%;margin:6px 0 0;justify-content:center}.topbar{gap:8px}}
