*{margin:0;padding:0;box-sizing:border-box}:root{--cyan: #00d4ff;--magenta: #c850c0;--pink: #ff2d9b;--bg: #000;--bg-surface: #111;--bg-raised: #1a1a1a;--border: #333;--text: #fff;--text-dim: #555;--text-muted: #666;--heading: rgba(0, 212, 255, .7);--heading-alt: rgba(200, 80, 192, .6)}body{background:var(--bg);color:var(--text);font-family:system-ui,-apple-system,sans-serif;min-height:100vh;display:flex;justify-content:center;align-items:center;overflow:hidden;touch-action:none}body:after{content:"";position:fixed;bottom:-10%;right:-5%;width:80vh;height:80vh;background:url(/skull.svg) no-repeat center / contain;opacity:.07;pointer-events:none;z-index:0}#app{display:flex;justify-content:center;align-items:center;min-height:100vh;width:100%}button{background:var(--bg-surface);color:var(--text);border:1px solid var(--border);padding:.5rem 1.25rem;border-radius:4px;cursor:pointer;font-size:.9rem;letter-spacing:.03em;transition:border-color .15s,background .15s}button:hover{background:var(--bg-raised);border-color:var(--cyan)}input{background:var(--bg-surface);color:var(--text);border:1px solid var(--border);padding:.5rem .75rem;border-radius:4px;font-size:.9rem;text-transform:uppercase;letter-spacing:.1em;width:8rem;text-align:center;transition:border-color .15s}input:focus{outline:none;border-color:var(--cyan)}input::placeholder{color:var(--text-muted);text-transform:none;letter-spacing:normal}.waiting{text-align:center}.waiting h1{font-size:1.2rem;font-weight:400;margin-bottom:.75rem;letter-spacing:.05em;color:var(--heading)}.code-display{font-size:3rem;font-weight:700;letter-spacing:.2em;font-family:monospace;margin-bottom:.75rem;background:linear-gradient(90deg,var(--cyan),var(--magenta));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.waiting p{color:var(--text-dim);font-size:.9rem}.link-actions{display:flex;gap:.5rem;justify-content:center;margin-bottom:.75rem}.qr-container{margin:0 auto .75rem;line-height:0}.qr-container svg{border-radius:4px}.create-join{text-align:center}.create-join h1{font-size:1.2rem;font-weight:400;margin-bottom:1.5rem;letter-spacing:.05em;color:var(--heading)}.error-msg{color:var(--pink);font-size:.85rem;margin-bottom:1rem}.create-join-actions{display:flex;flex-direction:column;align-items:center;gap:.75rem}.game-selector{text-align:center}.game-selector h1{font-size:1.5rem;font-weight:400;margin-bottom:1.5rem;letter-spacing:.05em}.game-list{display:flex;flex-direction:column;gap:.5rem;min-width:280px}.game-card{display:flex;flex-direction:column;gap:.25rem;padding:1rem 1.5rem;text-align:left}.game-card-name{font-size:1rem;font-weight:600}.game-card-desc{font-size:.8rem;color:var(--text-muted)}.game-card:disabled{opacity:.3;cursor:not-allowed}.pick-game-heading{font-size:1rem;font-weight:400;margin:1rem 0 .75rem;letter-spacing:.05em;color:var(--heading-alt)}.exit-btn{position:fixed;top:12px;right:12px;width:32px;height:32px;padding:0;font-size:1.2rem;line-height:1;display:flex;align-items:center;justify-content:center;background:#ffffff0d;border:1px solid rgba(255,255,255,.15);border-radius:4px;color:var(--text-muted);z-index:100}.exit-btn:hover{background:#ff2d9b26;border-color:var(--pink);color:var(--pink)}.disconnect-overlay{display:flex;align-items:center;justify-content:center;width:100%;height:100vh;text-align:center}.disconnect-overlay p{font-size:1.2rem;color:var(--pink);letter-spacing:.05em}.name-entry{text-align:center}.name-entry h1{font-size:1.2rem;font-weight:400;margin-bottom:1rem;letter-spacing:.05em;color:var(--heading)}.name-entry input{display:block;margin:0 auto 1rem;text-transform:none;width:12rem}.name-entry button{display:block;margin:0 auto}.mesh-canvas{display:block;margin:1.5rem auto}.player-count{color:var(--text-dim);font-size:.9rem;margin-bottom:.75rem}.start-btn{margin-top:.5rem;padding:.6rem 2rem;font-size:1rem;letter-spacing:.05em}.start-btn:disabled{opacity:.3;cursor:not-allowed}.profile-btn{position:fixed;top:12px;left:12px;width:32px;height:32px;padding:0;font-size:.9rem;font-weight:700;line-height:1;display:flex;align-items:center;justify-content:center;background:#00d4ff14;border:1px solid rgba(0,212,255,.25);border-radius:50%;color:var(--cyan);z-index:100;text-transform:uppercase}.profile-btn:hover{background:#00d4ff26;border-color:var(--cyan);color:var(--text)}.profile-editor{position:fixed;top:52px;left:12px;display:flex;gap:.5rem;background:var(--bg);border:1px solid rgba(0,212,255,.2);border-radius:6px;padding:.5rem;z-index:100}.profile-name-input{width:10rem;text-transform:none}.profile-save-btn{font-size:.8rem;padding:.3rem .75rem}.profile-logout-btn{font-size:.8rem;padding:.3rem .75rem;color:var(--pink);border-color:var(--pink)}.lobby{text-align:center;max-width:640px}.lobby h1{font-size:1.5rem;font-weight:400;margin-bottom:1rem;letter-spacing:.05em}.emoji-grid{display:grid;grid-template-columns:repeat(8,36px);gap:2px;margin-bottom:1.5rem;justify-content:center}.emoji-swatch{width:36px;height:36px;border-radius:4px;cursor:pointer;border:2px solid transparent;transition:border-color .15s;font-size:1.4rem;display:flex;align-items:center;justify-content:center;-webkit-user-select:none;user-select:none}.emoji-swatch:hover{border-color:#fff9}.emoji-swatch.selected{border-color:var(--text);box-shadow:0 0 0 1px var(--text)}.lobby-actions{display:flex;flex-direction:column;align-items:center;gap:.75rem}.join-row{display:flex;gap:.5rem}.game-wrapper{display:flex;flex-direction:column;align-items:center;gap:.5rem}.game-header{display:flex;align-items:center;gap:.75rem}.room-code{font-size:.8rem;color:var(--text-muted);letter-spacing:.1em;font-family:monospace}.announcements{position:absolute;bottom:8px;left:8px;display:flex;flex-direction:column;gap:4px;pointer-events:none;z-index:10}.announcement{font-size:.75rem;font-family:monospace;color:var(--bg);background:#ffffffe6;padding:4px 8px;border-radius:3px;border-left:3px solid var(--magenta);transition:opacity .5s}.announcement.fade-out{opacity:0}.play-area-container{overflow:hidden}.play-area{width:390px;height:700px;background:var(--text);position:relative;overflow:hidden;cursor:none;transform-origin:top left;touch-action:none}.player-emoji{font-size:28px;line-height:1;position:absolute;top:0;left:0;pointer-events:none;will-change:transform;-webkit-user-select:none;user-select:none}.player-emoji.enter{animation:bounce-in .5s linear forwards}@keyframes bounce-in{0%{scale:0}18%{scale:1.2}32%{scale:.9}44%{scale:1.1}56%{scale:.95}68%{scale:1.04}80%{scale:.98}90%{scale:1.01}to{scale:1}}.ah-lobby{text-align:center;max-width:400px}.ah-lobby h1{font-size:1.5rem;font-weight:400;margin-bottom:1rem;letter-spacing:.05em}.ah-color-grid{display:flex;gap:10px;margin-bottom:1.5rem;justify-content:center}.ah-color-swatch{width:48px;height:48px;border-radius:50%;cursor:pointer;border:3px solid transparent;transition:border-color .15s,transform .15s}.ah-color-swatch:hover{transform:scale(1.1);border-color:#fff6}.ah-color-swatch.selected{border-color:var(--text);box-shadow:0 0 0 2px var(--text);transform:scale(1.1)}.ah-wrapper{display:flex;flex-direction:column;align-items:center;gap:.5rem}.ah-score{display:flex;align-items:center;gap:.75rem;font-size:2rem;font-weight:700;font-variant-numeric:tabular-nums;letter-spacing:.05em}.ah-score-sep{color:var(--text-dim);font-weight:300}.ah-canvas-container{overflow:hidden;position:relative}.ah-canvas{display:block;cursor:none;touch-action:none}.ah-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:#000000b3;color:var(--text);font-size:2rem;font-weight:700;letter-spacing:.05em;z-index:10}.pong-lobby{text-align:center;max-width:400px}.pong-lobby h1{font-size:2.5rem;font-weight:700;margin-bottom:.25rem;letter-spacing:.15em;font-family:monospace}.pong-lobby-desc{color:var(--text-muted);font-size:.85rem;font-family:monospace;margin-bottom:1.5rem}.pong-lobby-actions{display:flex;flex-direction:column;align-items:center;gap:.75rem}.pong-wrapper{display:flex;flex-direction:column;align-items:center;gap:.5rem}.pong-score{display:flex;align-items:center;gap:1rem;font-size:2.5rem;font-weight:700;font-family:monospace;font-variant-numeric:tabular-nums;letter-spacing:.1em}.pong-score-sep{color:var(--text-dim);font-weight:300}.pong-canvas-container{overflow:hidden;position:relative}.pong-canvas{display:block;cursor:none;touch-action:none;border:1px solid var(--border)}.pong-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:#000c;color:var(--text);font-size:2.5rem;font-weight:700;font-family:monospace;letter-spacing:.15em;z-index:10}
