:root{--bg: #060b07;--surface: #0c1209;--surface-2: #121a12;--surface-3: #192418;--surface-4: #202e20;--border: #223324;--border-bright: #2e4830;--lime: #b8ff00;--lime-dim: rgba(184, 255, 0, .06);--lime-glow: rgba(184, 255, 0, .18);--green: #00cc55;--orange: #ff6a00;--yellow: #ffd000;--red: #ff2020;--blue: #00aaff;--cyan: #00e5b0;--flag-green: #00cc55;--flag-yellow: #ffd000;--flag-sc: #ff8c00;--flag-red: #ff2020;--urgency-info: var(--blue);--urgency-advisory: var(--green);--urgency-warning: var(--yellow);--urgency-critical: var(--red);--text: #d8edd9;--text-2: #82b084;--text-3: #527554;--font-display: "Chakra Petch", sans-serif;--font-mono: "Fira Code", monospace;--gap: 10px;--gap-lg: 16px;--radius: 4px;--radius-lg: 6px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;background:var(--bg);color:var(--text);font-family:var(--font-display);font-size:15px;line-height:1.4;-webkit-font-smoothing:antialiased;overflow:hidden}.app-shell{display:flex;flex-direction:column;height:100vh;overflow:hidden;background:radial-gradient(ellipse 70% 40% at 50% -5%,rgba(0,60,15,.55) 0%,transparent 70%),radial-gradient(ellipse 45% 65% at 100% 100%,rgba(0,25,8,.22) 0%,transparent 60%),radial-gradient(ellipse 35% 50% at 0% 60%,rgba(0,20,6,.15) 0%,transparent 60%),var(--bg)}.race-header-subrow{display:none}.new-session-fab{position:fixed;left:24px;bottom:24px;z-index:60;width:56px;height:56px;border-radius:50%;background:#22311f;color:var(--lime);border:3px solid var(--lime);font-size:28px;font-weight:400;line-height:1;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 4px 12px #00000080,0 0 0 1px #b8ff0026;transition:transform .15s ease,border-color .15s ease,box-shadow .2s ease}.new-session-fab:hover{transform:translateY(-1px);border-color:var(--lime);box-shadow:0 6px 16px #0000008c,0 0 0 1px #b8ff0066}.new-session-fab:active{transform:translateY(0)}.race-header{position:relative;display:flex;align-items:stretch;min-height:74px;background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0;overflow:hidden;z-index:10}.race-header:before{content:"";position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--flag-color, var(--lime));transition:background .6s ease}.race-header-brand{display:flex;flex-direction:column;justify-content:center;padding:12px 20px;border-right:1px solid var(--border);min-width:220px;max-width:280px;flex-shrink:0}.brand-name{font-size:20px;font-weight:700;letter-spacing:.12em;color:var(--lime);line-height:1}.brand-sub{font-size:11px;font-weight:300;letter-spacing:.25em;color:var(--text-2);margin-top:4px}.header-stat-event{flex-shrink:0}.header-stat-value.event-name{font-family:var(--font-display);font-size:18px;font-weight:700;letter-spacing:.14em;color:var(--lime);text-transform:uppercase;white-space:nowrap}.header-stat-value.car-name{font-family:var(--font-display);font-size:18px;font-weight:700;letter-spacing:.14em;color:var(--cyan);text-transform:uppercase;white-space:nowrap}.race-header-center{display:flex;align-items:center;gap:32px;flex:1 1 0;min-width:0;padding:0 28px;overflow-x:auto;scrollbar-width:none}.race-header-center::-webkit-scrollbar{display:none}.header-stat{display:flex;flex-direction:column;gap:2px}.header-stat-label{font-size:11px;font-weight:500;letter-spacing:.2em;color:var(--text-2)}.header-stat-value{font-family:var(--font-mono);font-size:24px;font-weight:700;color:var(--text);line-height:1;letter-spacing:.04em}.header-stat-value.lap{color:var(--lime)}.header-stat-value.elapsed{color:var(--cyan)}.header-stat-value.remaining{color:var(--text)}.header-divider{width:1px;background:var(--border);align-self:stretch;margin:10px 0}.race-header-right{display:flex;align-items:center;gap:12px;padding:0 20px;border-left:1px solid var(--border);flex-shrink:0}.flag-badge{display:flex;align-items:center;gap:6px;padding:5px 11px;border-radius:var(--radius);border:1px solid currentColor;font-size:12px;font-weight:700;letter-spacing:.15em;transition:all .3s ease}.flag-badge.green{color:var(--flag-green);background:#00cc5514}.flag-badge.yellow{color:var(--flag-yellow);background:#ffd00014;animation:flag-pulse-yellow 1.4s ease-in-out infinite}.flag-badge.sc{color:var(--flag-sc);background:#ff8c001a;animation:flag-pulse-sc 1s ease-in-out infinite}.flag-badge.red{color:var(--flag-red);background:#ff20201a;animation:flag-pulse-red .7s ease-in-out infinite}.flag-dot{width:7px;height:7px;border-radius:50%;background:currentColor}.flag-badge.green .flag-dot{animation:dot-pulse 2s ease-in-out infinite}.flag-badge.yellow .flag-dot{animation:dot-blink .8s step-end infinite}.flag-badge.sc .flag-dot{animation:dot-blink .6s step-end infinite}.flag-badge.red .flag-dot{animation:dot-blink .4s step-end infinite}@keyframes dot-pulse{0%,to{opacity:1}50%{opacity:.3}}@keyframes dot-blink{0%,to{opacity:1}50%{opacity:0}}@keyframes flag-pulse-yellow{0%,to{box-shadow:0 0 6px #ffd00026}50%{box-shadow:0 0 14px #ffd00059}}@keyframes flag-pulse-sc{0%,to{box-shadow:0 0 6px #ff8c0026}50%{box-shadow:0 0 16px #ff8c0066}}@keyframes flag-pulse-red{0%,to{box-shadow:0 0 8px #ff202033}50%{box-shadow:0 0 20px #ff202080}}.weather-badge{font-size:22px;line-height:1}.weather-label{font-size:11px;letter-spacing:.15em;color:var(--text-2);font-weight:500}.position-badge{font-family:var(--font-mono);font-size:26px;font-weight:700;color:var(--lime);display:flex;flex-direction:column;align-items:center;gap:1px}.position-badge span{font-size:10px;font-family:var(--font-display);letter-spacing:.2em;color:var(--text-2)}.conn-status{display:flex;align-items:center;justify-content:center;gap:6px;font-size:11px;font-weight:500;letter-spacing:.15em;padding:4px 8px;border-radius:var(--radius);min-width:120px}.conn-status.connected{color:var(--green)}.conn-status.connecting{color:var(--yellow)}.conn-status.reconnecting{color:var(--orange)}.conn-status.disconnected{color:var(--red)}.conn-dot{width:6px;height:6px;border-radius:50%;background:currentColor}.conn-status.connected .conn-dot{animation:dot-pulse 2s ease-in-out infinite}.conn-status.connecting .conn-dot{animation:dot-blink .8s step-end infinite}.conn-status.reconnecting .conn-dot{animation:dot-blink .6s step-end infinite}.conn-status .reconnect-in{font-family:var(--font-mono);font-size:11px;color:var(--text-2)}.profile-badge{display:flex;align-items:center;gap:8px;padding:4px 8px;border-radius:var(--radius);background:var(--surface-2);border:1px solid var(--border)}.profile-avatar{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,var(--lime),var(--lime-dim));display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:var(--surface);letter-spacing:.05em}.profile-info{display:flex;flex-direction:column;line-height:1.2;gap:3px}.profile-name{font-size:12px;font-weight:600;color:var(--text-1);letter-spacing:.05em}.profile-role{font-size:9px;font-family:var(--font-display);font-weight:500;color:var(--text-2);letter-spacing:.15em}.main-body{display:grid;grid-template-columns:310px 1fr 298px;grid-template-rows:1fr;gap:0;flex:1;min-height:0;overflow:hidden}.col-left{display:flex;flex-direction:column;gap:0;border-right:1px solid var(--border);overflow-y:auto;overflow-x:hidden}.col-left:after{content:"";flex:1;background:var(--surface);border-bottom:none}.col-center{display:flex;flex-direction:column;gap:0;overflow-y:auto;overflow-x:hidden}.col-right{display:flex;flex-direction:column;border-left:1px solid var(--border);overflow:hidden}.col-right-alerts{flex:3;min-height:0;display:flex;flex-direction:column;overflow:hidden}.col-right-events{flex:0 0 auto;min-height:0;max-height:260px;display:flex;flex-direction:column;overflow:hidden;border-top:1px solid var(--border-bright)}.col-right-events:has(.collapsible-panel.is-collapsed){max-height:40px;flex:0 0 auto}.collapsible-panel{display:flex;flex-direction:column;min-height:0;background:var(--surface)}.collapsible-header{all:unset;display:flex;align-items:center;gap:10px;padding:8px 14px;background:var(--surface-2);border-bottom:1px solid var(--border);font-size:11px;font-weight:600;letter-spacing:.25em;color:var(--text-2);cursor:pointer;-webkit-user-select:none;user-select:none;transition:color .15s ease,background .15s ease;flex-shrink:0}.collapsible-header:hover{color:var(--text);background:var(--surface-3, var(--surface-2))}.collapsible-header:focus-visible{outline:1px solid var(--lime);outline-offset:-2px}.collapsible-panel.is-collapsed .collapsible-header{border-bottom-color:transparent}.collapsible-chevron{display:inline-block;width:10px;font-size:10px;line-height:1;color:var(--text-3);transition:transform .22s cubic-bezier(.22,1,.36,1);transform-origin:center}.collapsible-chevron.collapsed{transform:rotate(-90deg)}.collapsible-header:hover .collapsible-chevron{color:var(--lime)}.collapsible-label{flex-shrink:0}.collapsible-meta{display:inline-flex;align-items:center;gap:10px;margin-left:auto;color:var(--text-3);font-family:var(--font-mono);font-size:11px;letter-spacing:.1em}.cp-meta-count{color:var(--text-3)}.cp-meta-replay{color:var(--cyan)}.collapsible-body{overflow:hidden;min-height:0;display:flex;flex-direction:column}.collapsible-body-inner{display:flex;flex-direction:column;min-height:0;max-height:260px;overflow-y:auto;overflow-x:hidden}.col-center>.collapsible-panel{border-top:1px solid var(--border)}.col-center>.collapsible-panel:has(.stint-history) .collapsible-body-inner{max-height:340px}.analysis-row{border-top:1px solid var(--border)}.analysis-row>.collapsible-panel{border-bottom:none}.analysis-row>.collapsible-panel .collapsible-body-inner{max-height:260px}.col-right-events .collapsible-panel,.col-right-events .collapsible-body{flex:1;min-height:0}.col-right-events .collapsible-body-inner{flex:1;min-height:0;max-height:none}.panel{background:var(--surface);border-bottom:1px solid var(--border);padding:14px 16px;position:relative}.panel-label{font-size:11px;font-weight:600;letter-spacing:.25em;color:var(--text-2);margin-bottom:12px;display:flex;align-items:center;gap:8px}.panel-label:after{content:"";flex:1;height:1px;background:var(--border)}.driver-name{font-size:26px;font-weight:700;letter-spacing:.06em;color:var(--text);line-height:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.driver-driving-indicator{display:flex;align-items:center;gap:6px;font-size:11px;font-weight:600;letter-spacing:.2em;color:var(--lime);margin-top:8px}.driver-driving-indicator .dot{width:5px;height:5px;border-radius:50%;background:var(--lime);animation:dot-pulse 1.4s ease-in-out infinite}.stint-stats{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:12px}.stint-stat{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);padding:8px 10px}.stint-stat-label{font-size:13px;font-weight:600;letter-spacing:.15em;color:var(--text-2);margin-bottom:4px}.stint-stat-value{font-family:var(--font-mono);font-size:20px;font-weight:600;color:var(--lime);line-height:1}.fuel-bar-container{position:relative;height:16px;background:var(--surface-3);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;margin:10px 0}.fuel-bar{height:100%;border-radius:var(--radius);transition:width .8s ease,background .6s ease;position:relative}.fuel-bar:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.08) 50%,transparent 100%);animation:shimmer 2s linear infinite}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(200%)}}.fuel-bar.high{background:linear-gradient(90deg,var(--green),rgba(0,204,85,.7))}.fuel-bar.medium{background:linear-gradient(90deg,var(--yellow),rgba(255,208,0,.7))}.fuel-bar.low{background:linear-gradient(90deg,var(--red),rgba(255,32,32,.8));animation:bar-pulse-red .7s ease-in-out infinite}@keyframes bar-pulse-red{0%,to{opacity:1}50%{opacity:.6}}.fuel-pit-marker{position:absolute;top:0;bottom:0;width:2px;background:var(--lime);opacity:.7}.fuel-stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px}.fuel-stat{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);padding:8px 10px}.fuel-stat-label{font-size:13px;font-weight:600;letter-spacing:.15em;color:var(--text-2);margin-bottom:4px}.fuel-stat-value{font-family:var(--font-mono);font-size:20px;font-weight:700;color:var(--text);line-height:1}.fuel-stat-value.highlight{color:var(--lime)}.fuel-stat-value.warn{color:var(--yellow)}.fuel-stat-value.critical{color:var(--red)}.tire-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-top:4px}.tire-stat{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);padding:8px 10px}.tire-stat-label{font-size:13px;font-weight:600;letter-spacing:.15em;color:var(--text-2);margin-bottom:4px}.col-left .panel-label{font-size:13px;font-weight:600;letter-spacing:.22em}.tire-stat-value{font-family:var(--font-mono);font-size:22px;font-weight:700;line-height:1}.tire-stat-value.fresh{color:var(--green)}.tire-stat-value.worn{color:var(--yellow)}.tire-stat-value.degraded{color:var(--orange)}.tire-stat-value.critical{color:var(--red)}.tire-deg-bar-container{height:6px;background:var(--surface-3);border-radius:3px;overflow:hidden;margin-top:10px;border:1px solid var(--border)}.tire-deg-bar{height:100%;border-radius:3px;transition:width .8s ease,background .6s ease}.tire-deg-bar.fresh{background:var(--green)}.tire-deg-bar.worn{background:var(--yellow)}.tire-deg-bar.degraded{background:var(--orange)}.tire-deg-bar.critical{background:var(--red);animation:bar-pulse-red .7s ease-in-out infinite}.pit-rec{margin:14px;border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;transition:border-color .4s ease,box-shadow .4s ease;background:var(--surface);flex-shrink:0}.pit-rec.info{border-color:#00aaff40;box-shadow:0 0 20px #00aaff0d}.pit-rec.advisory{border-color:#00cc554d;box-shadow:0 0 20px #00cc550f}.pit-rec.warning{border-color:#ffd00066;box-shadow:0 0 24px #ffd0001a;animation:rec-pulse-warn 2s ease-in-out infinite}.pit-rec.critical{border-color:#ff202099;box-shadow:0 0 32px #ff20202e;animation:rec-pulse-crit 1s ease-in-out infinite}@keyframes rec-pulse-warn{0%,to{box-shadow:0 0 24px #ffd0001a}50%{box-shadow:0 0 36px #ffd00038}}@keyframes rec-pulse-crit{0%,to{box-shadow:0 0 32px #ff20202e}50%{box-shadow:0 0 52px #ff202061}}.pit-rec-header{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;background:var(--surface-2);border-bottom:1px solid var(--border)}.pit-rec-label{font-size:11px;font-weight:600;letter-spacing:.25em;color:var(--text-2)}.urgency-badge{font-size:11px;font-weight:700;letter-spacing:.2em;padding:4px 9px;border-radius:var(--radius);border:1px solid currentColor}.urgency-badge.info{color:var(--blue);background:#00aaff14}.urgency-badge.advisory{color:var(--green);background:#00cc5514}.urgency-badge.warning{color:var(--yellow);background:#ffd00014;animation:badge-blink-warn 1.5s step-end infinite}.urgency-badge.critical{color:var(--red);background:#ff20201a;animation:badge-blink-crit .8s step-end infinite}@keyframes badge-blink-warn{0%,80%,to{opacity:1}90%{opacity:.3}}@keyframes badge-blink-crit{0%,60%,to{opacity:1}80%{opacity:0}}.pit-rec-body{padding:20px 16px 16px}.pit-action-text{font-size:36px;font-weight:700;letter-spacing:.04em;line-height:1.05;color:var(--text);margin-bottom:4px}.pit-action-text.advisory{color:var(--green)}.pit-action-text.warning{color:var(--yellow)}.pit-action-text.critical{color:var(--red)}.pit-swap-target{font-size:17px;font-weight:500;letter-spacing:.08em;color:var(--cyan);margin-bottom:12px}.pit-lap-row{display:flex;align-items:baseline;gap:16px;margin:14px 0 12px;padding:10px 12px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius)}.pit-lap-item{display:flex;flex-direction:column;gap:2px}.pit-lap-item-label{font-size:10px;letter-spacing:.18em;color:var(--text-2);font-weight:500}.pit-lap-item-value{font-family:var(--font-mono);font-size:28px;font-weight:700;color:var(--lime);line-height:1}.pit-reasoning{font-size:13px;color:var(--text-2);line-height:1.5;letter-spacing:.01em;font-style:italic;padding:10px 12px;background:var(--surface-2);border-left:2px solid var(--border-bright);border-radius:0 var(--radius) var(--radius) 0}.swap-rec{margin:0 14px 14px;padding:14px 16px;background:var(--surface-2);border:1px solid rgba(0,229,176,.25);border-radius:var(--radius-lg);box-shadow:0 0 16px #00e5b00f}.swap-rec-label{font-size:11px;font-weight:600;letter-spacing:.25em;color:var(--cyan);margin-bottom:10px}.swap-driver-name{font-size:23px;font-weight:700;letter-spacing:.05em;color:var(--cyan);line-height:1}.swap-at-lap{font-family:var(--font-mono);font-size:14px;color:var(--text-2);margin-top:4px}.swap-reason{font-size:12px;color:var(--text-2);margin-top:8px;font-style:italic;line-height:1.4}.decision-meta{display:flex;align-items:center;gap:12px;padding:8px 14px;background:var(--surface-2);border-top:1px solid var(--border);font-size:11px;color:var(--text-3);letter-spacing:.12em}.decision-meta .version{font-family:var(--font-mono);color:var(--text-2)}.alert-feed{display:flex;flex-direction:column;flex:1;overflow:hidden}.alert-feed-section{display:flex;flex-direction:column;min-height:0}.alert-feed-section.active{flex:0 0 120px;overflow:hidden}.alert-feed-section.history{flex:1;overflow:hidden;display:flex;flex-direction:column;background:repeating-linear-gradient(0deg,transparent,transparent 23px,rgba(0,20,6,.18) 23px,rgba(0,20,6,.18) 24px),var(--surface)}.alert-section-header{display:flex;align-items:center;gap:8px;padding:8px 14px;height:32px;box-sizing:border-box;background:var(--surface-2);border-bottom:1px solid var(--border);font-size:11px;font-weight:600;letter-spacing:.25em;color:var(--text-2);flex-shrink:0}.alert-section-header.active-header{color:var(--red);background:#ff20200a}.alert-section-header.history-header{background:var(--surface-3);border-top:2px solid var(--border-bright);color:var(--text-3);font-size:10px;letter-spacing:.3em;gap:6px}.history-header-icon{font-size:9px;color:var(--border-bright);flex-shrink:0}.history-replay-hint{margin-left:auto;font-size:8px;color:var(--text-3);letter-spacing:.12em;font-family:var(--font-mono);opacity:.7}.alert-count{font-family:var(--font-mono);font-size:12px;background:var(--red);color:var(--bg);border-radius:10px;padding:1px 6px;font-weight:700}.alert-count.history-count{background:var(--surface-4);color:var(--text-2);border:1px solid var(--border-bright);font-size:10px}.alert-list{overflow-y:auto;display:flex;flex-direction:column}.alert-list.history-list{flex:1;overflow-y:auto}.alert-item{display:flex;gap:10px;padding:10px 14px;border-bottom:1px solid var(--border);background:var(--surface);transition:background .2s}.alert-item:hover{background:var(--surface-2)}.alert-item.severity-info{border-left:2px solid var(--blue)}.alert-item.severity-advisory{border-left:2px solid var(--green)}.alert-item.severity-warning{border-left:2px solid var(--yellow)}.alert-item.severity-critical{border-left:2px solid var(--red);background:#ff20200a}.alert-item--history{background:transparent;border-left-width:2px;border-left-style:solid}.alert-item--history:hover{background:var(--surface-2)!important}.alert-item--history.severity-info{border-left-color:#0af6}.alert-item--history.severity-advisory{border-left-color:#0c56}.alert-item--history.severity-warning{border-left-color:#ffd00066}.alert-item--history.severity-critical{border-left-color:#ff202080;background:transparent}.alert-item--history .alert-msg{color:var(--text-2)!important;font-weight:400!important;font-size:12px}.alert-item--history .alert-severity-dot.critical{animation:none}.alert-severity-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0;margin-top:3px}.alert-severity-dot.info{background:var(--blue)}.alert-severity-dot.advisory{background:var(--green)}.alert-severity-dot.warning{background:var(--yellow)}.alert-severity-dot.critical{background:var(--red);animation:dot-blink .7s step-end infinite}.alert-content{flex:1;min-width:0}.alert-msg{font-size:13px;color:var(--text);line-height:1.35}.alert-item.severity-critical .alert-msg{color:var(--red);font-weight:600}.alert-item.severity-warning .alert-msg{color:var(--yellow)}.alert-meta{display:flex;gap:6px;margin-top:3px;font-family:var(--font-mono);font-size:11px;color:var(--text-2)}.no-alerts{padding:20px 14px;font-size:12px;color:var(--text-3);letter-spacing:.1em;text-align:center}.trend-grid{display:flex;flex-direction:column;gap:0}.trend-sep{height:1px;background:var(--border);margin:10px 0}@media (min-width: 1400px){.trend-grid{flex-direction:row;align-items:stretch;gap:0}.trend-grid>.trend-metric{flex:1 1 0;min-width:0;padding:0 14px}.trend-grid>.trend-metric:first-child{padding-left:0}.trend-grid>.trend-metric:last-child{padding-right:0}.trend-sep{height:auto;width:1px;margin:0;align-self:stretch}}.trend-metric{display:flex;flex-direction:column;gap:8px;min-width:0}.trend-header{display:flex;align-items:baseline;justify-content:space-between;gap:6px;flex-wrap:wrap}.trend-label{font-size:10px;font-weight:600;letter-spacing:.2em;color:var(--text-3);white-space:nowrap}.trend-vals{display:flex;align-items:baseline;gap:6px;flex-wrap:wrap;justify-content:flex-end}.trend-current{font-family:var(--font-mono);font-size:18px;font-weight:700;line-height:1;letter-spacing:.04em}.trend-delta{font-family:var(--font-mono);font-size:11px;letter-spacing:.04em}.trend-pct{font-family:var(--font-mono);font-size:10px;color:var(--text-3);letter-spacing:.04em}.sparkline-wrap{display:flex;flex-direction:column;gap:3px}.sparkline-axis{display:flex;justify-content:space-between;font-family:var(--font-mono);font-size:9px;color:var(--text-3);letter-spacing:.08em;opacity:.7}.sparkline-empty{height:60px;display:flex;align-items:center;justify-content:center;font-size:10px;color:var(--text-3);letter-spacing:.15em}.sparkline-tooltip{position:absolute;pointer-events:none;display:flex;flex-direction:column;align-items:center;gap:1px;background:var(--surface-4);border:1px solid var(--border-bright);border-radius:var(--radius);padding:4px 8px;white-space:nowrap;z-index:10}.sparkline-tooltip-lap{font-family:var(--font-mono);font-size:9px;color:var(--text-3);letter-spacing:.1em}.sparkline-tooltip-val{font-family:var(--font-mono);font-size:13px;font-weight:700;letter-spacing:.04em;line-height:1}.analysis-row{display:grid;grid-template-columns:1fr 1px 1.4fr;overflow:hidden;background:var(--surface)}.analysis-row-sep{background:var(--border);align-self:stretch}.analysis-panel{display:flex;flex-direction:column;padding:10px 14px;overflow:hidden;min-height:0}.analysis-panel-label{font-size:10px;font-weight:600;letter-spacing:.25em;color:var(--text-2);margin-bottom:8px;flex-shrink:0;display:flex;align-items:center;gap:8px}.analysis-panel-label:after{content:"";flex:1;height:1px;background:var(--border)}.analysis-empty{flex:1;display:flex;align-items:center;justify-content:center;font-size:11px;color:var(--text-3);letter-spacing:.12em}.pit-stop-list{display:flex;flex-direction:column;gap:4px;overflow-y:auto;flex:1;min-height:0}.pit-stop-row{display:flex;align-items:center;gap:8px;font-size:13px;padding:3px 0 3px 10px;border-bottom:1px solid var(--border);flex-shrink:0}.pit-stop-row:last-child{border-bottom:none}.pit-stop-num{font-family:var(--font-mono);font-size:12px;color:var(--text-3);letter-spacing:.05em;min-width:22px}.pit-stop-lap{font-family:var(--font-mono);color:var(--text-2);min-width:34px;font-size:13px}.pit-stop-dur{font-family:var(--font-mono);font-size:14px;font-weight:700;min-width:48px}.pit-stop-fuel{font-family:var(--font-mono);font-size:13px;color:var(--lime);min-width:50px}.pit-stop-tires{font-size:12px;letter-spacing:.08em;min-width:60px}.pit-stop-swap{font-size:12px;font-family:var(--font-mono);color:var(--cyan);letter-spacing:.04em;margin-left:auto}.driver-pace-list{display:flex;flex-direction:column;gap:6px;overflow-y:auto;flex:1;min-height:0}.driver-pace-row{display:grid;grid-template-columns:90px 1fr auto auto auto;align-items:center;gap:8px;flex-shrink:0}.driver-pace-name{font-size:11px;font-weight:600;letter-spacing:.06em;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.driver-pace-bar-track{height:4px;background:var(--surface-3);border-radius:2px;overflow:hidden;border:1px solid var(--border)}.driver-pace-bar-fill{height:100%;border-radius:2px;transition:width .4s ease}.driver-pace-time{font-family:var(--font-mono);font-size:11px;font-weight:700;white-space:nowrap;letter-spacing:.04em}.driver-pace-gap{font-family:var(--font-mono);font-size:10px;color:var(--red);white-space:nowrap;letter-spacing:.04em}.driver-pace-meta{font-family:var(--font-mono);font-size:9px;color:var(--text-3);white-space:nowrap;letter-spacing:.06em}.driver-roster{display:flex;flex-direction:column;height:100%;overflow:hidden}.roster-grid{display:flex;flex:1;overflow-x:auto;padding:8px 14px;gap:10px;align-items:stretch}.driver-card{flex-shrink:0;width:190px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:8px 11px;display:flex;flex-direction:column;gap:5px;position:relative;overflow:hidden;transition:border-color .3s ease}.driver-card.driving{border-color:var(--lime);box-shadow:0 0 12px #b8ff0014}.driver-card.driving:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--lime)}.driver-card-header{display:flex;align-items:center;gap:6px;min-width:0}.driver-card-name{font-size:16px;font-weight:700;letter-spacing:.03em;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0}.driver-card.driving .driver-card-name{color:var(--lime)}.driver-card-badge{display:flex;gap:3px;flex-shrink:0}.driver-card-footer{display:flex;align-items:baseline;justify-content:space-between;gap:6px;min-width:0}.dc-badge{font-size:10px;font-weight:600;letter-spacing:.15em;padding:2px 6px;border-radius:2px;border:1px solid currentColor}.dc-badge.driving{color:var(--lime);background:var(--lime-dim)}.dc-badge.available{color:var(--green);background:#00cc550f}.dc-badge.unavail{color:var(--text-2);background:transparent}.driver-card-laps{display:flex;align-items:baseline;gap:4px}.driver-laps-value{font-family:var(--font-mono);font-size:20px;font-weight:700;color:var(--text);line-height:1}.driver-laps-label{font-size:11px;color:var(--text-2);letter-spacing:.1em}.fair-bar-container{height:5px;background:var(--surface-3);border-radius:3px;overflow:hidden;border:1px solid var(--border)}.fair-bar{height:100%;border-radius:3px;transition:width .8s ease}.fair-bar.met{background:var(--green)}.fair-bar.ontrack{background:var(--cyan)}.fair-bar.atrisk{background:var(--yellow)}.fair-bar.violation{background:var(--red);animation:bar-pulse-red .7s ease-in-out infinite}.fair-share-status{font-size:11px;font-weight:600;letter-spacing:.15em}.fair-share-status.met{color:var(--green)}.fair-share-status.ontrack{color:var(--cyan)}.fair-share-status.atrisk{color:var(--yellow)}.fair-share-status.violation{color:var(--red)}.driver-time{font-family:var(--font-mono);font-size:12px;color:var(--text-2)}.event-feed{display:flex;flex-direction:column;min-height:0;height:100%;overflow:hidden}.event-list{flex:1;min-height:0;overflow-y:auto}.event-item{display:flex;align-items:center;gap:10px;padding:7px 14px;font-size:13px;transition:background .15s}.event-item:nth-child(odd){background:#0a0f0b73}.event-item:hover{background:var(--surface-2)}.event-type{font-size:10px;font-weight:700;letter-spacing:.13em;padding:3px 6px;border-radius:2px;flex-shrink:0;min-width:72px;text-align:center}.event-type.lap{color:var(--lime);background:var(--lime-dim);border:1px solid rgba(184,255,0,.2)}.event-type.pitin{color:var(--orange);background:#ff6a0014;border:1px solid rgba(255,106,0,.2)}.event-type.pitout{color:var(--green);background:#00cc550f;border:1px solid rgba(0,204,85,.2)}.event-type.sc{color:var(--yellow);background:#ffd00014;border:1px solid rgba(255,208,0,.2)}.event-type.weather{color:var(--blue);background:#00aaff0f;border:1px solid rgba(0,170,255,.2)}.event-type.race{color:var(--red);background:#ff20200f;border:1px solid rgba(255,32,32,.2)}.event-type.default{color:var(--text-2);background:transparent;border:1px solid var(--border)}.event-summary{color:var(--text-2);flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.stint-history{display:flex;flex-direction:column;min-height:0;height:100%;overflow:hidden}.stint-empty{padding:16px 14px;font-size:13px;color:var(--text-3);letter-spacing:.1em}.gantt-wrap{flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;padding:10px 14px 6px;display:flex;flex-direction:column;gap:7px}.gantt-row{display:flex;align-items:center;gap:10px;height:28px}.gantt-label{flex-shrink:0;width:92px;font-size:12px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.gantt-lane{flex:1;position:relative;height:22px;background:var(--surface-3);border:1px solid var(--border);border-radius:3px;overflow:visible}.gantt-block{position:absolute;top:1px;bottom:1px;border-radius:2px;display:flex;align-items:center;justify-content:center;cursor:default;transition:filter .15s,box-shadow .15s;min-width:2px;overflow:hidden}.gantt-block:hover{filter:brightness(1.2);box-shadow:0 0 8px #ffffff26;z-index:2}.gantt-block-label{font-family:var(--font-mono);font-size:10px;font-weight:700;color:#050907;white-space:nowrap;line-height:1;padding:0 3px}.gantt-info{flex-shrink:0;width:52px;display:flex;align-items:baseline;gap:3px}.gantt-total-laps{font-family:var(--font-mono);font-size:16px;font-weight:700;line-height:1}.gantt-total-label{font-size:10px;color:var(--text-3);letter-spacing:.08em}.gantt-axis-row{display:flex;align-items:flex-start;gap:10px;height:18px}.gantt-axis{flex:1;position:relative;height:100%;border-top:1px solid var(--border-bright)}.gantt-tick{position:absolute;transform:translate(-50%);display:flex;flex-direction:column;align-items:center}.gantt-tick-line{width:1px;height:5px;background:var(--border-bright)}.gantt-tick-label{font-family:var(--font-mono);font-size:10px;color:var(--text-3);margin-top:1px;white-space:nowrap}.waiting-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--bg);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;z-index:100}.waiting-logo{font-size:32px;font-weight:700;letter-spacing:.15em;color:var(--lime)}.waiting-title{font-size:16px;font-weight:700;letter-spacing:.2em;color:var(--text)}.waiting-sub{font-size:13px;letter-spacing:.12em;color:var(--text-2);font-family:var(--font-mono)}.waiting-connected-icon{font-size:32px;color:var(--lime);animation:dot-pulse 1.6s ease-in-out infinite;line-height:1}.waiting-spinner{width:36px;height:36px;border:2px solid var(--border-bright);border-top-color:var(--lime);border-radius:50%;animation:spin .9s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.waiting-reconnect{font-family:var(--font-mono);font-size:14px;color:var(--orange);letter-spacing:.1em}.waiting-load-row{display:flex;flex-direction:column;align-items:center;gap:10px;margin-top:8px}.waiting-load-divider{display:flex;align-items:center;width:200px;gap:12px;color:var(--text-3);font-size:11px;letter-spacing:.15em}.waiting-load-divider:before,.waiting-load-divider:after{content:"";flex:1;height:1px;background:var(--border-bright)}.waiting-load-btn{padding:10px 24px;border:1px solid var(--border-bright);border-radius:var(--radius-lg);background:transparent;color:var(--text-2);font-family:var(--font-display);font-size:13px;font-weight:600;letter-spacing:.18em;cursor:pointer;transition:border-color .15s,color .15s,background .15s}.waiting-load-btn:hover{border-color:var(--lime);color:var(--lime);background:#b8ff000f}.waiting-load-hint{font-size:11px;color:var(--text-3);letter-spacing:.08em}.session-code-form{display:flex;flex-direction:column;align-items:center;gap:12px;margin:24px 0}.session-code-label{font-family:var(--font-display);font-size:11px;font-weight:600;letter-spacing:.2em;color:var(--text-2)}.session-code-input{width:400px;padding:12px 16px;border:1px solid var(--border-bright);border-radius:var(--radius-lg);background:var(--surface-2);color:var(--text);font-family:var(--font-mono);font-size:18px;font-weight:600;letter-spacing:.15em;text-align:center;outline:none;transition:border-color .15s,box-shadow .15s}.session-code-input::placeholder{color:var(--text-3);font-size:13px;letter-spacing:.1em;text-transform:none}.session-code-input:focus{border-color:var(--lime);box-shadow:0 0 0 3px #b8ff0026}.session-code-btn{padding:10px 32px;border:1px solid var(--lime);border-radius:var(--radius-lg);background:var(--lime);color:var(--bg);font-family:var(--font-display);font-size:13px;font-weight:700;letter-spacing:.18em;cursor:pointer;transition:background .15s,transform .1s}.session-code-btn:hover:not(:disabled){background:#c4e600}.session-code-btn:active:not(:disabled){transform:scale(.98)}.session-code-btn:disabled{opacity:.5;cursor:not-allowed}.session-code-actions{display:flex;gap:12px;align-items:center}.session-code-cancel-btn{padding:10px 24px;border:1px solid var(--border-bright);border-radius:var(--radius-lg);background:transparent;color:var(--text-2);font-family:var(--font-display);font-size:13px;font-weight:600;letter-spacing:.18em;cursor:pointer;transition:border-color .15s,color .15s}.session-code-cancel-btn:hover{border-color:var(--orange);color:var(--orange)}.waiting-error{font-family:var(--font-mono);font-size:12px;color:var(--orange);letter-spacing:.08em;margin-top:8px}.waiting-divider{display:flex;align-items:center;width:200px;gap:12px;color:var(--text-3);font-size:11px;letter-spacing:.15em;margin:16px 0}.waiting-divider:before,.waiting-divider:after{content:"";flex:1;height:1px;background:var(--border-bright)}.connect-overlay{justify-content:flex-start;padding:56px 0 48px;overflow-y:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch}.connect-layout{display:flex;align-items:stretch;gap:56px;margin-top:24px;padding:0 24px;width:100%;max-width:1480px}.connect-column{display:flex;flex-direction:column}.connect-column-form{flex:0 0 360px;align-items:center;gap:16px}.connect-column-sessions{flex:1 1 auto;min-width:0;padding-left:56px;border-left:1px solid var(--border-bright)}@media (max-width: 900px){.connect-layout{flex-direction:column;align-items:center;gap:32px}.connect-column-form{flex:0 0 auto;width:100%;max-width:480px}.connect-column-sessions{width:100%;max-width:560px;padding-left:0;padding-top:32px;border-left:none;border-top:1px solid var(--border-bright)}}.recent-sessions{width:100%;text-align:left;display:flex;flex-direction:column;height:100%}.recent-sessions-header{display:flex;align-items:center;justify-content:space-between;padding:0 6px 12px;border-bottom:1px solid var(--border-bright)}.recent-sessions-title{font-family:var(--font-display);font-size:13px;font-weight:700;letter-spacing:.24em;color:var(--text)}.recent-sessions-live{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-mono);font-size:10px;letter-spacing:.18em;color:var(--text-3)}.recent-sessions-live-dot{width:6px;height:6px;border-radius:50%;background:var(--lime);box-shadow:0 0 6px var(--lime-glow);animation:recent-sessions-pulse 1.6s ease-in-out infinite}.recent-sessions-live-loading .recent-sessions-live-dot{background:var(--text-3);box-shadow:none}.recent-sessions-live-error{color:var(--orange)}.recent-sessions-live-error .recent-sessions-live-dot{background:var(--orange);box-shadow:0 0 6px #ff6a0066;animation:none}@keyframes recent-sessions-pulse{0%,to{opacity:.45;transform:scale(.85)}50%{opacity:1;transform:scale(1.05)}}.recent-sessions-empty{padding:28px 6px;font-family:var(--font-mono);font-size:13px;letter-spacing:.1em;color:var(--text-3)}.recent-sessions-list{list-style:none;margin:0;padding:12px 0 0;display:flex;flex-direction:column;gap:8px}.recent-sessions-item{display:block}.recent-sessions-link{display:flex;align-items:center;gap:14px;padding:14px 16px;background:var(--surface);border:1px solid var(--border-bright);border-radius:var(--radius-lg);color:inherit;text-decoration:none;transition:border-color .15s,background .15s,transform .15s}.recent-sessions-link:hover{border-color:var(--lime);background:var(--surface-2)}.recent-sessions-link:focus-visible{outline:none;border-color:var(--lime);box-shadow:0 0 0 3px var(--lime-glow)}.recent-sessions-link:active{transform:translateY(1px)}.recent-sessions-code-cell{flex:0 0 auto;padding-right:12px;border-right:1px solid var(--border-bright);display:flex;align-items:center;gap:8px}.recent-sessions-badge{font-family:var(--font-mono);font-size:10px;font-weight:700;letter-spacing:.18em;padding:2px 6px;border:1px solid var(--lime);color:var(--lime);border-radius:2px;line-height:1}.recent-sessions-code{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-mono);font-size:15px;font-weight:700;letter-spacing:.12em;color:var(--lime);text-decoration:underline;text-decoration-color:#b8ff0059;text-underline-offset:3px;text-decoration-thickness:1px}.recent-sessions-link:hover .recent-sessions-code,.recent-sessions-link:focus-visible .recent-sessions-code{text-decoration-color:var(--lime)}.recent-sessions-code-icon{font-size:11px;line-height:1;opacity:.75;transform:translateY(-1px);transition:transform .15s,opacity .15s}.recent-sessions-link:hover .recent-sessions-code-icon{opacity:1;transform:translate(2px,-3px)}.recent-sessions-cell{flex:1 1 0;min-width:0;display:flex;flex-direction:column;gap:4px}.recent-sessions-cell-track,.recent-sessions-cell-car{flex:3 1 0}.recent-sessions-cell-driver{flex:.9 1 0}.recent-sessions-cell-time{flex:0 0 auto;align-items:flex-end;text-align:right;min-width:64px}.recent-sessions-cell-label{font-family:var(--font-display);font-size:12.5px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--text-2)}.recent-sessions-cell-value{font-family:var(--font-display);font-size:17px;font-weight:500;letter-spacing:0;line-height:1.25;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.recent-sessions-cell-mono{font-family:var(--font-mono);font-size:15px;font-weight:500;letter-spacing:.04em}.recent-sessions-cell-empty{color:var(--text-3)}@media (max-width: 720px){.recent-sessions-link{gap:12px;padding:12px 14px;flex-wrap:wrap}.recent-sessions-code-cell{flex:1 1 100%;border-right:none;border-bottom:1px solid var(--border-bright);padding:0 0 8px}.recent-sessions-cell{flex:1 1 45%}.recent-sessions-cell-time{flex:1 1 100%;align-items:flex-start;text-align:left}}.export-popup-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#050907d9;display:flex;align-items:center;justify-content:center;z-index:200;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.export-popup{background:var(--surface-2);border:1px solid var(--border-bright);border-radius:var(--radius-xl);padding:32px 40px;text-align:center;max-width:400px}.export-popup-icon{font-size:48px;margin-bottom:16px}.export-popup-title{font-family:var(--font-display);font-size:18px;font-weight:700;letter-spacing:.15em;color:var(--lime);margin-bottom:12px}.export-popup-message{font-family:var(--font-mono);font-size:13px;color:var(--text-2);line-height:1.5;margin-bottom:24px}.export-popup-actions{display:flex;flex-direction:column;gap:12px}.export-popup-btn{padding:12px 24px;border-radius:var(--radius-lg);font-family:var(--font-display);font-size:13px;font-weight:700;letter-spacing:.15em;cursor:pointer;transition:background .15s,transform .1s}.export-popup-btn-primary{background:var(--lime);color:var(--bg);border:1px solid var(--lime)}.export-popup-btn-primary:hover{background:#c4e600}.export-popup-btn-primary:active{transform:scale(.98)}.export-popup-btn-secondary{background:transparent;color:var(--text-2);border:1px solid var(--border-bright)}.export-popup-btn-secondary:hover{border-color:var(--text-2);color:var(--text)}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--border-bright);border-radius:2px}::-webkit-scrollbar-thumb:hover{background:var(--text-2)}.section-header{display:flex;align-items:center;gap:10px;padding:8px 14px;background:var(--surface-2);border-bottom:1px solid var(--border);font-size:11px;font-weight:600;letter-spacing:.25em;color:var(--text-2);flex-shrink:0}.section-header .lime{color:var(--lime)}.mono{font-family:var(--font-mono)}.replay-bar{flex-shrink:0;background:var(--surface-2);border-top:1px solid var(--border-bright);padding:12px 20px;display:flex;flex-direction:column;gap:10px;box-shadow:0 -4px 24px #0006}.replay-bar-header{display:flex;align-items:center;gap:16px}.replay-bar-title{font-size:12px;font-weight:700;letter-spacing:.25em;color:var(--lime);display:flex;align-items:center;gap:6px;flex-shrink:0}.replay-icon{font-size:8px;animation:dot-pulse 2s ease-in-out infinite}.replay-bar-info{display:flex;align-items:center;gap:14px;flex:1}.replay-lap{font-size:16px;font-weight:700;color:var(--text)}.replay-time{font-size:13px;color:var(--text-2)}.replay-live-badge{font-size:11px;font-weight:700;letter-spacing:.15em;color:var(--lime);background:var(--lime-dim);border:1px solid rgba(184,255,0,.25);border-radius:var(--radius);padding:2px 7px}.replay-nav-buttons{display:flex;align-items:center;gap:6px;flex-shrink:0}.replay-nav-btn{background:var(--surface-3);border:1px solid var(--border-bright);border-radius:var(--radius);color:var(--text);font-family:var(--font-display);font-size:12px;font-weight:600;letter-spacing:.15em;padding:5px 12px;cursor:pointer;transition:background .15s,border-color .15s,color .15s}.replay-nav-btn:hover:not(:disabled){background:var(--surface-4);border-color:var(--lime);color:var(--lime)}.replay-nav-btn:disabled{opacity:.3;cursor:not-allowed}.replay-live-btn{border-color:#b8ff004d;color:var(--lime)}.replay-live-btn:hover:not(:disabled){background:var(--lime-dim)}.replay-track-wrapper{position:relative}.replay-slider-pct{font-size:11px;color:var(--lime)}.replay-slider{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;height:4px;border-radius:2px;outline:none;cursor:pointer;background:linear-gradient(to right,var(--lime) 0%,var(--lime) var(--replay-pct, 0%),var(--border-bright) var(--replay-pct, 0%),var(--border-bright) 100%)}.replay-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:14px;height:14px;border-radius:50%;background:var(--lime);cursor:pointer;border:2px solid var(--bg);box-shadow:0 0 8px #b8ff0080;transition:box-shadow .15s}.replay-slider::-webkit-slider-thumb:hover{box-shadow:0 0 14px #b8ff00cc}.replay-slider::-moz-range-thumb{width:14px;height:14px;border-radius:50%;background:var(--lime);cursor:pointer;border:2px solid var(--bg);box-shadow:0 0 8px #b8ff0080}.replay-range-labels{display:flex;justify-content:space-between;font-size:11px;color:var(--text-3);letter-spacing:.1em;margin-top:3px}.replay-events{display:flex;flex-direction:column;gap:8px;border-top:1px solid var(--border);padding-top:10px;margin-top:2px}.replay-events-header{display:flex;align-items:center;gap:8px;flex-shrink:0}.replay-events-title{font-size:11px;font-weight:700;letter-spacing:.25em;color:var(--text-2)}.replay-events-count{font-family:var(--font-mono);font-size:11px;font-weight:700;background:var(--surface-4);border:1px solid var(--border-bright);border-radius:10px;padding:1px 7px;color:var(--text-2)}.replay-events-nav{display:flex;align-items:center;gap:6px;margin-left:auto}.replay-ann-nav-btn{width:26px;height:26px;background:var(--surface-3);border:1px solid var(--border-bright);border-radius:var(--radius);color:var(--text);font-size:18px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,border-color .15s,color .15s;padding:0}.replay-ann-nav-btn:hover:not(:disabled){background:var(--surface-4);border-color:var(--lime);color:var(--lime)}.replay-ann-nav-btn:disabled{opacity:.25;cursor:not-allowed}.replay-sc-nav{border-left:1px solid var(--border);padding-left:10px}.replay-sc-nav-label{font-size:10px;font-weight:700;letter-spacing:.08em;color:var(--yellow);font-family:var(--font-mono)}.replay-sc-markers{position:absolute;left:7px;right:7px;top:2px;height:8px;pointer-events:none}.replay-sc-marker{position:absolute;transform:translate(-50%);width:3px;height:8px;background:var(--yellow);border-radius:1px;opacity:.7;pointer-events:all;cursor:pointer;transition:opacity .15s,height .15s}.replay-sc-marker:hover{opacity:1;height:10px;top:-1px}.replay-sc-marker--active{opacity:1;background:var(--yellow);box-shadow:0 0 6px var(--yellow);height:10px;top:-1px}.replay-ann-pos{font-family:var(--font-mono);font-size:11px;color:var(--text-2);min-width:52px;text-align:center}.replay-events-list{display:flex;gap:8px;overflow-x:auto;padding-bottom:4px;scroll-behavior:smooth}.replay-events-list::-webkit-scrollbar{height:3px}.replay-events-list::-webkit-scrollbar-track{background:transparent}.replay-events-list::-webkit-scrollbar-thumb{background:var(--border-bright);border-radius:2px}.replay-event-chip{flex-shrink:0;width:188px;display:flex;flex-direction:column;gap:5px;padding:9px 12px;border-radius:var(--radius-lg);border:1px solid rgba(128,128,128,.2);background:var(--surface-3);cursor:pointer;text-align:left;transition:border-color .15s,background .15s,box-shadow .15s;position:relative;overflow:hidden}.replay-event-chip:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--chip-color, var(--text-3));border-radius:var(--radius-lg) 0 0 var(--radius-lg)}.replay-event-chip:hover{border-color:var(--chip-color, var(--border-bright));background:var(--surface-4);box-shadow:0 0 12px #0000004d}.replay-event-chip--active{border-color:var(--chip-color, var(--border-bright));background:color-mix(in srgb,var(--chip-color, transparent) 8%,var(--surface-3));box-shadow:0 0 16px color-mix(in srgb,var(--chip-color, transparent) 15%,transparent)}.rec-top{display:flex;align-items:baseline;justify-content:space-between;gap:6px}.rec-lap{font-family:var(--font-mono);font-size:16px;font-weight:700;color:var(--text);line-height:1}.replay-event-chip--active .rec-lap{color:var(--chip-color, var(--text))}.rec-sev{font-size:10px;font-weight:700;letter-spacing:.15em;opacity:.85}.rec-label{font-size:11px;color:var(--text-2);line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.replay-event-chip--past{opacity:.45}.replay-event-chip--alert{width:200px;min-width:200px}.race-finished-banner{display:flex;align-items:center;gap:24px;padding:11px 20px;background:var(--surface-2);border-bottom:1px solid var(--border-bright);flex-shrink:0;overflow:hidden;position:relative}.race-finished-banner:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--yellow)}.race-finished-banner--replay:before{background:var(--cyan)}.rfb-left{display:flex;align-items:center;gap:12px;flex-shrink:0}.rfb-flag{font-size:20px;line-height:1}.rfb-title{font-size:17px;font-weight:700;letter-spacing:.14em;color:var(--yellow);white-space:nowrap}.race-finished-banner--replay .rfb-title{color:var(--cyan)}.rfb-divider{width:1px;height:32px;background:var(--border-bright);flex-shrink:0}.rfb-stats{display:flex;align-items:center;gap:22px;flex:1}.rfb-stat{display:flex;flex-direction:column;gap:2px}.rfb-stat-label{font-size:11px;font-weight:600;letter-spacing:.18em;color:var(--text-2)}.rfb-stat-value{font-family:var(--font-mono);font-size:18px;font-weight:700;color:var(--text);line-height:1}.rfb-hint{font-size:13px;color:var(--text);letter-spacing:.03em;text-align:right;flex-shrink:0;max-width:320px;line-height:1.5;opacity:.7}.rfb-export-btn{flex-shrink:0;margin-left:auto;padding:7px 16px;border:1px solid var(--border-bright);border-radius:var(--radius-lg);background:transparent;color:var(--text-2);font-family:var(--font-display);font-size:11px;font-weight:700;letter-spacing:.18em;cursor:pointer;transition:border-color .15s,color .15s,background .15s;white-space:nowrap}.rfb-export-btn:hover{border-color:var(--lime);color:var(--lime);background:#b8ff000f}.driver-finished-indicator{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;margin-top:14px;font-size:14px;font-weight:700;letter-spacing:.22em;color:var(--lime);padding:8px 10px;background:#b8ff0014;border:1px solid rgba(184,255,0,.35);border-radius:var(--radius);text-transform:uppercase}.panel--finished{opacity:.85}.panel--finished .panel-label{color:var(--text-3)}.pit-rec--finished{border-color:#ffd00026!important;box-shadow:none!important;animation:none!important;opacity:.8}.pit-action-text--finished{font-size:32px;font-weight:700;letter-spacing:.08em;color:var(--yellow);opacity:.75}.pit-rec--replay{opacity:.95}.pit-rec--replay .pit-rec-label{color:var(--cyan)}.fuel-bar--static:after{animation:none!important}.alert-item--jumpable{cursor:pointer;transition:background .15s,padding-left .15s}.alert-item--jumpable:hover{background:var(--surface-3)!important;padding-left:18px}.alert-item--jumpable:hover .alert-jump-hint{opacity:1}.alert-jump-hint{font-family:var(--font-mono);font-size:10px;font-weight:700;letter-spacing:.15em;color:var(--lime);opacity:0;transition:opacity .15s;margin-left:4px}.event-item--replay-match{background:#00e5b014!important;border-left:2px solid var(--cyan)!important}.pit-stop-row--replay-match{box-shadow:inset 2px 0 0 var(--lime)}.weather-panel-content{display:flex;align-items:center;gap:16px}.weather-panel-icon{font-size:38px;line-height:1;flex-shrink:0}.weather-panel-right{display:flex;flex-direction:column;gap:7px}.weather-panel-condition{font-size:18px;font-weight:700;letter-spacing:.06em;color:var(--text);line-height:1}.weather-panel--dry .weather-panel-condition{color:var(--lime)}.weather-panel--light-rain .weather-panel-condition{color:var(--blue)}.weather-panel--heavy-rain .weather-panel-condition{color:var(--orange)}.weather-panel-tire{font-size:11px;font-weight:700;letter-spacing:.16em;padding:3px 9px;border-radius:3px;display:inline-block}.weather-panel-tire--dry{color:var(--lime);border:1px solid rgba(184,255,0,.3);background:var(--lime-dim)}.weather-panel-tire--light-rain{color:var(--blue);border:1px solid rgba(0,170,255,.25);background:#00aaff0f}.weather-panel-tire--heavy-rain{color:var(--orange);border:1px solid rgba(255,106,0,.35);background:#ff6a000f;animation:badge-blink-warn 1.6s step-end infinite}.sc-indicator{border-left:3px solid var(--border)}.sc-indicator--active{border-left-color:var(--yellow);background:#ffd00014}.sc-indicator-content{display:flex;align-items:center;gap:8px;margin-top:4px}.sc-indicator-dot{width:10px;height:10px;border-radius:50%;background:var(--border)}.sc-indicator--active .sc-indicator-dot{background:var(--yellow);box-shadow:0 0 8px var(--yellow);animation:sc-blink .8s ease-in-out infinite}.sc-indicator-text{font-family:var(--font-mono);font-size:12px;letter-spacing:.1em;color:var(--text-3)}.sc-indicator--active .sc-indicator-text{color:var(--yellow);font-weight:600}@keyframes sc-blink{0%,to{opacity:1}50%{opacity:.4}}.mobile-tab-bar{display:none}@media (max-width: 1200px){.race-header{min-height:52px}.race-header-brand{min-width:110px;max-width:130px;padding:8px 12px}.brand-name{font-size:13px;letter-spacing:.08em}.brand-sub,.header-stat-event{display:none}.race-header-subrow{display:flex;align-items:center;gap:16px;padding:10px 12px;background:var(--surface);border-bottom:1px solid var(--border);overflow-x:auto;scrollbar-width:none;flex-shrink:0}.race-header-subrow::-webkit-scrollbar{display:none}.subrow-item{display:inline-flex;align-items:baseline;gap:6px;white-space:nowrap}.subrow-label{font-family:var(--font-display);font-size:13px;letter-spacing:.1em;color:var(--text-3)}.subrow-value{font-size:16px;color:var(--text-1)}.race-header-center{gap:12px;padding:0 12px}.header-stat-label{font-size:10px}.header-stat-value{font-size:19px}.race-header-right{padding:0 10px;gap:8px}.race-header-right .header-divider,.weather-label,.profile-badge{display:none}.conn-status{font-size:10px;letter-spacing:.08em}.mobile-tab-bar{display:flex;flex-shrink:0;background:var(--surface);border-bottom:2px solid var(--border);z-index:5}.mobile-tab-btn{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:8px 4px 9px;min-height:50px;background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;cursor:pointer;color:var(--text-3);font-family:var(--font-display);letter-spacing:.15em;transition:color .15s ease,border-color .15s ease;-webkit-tap-highlight-color:transparent}.mobile-tab-btn.active{color:var(--lime);border-bottom-color:var(--lime)}.mobile-tab-icon{font-size:15px;line-height:1}.mobile-tab-label{font-size:8px;font-weight:700;letter-spacing:.2em}.main-body{grid-template-columns:1fr;grid-template-rows:1fr}.col-left,.col-center,.col-right{display:none}.col-left{border-right:none}.col-right{border-left:none}.app-shell[data-mobile-tab=telemetry] .main-body{display:grid}.app-shell[data-mobile-tab=telemetry] .col-left{display:flex}.app-shell[data-mobile-tab=strategy] .main-body{display:grid}.app-shell[data-mobile-tab=strategy] .col-center{display:flex}.app-shell[data-mobile-tab=alerts] .main-body{display:grid}.app-shell[data-mobile-tab=alerts] .col-right{display:flex}.session-code-input{width:100%;max-width:380px}.session-code-btn,.session-code-cancel-btn,.waiting-load-btn{min-height:48px}.race-finished-banner{flex-wrap:wrap;gap:8px;padding:8px 14px}.replay-bar{padding:10px 14px;gap:8px}.replay-bar-header{flex-wrap:wrap;gap:6px 12px}.replay-nav-buttons{width:100%;gap:8px}.replay-nav-btn{flex:1;min-height:40px;justify-content:center;text-align:center}}@media (max-width: 640px){.race-header-center>div:nth-child(n+4){display:none}.race-header-brand{min-width:80px;max-width:95px;padding:7px 10px}.brand-name{font-size:11px}.header-stat-value{font-size:17px}.header-stat-label{font-size:9px}.waiting-logo{font-size:22px;letter-spacing:.12em}.waiting-overlay{padding:32px 20px}.session-code-input{width:100%;max-width:none}.race-finished-banner{flex-direction:column;align-items:flex-start}.rfb-divider{display:none}.rfb-stats{flex-wrap:wrap;gap:12px}}
