@import"https://fonts.googleapis.com/css2?family=Fredoka:wght@600;700&family=Inter:wght@400;500;600&family=JetBrains+Mono:wght@500;600&display=swap";*{box-sizing:border-box}html,body,#root{margin:0;height:100%;overflow:hidden;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:radial-gradient(circle at top,#1a1a2e,#0f0f1e 65%);color:#f4f5f7}a{color:inherit}button,input,select{font-family:inherit}.app-shell{height:100%;display:flex;align-items:center;justify-content:center;padding:2rem;overflow-y:auto}.lobby{width:100%;max-width:540px}.lobby-card{background:#0f1224f2;border:1px solid rgba(255,255,255,.08);border-radius:24px;padding:2rem;box-shadow:0 40px 80px #0006}.lobby-header h1{font-family:Fredoka,Inter,sans-serif;font-size:3rem;margin:0}.lobby-header p{margin:.25rem 0 1.5rem;color:#b0b0c8}.tab-bar{display:grid;grid-template-columns:repeat(2,1fr);background:#0f0f1e;border-radius:999px;padding:4px;margin-bottom:1.5rem;border:1px solid rgba(255,255,255,.08)}.tab-bar button{border:none;border-radius:999px;padding:.75rem 1.5rem;background:transparent;color:#b0b0c8;cursor:pointer;transition:background .2s ease,color .2s ease}.tab-bar button.active{background:linear-gradient(135deg,#e040fb,#00e5ff);color:#05060b;font-weight:600}.blob-panel{display:grid;grid-template-columns:160px 1fr;gap:1.5rem;padding:1.5rem;background:#05060bb3;border-radius:1.5rem;margin-bottom:1.5rem}.blob-preview{width:140px;height:140px;border-radius:50%;border:6px solid rgba(255,255,255,.12);box-shadow:0 0 25px #e040fb4d}label{display:flex;flex-direction:column;gap:.4rem;font-size:.9rem;margin-bottom:1rem}input,select{padding:.75rem 1rem;border-radius:.85rem;border:1px solid rgba(255,255,255,.1);background:#ffffff0a;color:inherit}.color-picker{margin-bottom:1rem}.color-picker span{display:block;margin-bottom:.5rem}.color-swatches{display:grid;grid-template-columns:repeat(6,1fr);gap:.4rem}.color-swatches .swatch{width:36px;height:36px;border-radius:50%;border:2px solid transparent;cursor:pointer;padding:0;background-clip:padding-box}.color-swatches .swatch.selected{border-color:#fff;box-shadow:0 0 12px #fff6}.form{display:flex;flex-direction:column;gap:1rem}.primary-button,.pill-button{border:none;border-radius:999px;padding:.85rem 1.5rem;font-size:1rem;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}.primary-button{background:linear-gradient(135deg,#e040fb,#00e5ff);color:#05060b;font-weight:600}.primary-button:disabled{opacity:.6;cursor:not-allowed}.pill-button{background:#ffffff14;color:#fff}.primary-button:not(:disabled):hover,.pill-button:not(:disabled):hover{transform:translateY(-2px);box-shadow:0 20px 40px #00000040}.error{color:#ff6b81;margin-top:1rem;text-align:center}.game-view{width:100%;height:100%;display:flex;flex-direction:column}.game-stage{flex:1;position:relative;background:#05060b;border-radius:24px;overflow:hidden;border:1px solid rgba(255,255,255,.08)}.canvas-mount{width:100%;height:100%;touch-action:none}.canvas-mount canvas{touch-action:none}.touch-controls{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;user-select:none;-webkit-user-select:none}.touch-joystick{position:absolute;left:16px;bottom:16px;width:calc(var(--joy-radius, 120px) * 2);height:calc(var(--joy-radius, 120px) * 2);pointer-events:auto;touch-action:none}.touch-joystick__base{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:50%;background:#ffffff0f;border:1px solid rgba(255,255,255,.12);box-shadow:0 10px 30px #00000059;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.touch-joystick__knob{position:absolute;left:50%;top:50%;transform:translate(0);translate:-50% -50%;border-radius:50%;background:#ffffff24;border:1px solid rgba(255,255,255,.2);box-shadow:0 12px 35px #00000059}.touch-buttons{position:absolute;right:16px;bottom:16px;display:flex;gap:14px;pointer-events:auto;touch-action:none}.touch-button{min-width:56px;min-height:56px;width:clamp(56px,10vw,84px);height:clamp(56px,10vw,84px);border-radius:999px;border:1px solid rgba(255,255,255,.18);background:#ffffff14;color:#fff;font-weight:700;letter-spacing:.02em;pointer-events:auto}.touch-button--primary{background:linear-gradient(135deg,#e040fb99,#00e5ff8c);color:#05060b}.touch-button:active{transform:translateY(1px) scale(.98)}.canvas-hidden{opacity:.1;pointer-events:none}.waiting-room{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;padding:2rem;gap:1.5rem;background:#05060ceb;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.waiting-room__header{display:flex;justify-content:space-between;align-items:center}.overline{text-transform:uppercase;letter-spacing:.2em;font-size:.75rem;color:#b0b0c8;margin:0}.code-display{font-family:JetBrains Mono,monospace;font-size:2rem;letter-spacing:.2em}.waiting-room__body{flex:1;background:#0f0f1ee6;border-radius:20px;padding:1.5rem;display:flex;flex-direction:column}.subtitle{color:#b0b0c8;margin:0 0 1rem}.player-list{flex:1;overflow-y:auto;padding-right:.5rem;display:flex;flex-direction:column;gap:.5rem}.player-row{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;border-radius:12px;background:#05060bcc}.status-dot{width:10px;height:10px;border-radius:50%}.status-dot.online{background:#00e676}.status-dot.offline{background:#ff1744}.player-info{flex:1;display:flex;align-items:center;gap:.5rem}.player-info strong{font-size:1rem}.badge{font-size:.75rem;text-transform:uppercase;color:#ffd600;letter-spacing:.05em}.badge.muted{color:#b0b0c8}.color-chip{width:18px;height:18px;border-radius:50%;border:2px solid rgba(255,255,255,.5)}.waiting-room__actions{margin-top:1.25rem}.connection-note{margin-top:.75rem;font-size:.9rem;color:#b0b0c8}.game-hud{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.hud-timer{position:absolute;top:1.5rem;left:50%;transform:translate(-50%);background:#0f0f1ee6;border-radius:999px;padding:.5rem 1.5rem;border:1px solid rgba(255,255,255,.08);display:flex;flex-direction:column;align-items:center}.timer-label{font-size:.75rem;color:#b0b0c8}.timer-value{font-family:JetBrains Mono,monospace;font-size:1.5rem;color:#00e5ff}.hud-leaderboard{position:absolute;top:1.5rem;right:1.5rem;width:220px;background:#0f0f1eeb;border-radius:16px;border:1px solid rgba(255,255,255,.08);padding:1rem}.hud-leaderboard__header{display:flex;justify-content:space-between;font-size:.85rem;color:#b0b0c8;margin-bottom:.5rem}.room-code{font-size:.75rem;color:#b0b0c8}.hud-leaderboard ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.35rem}.hud-leaderboard li{display:flex;justify-content:space-between;font-size:.9rem}.hud-status{position:absolute;bottom:1rem;left:50%;transform:translate(-50%);padding:.4rem .8rem;background:#0f0f1ecc;border-radius:999px;font-size:.8rem;color:#b0b0c8}.exit-button{position:absolute;bottom:1.5rem;left:1.5rem;border:none;background:#ffffff14;color:#fff;padding:.5rem 1rem;border-radius:999px;cursor:pointer;z-index:20}.countdown-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#05060bd9}.countdown-card{text-align:center;padding:2rem 3rem;background:#0f0f1ef2;border-radius:24px;border:1px solid rgba(255,255,255,.08)}.countdown-card p{margin:0;color:#b0b0c8}.countdown-number{font-size:4rem;font-family:Fredoka,sans-serif}.end-screen{position:absolute;top:0;right:0;bottom:0;left:0;background:#05060beb;display:flex;align-items:center;justify-content:center}.end-card{width:min(600px,90%);background:#0f0f1ef2;border-radius:24px;padding:2rem;border:1px solid rgba(255,255,255,.1);text-align:center}.winner-callout{background:#e040fb26;border-radius:18px;padding:1rem;margin-bottom:1.5rem}.ranking-list{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1.5rem}.ranking-row{display:flex;justify-content:space-between;padding:.75rem 1rem;background:#05060bcc;border-radius:12px}@media (max-width: 640px){.app-shell{padding:1rem}.blob-panel{grid-template-columns:1fr}.color-swatches{grid-template-columns:repeat(4,1fr)}.waiting-room{padding:1rem}}.consumed-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#05060bd9;display:flex;align-items:center;justify-content:center;z-index:30}.consumed-card{background:#0f0f1ef2;padding:2rem 3rem;border-radius:20px;border:1px solid rgba(255,255,255,.1);text-align:center;box-shadow:0 15px 40px #0006}.consumed-card h2{margin:.5rem 0 1rem;color:#ff1744}.consumed-card .countdown{color:#ffd600;font-size:1.2rem}.minimap{position:absolute;bottom:1.5rem;right:1.5rem;width:120px;height:120px;background:#0f0f1ee6;border:1px solid rgba(255,255,255,.1);border-radius:12px;overflow:hidden;pointer-events:none}.minimap-dot{position:absolute;width:6px;height:6px;border-radius:50%;background:#00e5ff;transform:translate(-50%,-50%);opacity:.8}.minimap-dot.self{background:#ffd600;box-shadow:0 0 6px #ffd600e6}.minimap-dot.ghost{opacity:.3}
