:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}:root[data-theme=dark]{color-scheme:dark;--bg: #242424;--text: rgba(255, 255, 255, .87);--surface: #1a1a1a;--surface2: #2a2a2a;--border: #333;--muted: #888;--primary: #646cff;--primaryHover: #535bf2;--danger: #ff4444;--overlay: rgba(0, 0, 0, .7);--touchRingBg: rgba(255, 255, 255, .03);--touchRingBorder: rgba(255, 255, 255, .05);--touchRingBgCooldown: rgba(255, 255, 255, .05);--touchRingBorderCooldown: rgba(255, 255, 255, .1);--avatarInnerBg: rgba(255, 255, 255, .2);--avatarInnerBorder: rgba(255, 255, 255, .3);--pickerIndicatorBorder: #ffffff}:root[data-theme=light]{color-scheme:light;--bg: #ffffff;--text: #213547;--surface: #f7f7fb;--surface2: #ffffff;--border: #d7d7e3;--muted: #5d6470;--primary: #3b49df;--primaryHover: #2f3ad6;--danger: #d83a3a;--overlay: rgba(0, 0, 0, .35);--touchRingBg: rgba(0, 0, 0, .03);--touchRingBorder: rgba(0, 0, 0, .08);--touchRingBgCooldown: rgba(0, 0, 0, .05);--touchRingBorderCooldown: rgba(0, 0, 0, .12);--avatarInnerBg: rgba(255, 255, 255, .55);--avatarInnerBorder: rgba(0, 0, 0, .08);--pickerIndicatorBorder: #111111}:root{color:var(--text);background-color:var(--bg)}a{font-weight:500;color:var(--primary);text-decoration:inherit}a:hover{color:var(--primaryHover)}html{width:100%;overflow-x:hidden}body{margin:0;padding:0;width:100%;display:flex;justify-content:center;align-items:center;min-width:320px;min-height:100vh;overflow-x:hidden}body.no-pull-refresh{overscroll-behavior-y:none;overscroll-behavior:none;-webkit-overflow-scrolling:touch}html.no-pull-refresh{overscroll-behavior-y:none;overscroll-behavior:none}#root{width:100%;max-width:100vw;display:flex;justify-content:center;align-items:center;overflow-x:hidden}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:var(--surface);cursor:pointer;transition:border-color .25s}button:hover{border-color:var(--primary)}button:focus,button:focus-visible{outline:none}.app{max-width:1200px;width:100%;margin-left:auto;margin-right:auto;padding:2rem;text-align:center;display:flex;flex-direction:column;justify-content:center;align-items:center;min-height:100vh;box-sizing:border-box;position:relative;-webkit-tap-highlight-color:transparent}.app h1{font-size:2.5rem;margin-bottom:2rem;color:var(--primary)}.join-section{display:flex;flex-direction:column;align-items:center;gap:1.5rem;margin-bottom:2rem}.input-group{display:flex;flex-direction:column;align-items:center;gap:.5rem}.input-group label{font-size:1.1rem;font-weight:500;margin-bottom:.5rem}.input-group input{padding:.75rem 1rem;font-size:1.5rem;text-align:center;letter-spacing:.5rem;text-transform:uppercase;border:2px solid var(--primary);border-radius:8px;width:200px;transition:border-color .3s;-webkit-appearance:none;appearance:none;background-color:var(--surface2);color:var(--text)}.input-group input.player-name-input{text-transform:none;letter-spacing:normal}.color-picker-container{display:flex;align-items:center;gap:1rem;justify-content:center;flex-wrap:wrap}.hex-color-input{padding:.75rem 1rem;font-size:1.2rem;text-align:center;text-transform:uppercase;border:2px solid var(--primary);border-radius:8px;width:150px;transition:border-color .3s;font-family:Courier New,monospace;letter-spacing:.2rem;background-color:var(--surface2);color:var(--text)}.hex-color-input:focus{outline:none;border-color:var(--primaryHover)}.hex-color-input.error{border-color:var(--danger)}.color-preview{width:60px;height:60px;border:2px solid var(--primary);border-radius:8px;box-shadow:0 2px 8px #646cff4d}.input-group input:focus{outline:none;border-color:var(--primaryHover)}.input-group input:disabled{opacity:.6;cursor:not-allowed}.input-group input.error{border-color:var(--danger)}.join-button{padding:.75rem 2rem;font-size:1.1rem;font-weight:600;color:#fff;background-color:var(--primary);border:none;border-radius:8px;cursor:pointer;transition:background-color .3s;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.join-button:hover:not(:disabled){background-color:var(--primaryHover)}.join-button:disabled{opacity:.6;cursor:not-allowed}.error-message{color:var(--danger);font-weight:500;margin-top:.5rem;padding:.5rem 1rem;background-color:color-mix(in srgb,var(--danger) 12%,transparent);border-radius:4px}.joined-section{margin-bottom:2rem}.info-panel{background-color:var(--surface);border:2px solid var(--primary);border-radius:12px;padding:2rem;margin-bottom:2rem;text-align:left}.info-panel h2{margin-top:0;margin-bottom:1.5rem;color:var(--primary);text-align:center}.info-item{margin-bottom:1rem;font-size:1rem}.info-item strong{color:var(--muted);margin-right:.5rem}.info-item code{background-color:var(--surface2);padding:.25rem .5rem;border-radius:4px;color:var(--primary);font-family:Courier New,monospace;font-size:.9rem;word-break:break-all}.messages-section{text-align:left;width:100%;max-width:100%}.messages-section h2{color:var(--primary);margin-bottom:1rem;text-align:center}.messages-container{background-color:var(--surface);border:2px solid var(--border);border-radius:8px;padding:1rem;max-height:500px;overflow-y:auto;font-family:Courier New,monospace;font-size:.85rem}.message-item{margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid var(--border)}.message-item:last-child{border-bottom:none;margin-bottom:0}.message-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.message-time{color:var(--muted);font-size:.75rem}.message-type{color:var(--primary);font-weight:600;font-size:.9rem;text-transform:uppercase}.message-content{background-color:var(--surface2);padding:.75rem;border-radius:4px;margin:0;color:var(--text);white-space:pre-wrap;word-wrap:break-word;overflow-x:auto;font-size:.8rem;line-height:1.4}.messages-container::-webkit-scrollbar{width:8px}.messages-container::-webkit-scrollbar-track{background:var(--surface)}.messages-container::-webkit-scrollbar-thumb{background:var(--primary);border-radius:4px}.messages-container::-webkit-scrollbar-thumb:hover{background:var(--primaryHover)}.game-header{width:100%;display:flex;align-items:center;justify-content:center;margin-bottom:1rem;position:relative}.game-header h1{margin:0;text-align:center}.menu-button{position:absolute;left:0;top:50%;transform:translateY(-50%);padding:.5rem 1rem;font-size:1rem;font-weight:600;color:#fff;background-color:var(--primary);border:none;border-radius:8px;cursor:pointer;transition:all .3s;-webkit-tap-highlight-color:transparent;touch-action:manipulation;z-index:10}.menu-button:hover{background-color:var(--primaryHover)}.menu-overlay{position:fixed;inset:0;background-color:var(--overlay);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.menu-panel{background-color:var(--surface);border:2px solid var(--primary);border-radius:12px;width:90%;max-width:600px;max-height:90vh;display:flex;flex-direction:column;animation:slideIn .3s ease;overflow:hidden}@keyframes slideIn{0%{transform:translateY(-20px);opacity:0}to{transform:translateY(0);opacity:1}}.menu-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem;border-bottom:2px solid var(--border)}.menu-header h2{margin:0;color:var(--primary);font-size:1.5rem}.menu-close-button{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background-color:transparent;border:2px solid var(--primary);border-radius:50%;color:var(--primary);font-size:1.5rem;line-height:1;cursor:pointer;transition:all .2s;padding:0;-webkit-tap-highlight-color:transparent;outline:none}.menu-close-button:hover{background-color:var(--primary);color:#fff}.menu-content{padding:1.5rem;overflow-y:auto;flex:1}.theme-toggle-row{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.75rem 1rem;margin-bottom:1rem;background-color:var(--surface2);border:1px solid var(--border);border-radius:12px}.theme-toggle-label{font-weight:600;color:var(--muted)}.theme-toggle{display:inline-flex;border:1px solid var(--border);border-radius:10px;overflow:hidden}.theme-toggle-button{padding:.5rem .75rem;border:none;background-color:transparent;color:var(--text);cursor:pointer}.theme-toggle-button:hover{background-color:color-mix(in srgb,var(--primary) 10%,transparent)}.theme-toggle-button.active{background-color:var(--primary);color:#fff}.theme-toggle-icon-button{width:40px;height:40px;display:inline-flex;align-items:center;justify-content:center;border-radius:10px;border:1px solid var(--border);background-color:var(--surface);color:var(--text);padding:0}.theme-toggle-icon-button:hover{border-color:var(--primary)}.menu-content .info-panel{margin-bottom:2rem;padding:1.5rem}.menu-content .info-panel h2{display:none}.menu-content .messages-section{margin-top:2rem}.menu-content .messages-section h3{color:var(--primary);margin-bottom:1rem;text-align:center;font-size:1.2rem}.menu-content .messages-container{max-height:400px}@media(max-width:768px){.app{padding:1rem;min-height:100dvh}.app h1{font-size:2rem;margin-bottom:1.5rem}.game-header{margin-bottom:.5rem}.game-header h1{font-size:1.5rem}.menu-button{padding:.5rem .75rem;font-size:.9rem}.menu-panel{width:95%;max-height:95vh}.menu-header{padding:1rem}.menu-header h2{font-size:1.2rem}.menu-content{padding:1rem}.menu-content .info-panel{padding:1rem;margin-bottom:1.5rem}.menu-content .messages-container{max-height:300px}.join-section{gap:1rem;margin-bottom:1.5rem}.input-group label{font-size:1rem}.input-group input{font-size:1.25rem;padding:.875rem .75rem;width:180px;letter-spacing:.4rem}.join-button{padding:.875rem 1.5rem;font-size:1rem;min-height:44px}.info-panel{padding:1.5rem;margin-bottom:1.5rem}.info-panel h2{font-size:1.5rem;margin-bottom:1rem}.info-item{font-size:.9rem;margin-bottom:.75rem}.info-item code{font-size:.8rem;display:block;margin-top:.25rem}.messages-section h2{font-size:1.5rem}.messages-container{padding:.75rem;max-height:400px;font-size:.8rem}.message-content{padding:.5rem;font-size:.75rem}}@media(max-width:480px){.app{padding:.75rem}.app h1{font-size:1.75rem;margin-bottom:1rem}.game-header h1{font-size:1.25rem}.menu-button{padding:.4rem .6rem;font-size:.85rem}.menu-panel{width:100%;max-height:100vh;border-radius:0;border-left:none;border-right:none}.menu-header,.menu-content{padding:.75rem}.menu-content .messages-container{max-height:250px}.input-group input{width:160px;font-size:1.1rem;letter-spacing:.3rem}.info-panel{padding:1rem}.info-item code{font-size:.75rem;word-break:break-all}.messages-container{max-height:300px}}.respawn-cooldown-container{width:100%;height:60vh;min-height:400px;display:flex;align-items:center;justify-content:center}.respawn-cooldown-indicator{width:100%;max-width:400px;display:flex;flex-direction:column;align-items:center;gap:1rem;padding:2rem;background-color:var(--surface);border:2px solid var(--primary);border-radius:12px}.respawn-cooldown-text{color:var(--primary);font-size:1.5rem;font-weight:600;text-align:center}.respawn-cooldown-bar{width:100%;height:12px;background-color:var(--surface2);border-radius:6px;overflow:hidden;border:1px solid var(--border)}.respawn-cooldown-progress{height:100%;background:linear-gradient(90deg,var(--primary) 0%,var(--primaryHover) 100%);transition:width .1s linear;border-radius:6px}@media(max-width:768px){.respawn-cooldown-container{height:50vh;min-height:300px}.respawn-cooldown-indicator{max-width:300px;padding:1.5rem}.respawn-cooldown-text{font-size:1.2rem}}.firing-controls{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;-webkit-user-select:none;user-select:none;touch-action:none;-webkit-tap-highlight-color:transparent;outline:none}.firing-controls.aiming{cursor:pointer}.firing-area{position:relative;width:100%;height:60vh;min-height:400px;display:flex;align-items:center;justify-content:center;-webkit-tap-highlight-color:transparent;outline:none}.touch-area-circle{position:absolute;width:300px;height:300px;border-radius:50%;background-color:var(--touchRingBg);border:1px solid var(--touchRingBorder);pointer-events:none;z-index:1;overflow:hidden;-webkit-tap-highlight-color:transparent;outline:none}.touch-area-circle.cooldown{background-color:var(--touchRingBgCooldown);border:1px solid var(--touchRingBorderCooldown)}.cooldown-fill{position:absolute;top:50%;left:50%;width:100%;height:100%;border-radius:50%;background:radial-gradient(circle,color-mix(in srgb,var(--primary) 20%,transparent),color-mix(in srgb,var(--primary) 8%,transparent));pointer-events:none;transition:transform .1s linear}.avatar{width:60px;height:60px;border-radius:50%;background:linear-gradient(135deg,var(--primary) 0%,var(--primaryHover) 100%);display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px color-mix(in srgb,var(--primary) 40%,transparent);transition:all .2s ease;cursor:pointer;position:relative;z-index:2;-webkit-tap-highlight-color:transparent;outline:none}.avatar:hover:not(.cooldown),.avatar.aiming:not(.cooldown){transform:scale(1.1);box-shadow:0 6px 16px color-mix(in srgb,var(--primary) 60%,transparent)}.avatar.cooldown{opacity:.5;cursor:not-allowed;background:linear-gradient(135deg,#888,#666)}.avatar-inner{width:40px;height:40px;border-radius:50%;background:var(--avatarInnerBg);border:2px solid var(--avatarInnerBorder)}.aim-line{pointer-events:none}.cooldown-indicator{margin-top:2rem;width:100%;max-width:300px;display:flex;flex-direction:column;align-items:center;gap:.5rem}.cooldown-text{color:var(--muted);font-size:1.2rem;font-weight:500}.instruction-text{margin-top:2rem;color:var(--muted);font-size:1.2rem;text-align:center;opacity:.7;white-space:nowrap}@media(max-width:768px){.firing-area{height:50vh;min-height:300px}.avatar{width:50px;height:50px}.avatar-inner{width:32px;height:32px}.cooldown-indicator{max-width:250px;margin-top:1.5rem}.cooldown-text{font-size:1.1rem}.instruction-text{font-size:1.1rem;margin-top:1.5rem;padding:0 1rem;white-space:nowrap}@media(max-width:400px){.instruction-text{font-size:.95rem}}}.color-picker{display:flex;flex-direction:column;align-items:center;gap:1.5rem;width:100%;max-width:300px}.color-picker-main-container{display:flex;flex-direction:column;gap:1rem;align-items:center;width:100%;justify-content:center}.color-picker-wheel{position:relative;width:250px;height:250px;border:2px solid var(--primary);border-radius:50%;cursor:pointer;touch-action:none;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none;overflow:hidden}.color-picker-indicator{position:absolute;width:20px;height:20px;border:2px solid var(--pickerIndicatorBorder);border-radius:50%;box-shadow:0 0 0 1px #0000004d,0 2px 4px #0003;transform:translate(-50%,-50%);pointer-events:none;z-index:2}.color-picker-brightness{position:relative;width:250px;height:20px;border:2px solid var(--primary);border-radius:8px;cursor:pointer;touch-action:none;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none;overflow:hidden}.color-picker-brightness-thumb{position:absolute;top:0;bottom:0;width:4px;height:auto;background-color:#fff;border:2px solid rgba(255,255,255,.9);border-radius:2px;box-shadow:0 0 4px #fffc,0 1px 3px #00000080;transform:translate(-50%);pointer-events:none;z-index:2;box-sizing:border-box;left:var(--brightness-position, 0%)}.color-picker-controls{display:flex;flex-direction:column;align-items:center;gap:1rem;width:100%}.color-picker-preview{width:80px;height:80px;border:2px solid var(--primary);border-radius:8px;box-shadow:0 2px 8px #0003}@media(max-width:768px){.color-picker{max-width:100%}.color-picker-wheel{width:min(250px,80vw);height:min(250px,80vw)}.color-picker-brightness{width:min(250px,80vw);height:20px}.color-picker-preview{width:60px;height:60px}}@media(max-width:768px){.color-picker-wheel{min-width:200px;min-height:200px}.color-picker-brightness{min-width:200px;min-height:44px}}
