:root{color-scheme:dark;--bg: #040711;--panel: rgba(6, 12, 24, .88);--panel-border: rgba(49, 242, 255, .2);--text: #f2f7ff;--muted: #9fa9ba;--cyan: #31f2ff;--magenta: #ff4fd8;--lime: #b0ff57;--stage-frame-width: 430px;--stage-frame-ratio: 9 / 16}*{box-sizing:border-box}html,body,#app{min-height:100%;margin:0}body{background:radial-gradient(circle at top,rgba(49,242,255,.12),transparent 28%),radial-gradient(circle at bottom,rgba(255,79,216,.12),transparent 24%),var(--bg);color:var(--text);font-family:Segoe UI,system-ui,sans-serif}button,input{font:inherit}button{border:1px solid var(--panel-border);background:linear-gradient(135deg,#31f2ff29,#b0ff5738);color:var(--text);border-radius:16px;padding:.8rem 1rem;font-weight:700;cursor:pointer}button.ghost{background:#0a1220a8}button:disabled{opacity:.45;cursor:not-allowed}input{width:100%;margin-top:.4rem;border-radius:12px;border:1px solid rgba(255,255,255,.08);background:#040911e6;color:var(--text);padding:.8rem .9rem}.hidden{display:none!important}.shell{width:min(1240px,calc(100vw - 24px));margin:0 auto;padding:12px}.topbar,.card{background:var(--panel);border:1px solid var(--panel-border);border-radius:24px;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.topbar{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;margin-bottom:12px}.topbar h1{margin:0;color:var(--cyan);letter-spacing:.08em}.topbar p,.room-chip,.hint,.player-row span,.guide-card p{color:var(--muted)}.layout{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:12px;min-height:calc(100dvh - 130px)}.stage-panel{min-width:0;display:flex;justify-content:center}.stage{position:relative;width:min(100%,var(--stage-frame-width));aspect-ratio:var(--stage-frame-ratio);max-height:calc(100dvh - 180px);overflow:hidden;border-radius:28px;border:1px solid var(--panel-border);background:#02060ef5}.webcam,canvas,.stage-overlay{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%}.webcam{object-fit:cover;transform:scaleX(-1);opacity:.35}#gameCanvas,#handCanvas{pointer-events:none}.stage-overlay{display:grid;place-items:center;padding:1rem}.auth-card{width:min(460px,100%);padding:1.25rem}.auth-card h2,.lobby-head h2,.guide-card h3{margin-top:0}.invite-copy{margin:0 0 1rem;color:var(--cyan);font-size:.95rem}.mode-switch{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.75rem;margin-bottom:1rem}.game-mode-picker{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.75rem;margin:.8rem 0 1rem}.game-mode-picker.compact{margin:0 0 .9rem}.game-mode-button.selected{border-color:var(--lime);box-shadow:0 0 18px #b0ff5729}.mode-button.selected{border-color:var(--cyan);box-shadow:0 0 22px #31f2ff2e}.avatar-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:.75rem;margin:1rem 0}.avatar-option{min-height:64px;font-size:1.8rem}.avatar-option.selected{border-color:var(--lime);box-shadow:0 0 22px #b0ff5738}.cta-row,.action-row,.lobby-head{display:flex;gap:.75rem;align-items:center;justify-content:space-between}.sidebar{display:grid;grid-template-rows:auto auto auto 1fr;gap:12px}.score-card{padding:1rem 1.2rem}.eyebrow{display:block;color:var(--cyan);font-size:.85rem;text-transform:uppercase;letter-spacing:.12em}.score-card strong{display:block;font-size:clamp(3rem,8vw,5rem);line-height:1;margin:.4rem 0 .5rem}.lobby-card,.guide-card,.chat-card{padding:1rem 1.1rem}.chat-head,.chat-compose{display:flex;align-items:center;justify-content:space-between;gap:.75rem}.chat-head{margin-bottom:.75rem}.chat-head h3{margin:0}.chat-messages{max-height:260px;min-height:180px;overflow:auto;display:grid;gap:.65rem;padding-right:.25rem;margin-bottom:.8rem}.chat-message{padding:.7rem .8rem;border-radius:16px;background:#ffffff0a}.chat-meta{display:grid;grid-template-columns:28px minmax(0,1fr) auto;gap:.5rem;align-items:center;color:var(--muted);font-size:.85rem;margin-bottom:.4rem}.chat-message p,.chat-empty{margin:0;color:var(--text)}.chat-empty{color:var(--muted)}.chat-compose input{margin-top:0}.players{list-style:none;padding:0;margin:1rem 0 0;display:grid;gap:.65rem}.player-row{display:grid;grid-template-columns:36px minmax(0,1fr) auto;gap:.75rem;align-items:center;padding:.75rem;border-radius:18px;background:#ffffff08}.avatar{font-size:1.4rem}.countdown{position:absolute;top:14px;left:50%;transform:translate(-50%);z-index:5;background:#ff4fd82e;border:1px solid rgba(255,79,216,.3);border-radius:999px;padding:.6rem 1rem;font-weight:900;letter-spacing:.06em}@media (max-width: 1100px){.shell{width:min(100vw,calc(100vw - 12px));padding:6px}.layout{grid-template-columns:1fr}.sidebar{grid-template-columns:repeat(2,minmax(0,1fr));grid-template-rows:auto auto}.guide-card,.chat-card{grid-column:1 / -1}.stage{max-height:calc(100dvh - 220px)}}@media (max-width: 760px){.shell{width:100vw;padding:4px}.topbar{flex-direction:column;align-items:flex-start;gap:.6rem;padding:.85rem 1rem}.sidebar{grid-template-columns:1fr}.topbar h1{font-size:1.6rem}.room-chip{font-size:.92rem}.avatar-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:.5rem}.stage{width:min(100%,420px);max-height:calc(100dvh - 210px);border-radius:22px}.cta-row,.action-row{flex-direction:column}.auth-card,.lobby-card,.guide-card,.score-card,.chat-card{padding:.9rem;border-radius:18px}.auth-card{width:min(100%,420px)}.avatar-option{min-height:56px;font-size:1.55rem}.score-card strong{font-size:clamp(2.4rem,12vw,3.8rem)}.player-row{grid-template-columns:32px minmax(0,1fr) auto;gap:.55rem;padding:.6rem}.chat-messages{max-height:220px;min-height:160px}}@media (max-width: 520px){.layout{gap:8px;min-height:auto}.stage{width:min(100%,380px);max-height:calc(100dvh - 200px)}.mode-switch{gap:.5rem}.mode-button,.cta-row button,.action-row button{width:100%}.guide-card p,.player-row span,.hint,.topbar p,.chat-meta{font-size:.92rem}.chat-compose{flex-direction:column}.chat-compose button{width:100%}}
