:root{--color-karting-red: #E92C2C;--color-track-navy: #0E1A2B;--color-asphalt-gray: #23272E;--color-pit-gray: #2F3640;--color-telemetry-silver: #A9B4C2;--color-green-delta: #2EC27E;--color-amber-apex: #FFB100;--color-heat-red: #FF3B30;--color-neon-green: #39FF14;--color-lap-cyan: #17C2E6;--color-sector-violet: #7C57FF;--color-g-force-lime: #A8E063;--color-text-primary: #FFFFFF;--color-text-secondary: #A9B4C2;--color-text-tertiary: #6B7280;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--radius-card: 12px;--radius-button: 24px;--radius-input: 6px;--elevation-card: 0 2px 8px rgba(0, 0, 0, .2);--elevation-card-hover: 0 4px 12px rgba(0, 0, 0, .3)}*{box-sizing:border-box;margin:0;padding:0}body{margin:0;font-family:Inter,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--color-track-navy);color:var(--color-text-primary)}#root{min-height:100vh}.tracktaktak-button{min-height:56px;padding:16px 24px;border:none;border-radius:var(--radius-button);font-family:Inter,sans-serif;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease;display:inline-flex;align-items:center;justify-content:center;gap:8px}.tracktaktak-button:disabled{opacity:.6;cursor:not-allowed}.tracktaktak-button--primary{background-color:var(--color-neon-green);color:var(--color-track-navy)}.tracktaktak-button--primary:hover:not(:disabled){background-color:var(--color-green-delta);transform:translateY(-2px);box-shadow:0 4px 12px #39ff144d}.tracktaktak-button--primary:active:not(:disabled){transform:translateY(0)}.tracktaktak-button--secondary{background-color:var(--color-pit-gray);color:var(--color-text-primary)}.tracktaktak-button--secondary:hover:not(:disabled){background-color:var(--color-asphalt-gray);transform:translateY(-2px);box-shadow:0 4px 12px #0003}.tracktaktak-button--secondary:active:not(:disabled){transform:translateY(0)}.tracktaktak-button--danger{background-color:var(--color-heat-red);color:var(--color-text-primary)}.tracktaktak-button--danger:hover:not(:disabled){background-color:var(--color-karting-red);transform:translateY(-2px);box-shadow:0 4px 12px #ff3b304d}.tracktaktak-button--danger:active:not(:disabled){transform:translateY(0)}.tracktaktak-button--info{background-color:var(--color-lap-cyan);color:var(--color-text-primary)}.tracktaktak-button--info:hover:not(:disabled){background-color:var(--color-lap-cyan);opacity:.9;transform:translateY(-2px);box-shadow:0 4px 12px #17c2e64d}.tracktaktak-button--info:active:not(:disabled){transform:translateY(0)}.login-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background-color:var(--color-track-navy)}.login-card{background:var(--color-asphalt-gray);padding:2.5rem;border-radius:var(--radius-card);box-shadow:var(--elevation-card-hover);width:100%;max-width:400px}.login-card h1{margin:0 0 .5rem;color:var(--color-text-primary);font-size:2rem;font-weight:700;font-family:Inter Display,Inter,sans-serif}.login-card h2{margin:0 0 2rem;color:var(--color-text-secondary);font-size:1.25rem;font-weight:500}.login-footer{margin-top:1.5rem;text-align:center}.login-footer a{color:var(--color-lap-cyan);text-decoration:none;font-size:.9rem;transition:color .2s}.login-footer a:hover{color:var(--color-neon-green);text-decoration:underline}.verification-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.verification-dialog{background:var(--color-asphalt-gray);padding:2rem;border-radius:var(--radius-card);box-shadow:var(--elevation-card-hover);width:90%;max-width:400px}.verification-dialog h2{margin:0 0 1rem;color:var(--color-text-primary);font-size:1.5rem;font-weight:600;font-family:Inter Display,Inter,sans-serif}.verification-instructions{margin:0 0 1.5rem;color:var(--color-text-secondary);font-size:.9rem;line-height:1.5}.verification-instructions strong{color:var(--color-text-primary);font-weight:600}.verification-code-input-group{margin-bottom:1rem}.verification-code-input{width:100%;padding:1rem;border:2px solid var(--color-telemetry-silver);border-radius:var(--radius-input);font-size:1.5rem;text-align:center;letter-spacing:.5rem;font-weight:600;background-color:var(--color-pit-gray);color:var(--color-text-primary);transition:border-color .2s,box-shadow .2s;box-sizing:border-box;font-family:JetBrains Mono,monospace}.verification-code-input:focus{outline:none;border-color:var(--color-lap-cyan);box-shadow:0 0 0 3px #17c2e61a}.verification-code-input:disabled{background-color:var(--color-asphalt-gray);cursor:not-allowed;opacity:.6}.verification-error{padding:.75rem;margin-bottom:1rem;background-color:#ff3b3033;color:var(--color-heat-red);border-radius:var(--radius-input);font-size:.9rem;border:1px solid var(--color-heat-red)}.verification-actions{display:flex;gap:.75rem;justify-content:flex-end}.registration-container{display:flex;justify-content:center;align-items:center;min-height:100vh;padding:2rem 1rem;background-color:var(--color-track-navy)}.registration-card{background:var(--color-asphalt-gray);padding:2.5rem;border-radius:var(--radius-card);box-shadow:var(--elevation-card-hover);width:100%;max-width:500px}.registration-card h1{margin:0 0 .5rem;color:var(--color-text-primary);font-size:2rem;font-weight:700;font-family:Inter Display,Inter,sans-serif}.registration-card h2{margin:0 0 2rem;color:var(--color-text-secondary);font-size:1.25rem;font-weight:500}.form-group label{display:block;margin-bottom:.5rem;color:var(--color-text-secondary);font-weight:500;font-size:.9rem}.form-group input{width:100%;padding:.75rem;border:1px solid var(--color-telemetry-silver);border-radius:var(--radius-input);font-size:1rem;background-color:var(--color-pit-gray);color:var(--color-text-primary);transition:border-color .2s,box-shadow .2s;box-sizing:border-box}.form-group input:focus{outline:none;border-color:var(--color-lap-cyan);box-shadow:0 0 0 3px #17c2e61a}.form-group input:disabled{background-color:var(--color-asphalt-gray);cursor:not-allowed;opacity:.6}.form-group input.error{border-color:var(--color-heat-red)}.field-error{margin-top:.25rem;color:var(--color-heat-red);font-size:.875rem}.error-message{padding:.75rem;margin-bottom:1rem;background-color:#ff3b3033;color:var(--color-heat-red);border-radius:var(--radius-input);font-size:.9rem;border:1px solid var(--color-heat-red)}.registration-footer{margin-top:1.5rem;text-align:center}.registration-footer a{color:var(--color-lap-cyan);text-decoration:none;font-size:.9rem;transition:color .2s}.registration-footer a:hover{color:var(--color-neon-green);text-decoration:underline}.resend-verification-button{width:100%}.mychron-modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.mychron-modal{background:var(--color-asphalt-gray);border-radius:16px;box-shadow:0 20px 60px #00000080;width:100%;max-width:560px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column}.mychron-modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--color-pit-gray);background:var(--color-pit-gray);color:var(--color-text-primary)}.mychron-modal-header h2{margin:0;font-size:20px;font-weight:600}.close-button{background:none;border:none;font-size:28px;cursor:pointer;color:#fff;opacity:.8;transition:opacity .2s;padding:0;line-height:1}.close-button:hover{opacity:1}.mychron-modal-content{padding:24px;overflow-y:auto;flex:1}.step-description{color:var(--color-text-secondary);margin-bottom:20px;line-height:1.5}.format-selector{display:flex;gap:16px;margin-bottom:24px;padding:16px;background:var(--color-pit-gray);border-radius:10px}.format-option{display:flex;align-items:center;gap:8px;cursor:pointer;padding:8px 16px;border-radius:8px;transition:background .2s;flex:1}.format-option:hover{background:var(--color-asphalt-gray)}.format-option input[type=radio]{margin:0;cursor:pointer;accent-color:var(--color-lap-cyan)}.format-option span{font-weight:500;color:var(--color-text-primary)}.file-upload-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:20px}.file-upload-grid.single-file{grid-template-columns:1fr}.file-dropzone{border:2px dashed var(--color-telemetry-silver);border-radius:12px;padding:24px;text-align:center;cursor:pointer;position:relative;transition:all .2s ease;background:var(--color-pit-gray)}.file-dropzone:hover,.file-dropzone.dragging{border-color:var(--color-lap-cyan);background:var(--color-asphalt-gray)}.file-dropzone.has-file{border-color:var(--color-green-delta);background:#2ec27e1a;border-style:solid}.dropzone-content{display:flex;flex-direction:column;align-items:center;gap:8px}.file-icon{font-size:32px}.file-type{font-weight:600;color:var(--color-text-primary)}.file-hint{font-size:12px;color:var(--color-text-tertiary)}.file-name{font-size:13px;color:var(--color-green-delta);font-weight:500;word-break:break-all}.drop-hint{font-size:12px;color:var(--color-text-tertiary)}.file-input{position:absolute;top:0;left:0;width:100%;height:100%;opacity:0;cursor:pointer}.preview-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-bottom:24px}.stat-item{background:var(--color-pit-gray);padding:16px;border-radius:10px;text-align:center}.stat-label{display:block;font-size:12px;color:var(--color-text-tertiary);margin-bottom:4px;text-transform:uppercase;letter-spacing:.5px}.stat-value{display:block;font-size:20px;font-weight:600;color:var(--color-lap-cyan);font-family:JetBrains Mono,monospace}.preview-metadata{background:var(--color-pit-gray);border-radius:10px;padding:16px;margin-bottom:20px}.preview-metadata h4{margin:0 0 12px;font-size:14px;color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.5px}.metadata-item{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid #eee}.metadata-item:last-child{border-bottom:none}.metadata-label{color:var(--color-text-tertiary)}.metadata-value{color:var(--color-text-primary);font-weight:500}.form-group{margin-bottom:20px}.form-group label{display:block;font-weight:500;margin-bottom:8px;color:var(--color-text-secondary)}.track-dropdown,.session-name-input{width:100%;padding:12px 16px;font-size:15px;border:2px solid var(--color-telemetry-silver);border-radius:var(--radius-input);background:var(--color-pit-gray);color:var(--color-text-primary);transition:border-color .2s}.track-dropdown:focus,.session-name-input:focus{outline:none;border-color:var(--color-lap-cyan);box-shadow:0 0 0 3px #17c2e61a}.modal-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:24px;padding-top:20px;border-top:1px solid var(--color-pit-gray)}.converting-step{text-align:center;padding:40px 20px}.loading-spinner{width:48px;height:48px;border:4px solid var(--color-pit-gray);border-top-color:var(--color-lap-cyan);border-radius:50%;margin:0 auto 20px;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.converting-hint{font-size:13px;color:var(--color-text-tertiary)}.success-step{text-align:center;padding:20px}.success-icon{width:64px;height:64px;background:var(--color-green-delta);color:var(--color-track-navy);font-size:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 20px}.success-step h3{color:var(--color-green-delta);margin-bottom:8px}.error-step{text-align:center;padding:20px}.error-icon{width:64px;height:64px;background:var(--color-heat-red);color:var(--color-text-primary);font-size:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 20px}.error-step h3{color:var(--color-heat-red);margin-bottom:8px}.error-message{color:var(--color-heat-red);background:#ff3b3033;padding:12px 16px;border-radius:var(--radius-input);margin:16px 0;border:1px solid var(--color-heat-red)}@media(max-width:600px){.mychron-modal{margin:16px;max-height:calc(100vh - 32px)}.file-upload-grid,.preview-stats{grid-template-columns:1fr}.modal-actions{flex-direction:column}.btn-primary,.btn-secondary{width:100%}}.tracktaktak-card{background-color:var(--color-asphalt-gray);border-radius:var(--radius-card);padding:var(--spacing-md);box-shadow:var(--elevation-card);transition:all .2s ease}.tracktaktak-card--clickable{cursor:pointer}.tracktaktak-card--clickable:hover{box-shadow:var(--elevation-card-hover);transform:translateY(-2px)}.tracktaktak-card--clickable:active{transform:translateY(0)}.sessions-container{min-height:100vh;background-color:var(--color-track-navy)}.sessions-header{background:var(--color-asphalt-gray);color:var(--color-text-primary);padding:1.5rem 2rem;box-shadow:var(--elevation-card)}.sessions-header h1{margin:0;font-size:1.75rem;font-weight:700;color:var(--color-text-primary)}.header-user{display:flex;align-items:center;gap:1rem}.header-user span{font-size:.9rem;opacity:.9}.sessions-main{max-width:1200px;margin:0 auto;padding:2rem}.sessions-title-bar{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.sessions-title-bar h2{margin:0;color:var(--color-text-primary);font-size:1.5rem;font-weight:600;font-family:Inter Display,Inter,sans-serif}.title-bar-actions{display:flex;gap:.75rem;align-items:center}.sessions-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem}.session-card-header{margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;align-items:center}.session-card-header h3{margin:0;color:var(--color-text-primary);font-size:1.1rem;font-weight:600;flex:1}.delete-button{background:none;border:none;cursor:pointer;font-size:1.2rem;padding:.25rem .5rem;border-radius:4px;transition:background-color .2s;opacity:.6;color:var(--color-text-secondary)}.session-card-info{display:flex;flex-direction:column;gap:.75rem}.info-row{display:flex;justify-content:space-between;align-items:center}.info-label{color:var(--color-text-tertiary);font-size:.875rem;font-weight:500}:root,:host{--ol-background-color: white;--ol-accent-background-color: #F5F5F5;--ol-subtle-background-color: rgba(128, 128, 128, .25);--ol-partial-background-color: rgba(255, 255, 255, .75);--ol-foreground-color: #333333;--ol-subtle-foreground-color: #666666;--ol-brand-color: #00AAFF}.ol-box{box-sizing:border-box;border-radius:2px;border:1.5px solid var(--ol-background-color);background-color:var(--ol-partial-background-color)}.ol-mouse-position{top:8px;right:8px;position:absolute}.ol-scale-line{background:var(--ol-partial-background-color);border-radius:4px;bottom:8px;left:8px;padding:2px;position:absolute}.ol-scale-line-inner{border:1px solid var(--ol-subtle-foreground-color);border-top:none;color:var(--ol-foreground-color);font-size:10px;text-align:center;margin:1px;will-change:contents,width;transition:all .25s}.ol-scale-bar{position:absolute;bottom:8px;left:8px}.ol-scale-bar-inner{display:flex}.ol-scale-step-marker{width:1px;height:15px;background-color:var(--ol-foreground-color);float:right;z-index:10}.ol-scale-step-text{position:absolute;bottom:-5px;font-size:10px;z-index:11;color:var(--ol-foreground-color);text-shadow:-1.5px 0 var(--ol-partial-background-color),0 1.5px var(--ol-partial-background-color),1.5px 0 var(--ol-partial-background-color),0 -1.5px var(--ol-partial-background-color)}.ol-scale-text{position:absolute;font-size:12px;text-align:center;bottom:25px;color:var(--ol-foreground-color);text-shadow:-1.5px 0 var(--ol-partial-background-color),0 1.5px var(--ol-partial-background-color),1.5px 0 var(--ol-partial-background-color),0 -1.5px var(--ol-partial-background-color)}.ol-scale-singlebar{position:relative;height:10px;z-index:9;box-sizing:border-box;border:1px solid var(--ol-foreground-color)}.ol-scale-singlebar-even{background-color:var(--ol-subtle-foreground-color)}.ol-scale-singlebar-odd{background-color:var(--ol-background-color)}.ol-unsupported{display:none}.ol-viewport,.ol-unselectable{-webkit-touch-callout:none;-webkit-user-select:none;-moz-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.ol-viewport canvas{all:unset;overflow:hidden}.ol-viewport{touch-action:pan-x pan-y}.ol-selectable{-webkit-touch-callout:default;-webkit-user-select:text;-moz-user-select:text;user-select:text}.ol-grabbing{cursor:-webkit-grabbing;cursor:-moz-grabbing;cursor:grabbing}.ol-grab{cursor:move;cursor:-webkit-grab;cursor:-moz-grab;cursor:grab}.ol-control{position:absolute;background-color:var(--ol-subtle-background-color);border-radius:4px}.ol-zoom{top:.5em;left:.5em}.ol-rotate{top:.5em;right:.5em;transition:opacity .25s linear,visibility 0s linear}.ol-rotate.ol-hidden{opacity:0;visibility:hidden;transition:opacity .25s linear,visibility 0s linear .25s}.ol-zoom-extent{top:4.643em;left:.5em}.ol-full-screen{right:.5em;top:.5em}.ol-control button{display:block;margin:1px;padding:0;color:var(--ol-subtle-foreground-color);font-weight:700;text-decoration:none;font-size:inherit;text-align:center;height:1.375em;width:1.375em;line-height:.4em;background-color:var(--ol-background-color);border:none;border-radius:2px}.ol-control button::-moz-focus-inner{border:none;padding:0}.ol-zoom-extent button{line-height:1.4em}.ol-compass{display:block;font-weight:400;will-change:transform}.ol-touch .ol-control button{font-size:1.5em}.ol-touch .ol-zoom-extent{top:5.5em}.ol-control button:hover,.ol-control button:focus{text-decoration:none;outline:1px solid var(--ol-subtle-foreground-color);color:var(--ol-foreground-color)}.ol-zoom .ol-zoom-in{border-radius:2px 2px 0 0}.ol-zoom .ol-zoom-out{border-radius:0 0 2px 2px}.ol-attribution{text-align:right;bottom:.5em;right:.5em;max-width:calc(100% - 1.3em);display:flex;flex-flow:row-reverse;align-items:center}.ol-attribution a{color:var(--ol-subtle-foreground-color);text-decoration:none}.ol-attribution ul{margin:0;padding:1px .5em;color:var(--ol-foreground-color);text-shadow:0 0 2px var(--ol-background-color);font-size:12px}.ol-attribution li{display:inline;list-style:none}.ol-attribution li:not(:last-child):after{content:" "}.ol-attribution img{max-height:2em;max-width:inherit;vertical-align:middle}.ol-attribution button{flex-shrink:0}.ol-attribution.ol-collapsed ul{display:none}.ol-attribution:not(.ol-collapsed){background:var(--ol-partial-background-color)}.ol-attribution.ol-uncollapsible{bottom:0;right:0;border-radius:4px 0 0}.ol-attribution.ol-uncollapsible img{margin-top:-.2em;max-height:1.6em}.ol-attribution.ol-uncollapsible button{display:none}.ol-zoomslider{top:4.5em;left:.5em;height:200px}.ol-zoomslider button{position:relative;height:10px}.ol-touch .ol-zoomslider{top:5.5em}.ol-overviewmap{left:.5em;bottom:.5em}.ol-overviewmap.ol-uncollapsible{bottom:0;left:0;border-radius:0 4px 0 0}.ol-overviewmap .ol-overviewmap-map,.ol-overviewmap button{display:block}.ol-overviewmap .ol-overviewmap-map{border:1px solid var(--ol-subtle-foreground-color);height:150px;width:150px}.ol-overviewmap:not(.ol-collapsed) button{bottom:0;left:0;position:absolute}.ol-overviewmap.ol-collapsed .ol-overviewmap-map,.ol-overviewmap.ol-uncollapsible button{display:none}.ol-overviewmap:not(.ol-collapsed){background:var(--ol-subtle-background-color)}.ol-overviewmap-box{border:1.5px dotted var(--ol-subtle-foreground-color)}.ol-overviewmap .ol-overviewmap-box:hover{cursor:move}.ol-overviewmap .ol-viewport:hover{cursor:pointer}.map-container{width:100%;height:600px;border-radius:var(--radius-card);overflow:hidden;background-color:var(--color-pit-gray);position:relative}.map-empty-state{display:flex;justify-content:center;align-items:center;height:100%;color:var(--color-text-secondary);font-size:1.1rem}.ol-control{background-color:#23272ee6;border-radius:4px}.ol-control button{background-color:#23272ee6;color:var(--color-text-primary);font-weight:600}.ol-control button:hover{background-color:#2f3640f2}.ol-attribution{font-size:.7rem}.acceleration-legend{position:absolute;top:10px;right:10px;background:#23272ef2;padding:10px;border-radius:var(--radius-input);box-shadow:var(--elevation-card);z-index:1000;font-size:12px;color:var(--color-text-primary);border:1px solid var(--color-pit-gray)}.legend-item{display:flex;align-items:center;margin-bottom:5px}.legend-item:last-child{margin-bottom:0}.color-gradient{display:flex;align-items:center;gap:8px;font-size:11px}.color-start{color:red;font-weight:500}.gradient-bar{width:80px;height:6px;background:linear-gradient(to right,red,#ff0,#0f0);border-radius:3px;border:1px solid rgba(0,0,0,.1)}.color-end{color:#0a0;font-weight:500}.session-details-container{min-height:100vh;background-color:var(--color-track-navy)}.details-header{background:var(--color-asphalt-gray);color:var(--color-text-primary);padding:1.5rem 2rem;box-shadow:var(--elevation-card);display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.details-header h1{margin:0;flex:1;font-size:1.75rem;font-weight:700;font-family:Inter Display,Inter,sans-serif}.details-main{max-width:1200px;margin:0 auto;padding:2rem;display:flex;flex-direction:column;gap:2rem}.session-info-panel h2,.map-panel h2,.laps-panel h2{margin:0 0 1.5rem;color:var(--color-text-primary);font-size:1.25rem;font-weight:600;font-family:Inter Display,Inter,sans-serif}.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem}.info-item{display:flex;flex-direction:column;gap:.5rem}.info-item-label{color:var(--color-text-tertiary);font-size:.875rem;font-weight:500;text-transform:uppercase;letter-spacing:.05em}.info-item-value{color:var(--color-text-primary);font-size:1.25rem;font-weight:600}.info-item-value.highlight{color:var(--color-lap-cyan);font-size:1.5rem;font-family:JetBrains Mono,monospace}.map-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.map-header h2{margin:0}.lap-indicator{color:var(--color-lap-cyan);font-weight:500}.gps-count{margin:0 0 1rem;color:var(--color-text-secondary);font-size:.9rem}.laps-header{margin-bottom:1rem}.laps-header h2{margin-bottom:.25rem}.laps-hint{margin:0;color:var(--color-text-tertiary);font-size:.8rem;font-style:italic}.laps-table{overflow-x:auto}.laps-table table{width:100%;border-collapse:collapse}.laps-table th{text-align:left;padding:.75rem;background-color:var(--color-pit-gray);color:var(--color-text-secondary);font-weight:600;font-size:.875rem;text-transform:uppercase;letter-spacing:.05em;border-bottom:2px solid var(--color-asphalt-gray)}.laps-table td{padding:.75rem;color:var(--color-text-primary);font-size:.9rem;border-bottom:1px solid var(--color-pit-gray)}.laps-table .lap-row{cursor:pointer;transition:background-color .15s,box-shadow .15s}.laps-table .lap-row:hover{background-color:var(--color-pit-gray)}.laps-table .lap-row.selected{background-color:#17c2e61a;box-shadow:inset 3px 0 0 var(--color-lap-cyan)}.laps-table .lap-row.selected:hover{background-color:#17c2e626}.laps-table td.best-lap{color:var(--color-lap-cyan);font-weight:700;font-family:JetBrains Mono,monospace}.laps-table .incomplete-lap{color:var(--color-text-tertiary);font-style:italic}.error-message{padding:1rem;margin:2rem;background-color:#ff3b3033;color:var(--color-heat-red);border-radius:var(--radius-input);font-size:.9rem;border:1px solid var(--color-heat-red)}.map-controls{display:flex;gap:1rem;align-items:center}.acceleration-toggle{display:flex;align-items:center;gap:.5rem;font-size:.9rem;font-weight:500;color:var(--color-text-secondary);cursor:pointer}.status-badge{padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase;display:inline-block}.status-created{background-color:#17c2e633;color:var(--color-lap-cyan)}.status-started,.status-recording{background-color:#ffb10033;color:var(--color-amber-apex)}.status-finished{background-color:#2ec27e33;color:var(--color-green-delta)}.status-paused{background-color:#ff3b3033;color:var(--color-heat-red)}.acceleration-toggle input[type=checkbox]{margin:0}.map-type-switcher{position:absolute;top:10px;right:10px;z-index:1000;display:flex;gap:4px;background:#23272ee6;border-radius:4px;padding:4px;box-shadow:0 2px 8px #0000004d}.map-type-button{background:transparent;border:none;color:var(--color-text-primary);font-size:1.2rem;padding:8px 12px;cursor:pointer;border-radius:4px;transition:background-color .2s;opacity:.7}.map-type-button:hover{background-color:#2f3640cc;opacity:1}.map-type-button.active{background-color:#17c2e64d;opacity:1}.create-track-view{display:flex;flex-direction:column;height:100vh;background-color:var(--color-track-navy)}.map-container{flex:1;position:relative}.control-panel{background:var(--color-asphalt-gray);color:var(--color-text-primary);padding:1rem 1.5rem;box-shadow:var(--elevation-card);z-index:1000}.control-panel h2{margin-top:0;color:var(--color-text-primary)}.control-panel p{color:var(--color-text-primary)}.control-panel label{color:var(--color-text-primary);display:inline-flex;align-items:center;margin-right:1.5rem;cursor:pointer;white-space:nowrap}.control-panel input[type=radio]{width:auto;margin:0 .5rem 0 0;cursor:pointer}.control-panel button{margin:0;padding:8px 16px;background:var(--color-lap-cyan);color:var(--color-track-navy);border:none;border-radius:var(--radius-button);cursor:pointer;font-weight:600;transition:background-color .2s;font-size:.9rem}.control-panel button:hover:not(:disabled){background:var(--color-lap-cyan);opacity:.9}.control-panel button:disabled{background:var(--color-pit-gray);color:var(--color-text-tertiary);cursor:not-allowed;opacity:.6}.control-panel input,.control-panel textarea{width:100%;padding:12px;margin:8px 0;background:var(--color-pit-gray);color:var(--color-text-primary);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-input);font-size:1rem;font-family:inherit}.control-panel textarea{resize:vertical;min-height:80px}.control-panel label{display:block;margin-bottom:.5rem;color:var(--color-text-primary);font-weight:500}.control-panel input::placeholder{color:var(--color-text-tertiary)}.control-panel input:focus{outline:none;border-color:var(--color-lap-cyan)}.error{color:var(--color-heat-red);margin-top:8px;padding:1rem;background-color:#ff3b3033;border-radius:var(--radius-input);border:1px solid var(--color-heat-red)}.recommendation{margin-top:.5rem;padding:8px 12px;background-color:#00bfff1a;border-radius:var(--radius-input);border:1px solid rgba(0,191,255,.3);color:var(--color-lap-cyan);font-size:.85rem;line-height:1.3}.modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;justify-content:center;align-items:center;z-index:2000}.modal-content{background:var(--color-asphalt-gray);color:var(--color-text-primary);padding:2rem;border-radius:var(--radius-card);max-width:500px;width:90%;max-height:90vh;overflow-y:auto;box-shadow:var(--elevation-card-hover)}.modal-content h2{margin-top:0;color:var(--color-text-primary);margin-bottom:1.5rem}.modal-content h3{color:var(--color-text-primary);font-size:1rem;margin-top:1.5rem;margin-bottom:.5rem}.form-group{margin-bottom:1.5rem}.form-group>label{width:auto;display:inline-flex}.form-group label{display:inline-flex;align-items:center;color:var(--color-text-primary);cursor:pointer;margin-bottom:.5rem;white-space:nowrap}.form-group input[type=checkbox]{margin-right:.5rem;cursor:pointer}.form-group ul{list-style:none;padding:0;margin:.5rem 0}.form-group li{display:flex;justify-content:space-between;align-items:center;padding:.5rem;background:var(--color-pit-gray);border-radius:var(--radius-input);margin-bottom:.5rem;color:var(--color-text-primary)}.form-group button{background:var(--color-lap-cyan);color:var(--color-track-navy);border:none;padding:.5rem 1rem;border-radius:var(--radius-button);cursor:pointer;font-weight:600;transition:opacity .2s}.form-group button:hover{opacity:.9}.modal-actions{display:flex;justify-content:flex-end;gap:1rem;margin-top:2rem}.modal-actions button{padding:.75rem 1.5rem;border:none;border-radius:var(--radius-button);cursor:pointer;font-weight:600;transition:opacity .2s}.modal-actions button:first-child{background:var(--color-pit-gray);color:var(--color-text-primary)}.modal-actions button:last-child{background:var(--color-lap-cyan);color:var(--color-track-navy)}.modal-actions button:hover:not(:disabled){opacity:.9}.modal-actions button:disabled{opacity:.6;cursor:not-allowed}.error{color:var(--color-heat-red);padding:.75rem;background-color:#ff3b3033;border-radius:var(--radius-input);border:1px solid var(--color-heat-red);margin-bottom:1rem}.track-edit-warning{color:var(--color-amber-apex);padding:.5rem .75rem;margin-top:.5rem;font-size:.9rem;background-color:#ffb10026;border-radius:var(--radius-input);border:1px solid var(--color-amber-apex)}.tracks-container{min-height:100vh;background-color:var(--color-track-navy)}.tracks-header{background:var(--color-asphalt-gray);color:var(--color-text-primary);padding:1.5rem 2rem;box-shadow:var(--elevation-card)}.header-content{max-width:1200px;margin:0 auto;display:flex;justify-content:space-between;align-items:center}.header-content h1{margin:0;font-size:1.75rem;font-weight:700;color:var(--color-text-primary)}.header-actions{display:flex;gap:1rem}.tracks-main{max-width:1200px;margin:0 auto;padding:2rem}.tracks-title-bar{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.tracks-title-bar h2{margin:0;color:var(--color-text-primary);font-size:1.5rem;font-weight:600;font-family:Inter Display,Inter,sans-serif}.title-bar-actions{display:flex;gap:1rem}.tracks-section{margin-bottom:3rem}.tracks-section h3{margin-bottom:1rem;font-size:1.5rem;color:var(--color-text-primary)}.section-description{margin-bottom:1rem;color:var(--color-text-secondary);font-size:.9rem}.tracks-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.track-card{background:var(--color-asphalt-gray);border-radius:var(--radius-card);padding:1.5rem;box-shadow:var(--elevation-card);transition:transform .2s,box-shadow .2s}.track-card:hover{transform:translateY(-2px);box-shadow:var(--elevation-card-hover)}.track-card-header{margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid rgba(255,255,255,.1);display:flex;justify-content:space-between;align-items:center}.track-card-header h3{margin:0 0 .5rem;font-size:1.1rem;font-weight:600;color:var(--color-text-primary)}.track-type-badge{display:inline-block;padding:.25rem .75rem;background-color:#17c2e633;color:var(--color-lap-cyan);border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase}.track-type-badge.read-only-badge{margin-left:.5rem;background-color:#80808033;color:var(--color-text-secondary, #888);text-transform:none}.track-card-info{display:flex;flex-direction:column;gap:.5rem}.info-row{display:flex;gap:.5rem}.info-label{color:var(--color-text-tertiary);font-size:.875rem;font-weight:500;min-width:80px}.info-value{color:var(--color-text-primary);font-size:.875rem;font-weight:600}.edit-button,.share-button,.delete-button{background:none;border:none;cursor:pointer;font-size:1.2rem;padding:.25rem .5rem;border-radius:4px;transition:background-color .2s;opacity:.6;color:var(--color-text-secondary)}.edit-button:hover{background-color:#ffc10733;color:#ffc107;opacity:1}.share-button:hover{background-color:#17c2e633;color:var(--color-lap-cyan);opacity:1}.delete-button:hover{background-color:#ff3b3033;color:var(--color-heat-red);opacity:1}.empty-state{text-align:center;padding:3rem;background:var(--color-asphalt-gray);border-radius:var(--radius-card);color:var(--color-text-secondary)}.empty-state p{margin-bottom:1.5rem}.error-message{padding:1rem;margin-bottom:1.5rem;background-color:#ff3b3033;color:var(--color-heat-red);border-radius:var(--radius-input);font-size:.9rem;border:1px solid var(--color-heat-red)}.loading{text-align:center;padding:3rem;color:var(--color-text-secondary);font-size:1.1rem}.lap-selector{background:var(--bg-secondary, #1a1a2e);border-radius:12px;padding:1rem;position:relative}.lap-selector-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;flex-wrap:wrap;gap:.5rem}.lap-selector-header h3{margin:0;font-size:1rem;color:var(--text-primary, #fff)}.slot-buttons{display:flex;gap:.5rem}.slot-button{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border:2px solid var(--border-color, #333);border-radius:8px;background:transparent;color:var(--text-secondary, #888);cursor:pointer;transition:all .2s ease;font-size:.875rem}.slot-marker{display:flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:50%;font-size:.625rem;font-weight:700;color:#fff;flex-shrink:0}.slot-button.slot-1 .slot-marker{background:#007bff}.slot-button.slot-1:hover,.slot-button.slot-1.active{border-color:#007bff}.slot-button.slot-1.active{background:#007bff26;color:var(--text-primary, #fff)}.slot-button.slot-1.has-selection{border-color:#007bff;color:var(--text-primary, #fff)}.slot-button.slot-2 .slot-marker{background:#ff6b35}.slot-button.slot-2:hover,.slot-button.slot-2.active{border-color:#ff6b35}.slot-button.slot-2.active{background:#ff6b3526;color:var(--text-primary, #fff)}.slot-button.slot-2.has-selection{border-color:#ff6b35;color:var(--text-primary, #fff)}.slot-text{font-weight:500}.lap-selector-error{background:var(--error-bg, rgba(220, 53, 69, .1));color:var(--error-color, #dc3545);padding:.75rem;border-radius:8px;margin-bottom:1rem;font-size:.875rem}.lap-selector-content{display:flex;flex-direction:column;gap:1rem}.session-select{display:flex;flex-direction:column;gap:.5rem}.session-select label{font-size:.875rem;color:var(--text-secondary, #888)}.session-select select{padding:.75rem;border:1px solid var(--border-color, #333);border-radius:8px;background:var(--bg-tertiary, #252540);color:var(--text-primary, #fff);font-size:1rem;cursor:pointer}.session-select select:focus{outline:none;border-color:var(--primary-color, #007bff)}.laps-list{min-height:150px}.laps-loading,.laps-empty{display:flex;align-items:center;justify-content:center;height:150px;color:var(--text-secondary, #888);font-size:.875rem}.laps-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:.5rem}.lap-card{background:var(--bg-tertiary, #252540);border:2px solid transparent;border-radius:8px;padding:.75rem;cursor:pointer;transition:all .2s ease;text-align:center}.lap-card:hover{border-color:var(--primary-color, #007bff);transform:translateY(-2px)}.lap-card.selected{background:#ffffff0d}.lap-card.selected-1{border-color:#007bff;background:#007bff1a}.lap-card.selected-2{border-color:#ff6b35;background:#ff6b351a}.lap-card.disabled{opacity:.5;pointer-events:none}.lap-number{font-size:.75rem;color:var(--text-secondary, #888);margin-bottom:.25rem;display:flex;align-items:center;justify-content:center;gap:.5rem}.selection-badge{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;color:#fff;border-radius:50%;font-size:.625rem;font-weight:700}.selection-badge.slot-1{background:#007bff}.selection-badge.slot-2{background:#ff6b35}.lap-time{font-size:1rem;font-weight:600;color:var(--text-primary, #fff);font-variant-numeric:tabular-nums}.lap-selector-loading-overlay{position:absolute;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;border-radius:12px}.loading-spinner{color:var(--text-primary, #fff);font-size:.875rem}@media(max-width:600px){.lap-selector-header{flex-direction:column;align-items:flex-start}.laps-grid{grid-template-columns:repeat(auto-fill,minmax(80px,1fr))}}.comparison-map-container{position:relative;width:100%;height:400px;border-radius:12px;overflow:hidden;background:var(--bg-secondary, #1a1a2e)}.comparison-map{width:100%;height:100%}.comparison-map-empty{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;z-index:1;pointer-events:none}.comparison-map-empty p{color:var(--text-secondary, #888);font-size:1rem;background:#00000080;padding:1rem 2rem;border-radius:8px}.comparison-map-legend{position:absolute;top:1rem;left:1rem;background:#000000bf;padding:.75rem 1rem;border-radius:8px;display:flex;flex-direction:column;gap:.5rem;z-index:1}.legend-item{display:flex;align-items:center;gap:.5rem}.legend-marker{display:flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:50%;color:#fff;font-size:.625rem;font-weight:700;flex-shrink:0}.legend-color{width:16px;height:4px;border-radius:2px}.legend-label{display:flex;flex-direction:column;gap:.125rem}.legend-lap-info{color:var(--text-primary, #fff);font-size:.75rem;font-weight:600}.legend-session-name{color:var(--text-secondary, #888);font-size:.625rem;white-space:nowrap;max-width:150px;overflow:hidden;text-overflow:ellipsis}.speed-tooltip{position:absolute;background:#000000d9;padding:.5rem .75rem;border-radius:6px;display:flex;flex-direction:column;gap:.125rem;z-index:10;pointer-events:none;animation:tooltipFadeIn .15s ease}.speed-tooltip.lap1{border-left:3px solid #007BFF}.speed-tooltip.lap2{border-left:3px solid #FF6B35}.tooltip-speed{color:var(--text-primary, #fff);font-size:.875rem;font-weight:600;font-family:JetBrains Mono,monospace}.tooltip-lap{color:var(--text-secondary, #888);font-size:.625rem}@keyframes tooltipFadeIn{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}.comparison-map :global(.ol-control button){background:#000000b3;color:#fff}.comparison-map :global(.ol-control button:hover){background:#000000e6}.comparison-map-container.selecting-segment,.comparison-map-container.selecting-segment .comparison-map{cursor:crosshair}.segment-controls{position:absolute;top:1rem;right:1rem;z-index:10}.segment-btn{padding:.5rem 1rem;border:none;border-radius:6px;font-size:.75rem;font-weight:500;cursor:pointer;transition:all .2s}.segment-btn.start-selection{background:#0f03;color:#0f0;border:1px solid #00FF00}.segment-btn.start-selection:hover{background:#00ff004d}.segment-btn.cancel{background:#ff646433;color:#ff6464;border:1px solid #ff6464;margin-left:.5rem}.segment-btn.cancel:hover{background:#ff64644d}.segment-btn.clear{background:transparent;color:#888;border:none;padding:.25rem .5rem;font-size:1rem;line-height:1}.segment-btn.clear:hover{color:#ff6464}.segment-selection-hint{display:flex;align-items:center;gap:.5rem;background:#000000d9;padding:.5rem .75rem;border-radius:6px;border:1px solid #00FF00}.segment-selection-hint span{color:#0f0;font-size:.75rem;font-weight:500}.segment-info{display:flex;align-items:center;gap:.5rem;background:#000000d9;padding:.5rem .75rem;border-radius:6px;border:1px solid #00FF00}.segment-label{color:#0f0;font-size:.75rem;font-weight:500;font-family:JetBrains Mono,monospace}.comparison-stats{background:var(--bg-secondary, #1a1a2e);border-radius:12px;padding:1rem}.comparison-stats h3{margin:0 0 1rem;font-size:1rem;color:var(--text-primary, #fff)}.comparison-stats-empty{background:var(--bg-secondary, #1a1a2e);border-radius:12px;padding:2rem;display:flex;align-items:center;justify-content:center}.comparison-stats-empty p{color:var(--text-secondary, #888);margin:0}.stats-table{display:flex;flex-direction:column;gap:.25rem}.stats-header{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:.5rem;padding:.5rem;background:var(--bg-tertiary, #252540);border-radius:8px;font-size:.75rem;color:var(--text-secondary, #888);text-transform:uppercase;letter-spacing:.05em}.stats-row{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:.5rem;padding:.75rem .5rem;border-bottom:1px solid var(--border-color, #333)}.stats-row:last-child{border-bottom:none}.stats-cell{display:flex;align-items:center}.metric-name{color:var(--text-secondary, #888);font-size:.875rem}.lap1-value,.lap2-value{color:var(--text-primary, #fff);font-size:.875rem;font-variant-numeric:tabular-nums;justify-content:flex-end}.delta-value{font-size:.875rem;font-weight:500;font-variant-numeric:tabular-nums;justify-content:flex-end;color:var(--text-secondary, #888)}.delta-value.positive{color:var(--success-color, #28a745)}.delta-value.negative{color:var(--error-color, #dc3545)}@media(max-width:600px){.stats-header,.stats-row{grid-template-columns:1.5fr 1fr 1fr 1fr;font-size:.75rem}.metric-name,.lap1-value,.lap2-value,.delta-value{font-size:.75rem}}.replay-controller{display:flex;align-items:center;gap:1rem;padding:.75rem 1rem;background:var(--bg-secondary, #1a1a2e);border-radius:12px;flex-wrap:wrap}.replay-controller.disabled{opacity:.5;pointer-events:none}.replay-controls{display:flex;align-items:center;gap:.5rem}.replay-button{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;border-radius:50%;background:var(--bg-tertiary, #252540);color:var(--text-primary, #fff);cursor:pointer;transition:all .2s ease}.replay-button:hover:not(:disabled){background:var(--primary-color, #007bff)}.replay-button:disabled{opacity:.5;cursor:not-allowed}.play-button{width:44px;height:44px;background:var(--primary-color, #007bff)}.play-button:hover:not(:disabled){background:#0056b3;transform:scale(1.05)}.replay-timeline{display:flex;align-items:center;gap:.75rem;flex:1;min-width:200px}.time-display{font-size:.75rem;font-family:JetBrains Mono,monospace;color:var(--text-secondary, #888);min-width:45px}.time-display.current{color:var(--text-primary, #fff);text-align:right}.time-display.total{text-align:left}.timeline-slider-container{flex:1;position:relative}.timeline-slider{-webkit-appearance:none;appearance:none;width:100%;height:6px;border-radius:3px;background:linear-gradient(to right,var(--primary-color, #007bff) 0%,var(--primary-color, #007bff) var(--progress),var(--bg-tertiary, #252540) var(--progress),var(--bg-tertiary, #252540) 100%);cursor:pointer;outline:none}.timeline-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:14px;height:14px;border-radius:50%;background:var(--text-primary, #fff);cursor:pointer;box-shadow:0 2px 4px #0000004d;transition:transform .1s ease}.timeline-slider::-webkit-slider-thumb:hover{transform:scale(1.2)}.timeline-slider::-moz-range-thumb{width:14px;height:14px;border-radius:50%;background:var(--text-primary, #fff);cursor:pointer;border:none;box-shadow:0 2px 4px #0000004d}.replay-speed{display:flex;align-items:center;gap:.5rem}.speed-label{font-size:.75rem;color:var(--text-secondary, #888)}.speed-buttons{display:flex;gap:.25rem}.speed-button{padding:.25rem .5rem;border:1px solid var(--border-color, #333);border-radius:4px;background:transparent;color:var(--text-secondary, #888);font-size:.625rem;cursor:pointer;transition:all .15s ease}.speed-button:hover:not(:disabled){border-color:var(--primary-color, #007bff);color:var(--text-primary, #fff)}.speed-button.active{background:var(--primary-color, #007bff);border-color:var(--primary-color, #007bff);color:#fff}.speed-button:disabled{opacity:.5;cursor:not-allowed}.replay-controller.segment-mode{border:1px solid #00FF00}.replay-controller.segment-mode .timeline-slider{background:linear-gradient(to right,#00FF00 0%,#00FF00 var(--progress),var(--bg-tertiary, #252540) var(--progress),var(--bg-tertiary, #252540) 100%)}.replay-controller.segment-mode .play-button{background:#0c0}.replay-controller.segment-mode .play-button:hover:not(:disabled){background:#090}.sync-mode-selector{display:flex;align-items:center;gap:.25rem}.sync-mode-label{font-size:.625rem;color:var(--text-secondary, #888);margin-right:.25rem}.sync-mode-btn{padding:.2rem .5rem;border:1px solid var(--border-color, #333);border-radius:4px;background:transparent;color:var(--text-secondary, #888);font-size:.625rem;cursor:pointer;transition:all .15s ease}.sync-mode-btn:hover{border-color:#0f0;color:var(--text-primary, #fff)}.sync-mode-btn.active{background:#0c0;border-color:#0c0;color:#000}@media(max-width:600px){.replay-controller{padding:.5rem;gap:.5rem}.replay-timeline{order:3;width:100%;min-width:unset}.replay-speed{order:2}.speed-label{display:none}}.telemetry-charts{display:flex;flex-direction:column;gap:1rem;background:var(--bg-secondary, #1a1a2e);border-radius:12px;padding:1rem}.chart-mode-selector{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}.mode-label{font-size:.75rem;color:var(--text-secondary, #888)}.mode-btn{padding:.25rem .75rem;font-size:.75rem;border:1px solid var(--border-color, #444);background:transparent;color:var(--text-secondary, #888);border-radius:4px;cursor:pointer;transition:all .2s}.mode-btn:hover{border-color:var(--accent-color, #007BFF);color:var(--text-primary, #fff)}.mode-btn.active{background:var(--accent-color, #007BFF);border-color:var(--accent-color, #007BFF);color:#fff}.mode-label.segment-mode{color:#0f0}.segment-info-text{color:#0f0;font-size:.75rem;font-weight:500;font-family:JetBrains Mono,monospace}.chart-container{width:100%}.chart-title{margin:0 0 .5rem;font-size:.875rem;font-weight:600;color:var(--text-primary, #fff)}.telemetry-empty{padding:2rem;text-align:center;color:var(--text-secondary, #888)}.telemetry-charts .recharts-cartesian-grid-horizontal line,.telemetry-charts .recharts-cartesian-grid-vertical line{stroke:#333}.telemetry-charts .recharts-legend-item-text{color:var(--text-secondary, #888)!important;font-size:.75rem}.telemetry-charts .recharts-tooltip-wrapper{outline:none}.telemetry-charts .recharts-default-tooltip{background:var(--bg-secondary, #1a1a2e)!important;border:1px solid var(--border-color, #333)!important;border-radius:6px}.telemetry-charts .recharts-tooltip-label{color:var(--text-primary, #fff)!important;font-size:.75rem;margin-bottom:.25rem}.telemetry-charts .recharts-tooltip-item{font-size:.75rem!important;padding:2px 0!important}.telemetry-charts .recharts-wrapper{cursor:crosshair}.comparison-view{min-height:100vh;background:var(--bg-primary, #0f0f23);color:var(--text-primary, #fff)}.comparison-header{display:flex;align-items:center;gap:1rem;padding:1rem;background:var(--bg-secondary, #1a1a2e);border-bottom:1px solid var(--border-color, #333)}.comparison-header h1{margin:0;font-size:1.25rem;flex:1}.back-button,.clear-button{padding:.5rem 1rem;border:1px solid var(--border-color, #333);border-radius:8px;background:transparent;color:var(--text-primary, #fff);cursor:pointer;font-size:.875rem;transition:all .2s ease}.back-button:hover,.clear-button:hover{background:var(--bg-tertiary, #252540);border-color:var(--primary-color, #007bff)}.clear-button{border-color:var(--error-color, #dc3545);color:var(--error-color, #dc3545)}.clear-button:hover{background:#dc35451a;border-color:var(--error-color, #dc3545)}.comparison-layout{display:grid;grid-template-columns:350px 1fr;gap:1rem;padding:1rem;min-height:calc(100vh - 60px)}.comparison-sidebar,.comparison-main{display:flex;flex-direction:column;gap:1rem}.comparison-map-section{flex:1;min-height:400px}.comparison-replay-section,.comparison-telemetry-section,.comparison-stats-section{flex-shrink:0}@media(max-width:900px){.comparison-layout{grid-template-columns:1fr}.comparison-sidebar{order:2}.comparison-main{order:1}.comparison-map-section{min-height:300px}}@media(max-width:600px){.comparison-header{flex-wrap:wrap}.comparison-header h1{order:-1;width:100%;margin-bottom:.5rem}.back-button,.clear-button{flex:1}}.loading-screen{display:flex;justify-content:center;align-items:center;min-height:100vh;background-color:var(--color-track-navy)}.loading-spinner{color:var(--color-lap-cyan);font-size:1.25rem;font-weight:500}
