:root{--bg-0: #040712;--bg-1: rgba(8, 15, 31, .72);--bg-2: rgba(11, 24, 46, .82);--text-0: #f7fbff;--text-1: #aab7ca;--accent-cyan: #47d6ff;--voice-amber: #ffc76b;--danger: #ff6b8f;--panel-border: rgba(116, 218, 255, .22);--shadow: 0 24px 80px rgba(0, 0, 0, .42);color:var(--text-0);font-family:Aptos,Trebuchet MS,Segoe UI,sans-serif;background:var(--bg-0);font-synthesis:none;text-rendering:optimizeLegibility}*{box-sizing:border-box}html,body,#root{width:100%;height:100%;margin:0;overflow:hidden}button{font:inherit}.app-shell{position:relative;width:100%;height:100%;overflow:hidden;background:radial-gradient(circle at 50% 50%,rgba(71,214,255,.16),transparent 28%),linear-gradient(135deg,#040712,#071225 54%,#050814)}.game-canvas{position:absolute;inset:0}.game-canvas canvas{display:block}.join-panel{position:absolute;inset:0;z-index:5;display:grid;align-items:center;padding:clamp(24px,6vw,92px);pointer-events:none;background:linear-gradient(90deg,rgba(3,7,16,.88) 0%,rgba(3,7,16,.52) 34%,transparent 76%),radial-gradient(circle at 28% 50%,rgba(71,214,255,.12),transparent 34%);transition:opacity .22s ease,visibility .22s ease}.join-panel--joined{visibility:hidden;opacity:0}.join-panel__content{width:min(440px,92vw);pointer-events:auto;animation:rise-in .56s cubic-bezier(.19,1,.22,1)}.brand{margin:0 0 14px;color:var(--accent-cyan);font-size:clamp(28px,5vw,54px);font-weight:900;line-height:.95}h1{max-width:8ch;margin:0;font-size:clamp(44px,9vw,96px);line-height:.94;font-weight:900}.join-panel__copy{max-width:32ch;margin:22px 0 28px;color:var(--text-1);font-size:clamp(16px,2vw,19px);line-height:1.5}.primary-action{min-width:228px;min-height:52px;border:1px solid rgba(71,214,255,.58);border-radius:6px;padding:0 22px;color:#03101a;background:linear-gradient(135deg,var(--accent-cyan),#d9fbff);box-shadow:0 0 30px #47d6ff47;font-size:15px;font-weight:900;cursor:pointer}.primary-action:disabled{cursor:wait;filter:grayscale(.4)}.join-panel__error{max-width:34ch;margin:16px 0 0;color:var(--danger);font-size:14px;line-height:1.45}.hud{position:absolute;z-index:7;display:inline-flex;align-items:center;gap:9px;min-height:38px;border:1px solid var(--panel-border);border-radius:6px;padding:0 12px;color:var(--text-0);background:var(--bg-1);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);font-size:13px;font-weight:800}.hud--top-left{top:18px;left:18px}.hud--top-right{top:18px;right:18px}.hud__brand{color:var(--accent-cyan);font-weight:900}.hud__crowd{color:var(--voice-amber)}.status-dot{width:9px;height:9px;border-radius:999px;background:var(--text-1);box-shadow:0 0 14px currentColor}.status-dot--joined{color:var(--accent-cyan);background:var(--accent-cyan)}.status-dot--error,.status-dot--permission-denied{color:var(--danger);background:var(--danger)}.center-compass{position:absolute;z-index:7;top:62px;left:18px;display:inline-flex;align-items:center;gap:7px;min-height:28px;border:1px solid rgba(116,218,255,.14);border-radius:999px;padding:0 10px;color:#f7fbff94;background:#040a185c;box-shadow:0 16px 48px #0000002e;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);font-size:10px;font-weight:900;letter-spacing:.12em;pointer-events:none;text-transform:uppercase}.center-compass__arrow{width:16px;height:16px;border-radius:999px;background:linear-gradient(45deg,transparent 48%,rgba(71,214,255,.82) 49% 55%,transparent 56%),radial-gradient(circle,rgba(71,214,255,.16),transparent 62%);box-shadow:0 0 18px #47d6ff38;transform-origin:50% 50%}.center-compass__arrow:before{display:block;width:0;height:0;margin:-2px auto 0;border-right:4px solid transparent;border-bottom:10px solid rgba(216,251,255,.9);border-left:4px solid transparent;content:""}.donate-button{position:absolute;z-index:7;top:18px;right:18px;display:inline-grid;min-height:34px;min-width:74px;place-items:center;border:1px solid rgba(255,199,107,.34);border-radius:999px;padding:0 14px;color:#fff0bf;background:#22152a8f;box-shadow:0 18px 52px #00000052;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);font-size:12px;font-weight:900;text-decoration:none}.donate-button:hover{border-color:#ffc76bad;background:#361f3abd}.hint-stack{position:absolute;z-index:6;left:50%;bottom:32px;display:flex;gap:10px;transform:translate(-50%);animation:hint-fade 6s ease forwards;pointer-events:none}.hint-stack span{border:1px solid rgba(255,199,107,.28);border-radius:999px;padding:9px 12px;color:var(--text-0);background:#040914a3;box-shadow:0 14px 50px #00000038;font-size:12px;font-weight:800}.joystick{position:absolute;right:max(22px,env(safe-area-inset-right));bottom:max(24px,env(safe-area-inset-bottom));z-index:8;width:112px;height:112px;border:1px solid rgba(71,214,255,.34);border-radius:999px;padding:0;background:radial-gradient(circle,rgba(71,214,255,.1),transparent 58%),#040a1880;box-shadow:inset 0 0 34px #47d6ff14,0 18px 50px #0000005c;touch-action:none}.joystick:disabled{opacity:.42}.joystick__nub{position:absolute;top:50%;left:50%;width:40px;height:40px;border-radius:999px;background:linear-gradient(135deg,#47d6fff2,#ffc76bd1);box-shadow:0 0 32px #47d6ff6b;translate:-50% -50%;transition:transform 80ms linear}@keyframes rise-in{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}@keyframes hint-fade{0%,72%{opacity:1;transform:translate(-50%) translateY(0)}to{opacity:0;transform:translate(-50%) translateY(10px)}}@media(max-width:720px){.join-panel{align-items:end;padding:24px 18px 168px;background:linear-gradient(0deg,rgba(3,7,16,.94) 0%,rgba(3,7,16,.64) 42%,transparent 100%),radial-gradient(circle at 50% 60%,rgba(71,214,255,.14),transparent 52%)}.hud{min-height:34px;padding:0 10px;font-size:12px}.hud--top-left{top:12px;left:12px;max-width:calc(100vw - 104px)}.hud--top-right{top:12px;right:12px}.center-compass{top:52px;left:12px}.donate-button{top:12px;right:12px;min-height:32px;min-width:68px;padding:0 12px;font-size:11px}.hud__crowd{display:none}.hint-stack{left:14px;right:142px;bottom:26px;flex-direction:column;gap:6px;transform:none}.hint-stack span{width:fit-content;max-width:100%}.joystick{width:112px;height:112px}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;scroll-behavior:auto!important;transition-duration:.01ms!important}}
