:root{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;--bg:#060218;--bg-2:#0a0420;--accent:#ff3ad1;--accent-2:#3affe1;--power:#3eff8b;--ko:#ffd23a;--danger:#ff4040;--text:#f5f5ff;--muted:#9ea0c4;font-family:Inter,Segoe UI,Roboto,sans-serif}*{box-sizing:border-box}html,body{background:var(--bg);width:100%;height:100%;color:var(--text);-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;margin:0;padding:0;overflow:hidden}#root{width:100%;height:100%}button{color:var(--text);border:1px solid var(--accent);letter-spacing:.04em;cursor:pointer;text-transform:uppercase;background:linear-gradient(#2a1455,#150827);border-radius:6px;padding:12px 26px;font-size:16px;font-weight:600;transition:transform 60ms,box-shadow 60ms;box-shadow:0 0 12px #ff3ad140,inset 0 0 8px #3affe126}button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 0 18px #ff3ad18c,inset 0 0 12px #3affe133}button:disabled{opacity:.4;cursor:not-allowed}input[type=text]{color:var(--text);background:#ffffff0a;border:1px solid #ffffff26;border-radius:4px;outline:none;padding:10px 12px;font-size:16px}input[type=text]:focus{border-color:var(--accent)}.app{justify-content:center;align-items:center;width:100vw;height:100vh;display:flex;position:relative}.menu{background:#0a0420d9;border:1px solid #ff3ad166;border-radius:12px;flex-direction:column;gap:18px;width:min(440px,90vw);padding:32px;display:flex;box-shadow:0 0 50px #ff3ad126}.menu h1{letter-spacing:.18em;background:linear-gradient(90deg, var(--accent-2), var(--accent));color:#0000;text-align:center;-webkit-background-clip:text;background-clip:text;margin:0;font-size:38px}.menu .row{align-items:center;gap:10px;display:flex}.menu label{color:var(--muted);text-transform:uppercase;letter-spacing:.1em;margin-bottom:4px;font-size:12px}.color-row{flex-wrap:wrap;gap:8px;display:flex}.swatch{cursor:pointer;border:2px solid #0000;border-radius:50%;width:32px;height:32px;transition:transform 80ms,border-color 80ms}.swatch:hover{transform:scale(1.08)}.swatch.selected{border-color:#fff;box-shadow:0 0 12px}.lobby-info{color:var(--muted);text-align:center;font-size:14px}.canvas-wrap{position:absolute;inset:0}canvas{width:100%;height:100%;display:block}.hud{pointer-events:none;z-index:10;position:absolute;inset:0}.hud-bar{flex-direction:column;gap:12px;width:320px;display:flex;position:absolute;bottom:24px;left:24px}.meter{background:#0000008c;border:1px solid #fff3;border-radius:4px;height:14px;position:relative;overflow:hidden}.meter>.fill{height:100%;transition:width 50ms linear}.meter.power>.fill{background:linear-gradient(90deg,#3eff8b,#ffd23a,#ff4040)}.meter.ko>.fill{background:linear-gradient(90deg,#3affe1,#ff3ad1)}.meter.meter-ready-glow{border-color:var(--accent-2);animation:.9s ease-in-out infinite alternate ko-glow}.meter.meter-low{animation:.5s ease-in-out infinite alternate power-warn}.meter-ready{color:var(--accent-2);letter-spacing:.18em;margin-left:8px;font-size:10px;animation:.6s ease-in-out infinite alternate ko-text;display:inline-block}@keyframes ko-glow{0%{box-shadow:0 0 4px #3affe166}to{box-shadow:0 0 18px #3affe1f2,0 0 28px #ff3ad180}}@keyframes power-warn{0%{box-shadow:0 0 #ff404000}to{box-shadow:0 0 14px #ff4040b3}}@keyframes ko-text{0%{opacity:.55}to{opacity:1}}@keyframes shake{0%{transform:translate(0)}20%{transform:translate(-4px,2px)}40%{transform:translate(3px,-3px)}60%{transform:translate(-3px,-2px)}80%{transform:translate(2px,3px)}to{transform:translate(0)}}.canvas-wrap.shake{animation:.22s ease-out shake}.fx-flash{pointer-events:none;z-index:40;background:radial-gradient(circle at 50% 72%,#ffffffb3,#ffffff26 25%,#fff0 50%);animation:.24s ease-out fx-flash;position:absolute;inset:0}@keyframes fx-flash{0%{opacity:1}to{opacity:0}}.fx-side-ring{pointer-events:none;z-index:40;transform-origin:50%;filter:drop-shadow(0 0 8px #3affe199);border:4px solid #3affe1d9;border-radius:50%;width:200px;height:200px;animation:.32s ease-out fx-ring;position:absolute;bottom:22%}.fx-side-ring.left{clip-path:polygon(0 0,50% 0,50% 100%,0 100%);left:calc(50% - 200px)}.fx-side-ring.right{clip-path:polygon(50% 0,100% 0,100% 100%,50% 100%);right:calc(50% - 200px)}@keyframes fx-ring{0%{opacity:1;transform:scale(.4)}to{opacity:0;transform:scale(1.4)}}.fx-kos{pointer-events:none;z-index:50;flex-direction:column;gap:4px;display:flex;position:absolute;top:90px;right:26px}.fx-ko-pop{letter-spacing:.18em;color:#ffd23a;text-shadow:0 0 8px #ffd23ae6,0 0 14px #ff3ad199;font-size:18px;font-weight:700;animation:1.6s ease-out forwards fx-ko}@keyframes fx-ko{0%{opacity:0;transform:translateY(0)scale(.8)}10%{opacity:1;transform:translateY(-8px)scale(1.15)}30%{opacity:1;transform:translateY(-14px)scale(1)}to{opacity:0;transform:translateY(-46px)scale(.95)}}.meter-label{letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-bottom:4px;font-size:10px}.hud-top{align-items:baseline;gap:18px;display:flex;position:absolute;top:18px;left:18px}.hud-top .position{letter-spacing:.06em;font-size:30px;font-weight:700}.hud-top .position .total{color:var(--muted);margin-left:4px;font-size:16px}.hud-top .lap{letter-spacing:.2em;color:var(--muted);font-size:14px}.hud-top .time{font-variant-numeric:tabular-nums;color:var(--text);font-size:18px}.racers-left{text-align:right;letter-spacing:.2em;color:var(--muted);font-size:14px;position:absolute;top:18px;right:18px}.racers-left .count{color:var(--accent);font-size:30px;font-weight:700;display:block}.minimap{background:#0000008c;border:1px solid #fff3;border-radius:6px;width:200px;height:130px;position:absolute;bottom:24px;right:24px}.countdown-overlay,.pause-overlay,.spectator-overlay{pointer-events:none;z-index:20;background:#06021873;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.countdown-overlay .number{letter-spacing:.04em;background:linear-gradient(180deg, var(--accent-2), var(--accent));color:#0000;filter:drop-shadow(0 0 12px var(--accent));-webkit-background-clip:text;background-clip:text;font-size:180px;font-weight:800}.pause-overlay h2{letter-spacing:.3em;text-transform:uppercase;color:var(--accent-2);text-shadow:0 0 12px var(--accent-2);font-size:70px}.spectator-overlay{pointer-events:auto}.spectator-overlay .panel{border:1px solid var(--danger);text-align:center;background:#0a0420d9;border-radius:8px;padding:24px 32px}.spectator-overlay .panel h3{color:var(--danger);letter-spacing:.2em;text-transform:uppercase}.results-screen{z-index:30;background:#060218d9;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.results-card{background:#0a0420f2;border:1px solid #3affe166;border-radius:12px;flex-direction:column;gap:14px;width:min(560px,90vw);padding:28px;display:flex}.results-card h2{text-align:center;letter-spacing:.18em;margin:0}.results-row{font-variant-numeric:tabular-nums;border-bottom:1px solid #ffffff0f;grid-template-columns:40px 1fr 90px 60px;align-items:center;gap:8px;padding:6px 8px;display:grid}.results-row.you{background:#ff3ad11f;border-radius:4px}.lobby-screen{flex-direction:column;align-items:center;gap:18px;padding:32px;display:flex}.lobby-screen .pulse{letter-spacing:.1em;color:var(--accent-2);font-size:30px}.controls-help{color:var(--muted);text-align:center;font-size:11px;line-height:1.6}.error-banner{border:1px solid var(--danger);color:var(--text);z-index:100;background:#ff40402e;border-radius:4px;padding:8px 16px;font-size:13px;position:absolute;top:16px;left:50%;transform:translate(-50%)}
