.username-gate{position:fixed;inset:0;background:#05070fe6;display:flex;align-items:center;justify-content:center;z-index:20}.username-card{background:#0d1324;border:1px solid #24304a;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 rgba(255,255,255,.08)}.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:#ffffff0f;color:#dbe3ff;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:#ffffff40;background:#ffffff1a}.user-menu-close:active{transform:translateY(1px)}.user-menu-form{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:#cfe0ff}.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 #2c3550;background:#181f32e6;color:inherit;appearance:none;-webkit-appearance:none}.user-menu-input{width:100%}.user-menu-select:focus-visible{outline:2px solid rgba(83,224,255,.55);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:#9fb7ff}.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 #2c3550;background:#181f32e6;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,#4f7dff,#6e5bff);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:#ffffff1a!important;border:1px solid rgba(255,255,255,.2)!important}:root{color-scheme:dark;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background-color:#05070f;color:#f4f6fa}*{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:#8fa2c6;border:1px solid #273044;border-radius:999px;padding:.1rem .5rem;background:#0a1224;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 rgba(255,255,255,.15);background:#ffffff0d;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 rgba(255,255,255,.15);background:#ffffff0d}.header-room-name{font-size:.9rem;opacity:.9;pointer-events:none}.user-menu-lobby{display:inline-flex;align-items:center;justify-content:center;gap:.4rem}.username-card .username-form-actions .user-menu-lobby{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:inherit}.header-name:hover{background:#ffffff1a;border-color:#ffffff40}.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}.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 #1b1f2b;border-radius:1rem;overflow:hidden;position:relative;background:#0a0f1e;display:flex}.placeholder{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;color:#aeb5c7}.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:#080c18e6;border:1px solid #2f3650;box-shadow:0 10px 50px #00000073;border-radius:1rem;padding:1.5rem;color:#e4edff;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:#c4cbe0}.start-sequence-card .host-debug{font-size:.75rem;opacity:.7;color:#9fb7ff}.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:#050812cc;border:1px solid rgba(255,255,255,.12);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,#2a3b4ee6,#2a3b4e8c,#021428,#4dff8a33,#4dff8a80);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:#d8f8ff;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:#4af6c2;display:inline-block;min-width:9ch;text-align:right}.speed-heading-overlay .hud-metric-heading .hud-value{color:#ffcf70;display:inline-block;min-width:5ch;text-align:right}.speed-heading-overlay .hud-metric-wind .hud-value{color:#9fb7ff;display:inline-block;min-width:4ch;text-align:right}.speed-heading-overlay .hud-metric-windspd .hud-value{color:#fff;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:#4af6c2}.wind-speed-delta.negative{color:#7ea4ff}.speed-heading-overlay .hud-metric-winddir .hud-value{color:#fff;display:inline-block;min-width:5ch;text-align:right}.speed-heading-overlay .hud-metric-tack .hud-value{color:#d8f8ff}.speed-heading-overlay .hud-metric-tack .hud-value.tack-stbd{color:#4af6c2}.speed-heading-overlay .hud-metric-tack .hud-value.tack-port{color:#ff6b6b}.wake-overlay{padding:.55rem .7rem;background:#050812cc;border:1px solid rgba(255,255,255,.12);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:#0c1224e6;border:1px solid #1f2638;border-radius:.75rem;padding:.45rem .65rem;display:flex;flex-direction:column;gap:.1rem;text-align:right;color:#e4edff;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}.spin-under-hud{pointer-events:auto}.leaderboard-overlay,.events-overlay{pointer-events:auto;width:260px;background:#0c1224e6;border:1px solid #1f2638;border-radius:.75rem;padding:.75rem;box-shadow:0 10px 40px #00000073}.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:#060a16d9;color:#e4edff;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:#04060ce0;border:1px solid rgba(255,255,255,.08);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 rgba(255,255,255,.12);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 rgba(83,224,255,.55);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:#0c1224e6;border:1px solid #1f2638;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:#9fb7ff}.speed-readout{font-family:IBM Plex Mono,SFMono-Regular,Menlo,monospace;font-size:1rem;color:#4af6c2}.heading-readout{font-family:IBM Plex Mono,SFMono-Regular,Menlo,monospace;font-size:.95rem;color:#ffcf70}.player-actions{display:flex;align-items:center;gap:.5rem}.spin-button{padding:.45rem .8rem;border-radius:.45rem;border:1px solid #b974ff;background:linear-gradient(135deg,#471e6de6,#301257f2);color:#f8ecff;font-size:.85rem;font-weight:600;transition:opacity .2s ease,transform .2s ease}.spin-button:active:not(:disabled){transform:translateY(1px)}.spin-button:disabled{opacity:.4;cursor:not-allowed;border-color:#2f3650;background:#121828cc;color:#6b7190}.countdown-status{font-size:.9rem;color:#f5a524}.start-sequence{padding:.6rem .9rem;border-radius:.5rem;border:none;background:#f5a524;color:#05070f;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 #28304a;padding-top:.5rem}.roster-panel h3{font-size:.85rem;text-transform:uppercase;letter-spacing:.08em;color:#9fb7ff;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:#b7c2ff;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:#dbe3ff}.roster-entry .badge{padding:.1rem .35rem;border-radius:.4rem;background:#4f7dff;font-size:.7rem;text-transform:uppercase}.roster-entry.offline{opacity:.5}.roster-entry .role{margin-left:auto;font-size:.75rem;text-transform:capitalize;color:#9fb7ff}.roster-empty{font-size:.85rem;color:#aeb5c7}.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 rgba(255,255,255,.1);background:#ffffff0d;border-radius:.3rem;color:inherit}.chat-panel .chat-input button{padding:.3rem .6rem;font-size:.75rem;border:1px solid rgba(255,255,255,.15);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:#9fb7ff}.chat-panel .chat-other .chat-author{color:#ffcf70}.chat-panel .chat-status{font-size:.7rem;opacity:.7;padding:.2rem .4rem;min-height:1.2em;margin:0;color:#ff6b6b}.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:#9fb7ff}.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:#9fb7ff}.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:#b7c2ff;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:#7df5b8;color:#7df5b8}.status-active .progress-bullet{border-color:#ffe29f;color:#ffe29f}.status-pending .progress-bullet{border-color:#ffffff4d;color:#ffffff4d}.status-done .progress-label{color:#7df5b8}.status-active .progress-label{color:#ffe29f}.status-pending .progress-label{color:#ffffff73}.mark-checklist{margin-top:1rem;padding:.75rem;border:1px solid rgba(255,255,255,.08);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:#7df5b8}.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:#9fb7ff}.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:#ff6b6b}.chat-empty{color:#5f6680}.tactician-popout{position:fixed;left:auto;right:1rem;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-end;max-width:220px;padding:.35rem .6rem;border-radius:999px;border:1px solid rgba(255,255,255,.14);background:#060a16e0;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 #2e3450;background:#0c1224e6;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 rgba(83,224,255,.55);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:#9fb7ff;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:#080c18f2;border:1px solid rgba(255,255,255,.14);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:#9fb7ff}.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:#ffffff0f;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 rgba(83,224,255,.55);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:#ffffff0f;color:#dbe3ff;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:#ffffff40;background:#ffffff1a}.keyboard-help-close:active{transform:translateY(1px)}.keyboard-help-close:focus-visible{outline:2px solid rgba(83,224,255,.55);outline-offset:2px}kbd{background:#ffffff14;border:1px solid rgba(255,255,255,.15);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 #28304a;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:#aeb5c7;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 #1f2638;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:#9fb7ff}.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;height:100%;width:100%;gap:1rem;padding:1rem}.replay-sidebar{border:1px solid #1f2638;border-radius:.75rem;padding:1rem;display:flex;flex-direction:column;gap:.5rem;background:#0c1224cc}.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 button{text-align:left;border-radius:.5rem;border:1px solid #2b3146;padding:.5rem;background:transparent;color:inherit}.replay-list button.active{border-color:#5b89ff;background:#5b89ff1a}.replay-stage{border:1px solid #1b1f2b;border-radius:.75rem;overflow:hidden;position:relative;display:flex;flex-direction:column;background:#05070f}.replay-stage .pixi-stage{flex:1}.replay-controls{padding:.75rem;border-top:1px solid #1f2638;background:#05070fe6;display:flex;flex-direction:column;gap:.75rem}.playback-controls{display:flex;align-items:center;gap:.5rem}.playback-controls input[type=range]{flex:1}.replay-chat{border-top:1px solid #28304a;padding-top:.5rem}.landing-shell{min-height:100vh;padding:clamp(2rem,4vw,4rem);background:radial-gradient(circle at top,#1f3d884d,#04060cf2),#05070f;overflow-y:auto;color:#f4f6fa;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:#cfd8ff}.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:#b7c2ff}.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 rgba(255,255,255,.12);border-radius:.9rem;background:#080c1aa6;font-weight:600;color:#e2e8ff}.landing-section h2{font-size:1.4rem;color:#9fb7ff;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:linear-gradient(130deg,#ff8f70,#ffcd70);color:#05070f}.landing-actions .secondary{border:1px solid #36405f;color:#b7c2ff}.eyebrow{text-transform:uppercase;letter-spacing:.2em;font-size:.75rem;color:#91a7ff}.testimonials{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem}.testimonial{border:1px solid rgba(255,255,255,.1);border-radius:.9rem;padding:1rem;background:#0a0e1ab3}.testimonial blockquote{font-size:1rem;line-height:1.5;color:#f8f9ff}.testimonial figcaption{margin-top:.6rem;font-size:.85rem;color:#9db2ff}.landing-footer{border-top:1px solid rgba(255,255,255,.1);padding-top:1rem;color:#a7b5d7}.landing-footer .note{font-size:.9rem;color:#7f8db4}.social-link{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:.5rem;border:1px solid rgba(255,255,255,.15);background:#ffffff0d;color:#b7c2ff;transition:all .2s ease}.social-link:hover,.social-link:focus-visible{border-color:#ffffff4d;background:#ffffff1a;color:#e2e8ff;transform:translateY(-1px)}.social-link svg{width:18px;height:18px;fill: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}}
