[data-theme=dark]{--bg-primary: #05070f;--bg-secondary: #0a0f1e;--bg-card: #0d1324;--bg-card-translucent: rgba(12, 18, 36, .9);--bg-overlay: rgba(5, 7, 15, .9);--bg-input: rgba(24, 31, 50, .9);--bg-hover: rgba(255, 255, 255, .1);--bg-subtle: rgba(255, 255, 255, .05);--bg-active: rgba(255, 255, 255, .06);--text-primary: #f4f6fa;--text-secondary: #cfe0ff;--text-muted: #9fb7ff;--text-dim: #7f8db4;--text-faint: #6b7190;--text-on-accent: white;--border-default: #24304a;--border-subtle: rgba(255, 255, 255, .08);--border-hover: rgba(255, 255, 255, .25);--border-input: #2c3550;--border-panel: #1f2638;--border-strong: #2f3650;--accent-primary: #4f7dff;--accent-primary-end: #6e5bff;--accent-speed: #4af6c2;--accent-heading: #ffcf70;--accent-wind: #9fb7ff;--accent-danger: #ff8a8a;--accent-danger-bg: rgba(255, 82, 82, .15);--accent-danger-border: rgba(255, 82, 82, .3);--accent-warning: #f5a524;--accent-warning-text: #ffcc44;--accent-success: #7df5b8;--accent-info: #d8f8ff;--accent-cyan: rgba(83, 224, 255, .55);--hud-bg: rgba(5, 8, 18, .8);--hud-border: rgba(255, 255, 255, .12);--shadow-large: 0 12px 40px rgba(0, 0, 0, .5);--shadow-panel: 0 10px 40px rgba(0, 0, 0, .45);--landing-bg: radial-gradient(circle at top, rgba(31, 61, 136, .3), rgba(4, 6, 12, .95)), #05070f;--landing-cta-bg: linear-gradient(130deg, #ff8f70, #ffcd70);--landing-cta-color: #05070f}[data-theme=light]{--bg-primary: #f0f2f8;--bg-secondary: #e8eaf2;--bg-card: #ffffff;--bg-card-translucent: rgba(255, 255, 255, .95);--bg-overlay: rgba(240, 242, 248, .95);--bg-input: rgba(240, 242, 248, .9);--bg-hover: rgba(0, 0, 0, .06);--bg-subtle: rgba(0, 0, 0, .03);--bg-active: rgba(0, 0, 0, .05);--text-primary: #1a1d2e;--text-secondary: #3a4058;--text-muted: #4a5680;--text-dim: #6b7190;--text-faint: #8a90a8;--text-on-accent: white;--border-default: #d4d8e8;--border-subtle: rgba(0, 0, 0, .08);--border-hover: rgba(0, 0, 0, .2);--border-input: #c8cde0;--border-panel: #d4d8e8;--border-strong: #b8bdd0;--accent-primary: #3a60cc;--accent-primary-end: #5544cc;--accent-speed: #0a8f6a;--accent-heading: #996600;--accent-wind: #4a6699;--accent-danger: #cc3333;--accent-danger-bg: rgba(204, 51, 51, .1);--accent-danger-border: rgba(204, 51, 51, .25);--accent-warning: #cc7700;--accent-warning-text: #996600;--accent-success: #0a8f6a;--accent-info: #2277bb;--accent-cyan: rgba(34, 119, 187, .5);--hud-bg: rgba(255, 255, 255, .88);--hud-border: rgba(0, 0, 0, .1);--shadow-large: 0 12px 40px rgba(0, 0, 0, .12);--shadow-panel: 0 10px 40px rgba(0, 0, 0, .1);--landing-bg: radial-gradient(circle at top, rgba(180, 200, 255, .3), rgba(240, 242, 248, .98)), #f0f2f8;--landing-cta-bg: linear-gradient(130deg, #cc5533, #cc8800);--landing-cta-color: #ffffff}.username-gate{position:fixed;inset:0;background:var(--bg-overlay);display:flex;align-items:center;justify-content:center;z-index:20}.username-card{background:var(--bg-card);border:1px solid var(--border-default);border-radius:.8rem;padding:1.5rem;width:min(420px,calc(100% - 2rem));display:flex;flex-direction:column;gap:1rem}.user-menu-card{padding-top:1.1rem}.user-menu-header{display:flex;flex-direction:column;align-items:flex-start;gap:.75rem;padding-bottom:.75rem;border-bottom:1px solid var(--border-subtle)}.user-menu-header-top{width:100%;display:flex;align-items:flex-start;justify-content:space-between;gap:.75rem}.user-menu-title{display:flex;align-items:flex-start;gap:.6rem}.user-menu-card h2{margin:0}.user-menu-header-actions,.user-menu-social-row{display:inline-flex;align-items:center;gap:.4rem}.user-menu-close{width:36px;height:36px;border-radius:.65rem;border:1px solid rgba(255,255,255,.16);background:var(--bg-active);color:var(--text-primary);display:inline-flex;align-items:center;justify-content:center;line-height:0;font-size:.95rem;flex:0 0 auto}.user-menu-close:hover{border-color:var(--border-hover);background:var(--bg-hover)}.user-menu-close:active{transform:translateY(1px)}.user-menu-form{display:flex;flex-direction:column;gap:.75rem;padding-top:.25rem}.user-menu-row{display:flex;align-items:center;gap:.6rem}.user-menu-label{opacity:.85;font-size:.8rem;min-width:42px;letter-spacing:.06em;text-transform:uppercase;color:var(--text-secondary)}.user-menu-field{flex:1;position:relative;min-width:0}.user-menu-select{width:100%;padding:.7rem 2.2rem .7rem .9rem;border-radius:.5rem;border:1px solid var(--border-input);background:var(--bg-input);color:inherit;font:inherit;appearance:none;-webkit-appearance:none}.user-menu-input{width:100%;padding:.7rem .9rem;border-radius:.5rem;border:1px solid var(--border-input);background:var(--bg-input);color:inherit;font:inherit}.user-menu-select:focus-visible{outline:2px solid var(--accent-cyan);outline-offset:2px}.user-menu-chevron{position:absolute;right:.8rem;top:50%;transform:translateY(-50%);pointer-events:none;opacity:.75;-webkit-user-select:none;user-select:none;font-size:.9rem}.username-card h2{font-size:1.25rem;color:var(--text-muted)}.username-card p{color:#cdd5f3;line-height:1.4}.username-form{display:flex;flex-direction:column;gap:.75rem}.username-form input{padding:.7rem .9rem;border-radius:.5rem;border:1px solid var(--border-input);background:var(--bg-input);color:inherit}.username-form-actions{display:flex;gap:.5rem}.username-form button,.username-card .username-form-actions button{padding:.75rem;border-radius:.5rem;border:none;background:linear-gradient(135deg,var(--accent-primary),var(--accent-primary-end));color:#fff;font-weight:600;cursor:pointer;flex:1}.username-form button:disabled,.username-card .username-form-actions button:disabled{opacity:.5;cursor:not-allowed}.username-form-cancel,.username-card .username-form-actions .username-form-cancel{background:var(--bg-hover)!important;border:1px solid rgba(255,255,255,.2)!important}.user-menu-settings{display:flex;flex-direction:column;gap:.75rem}.user-menu-save-btn{width:100%;padding:.65rem;border-radius:.5rem;border:1px solid var(--hud-border);background:var(--bg-active);color:#fff6;font-weight:600;cursor:default;font-size:.9rem;font-family:inherit;transition:background .15s ease,color .15s ease,border-color .15s ease}.user-menu-save-btn--active{background:linear-gradient(135deg,var(--accent-primary),var(--accent-primary-end));border-color:transparent;color:#fff;cursor:pointer}.user-menu-save-btn--active:hover{filter:brightness(1.1)}.user-menu-save-btn:disabled{opacity:1}.user-menu-actions{display:flex;flex-direction:column;gap:0;border-top:1px solid var(--border-subtle);padding-top:.35rem}.user-menu-action-row{display:flex;align-items:center;gap:.6rem;width:100%;padding:.65rem .5rem;background:none;border:none;border-radius:.4rem;color:var(--text-secondary);font-size:.9rem;cursor:pointer;text-align:left;font-family:inherit;font-weight:400;transition:background .15s ease}.user-menu-action-row:hover{background:#ffffff12}.user-menu-action-row:active{background:var(--bg-hover)}.user-menu-action-row svg{width:16px;height:16px;opacity:.55;flex-shrink:0}.user-menu-action-row--danger{color:var(--accent-danger)}.user-menu-action-row--danger:hover{background:#ff505014}.user-menu-action-row--danger svg{opacity:.65}:root{font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background-color:var(--bg-primary);color:var(--text-primary)}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{width:100%;height:100%}body{overflow-y:auto;min-height:100%}html.game-root,body.game-root{overscroll-behavior:none;overscroll-behavior-y:none;overflow:hidden;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none;touch-action:manipulation;-webkit-tap-highlight-color:transparent}html.game-root input,html.game-root textarea,html.game-root [contenteditable=true],body.game-root input,body.game-root textarea,body.game-root [contenteditable=true]{-webkit-user-select:text;user-select:text}a{color:inherit;text-decoration:none}button{font:inherit;cursor:pointer}.app-shell{display:flex;flex-direction:column;height:100%;width:100%;padding:1rem;gap:1rem}.app-header{display:flex;align-items:center;justify-content:space-between;gap:1rem}.brand{display:flex;align-items:center;gap:.5rem}.brand h1{font-size:1.5rem}.brand a{color:inherit;text-decoration:none}.app-version{font-size:.8rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-dim);border:1px solid var(--border-default);border-radius:999px;padding:.1rem .5rem;background:var(--bg-secondary);display:inline-flex;align-items:center;gap:.2rem;transition:border-color .2s ease,color .2s ease}.app-version:hover,.app-version:focus-visible{border-color:#4d68ff;color:#bfcdf0}.header-right{display:flex;align-items:center;gap:.75rem;flex:1;justify-content:flex-end}.header-name{display:flex;align-items:center;gap:.4rem;padding:.4rem .75rem;border-radius:.35rem;border:1px solid var(--hud-border);background:var(--bg-subtle);color:inherit;font-size:.9rem;cursor:pointer;transition:background-color .2s ease,border-color .2s ease}.header-room-group{display:inline-flex;align-items:center;gap:.5rem;padding:.4rem .75rem;border-radius:.35rem;border:1px solid var(--hud-border);background:var(--bg-subtle)}.header-room-name{font-size:.9rem;opacity:.9;pointer-events:none}.header-name:hover{background:var(--bg-hover);border-color:var(--border-hover)}.header-name-text{font-weight:500}.header-name svg{opacity:.7;transition:opacity .2s ease}.header-name:hover svg{opacity:1}.mode-switcher{display:inline-flex;gap:.5rem}.mode-switcher button{padding:.4rem .9rem;border-radius:.5rem;border:1px solid #39404f;background:transparent;color:inherit;transition:background .2s ease}.mode-switcher button.active{background:#1d2331;border-color:#5b89ff}.header-links{display:inline-flex;gap:.4rem}@media(max-width:1200px){.header-links,.app-version{display:none}.app-header{align-items:center;padding-bottom:0}.brand h1{display:none}.progress-stepper{top:18px;left:20%;transform:none}}.icon-link{width:32px;height:32px;border-radius:.5rem;border:1px solid #283146;display:inline-flex;align-items:center;justify-content:center;background:#0c1424;transition:border-color .2s ease,background .2s ease}.icon-link:hover,.icon-link:focus-visible{border-color:#6a8bff;background:#131c32}.icon-link svg{width:18px;height:18px;fill:currentColor}.header-cta{display:flex;align-items:center;gap:.5rem}.header-user-label{font-size:.9rem;color:var(--text-muted);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:160px}.header-menu-wrapper{position:relative}.header-hamburger{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:.4rem;border:1px solid var(--hud-border);background:var(--bg-subtle);color:var(--text-secondary);cursor:pointer;transition:background .15s ease,border-color .15s ease}.header-hamburger:hover{background:var(--bg-hover);border-color:var(--border-hover)}.header-menu-dropdown{position:absolute;top:calc(100% + .5rem);right:0;min-width:180px;background:var(--bg-card-translucent);border:1px solid var(--hud-border);border-radius:.6rem;padding:.4rem 0;box-shadow:var(--shadow-large);z-index:100}.header-menu-item{display:flex;align-items:center;gap:.5rem;width:100%;padding:.6rem 1rem;border:none;background:none;color:var(--text-secondary);font-size:.88rem;font-family:inherit;cursor:pointer;text-align:left;transition:background .12s ease}.header-menu-item:hover{background:var(--bg-active)}.header-menu-item svg{width:16px;height:16px;opacity:.7}.header-menu-item-danger{color:var(--accent-danger)}.header-menu-item-danger:hover{background:#ff525214}.header-menu-divider{height:1px;background:var(--border-subtle);margin:.3rem 0}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}.app-main{flex:1;min-height:0;border:1px solid var(--border-panel);border-radius:1rem;overflow:hidden;position:relative;background:var(--bg-primary);display:flex}.app-main:has(.stats-page),.app-main:has(.admin-page){overflow-y:auto}.placeholder{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;color:var(--text-dim)}.pixi-stage{width:100%;height:100%}.stage-shell{position:relative;min-height:0;display:flex}.stage-shell .pixi-stage{flex:1}.start-sequence-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;pointer-events:none;z-index:5}.start-sequence-card{pointer-events:auto;background:var(--bg-card-translucent);border:1px solid var(--border-strong);box-shadow:0 10px 50px #00000073;border-radius:1rem;padding:1.5rem;color:var(--text-primary);max-width:460px;text-align:center;display:flex;flex-direction:column;gap:.75rem}.start-sequence-card h2{margin:0;font-size:1.2rem}.start-sequence-card p{margin:0;color:var(--text-secondary)}.start-sequence-card .host-debug{font-size:.75rem;opacity:.7;color:var(--text-muted)}.speed-heading-row{position:absolute;top:.75rem;left:.4rem;z-index:6;display:flex;flex-direction:row;align-items:flex-start;gap:.5rem;pointer-events:none}.speed-heading-stack{display:flex;flex-direction:column;gap:.5rem;pointer-events:none}.speed-heading-overlay{position:relative;display:flex;flex-direction:column;gap:.9rem;padding:.55rem .7rem;background:var(--hud-bg);border:1px solid var(--hud-border);border-radius:.6rem;pointer-events:none;align-items:flex-start}.protest-sticker{position:absolute;top:-.8rem;right:-1.8rem;font-size:2.5rem;line-height:1;transform:rotate(12deg);filter:drop-shadow(0 2px 5px rgba(0,0,0,.6));pointer-events:none}.wind-arrow-svg{transform-origin:50% 50%}.wind-section-grid{display:grid;grid-template-columns:1fr max-content;align-items:center;column-gap:.75rem}.wind-section-numbers{display:flex;flex-direction:column;gap:.2rem}.wind-section-arrow{width:4.1rem;height:4.1rem;display:flex;align-items:center;justify-content:center;margin-left:-.35rem}.bottom-left-overlays{position:fixed;left:.55rem;bottom:.5rem;z-index:20;display:inline-flex;align-items:center;gap:.6rem;font-family:IBM Plex Mono,SFMono-Regular,Menlo,monospace;font-size:.72rem;letter-spacing:.02em;color:#fffc;opacity:.65;-webkit-user-select:none;user-select:none;pointer-events:none;text-shadow:0 1px 2px rgba(0,0,0,.7)}.rtt-overlay,.perf-overlay{pointer-events:none;-webkit-user-select:none;user-select:none}.wind-intensity-legend{position:relative;z-index:6;pointer-events:none;background:transparent;border:none;border-radius:0;padding:0;box-shadow:none;color:#dfe7ff;font-family:IBM Plex Mono,SFMono-Regular,Menlo,monospace;font-size:.86rem;letter-spacing:.02em;text-shadow:0 1px 2px rgba(0,0,0,.65);min-width:10.5rem;width:100%}.wind-intensity-title{text-transform:uppercase;font-size:.78rem;letter-spacing:.08em;opacity:.7;margin-bottom:.25rem}.wind-intensity-track{height:1rem;border-radius:.35rem;background:linear-gradient(90deg,#b07aa1e6,#b07aa180,#1a4a6e4d,#19d3c580,#19d3c5e6);box-shadow:inset 0 0 0 1px #fff3}.wind-intensity-track-wrap{position:relative}.wind-intensity-track-labels{position:absolute;top:50%;transform:translateY(-50%);left:0;right:0;display:flex;justify-content:space-between;font-size:.68rem;line-height:1;opacity:.85;pointer-events:none;padding:0 .5rem}.wind-intensity-labels{display:none}.wind-intensity-note{font-size:.66rem;opacity:.65}@media(max-height:720px){.wind-intensity-legend{display:none}}.speed-heading-overlay .hud-section{display:flex;align-items:stretch;gap:.5rem}.speed-heading-overlay .hud-section-header{font-family:IBM Plex Mono,SFMono-Regular,Menlo,monospace;font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;opacity:.7}.speed-heading-overlay .hud-section-side-label{font-family:IBM Plex Mono,SFMono-Regular,Menlo,monospace;font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;opacity:.7;display:flex;align-items:center;justify-content:center;writing-mode:vertical-rl;transform:rotate(180deg);line-height:1;padding:0}.speed-heading-overlay .hud-section-body{display:flex;flex-direction:column;justify-content:center}.speed-heading-overlay .hud-grid{display:grid;grid-template-columns:repeat(2,max-content);column-gap:.85rem;row-gap:.2rem}.speed-heading-overlay .hud-metric--span2{grid-column:1 / -1}.camera-toggle{display:inline-flex;align-items:center;gap:.4rem;padding:.35rem .7rem;border-radius:.55rem;border:1px solid rgba(83,224,255,.35);background:#050a18d1;color:var(--accent-info);font-size:.78rem;font-weight:650;letter-spacing:.02em;cursor:pointer;transition:transform .15s ease,border-color .15s ease,background .15s ease}.camera-toggle-icon{display:inline-flex;align-items:center;justify-content:center;line-height:0;opacity:.9}.camera-toggle-text{display:inline-block}.camera-toggle:hover{border-color:#53e0ff99;background:#060c1ce6}.camera-toggle:active{transform:translateY(1px)}.speed-heading-overlay.wake-active{box-shadow:0 0 0 1px #ffcf704d}.speed-heading-overlay .hud-metric{display:inline-flex;align-items:baseline;gap:.4rem;font-family:IBM Plex Mono,SFMono-Regular,Menlo,monospace;font-size:.92rem;white-space:nowrap}.speed-heading-overlay .hud-label{font-size:.72rem;letter-spacing:.06em;text-transform:uppercase;opacity:.75}.speed-heading-overlay .hud-value{font-weight:650;font-variant-numeric:tabular-nums}.speed-heading-overlay .hud-metric-speed .hud-value{color:var(--accent-speed);display:inline-block;min-width:9ch;text-align:right}.speed-heading-overlay .hud-metric-heading .hud-value{color:var(--accent-heading);display:inline-block;min-width:5ch;text-align:right}.speed-heading-overlay .hud-metric-wind .hud-value{color:var(--accent-wind);display:inline-block;min-width:4ch;text-align:right}.speed-heading-overlay .hud-metric-windspd .hud-value{color:var(--text-primary);display:inline-block;min-width:8ch;text-align:right;position:relative;padding-right:2.9ch}.wind-speed-delta{position:absolute;right:-.6ch;top:-.25em;font-size:.62rem;opacity:1;font-weight:600;line-height:1}.wind-speed-delta.positive{color:var(--accent-speed)}.wind-speed-delta.negative{color:#7ea4ff}.speed-heading-overlay .hud-metric-winddir .hud-value{color:var(--text-primary);display:inline-block;min-width:5ch;text-align:right}.speed-heading-overlay .hud-metric-tack .hud-value{color:var(--accent-info)}.speed-heading-overlay .hud-metric-tack .hud-value.tack-stbd{color:var(--accent-speed)}.speed-heading-overlay .hud-metric-tack .hud-value.tack-port{color:var(--accent-danger)}.wake-overlay{padding:.55rem .7rem;background:var(--hud-bg);border:1px solid var(--hud-border);border-radius:.6rem;pointer-events:none;display:flex;align-items:center;justify-content:center;box-shadow:0 0 0 1px #ffcf704d}.wake-indicator{color:#ff8570;font-size:.78rem;letter-spacing:.02em;font-family:IBM Plex Mono,SFMono-Regular,Menlo,monospace;font-weight:650;font-variant-numeric:tabular-nums;white-space:nowrap}.hud-stack{position:absolute;top:.75rem;right:.75rem;display:flex;flex-direction:column;align-items:flex-end;gap:.5rem;pointer-events:none;z-index:4;max-height:70vh}.hud-top-row{display:flex;align-items:flex-start;justify-content:flex-end;gap:.5rem;pointer-events:none}.hud-camera-toggle{pointer-events:auto}.race-time-panel{pointer-events:none;background:var(--bg-card-translucent);border:1px solid var(--border-panel);border-radius:.75rem;padding:.45rem .65rem;display:flex;flex-direction:column;gap:.1rem;text-align:right;color:var(--text-primary);min-width:108px}.race-time-label{font-size:.65rem;text-transform:uppercase;letter-spacing:.08em;color:#e4edffb3}.race-time-value{font-family:IBM Plex Mono,SFMono-Regular,Menlo,monospace;font-size:.9rem;font-weight:600;font-variant-numeric:tabular-nums}.spin-overlay{position:absolute;top:5.5rem;left:1rem;pointer-events:auto;z-index:9}.collision-warning-banner{pointer-events:none;display:flex;align-items:center;gap:.4rem;padding:.35rem .75rem;border-radius:.4rem;border:1px solid rgba(255,170,0,.5);background:#322300d9;color:var(--accent-warning-text);font-size:.82rem;font-weight:600;animation:warning-pulse 1.2s ease-in-out infinite;max-width:22rem;text-align:center;justify-content:center}.collision-warning-icon{font-size:1rem;flex-shrink:0}@keyframes warning-pulse{0%,to{opacity:.85}50%{opacity:1}}.spin-under-hud{pointer-events:auto}.leaderboard-overlay,.events-overlay{pointer-events:auto;width:260px;background:var(--bg-card-translucent);border:1px solid var(--border-panel);border-radius:.75rem;padding:.75rem;box-shadow:var(--shadow-panel)}.leaderboard-overlay{max-height:33vh;overflow:auto}.events-overlay{max-height:calc(37vh - .5rem);overflow:auto}.events-overlay .event-list{max-height:none}.on-screen-controls{position:fixed;bottom:1rem;left:0;right:0;display:flex;justify-content:center;pointer-events:none;z-index:6}.on-screen-toggle{pointer-events:auto;padding:.35rem .9rem;border-radius:999px;border:1px solid rgba(255,255,255,.2);background:var(--hud-bg);color:var(--text-primary);font-size:.8rem;letter-spacing:.05em;text-transform:uppercase;font-weight:600;touch-action:manipulation;-webkit-tap-highlight-color:transparent}.on-screen-cluster{position:absolute;pointer-events:auto;padding:.4rem .5rem;background:var(--hud-bg);border:1px solid var(--border-subtle);border-radius:.7rem;box-shadow:0 10px 24px #00000059}.on-screen-cluster.left{left:.75rem;bottom:.5rem;display:grid;grid-template-columns:1fr;gap:.3rem}.on-screen-cluster.left.extras{left:.75rem;bottom:9rem}.on-screen-cluster.right.extras{right:.75rem;bottom:14rem}.on-screen-cluster.right{right:.75rem;bottom:.5rem;display:grid;grid-template-columns:1fr;gap:.3rem}.on-screen-button{padding:.35rem .4rem;border-radius:.6rem;border:1px solid var(--hud-border);background:#0f1424d9;color:#f3f7ff;display:flex;flex-direction:column;gap:.15rem;align-items:center;justify-content:center;font-size:.78rem;font-weight:600;min-width:112px;transition:transform .06s ease,box-shadow .12s ease,border-color .12s ease,background .12s ease,filter .12s ease;touch-action:manipulation;user-select:none;-webkit-user-select:none;-webkit-tap-highlight-color:transparent}.on-screen-button.wide{min-width:158px}.on-screen-button:active,.on-screen-button.pressed{transform:translateY(1px) scale(.985);filter:brightness(1.12);border-color:#ffffff47;box-shadow:0 10px 22px #00000059,0 0 0 2px #53e0ff14}.on-screen-button:focus-visible,.on-screen-toggle:focus-visible{outline:2px solid var(--accent-cyan);outline-offset:2px}.on-screen-button.active{border-color:#53e0ffa6;box-shadow:0 0 0 1px #53e0ff40,0 0 18px #53e0ff2e;background:#0f1c2ceb}.on-screen-label{font-size:.85rem}.on-screen-sublabel{font-size:.7rem;opacity:.65;text-transform:uppercase;letter-spacing:.08em}.live-client{width:100%;height:100%;display:flex;flex-direction:column;gap:.75rem;padding:1rem}.live-main{flex:1;min-height:0;display:grid;grid-template-columns:minmax(0,1fr);gap:.5rem}.hud-panel{background:var(--bg-card-translucent);border:1px solid var(--border-panel);border-radius:.75rem;padding:1rem;display:flex;flex-direction:column;gap:.75rem}.hud-panel h2{font-size:1rem;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted)}.speed-readout{font-family:IBM Plex Mono,SFMono-Regular,Menlo,monospace;font-size:1rem;color:var(--accent-speed)}.heading-readout{font-family:IBM Plex Mono,SFMono-Regular,Menlo,monospace;font-size:.95rem;color:var(--accent-heading)}.player-actions{display:flex;align-items:center;gap:.5rem}.spin-button{padding:.75rem 1.1rem;border-radius:.6rem;border:1px solid #b974ff;background:linear-gradient(135deg,#471e6de6,#301257f2);color:#f8ecff;font-size:1rem;font-weight:600;display:inline-flex;flex-direction:column;align-items:center;gap:.25rem;max-width:22rem;text-align:center;transition:opacity .2s ease,transform .2s ease}.spin-button-title{font-size:1.05rem;font-weight:700}.spin-button-subtitle{font-size:.82rem;font-weight:500;color:#f8ecffcc;line-height:1.45}.kbd{display:inline-block;padding:.1em .45em;margin:0 .15em;font-family:inherit;font-size:.85em;font-weight:700;line-height:1.3;color:#f0e6ff;background:#ffffff1f;border:1px solid rgba(255,255,255,.25);border-radius:.3em;box-shadow:0 1px #0000004d,inset 0 1px #ffffff14;vertical-align:baseline;white-space:nowrap}.spin-button:active:not(:disabled){transform:translateY(1px)}.spin-button:disabled{opacity:.4;cursor:not-allowed;border-color:var(--border-strong);background:#121828cc;color:var(--text-faint)}.countdown-status{font-size:.9rem;color:var(--accent-warning)}.start-sequence{padding:.6rem .9rem;border-radius:.5rem;border:none;background:var(--accent-warning);color:var(--bg-primary);font-weight:600;cursor:pointer}.event-list{flex:1;overflow-y:auto;max-height:600px;display:flex;flex-direction:column;gap:.6rem;padding-right:.2rem}.event-item{padding:.5rem;border-radius:.5rem;border:1px solid #2b3146;background:#ffffff05;display:flex;flex-direction:column;gap:.25rem}.event-item.clickable{cursor:pointer;border-color:#f5a5248c;background:#f5a5240f}.event-item.clickable:hover{border-color:#f5a524bf;background:#f5a5241a}.event-item.clickable:active{transform:translateY(1px)}.event-kind{font-size:.75rem;text-transform:uppercase;color:#fad643}.event-message{font-size:.9rem;color:#d9deff}.roster-panel{border-top:1px solid var(--border-default);padding-top:.5rem}.roster-panel h3{font-size:.85rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin:0}.roster-panel>summary.roster-summary{list-style:none;cursor:pointer;display:flex;align-items:baseline;justify-content:space-between;gap:.5rem;-webkit-user-select:none;user-select:none}.roster-panel>summary.roster-summary::-webkit-details-marker{display:none}.roster-title{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.roster-summary-role{font-size:.8rem;letter-spacing:normal;text-transform:none;color:var(--text-muted);white-space:nowrap}.roster-body{margin-top:.4rem}.roster-panel ul{list-style:none;margin-top:.4rem;display:flex;flex-direction:column;gap:.25rem}.roster-entry{display:flex;align-items:center;gap:.35rem;font-size:.85rem;color:var(--text-primary)}.roster-entry .badge{padding:.1rem .35rem;border-radius:.4rem;background:var(--accent-primary);font-size:.7rem;text-transform:uppercase}.roster-entry.offline{opacity:.5}.roster-entry .role{margin-left:auto;font-size:.75rem;text-transform:capitalize;color:var(--text-muted)}.roster-empty{font-size:.85rem;color:var(--text-dim)}.chat-panel{position:absolute;left:.5rem;top:55vh;transform:translateY(calc(-1 * var(--touch-controls-chat-shift, 0rem)));transition:transform .2s ease;width:240px;max-height:25vh;height:25vh;display:flex;flex-direction:column;gap:.25rem;pointer-events:none;z-index:3}@media(orientation:landscape)and (max-width:1200px){.chat-panel{top:auto;bottom:calc(.75rem + var(--touch-controls-chat-shift, 0rem));transform:none;height:16vh;max-height:16vh}.chat-panel .chat-log{padding:.35rem}.chat-panel .chat-message{padding:.18rem .28rem;font-size:.74rem;line-height:1.2}.chat-panel .chat-input{padding:.2rem}.chat-panel .chat-input input{padding:.25rem .4rem;font-size:.75rem}.chat-panel .chat-input button{padding:.25rem .5rem;font-size:.7rem}}.chat-panel .chat-header{display:none}.chat-panel .chat-log{pointer-events:auto;display:flex;flex-direction:column;flex:1;justify-content:flex-end;gap:.2rem;overflow-y:auto;padding:.5rem;background:transparent;border-radius:0;-webkit-backdrop-filter:none;backdrop-filter:none;max-height:none}.chat-panel .chat-input{pointer-events:auto;display:flex;gap:.25rem;padding:.25rem;background:transparent;border-radius:0;-webkit-backdrop-filter:none;backdrop-filter:none}.chat-panel .chat-input input{flex:1;padding:.3rem .5rem;font-size:.8rem;border:1px solid var(--border-subtle);background:var(--bg-subtle);border-radius:.3rem;color:inherit}.chat-panel .chat-input button{padding:.3rem .6rem;font-size:.75rem;border:1px solid var(--hud-border);background:#4f7dff4d;border-radius:.3rem;color:inherit;cursor:pointer}.chat-panel .chat-message{padding:.25rem .4rem;border-radius:0;background:transparent;font-size:.8rem;line-height:1.3;display:flex;gap:.25rem;align-items:baseline;flex-wrap:nowrap;text-shadow:0 1px 2px rgba(0,0,0,.45)}.chat-panel .chat-author{font-weight:600;opacity:.9;white-space:nowrap}.chat-panel .chat-text{opacity:.85;flex:1;min-width:0}.chat-panel .chat-empty{display:none}.chat-panel .chat-mine .chat-author{color:var(--text-muted)}.chat-panel .chat-other .chat-author{color:var(--accent-heading)}.chat-panel .chat-status{font-size:.7rem;opacity:.7;padding:.2rem .4rem;min-height:1.2em;margin:0;color:var(--accent-danger)}.leaderboard-panel{padding-top:.25rem;display:flex;flex-direction:column;gap:.4rem}.leaderboard-panel h3{font-size:.85rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted)}.leaderboard-panel ol{list-style:none;display:flex;flex-direction:column;gap:.35rem;padding:0;margin:0}.leaderboard-panel li{display:grid;grid-template-columns:1.6rem 1fr max-content;align-items:center;column-gap:.25rem;font-size:.85rem;padding:.3rem 0;border-bottom:1px dashed rgba(255,255,255,.1)}.leaderboard-panel li:last-child{border-bottom:none}.leaderboard-position{width:1.6rem;color:var(--text-muted)}.leaderboard-name{font-weight:600;display:flex;align-items:center;justify-content:flex-start;gap:.2rem;flex:1;min-width:0;text-align:left}.leaderboard-badges{display:inline-flex;align-items:center;gap:.1rem;width:2.2em;flex:0 0 auto}.leaderboard-badge{width:1.3em;display:inline-flex;align-items:center;justify-content:center;line-height:1}.leaderboard-name-text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.leaderboard-meta{font-size:.8rem;color:var(--text-muted);flex:0 0 auto;display:flex;flex-direction:column;align-items:flex-end;gap:.05rem;line-height:1.05}.leaderboard-meta-top{white-space:nowrap}.leaderboard-meta-bottom{white-space:nowrap;font-size:.75rem;opacity:.9}.progress-stepper{position:fixed;top:18px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:.3rem;padding:.3rem .6rem;background:#00000073;border:1px solid rgba(255,255,255,.1);border-radius:999px;z-index:20;font-size:.65rem}@media(max-width:1200px){.progress-stepper{left:5%;right:auto;transform:none}}.progress-step{display:flex;align-items:center;gap:.2rem}.progress-bullet{width:16px;height:16px;border-radius:50%;border:1.5px solid rgba(255,255,255,.35);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.6rem}.progress-connector{width:12px;height:1.5px;background:#fff3}.progress-label{font-weight:600}.status-done .progress-bullet{border-color:var(--accent-success);color:var(--accent-success)}.status-active .progress-bullet{border-color:#ffe29f;color:#ffe29f}.status-pending .progress-bullet{border-color:#ffffff4d;color:#ffffff4d}.status-done .progress-label{color:var(--accent-success)}.status-active .progress-label{color:#ffe29f}.status-pending .progress-label{color:#ffffff73}.mark-checklist{margin-top:1rem;padding:.75rem;border:1px solid var(--border-subtle);border-radius:8px;background:#00000040}.mark-checklist h3{margin:0 0 .5rem;font-size:.85rem;text-transform:uppercase;letter-spacing:.08em;color:#9adff9}.mark-checklist ol{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.35rem}.checklist-item{display:flex;justify-content:space-between;align-items:center;font-size:.85rem;padding:.25rem 0;border-bottom:1px solid rgba(255,255,255,.05)}.checklist-item:last-child{border-bottom:none}.marker-label{flex:1;margin-right:.5rem}.marker-status{font-size:.7rem;text-transform:uppercase;letter-spacing:.1em}.status-done .marker-label,.status-done .marker-status{color:var(--accent-success)}.status-active .marker-label,.status-active .marker-status{color:#ffe29f}.status-pending .marker-label,.status-pending .marker-status{color:#ffffff73}.chat-header{display:flex;align-items:center;justify-content:space-between;font-size:.9rem;text-transform:uppercase;letter-spacing:.08em}.chat-header span{font-size:.75rem;color:var(--text-muted)}.chat-log{max-height:220px;overflow-y:auto;display:flex;flex-direction:column;gap:.4rem}.chat-message{display:flex;flex-direction:column;gap:.2rem;padding:.4rem .5rem;border-radius:.4rem;background:#ffffff05}.chat-panel .chat-message{flex-direction:row;flex-wrap:nowrap;align-items:baseline;gap:.25rem}.chat-author{font-size:.75rem;color:#94f2ff}.chat-text{font-size:.85rem}.chat-host,.chat-player,.chat-spectator{border:none}.chat-input{display:flex;gap:.5rem}.chat-input input{flex:1;padding:.4rem .6rem;border-radius:.4rem;border:1px solid #2b3146;background:transparent;color:#fff}.chat-input button{padding:.4rem .8rem;border-radius:.4rem;border:1px solid #5174b3;background:#1c2d4f;color:#fff}.chat-status{font-size:.75rem;color:var(--accent-danger)}.chat-empty{color:var(--text-faint)}.tactician-popout{position:fixed;left:1rem;right:auto;top:50%;transform:translateY(-50%);display:flex;flex-direction:column;gap:.5rem;z-index:10}.tactician-popout.nudge .tactician-toggle{animation:help-pulse 1.15s ease-in-out infinite}.tactician-nudge{align-self:flex-start;max-width:220px;padding:.35rem .6rem;border-radius:999px;border:1px solid rgba(255,255,255,.14);background:var(--hud-bg);color:#ffffffe0;font-size:.78rem;letter-spacing:.02em;box-shadow:0 10px 26px #00000073;pointer-events:none}.tactician-nudge .keyboard-icon{display:inline-flex;align-items:center;justify-content:center;line-height:0;margin-right:4px;vertical-align:middle;opacity:.9}@keyframes help-pulse{0%{box-shadow:0 12px 34px #00000073,0 0 #53e0ff59;transform:translateY(0)}60%{box-shadow:0 12px 34px #00000073,0 0 0 10px #53e0ff00;transform:translateY(-1px)}to{box-shadow:0 12px 34px #00000073,0 0 #53e0ff00;transform:translateY(0)}}.tactician-toggle{display:inline-flex;align-items:center;gap:.45rem;padding:.6rem 1rem;border-radius:999px;border:1px solid var(--border-input);background:var(--bg-card-translucent);color:inherit;font-weight:650;font-size:.95rem;letter-spacing:.02em;box-shadow:0 12px 34px #00000073;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.tactician-toggle-icon{display:inline-flex;align-items:center;justify-content:center;line-height:0;opacity:.95}.tactician-toggle-text{display:inline-block}.tactician-toggle:hover{border-color:#ffffff38;background:#121a30eb}.tactician-toggle:active{transform:translateY(1px)}.tactician-toggle:focus-visible{outline:2px solid var(--accent-cyan);outline-offset:2px}.tactician-card{width:220px;background:#05070ff2;border:1px solid #2a3148;border-radius:.6rem;padding:.75rem;font-size:.85rem;line-height:1.4}.tactician-card h4{margin-bottom:.5rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em}.tactician-card ul{list-style:none;display:flex;flex-direction:column;gap:.35rem}.keyboard-help-overlay{position:fixed;inset:0;background:#05070fd1;display:flex;align-items:center;justify-content:center;padding:1rem;z-index:30}.keyboard-help-card{position:relative;width:min(980px,calc(100vw - 2rem));max-height:calc(100vh - 2rem);background:var(--bg-card-translucent);border:1px solid var(--hud-border);border-radius:1rem;box-shadow:0 18px 60px #0000008c;display:flex;flex-direction:column;overflow:hidden}.keyboard-help-header{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.85rem .95rem;border-bottom:1px solid rgba(255,255,255,.1);background:#060a168c}.keyboard-help-title{font-weight:750;letter-spacing:.04em;text-transform:uppercase;font-size:.85rem;color:var(--text-muted)}.keyboard-help-tabs{display:inline-flex;gap:.4rem;align-items:center;justify-content:center;flex:1}.keyboard-help-tab{padding:.45rem .8rem;border-radius:999px;border:1px solid rgba(255,255,255,.14);background:var(--bg-active);color:#f0f5ffeb;font-size:.85rem;font-weight:650;display:inline-flex;align-items:center;gap:.4rem}.keyboard-help-tab-icon{display:inline-flex;align-items:center;justify-content:center;line-height:0;opacity:.9}.keyboard-help-tab.active{border-color:#53e0ff8c;box-shadow:0 0 0 2px #53e0ff1f;background:#0f1c2ceb}.keyboard-help-tab:focus-visible{outline:2px solid var(--accent-cyan);outline-offset:2px}.keyboard-help-body{padding:1rem;overflow:auto}.keyboard-help-lead{margin-bottom:.75rem;color:#cdd5f3eb;line-height:1.35}.keyboard-help-callout{margin:0 0 .85rem;padding:.55rem .7rem;border-radius:.65rem;border:1px solid rgba(83,224,255,.24);background:#0b1626b3;color:#e1ecfff5;font-size:.8rem;font-weight:600;letter-spacing:.02em}.keyboard-help-callout-header{margin-bottom:.5rem}.keyboard-help-callout-scale{display:flex;flex-direction:column;gap:.35rem}.keyboard-help-callout-track{height:.72rem;width:100%;border-radius:.36rem;background:linear-gradient(90deg,#2a3b4ee6,#2a3b4e8c,#021428,#4dff8a33,#4dff8a80);box-shadow:inset 0 0 0 1px #fff3}.keyboard-help-callout-track-wrap{position:relative}.keyboard-help-callout-track-labels{position:absolute;top:50%;transform:translateY(-50%);left:0;right:0;display:flex;justify-content:space-between;font-size:.6rem;line-height:1;opacity:.8;pointer-events:none;padding:0 .4rem}.keyboard-help-callout-labels{display:flex;justify-content:space-between;width:100%;font-size:.66rem;font-weight:600;opacity:.85}.keyboard-help-layout{display:flex;justify-content:center}.keyboard-help-image{width:100%;height:auto;max-width:920px;max-height:65vh;object-fit:contain;border-radius:.75rem;box-shadow:0 18px 50px #00000080}.keyboard-help-close{flex:0 0 auto;width:36px;height:36px;border-radius:.65rem;border:1px solid rgba(255,255,255,.16);background:var(--bg-active);color:var(--text-primary);display:inline-flex;align-items:center;justify-content:center;line-height:0;font-size:.95rem;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.keyboard-help-tips{margin:0;padding-left:1.2rem;display:flex;flex-direction:column;gap:.45rem;color:#ebf0ffeb;line-height:1.35}.keyboard-help-close:hover{border-color:var(--border-hover);background:var(--bg-hover)}.keyboard-help-close:active{transform:translateY(1px)}.keyboard-help-close:focus-visible{outline:2px solid var(--accent-cyan);outline-offset:2px}kbd{background:var(--border-subtle);border:1px solid var(--hud-border);border-radius:.3rem;padding:.1rem .35rem;font-size:.75rem;letter-spacing:.04em;color:#c6d4ff}.replay-save{display:flex;align-items:center;gap:.5rem;font-size:.8rem}.header-cta .replay-save{font-size:.85rem;gap:.35rem}.replay-save button{padding:.4rem .8rem;border-radius:.4rem;border:1px solid #49beaa;background:#12352b;color:#8ef5cd}.header-controls{display:flex;align-items:center;gap:.5rem}.header-cta .replay-save button{padding:.35rem .75rem;border-radius:999px;border-color:#6dd6ff;background:#0f2a3c;color:#b5f1ff;font-weight:600}.replay-save span{color:#8ef5cd}.debug-toggle{position:fixed;bottom:1rem;right:14rem;padding:.4rem .8rem;border-radius:.4rem;border:1px solid #3a4663;background:#11182a;color:#dfe7ff;cursor:pointer;z-index:100;font-size:.85rem}.debug-dock{position:relative;border:1px solid var(--border-default);border-radius:.8rem;background:#04060cfa;padding:.75rem;max-height:35%;overflow:auto;z-index:5}.debug-panel{display:flex;flex-direction:column;gap:.6rem;font-size:.8rem;position:relative}.debug-close{position:absolute;top:.4rem;right:.4rem;width:1.5rem;height:1.5rem;border-radius:999px;border:1px solid #3a4663;background:transparent;color:var(--text-dim);font-size:1rem;line-height:1rem;display:flex;align-items:center;justify-content:center}.debug-row{display:flex;gap:.4rem;align-items:baseline}.debug-table{border-top:1px solid var(--border-panel);padding-top:.5rem;display:flex;flex-direction:column;gap:.3rem}.debug-table-header,.debug-table-row{display:grid;grid-template-columns:1.2fr repeat(7,.9fr);gap:.3rem}.debug-table-header{text-transform:uppercase;font-size:.7rem;letter-spacing:.08em;color:var(--text-muted)}.debug-table-row{font-family:IBM Plex Mono,SFMono-Regular,Menlo,monospace;font-size:.72rem;padding:.2rem 0}.debug-table-row.self{background:#5b89ff14;border-radius:.3rem;padding:.3rem}.replay-client{display:grid;grid-template-columns:260px 1fr;grid-template-rows:1fr;height:100%;width:100%;gap:1rem;padding:1rem}.replay-sidebar{border:1px solid var(--border-panel);border-radius:.75rem;padding:1rem;display:flex;flex-direction:column;gap:.5rem;min-height:0;background:var(--bg-card-translucent)}.replay-sidebar h2{font-size:1rem;text-transform:uppercase;letter-spacing:.1em}.replay-list{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:.4rem}.replay-list-item{display:flex;align-items:stretch;border-radius:.5rem;border:1px solid var(--border-panel);overflow:hidden;flex-shrink:0}.replay-list-item.active{border-color:var(--accent-primary);background:#5b89ff1a}.replay-list-select{flex:1;text-align:left;padding:.5rem;background:transparent;color:inherit;border:none;cursor:pointer;min-width:0}.replay-share-btn{display:flex;align-items:center;justify-content:center;width:2rem;border:none;border-left:1px solid var(--border-panel);background:transparent;color:var(--text-secondary);cursor:pointer;font-size:.75rem;flex-shrink:0;transition:background .15s ease}.replay-share-btn:hover{background:#5b89ff26}.replay-stage{border:1px solid var(--border-panel);border-radius:.75rem;overflow:hidden;position:relative;display:flex;flex-direction:column;min-height:0;background:var(--bg-primary)}.replay-stage .pixi-stage{flex:1;min-height:0}.replay-controls{padding:.75rem;border-top:1px solid var(--border-panel);background:var(--bg-overlay);display:flex;flex-direction:column;gap:.75rem;flex-shrink:0}.playback-controls{display:flex;align-items:center;gap:.6rem}.playback-btn{background:#4f7dff26;border:1px solid rgba(79,125,255,.3);color:var(--text-secondary);padding:.4rem .75rem;border-radius:6px;font-size:.8rem;cursor:pointer;white-space:nowrap;transition:background .15s ease,border-color .15s ease}.playback-btn:hover:not(:disabled){background:#4f7dff40;border-color:#4f7dff80}.playback-btn:disabled{opacity:.35;cursor:default}.playback-scrubber{flex:1;min-width:80px;accent-color:#5b89ff}.playback-time{font-size:.8rem;color:#8a9cc0;font-variant-numeric:tabular-nums;white-space:nowrap}.replay-hint{font-size:.75rem;color:#667;text-align:center;padding-top:.25rem}.landing-shell{min-height:100vh;padding:clamp(2rem,4vw,4rem);background:var(--landing-bg);overflow-y:auto;color:var(--text-primary);display:flex;flex-direction:column;align-items:center;gap:3rem}.landing-hero{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center}@media(max-width:900px){.landing-hero{grid-template-columns:1fr;gap:2rem}}.landing-hero h1{font-size:clamp(2.5rem,6vw,4.5rem);margin:0}.landing-hero .lead,.landing-hero-copy .lead{font-size:1.2rem;line-height:1.6;color:var(--text-secondary)}.landing-hero-copy{display:flex;flex-direction:column;gap:1.2rem}.landing-social-top{display:flex;gap:.75rem;align-items:center;margin-bottom:.5rem}.landing-hero-video{display:flex;justify-content:center;align-items:center;width:100%;min-width:0}.landing-section{width:100%;display:flex;flex-direction:column;gap:.9rem}.landing-video{width:100%;display:flex;flex-direction:column;gap:.75rem}.video-frame{position:relative;width:100%;padding-top:56.25%;border-radius:1rem;overflow:hidden;box-shadow:0 18px 40px #00000073}.video-frame iframe{position:absolute;top:0;left:0;width:100%;height:100%;border:0}.video-caption{font-size:.9rem;color:var(--text-muted)}.value-list{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:.6rem}.value-list li{padding:.75rem 1rem;border:1px solid var(--hud-border);border-radius:.9rem;background:var(--bg-card-translucent);font-weight:600;color:var(--text-primary)}.landing-section h2{font-size:1.4rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em}.landing-actions{display:flex;flex-wrap:wrap;gap:.85rem;align-items:center}.landing-actions .cta,.landing-actions .secondary{padding:.85rem 1.5rem;border-radius:999px;font-weight:600;letter-spacing:.02em}.landing-actions .cta{background:var(--landing-cta-bg);color:var(--landing-cta-color)}.landing-actions .secondary{border:1px solid var(--border-default);color:var(--text-muted)}.eyebrow{text-transform:uppercase;letter-spacing:.2em;font-size:.75rem;color:var(--text-muted)}.testimonials{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem}.testimonial{border:1px solid var(--border-subtle);border-radius:.9rem;padding:1rem;background:var(--bg-card-translucent)}.testimonial blockquote{font-size:1rem;line-height:1.5;color:var(--text-primary)}.testimonial figcaption{margin-top:.6rem;font-size:.85rem;color:var(--text-muted)}.landing-footer{border-top:1px solid var(--border-subtle);padding-top:1rem;color:var(--text-dim)}.landing-footer .note{font-size:.9rem;color:var(--text-dim)}.social-link{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:.5rem;border:1px solid var(--hud-border);background:var(--bg-subtle);color:var(--text-muted);transition:all .2s ease}.social-link:hover,.social-link:focus-visible{border-color:#ffffff4d;background:var(--bg-hover);color:var(--text-primary);transform:translateY(-1px)}.social-link svg{width:18px;height:18px;fill:currentColor;stroke:none}.social-link svg[aria-hidden] path[stroke]{fill:none;stroke:currentColor}.replay-chat-log{max-height:180px;overflow-y:auto;display:flex;flex-direction:column;gap:.4rem}.replay-status{position:absolute;bottom:1rem;right:1rem;padding:.5rem .75rem;border-radius:.5rem;background:#0009}@media(max-width:900px){.live-main{grid-template-columns:1fr;grid-template-rows:auto auto}.on-screen-controls{bottom:.5rem}.on-screen-cluster{bottom:3.5rem;width:auto;max-width:calc(50% - 1.4rem)}.on-screen-button{min-width:104px}.on-screen-button.wide{min-width:140px}.on-screen-cluster.left{left:.4rem}.on-screen-cluster.right{right:.4rem}.on-screen-cluster.right.extras{right:.4rem;bottom:14rem}.on-screen-cluster.left.extras{bottom:8rem}}.results-overlay{z-index:10;background:#02040cbf}.results-card{max-width:540px;max-height:80vh;overflow-y:auto}.results-subtitle{font-size:.85rem;opacity:.7}.results-list{list-style:none;padding:0;margin:.5rem 0;display:flex;flex-direction:column;gap:.35rem;text-align:left;width:100%}.results-list li{display:flex;align-items:center;gap:.4rem;padding:.35rem .6rem;border-radius:.4rem;background:#ffffff0a;font-size:.9rem}.results-list li.results-dnf{opacity:.55}.results-pos{width:1.6em;text-align:right;font-weight:600;color:var(--text-muted);flex-shrink:0}.results-medal{width:1.4em;text-align:center;flex-shrink:0}.results-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.results-time{font-variant-numeric:tabular-nums;color:var(--text-secondary);flex-shrink:0}.results-split{font-size:.8rem;color:var(--text-dim);width:5.5em;text-align:right;flex-shrink:0}.results-points{font-size:.8rem;color:var(--text-muted);width:3.5em;text-align:right;flex-shrink:0}.results-waiting{margin-top:.5rem;font-size:.85rem;opacity:.6}.results-position-editable{cursor:pointer;border-bottom:1px dashed rgba(159,183,255,.4);transition:border-color .15s ease}.results-position-editable:hover{border-color:#9fb7ffcc;color:#c4d4ff}.results-position-input{width:2.4em;text-align:center;padding:.15rem .2rem;border-radius:.3rem;border:1px solid rgba(83,224,255,.5);background:#0f1c2ce6;color:#e4edff;font:inherit;font-weight:600;font-size:.9rem;flex-shrink:0;-moz-appearance:textfield}.results-position-input::-webkit-inner-spin-button,.results-position-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.results-options{margin-top:.75rem;display:flex;flex-direction:column;gap:.6rem;text-align:left;font-size:.85rem}.results-option-row{display:flex;align-items:center;gap:.5rem;color:var(--text-secondary)}.results-option-row input[type=checkbox],.results-option-row input[type=radio]{accent-color:#4f7dff}.results-option-label{color:var(--text-dim);font-size:.8rem;margin-right:.25rem}.results-fleet-hint{font-size:.75rem;color:var(--text-dim);margin-left:.4rem}.results-not-scored-badge{margin:0;padding:.3rem .6rem;border-radius:.3rem;background:#ff8a8a1f;border:1px solid rgba(255,138,138,.25);color:var(--accent-danger);font-size:.8rem;text-align:center}.finish-prompt{position:absolute;top:50px;left:50%;transform:translate(-50%);z-index:8;background:var(--bg-card-translucent);border:1px solid #3a5;border-radius:.6rem;padding:.5rem 1rem;color:var(--text-secondary);font-size:.85rem;display:flex;align-items:center;gap:.5rem;pointer-events:auto}.stats-page{display:flex;justify-content:center;padding:2rem 1rem;min-height:100%;background:var(--bg-primary);color:var(--text-primary)}.stats-card{background:var(--bg-card-translucent);border:1px solid var(--border-strong);border-radius:1rem;padding:2rem;max-width:960px;width:100%}.stats-card h2{margin:0 0 .25rem;font-size:1.4rem}.stats-card h3{margin:1.5rem 0 .5rem;font-size:1rem;color:var(--text-muted)}.stats-subtitle{color:var(--text-dim);font-size:.85rem;margin:0 0 1rem}.stats-loading,.stats-empty{color:var(--text-dim);text-align:center;padding:2rem 0}.stats-error{color:var(--accent-danger);text-align:center;padding:1rem 0}.stats-table{width:100%;border-collapse:collapse;font-size:.9rem}.stats-table th{text-align:left;padding:.4rem .6rem;border-bottom:1px solid var(--border-strong);color:var(--text-dim);font-weight:500;font-size:.8rem;text-transform:uppercase;letter-spacing:.04em}.stats-table td{padding:.5rem .6rem;border-bottom:1px solid rgba(47,54,80,.4)}.stats-table tbody tr:hover{background:#ffffff08}.stats-row-me{background:#648cff14}.stats-row-dnf{opacity:.55}.stats-you-badge{display:inline-block;font-size:.65rem;text-transform:uppercase;letter-spacing:.06em;background:#648cff33;color:var(--text-muted);padding:.1rem .4rem;border-radius:.25rem;margin-left:.4rem;vertical-align:middle}.stats-table a{color:var(--text-muted);text-decoration:none}.stats-table a:hover{text-decoration:underline}.stats-nav{margin-top:1.5rem;display:flex;gap:.5rem;justify-content:center}.stats-nav a{display:inline-flex;align-items:center;gap:.4rem;padding:.5rem 1rem;border-radius:8px;border:1px solid var(--hud-border);background:var(--bg-subtle);color:#c0d0ff;text-decoration:none;font-size:.9rem;font-weight:500;transition:background .15s,border-color .15s}.stats-nav a:hover{background:var(--bg-hover);border-color:#ffffff4d;color:#e0e8ff;text-decoration:none}.profile-summary{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;margin:1rem 0}.profile-stat{display:flex;flex-direction:column;align-items:center;gap:.2rem;padding:.75rem 1rem;background:#ffffff0a;border-radius:.5rem;min-width:80px}.profile-stat-value{font-size:1.4rem;font-weight:600;color:var(--text-primary);font-variant-numeric:tabular-nums}.profile-stat-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.06em;color:var(--text-dim)}.stats-toast{position:fixed;bottom:3rem;left:50%;transform:translate(-50%);padding:.5rem 1.25rem;border-radius:999px;font-size:.85rem;font-weight:500;color:var(--text-primary);background:#141a28e0;border:1px solid var(--hud-border);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:10000;pointer-events:none;animation:stats-toast-in .25s ease-out,stats-toast-out .4s ease-in 3.5s forwards}.stats-toast--success{border-color:#48c78e80}.stats-toast--error{border-color:#ff646499;color:#ffa0a0}@keyframes stats-toast-in{0%{opacity:0;transform:translate(-50%) translateY(.5rem)}to{opacity:1;transform:translate(-50%) translateY(0)}}@keyframes stats-toast-out{0%{opacity:1}to{opacity:0}}.lobby-layout{padding:2.5rem 2rem 3rem;max-width:980px;margin:0 auto}.lobby-sidebar{margin-top:2rem}.lobby-quick-nav{display:flex;gap:.5rem;margin-bottom:1.5rem}.lobby-quick-nav-link{flex:1;display:flex;align-items:center;justify-content:center;gap:.45rem;padding:.6rem .75rem;border-radius:8px;border:1px solid var(--hud-border);background:var(--bg-subtle);color:var(--text-secondary);font-size:.88rem;font-weight:500;text-decoration:none;transition:background .15s,border-color .15s}.lobby-quick-nav-link:hover{background:var(--bg-hover);border-color:var(--border-hover);color:var(--text-primary);text-decoration:none}.lobby-sidebar .stats-table{width:100%}@media(min-width:1200px){.lobby-layout{display:grid;grid-template-columns:420px minmax(0,720px);gap:3rem;max-width:100%;padding-left:2.5rem;padding-right:2.5rem;align-items:start}.lobby-sidebar{margin-top:0;position:sticky;top:2rem;order:-1}.lobby-main{max-width:720px;min-width:0;width:100%}}.header-menu-theme{padding:.4rem .75rem}.theme-toggle{display:flex;gap:.25rem;border-radius:.4rem;padding:.15rem;background:var(--bg-subtle);border:1px solid var(--border-subtle)}.theme-toggle-option{flex:1;display:flex;align-items:center;justify-content:center;gap:.3rem;padding:.35rem .5rem;border-radius:.3rem;border:1px solid transparent;background:none;color:var(--text-dim);font-size:.78rem;font-family:inherit;font-weight:500;cursor:pointer;transition:background .12s ease,color .12s ease,border-color .12s ease}.theme-toggle-option:hover{color:var(--text-secondary);background:var(--bg-hover)}.theme-toggle-option.active{background:var(--bg-card);color:var(--text-primary);border-color:var(--border-default);box-shadow:0 1px 3px #0000001f}.theme-toggle-option svg{width:14px;height:14px;flex-shrink:0}.regatta-tabs{display:flex;gap:0;border-bottom:1px solid var(--border-default);margin-bottom:1rem}.regatta-tab{padding:.5rem 1.25rem;background:none;border:none;border-bottom:2px solid transparent;color:var(--text-secondary);cursor:pointer;font-size:.9rem;font-weight:500;transition:color .15s,border-color .15s}.regatta-tab:hover{color:var(--text-primary)}.regatta-tab.active{color:var(--text-primary);border-bottom-color:var(--accent-primary, #4a9eff)}.regatta-card-wrapper{border:1px solid var(--border-default);border-radius:12px;overflow:hidden}.regatta-card-header{padding:1rem 1.25rem;background:var(--bg-card);cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:1rem;transition:background .15s}.regatta-card-header:hover{background:var(--bg-hover, rgba(255, 255, 255, .06))}.regatta-card-body{padding:1rem 1.25rem;border-top:1px solid var(--border-default);background:var(--bg-surface, rgba(255, 255, 255, .02))}.regatta-status-badge{display:inline-block;margin-left:.5rem;padding:.1rem .45rem;border-radius:4px;font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em}.regatta-status-completed{background:#4caf5026;color:#66bb6a}.regatta-status-cancelled{background:#f4433626;color:#ef5350}.btn-primary{padding:.5rem 1rem;border:none;border-radius:6px;background:var(--accent-primary, #4a9eff);color:#fff;font-weight:600;font-size:.85rem;cursor:pointer;transition:opacity .15s}.btn-primary:hover:not(:disabled){opacity:.85}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{padding:.5rem 1rem;border:1px solid var(--border-default);border-radius:6px;background:transparent;color:var(--text-primary);font-weight:500;font-size:.85rem;cursor:pointer;transition:background .15s}.btn-secondary:hover:not(:disabled){background:var(--bg-hover, rgba(255, 255, 255, .06))}.btn-danger{padding:.5rem 1rem;border:1px solid rgba(244,67,54,.4);border-radius:6px;background:transparent;color:#ef5350;font-weight:500;font-size:.85rem;cursor:pointer;transition:background .15s}.btn-danger:hover:not(:disabled){background:#f443361a}.modal-backdrop{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-card{background:var(--bg-card);border:1px solid var(--border-default);border-radius:12px;padding:1.5rem;max-width:500px;width:90%;max-height:90vh;overflow-y:auto}.modal-card h2{margin:0 0 1rem;font-size:1.2rem}.form-group{margin-bottom:.75rem}.form-group label{display:block;font-size:.85rem;opacity:.8;margin-bottom:.25rem}.form-group input,.form-group textarea,.form-group select{width:100%;padding:.5rem;border:1px solid var(--border-default);background:var(--bg-surface, rgba(255, 255, 255, .06));color:var(--text-primary);border-radius:6px;font-family:inherit;font-size:.9rem}.form-group select{cursor:pointer}.results-regatta-standings{margin-top:1rem;padding-top:1rem;border-top:1px solid rgba(255,255,255,.15)}.results-regatta-standings h3{font-size:1rem;margin:0 0 .5rem;opacity:.9}.results-regatta-standings .stats-table{font-size:.78rem}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;background:var(--landing-bg)}.auth-card{background:var(--bg-card-translucent);border:1px solid var(--border-subtle);border-radius:1rem;padding:2rem;width:100%;max-width:420px;box-shadow:0 20px 60px #0006}.auth-brand{display:block;text-align:center;margin-bottom:1.5rem;font-size:1.4rem;font-weight:700;color:var(--text-muted);text-decoration:none;letter-spacing:.02em;transition:color .2s ease}.auth-brand:hover{color:var(--text-secondary)}.auth-card h1{margin:0 0 .5rem;font-size:1.75rem;color:var(--text-primary)}.auth-subtitle{margin:0 0 1.5rem;color:var(--text-dim);font-size:.95rem}.auth-note{margin:1rem 0;color:var(--text-dim);font-size:.85rem;line-height:1.5}.auth-form{display:flex;flex-direction:column;gap:1rem}.auth-field{display:flex;flex-direction:column;gap:.4rem}.auth-field label{font-size:.85rem;font-weight:500;color:var(--text-muted)}.auth-field input{padding:.75rem 1rem;border-radius:.5rem;border:1px solid var(--hud-border);background:var(--bg-subtle);color:var(--text-primary);font-size:1rem;transition:border-color .2s ease,box-shadow .2s ease}.auth-field input:focus{outline:none;border-color:var(--accent-cyan);box-shadow:0 0 0 3px #53e0ff1a}.auth-field input::placeholder{color:var(--text-faint)}.auth-submit{margin-top:.5rem;padding:.85rem 1.5rem;border-radius:.5rem;border:none;background:linear-gradient(135deg,var(--accent-primary),var(--accent-primary-end));color:#fff;font-size:1rem;font-weight:600;cursor:pointer;transition:transform .1s ease,opacity .2s ease}.auth-submit:hover:not(:disabled){transform:translateY(-1px)}.auth-submit:active:not(:disabled){transform:translateY(0)}.auth-submit:disabled{opacity:.6;cursor:not-allowed}.auth-submit-link{display:inline-block;padding:.85rem 1.5rem;border-radius:.5rem;background:linear-gradient(135deg,var(--accent-primary),var(--accent-primary-end));color:#fff;font-weight:600;text-decoration:none;text-align:center}.auth-error{padding:.75rem 1rem;border-radius:.5rem;background:var(--accent-danger-bg);border:1px solid var(--accent-danger-border);color:var(--accent-danger);font-size:.9rem}.auth-error a{color:#ffb3b3;text-decoration:underline;font-weight:500}.auth-error a:hover{color:#fff}.auth-links{margin-top:1.5rem;text-align:center;font-size:.9rem;color:var(--text-dim);display:flex;align-items:center;justify-content:center;gap:.5rem;flex-wrap:wrap}.auth-links a{color:var(--text-muted);text-decoration:none;transition:color .2s ease}.auth-links a:hover{color:var(--text-secondary);text-decoration:underline}.auth-separator{color:var(--border-default)}.admin-page{min-height:100%;padding:2rem;background:var(--bg-primary);color:var(--text-primary)}.admin-header{max-width:1200px;margin:0 auto 1.5rem}.admin-header h1{margin:0 0 .25rem;font-size:1.75rem}.admin-subtitle{color:var(--text-dim);font-size:.9rem;margin:0}.admin-tabs{max-width:1200px;margin:0 auto;display:flex;gap:0;border-bottom:2px solid var(--border-subtle)}.admin-tab{padding:.7rem 1.25rem;background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;color:var(--text-dim);font-size:.95rem;font-weight:500;cursor:pointer;display:flex;align-items:center;gap:.5rem;transition:color .15s,border-color .15s}.admin-tab:hover{color:var(--text-secondary)}.admin-tab.active{color:var(--text-primary);border-bottom-color:var(--accent-primary)}.admin-tab-count{font-size:.78rem;padding:.15rem .5rem;border-radius:999px;background:var(--bg-subtle);color:var(--text-dim)}.admin-tab.active .admin-tab-count{background:#4f7dff1f;color:var(--accent-primary)}.admin-section{max-width:1200px;margin:0 auto;background:var(--bg-card-translucent);border:1px solid var(--border-subtle);border-top:none;border-radius:0 0 1rem 1rem;padding:1.5rem}.admin-count{color:var(--text-dim);font-size:.9rem}.admin-error{padding:.75rem 1rem;border-radius:.5rem;background:var(--accent-danger-bg);border:1px solid var(--accent-danger-border);color:var(--accent-danger);font-size:.9rem;margin-bottom:1rem}.admin-loading{text-align:center;padding:3rem;color:var(--text-dim)}.admin-table-container{overflow-x:auto}.admin-table{width:100%;border-collapse:collapse;font-size:.9rem}.admin-table th,.admin-table td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid var(--border-subtle)}.admin-table th{font-weight:600;color:var(--text-muted);font-size:.8rem;text-transform:uppercase;letter-spacing:.05em}.admin-table tr:hover{background:#ffffff05}.admin-table tr.current-user{background:#4f7dff14}.user-name{font-weight:500}.user-email{color:var(--text-dim)}.user-date{color:var(--text-dim);font-size:.85rem}.role-select{padding:.35rem .6rem;border-radius:.35rem;border:1px solid var(--hud-border);background:var(--bg-subtle);color:inherit;font-size:.85rem;cursor:pointer}.role-select:disabled{opacity:.5;cursor:not-allowed}.user-actions{display:flex;gap:.5rem}.action-btn{padding:.35rem .6rem;border-radius:.35rem;border:1px solid;font-size:.8rem;font-weight:500;cursor:pointer;transition:opacity .2s ease}.action-btn:disabled{opacity:.5;cursor:not-allowed}.action-btn.reset{border-color:#ffcf7066;background:#ffcf701a;color:var(--accent-heading)}.action-btn.reset:hover:not(:disabled){background:#ffcf7033}.action-btn.delete{border-color:#ff525266;background:#ff52521a;color:var(--accent-danger)}.action-btn.delete:hover:not(:disabled){background:#ff525233}.admin-pagination{display:flex;align-items:center;justify-content:center;gap:1rem;margin-top:1.5rem;padding-top:1rem;border-top:1px solid var(--border-subtle)}.admin-pagination button{padding:.5rem 1rem;border-radius:.4rem;border:1px solid var(--hud-border);background:var(--bg-subtle);color:inherit;font-size:.85rem;cursor:pointer}.admin-pagination button:disabled{opacity:.4;cursor:not-allowed}.admin-pagination span{color:var(--text-dim);font-size:.9rem}.admin-footer{max-width:1200px;margin:2rem auto 0;text-align:center}.admin-footer a{color:var(--text-muted);text-decoration:none}.admin-footer a:hover{text-decoration:underline}.admin-training-controls{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1rem;flex-wrap:wrap}.admin-filter-group{display:flex;align-items:center;gap:.5rem}.admin-filter-group label{color:var(--text-muted);font-size:.88rem}.admin-bulk-actions{display:flex;gap:.5rem}.admin-warning-cell{color:var(--accent-warning-text)}.training-toggle{padding:.25rem .75rem;border-radius:999px;border:1px solid var(--border-default);font-size:.8rem;font-weight:600;cursor:pointer;transition:all .15s}.training-toggle.approved{background:var(--accent-danger-bg);border-color:var(--accent-success);color:var(--accent-success)}.training-toggle.rejected{background:var(--bg-subtle);border-color:var(--border-default);color:var(--text-dim)}.training-toggle:hover{opacity:.8}.training-approved{background:var(--bg-subtle)}.auth-gate-wrapper{position:relative;max-width:420px;width:100%}.auth-gate-guest-sticker{position:absolute;top:-12px;right:-18px;display:flex;flex-direction:column;align-items:center;gap:1px;padding:.55rem .9rem .5rem;border-radius:10px;border:2px dashed rgba(255,220,100,.5);background:#1e190aeb;color:#ffe082;font-family:inherit;font-size:.78rem;font-weight:600;cursor:pointer;transform:rotate(3deg);transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease;box-shadow:0 2px 12px #0000004d;z-index:2;line-height:1.3}.auth-gate-guest-sticker:hover{transform:rotate(0) scale(1.05);border-color:#ffdc64cc;box-shadow:0 4px 20px #ffdc6426}.auth-gate-guest-emoji{font-size:1.3rem;line-height:1}.auth-gate-guest-cta{font-size:.7rem;font-weight:400;opacity:.7}@media(max-width:500px){.auth-gate-guest-sticker{position:static;transform:none;margin:1rem auto 0;flex-direction:row;gap:.4rem}.auth-gate-guest-sticker:hover{transform:scale(1.03)}}.auth-inline-link{background:none;border:none;color:var(--text-muted);font-size:inherit;font-family:inherit;cursor:pointer;padding:0;text-decoration:none;transition:color .2s ease}.auth-inline-link:hover{color:var(--text-secondary);text-decoration:underline}.profile-edit-section{margin-bottom:1.5rem;padding:1.25rem;background:#ffffff08;border:1px solid var(--border-subtle);border-radius:.75rem}.profile-edit-section h3{margin:0 0 1rem;font-size:1rem;color:var(--text-muted)}.profile-edit-form{display:flex;align-items:flex-end;gap:.75rem}.profile-edit-form .auth-field{flex:1}.profile-edit-form .auth-field label{font-size:.8rem}.profile-edit-form .auth-field input{padding:.55rem .75rem;font-size:.9rem}.profile-edit-save{padding:.55rem 1.25rem;border-radius:.4rem;border:none;background:linear-gradient(135deg,var(--accent-primary),var(--accent-primary-end));color:#fff;font-size:.85rem;font-weight:600;cursor:pointer;white-space:nowrap;transition:transform .1s ease,opacity .2s ease}.profile-edit-save:hover:not(:disabled){transform:translateY(-1px)}.profile-edit-save:disabled{opacity:.6;cursor:not-allowed}.profile-edit-feedback{margin-top:.6rem;font-size:.82rem}.profile-edit-feedback.success{color:var(--accent-success)}.profile-edit-feedback.error{color:var(--accent-danger)}.header-user-menu,.header-auth-links{display:flex;align-items:center;gap:.75rem}.header-user-name{font-size:.9rem;color:var(--text-muted);font-weight:500}.header-admin-link,.header-login-link{padding:.4rem .75rem;border-radius:.35rem;border:1px solid var(--hud-border);background:var(--bg-subtle);color:var(--text-muted);font-size:.85rem;text-decoration:none;transition:all .2s ease}.header-admin-link:hover,.header-login-link:hover{background:var(--bg-hover);border-color:var(--border-hover);color:var(--text-primary)}.header-register-link{padding:.4rem .75rem;border-radius:.35rem;border:none;background:linear-gradient(135deg,var(--accent-primary),var(--accent-primary-end));color:#fff;font-size:.85rem;font-weight:500;text-decoration:none;transition:transform .1s ease,opacity .2s ease}.header-register-link:hover{transform:translateY(-1px)}.header-logout-btn{padding:.4rem .75rem;border-radius:.35rem;border:1px solid var(--accent-danger-border);background:var(--accent-danger-bg);color:var(--accent-danger);font-size:.85rem;cursor:pointer;transition:all .2s ease}.header-logout-btn:hover{background:#ff525233;border-color:#ff525266}
