*,*:before,*:after{box-sizing:border-box}body{margin:0;font-family:system-ui,-apple-system,sans-serif;background:#080810;color:#f0f0f8;min-height:100vh;-webkit-font-smoothing:antialiased}button,input,select{font-family:inherit}:root{--bg: #080810;--sidebar-bg: #0d0d18;--card-bg: #12121e;--card-border: #1e1e2e;--text: #f0f0f8;--muted: #6b6b8a;--accent: #ef4444;--accent-hover: #dc2626;--orange: #f97316;--green: #22c55e;--red: #ef4444;--gold: #fbbf24;--silver: #94a3b8;--bronze: #c97b35}.auth-page{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--bg);padding:2rem}.auth-logo{font-size:1.1rem;font-weight:800;letter-spacing:.18em;margin-bottom:2rem;color:var(--text);display:flex;align-items:center;gap:8px}.auth-logo-mark{color:var(--accent);font-size:1.5rem}.auth-card{background:var(--card-bg);border:1px solid var(--card-border);border-radius:12px;padding:2rem;width:100%;max-width:360px}.auth-card h2{margin:0 0 1.5rem;font-size:1rem;font-weight:600;color:var(--text)}.form-field{margin-bottom:1rem}.form-input{display:block;width:100%;padding:.65rem .85rem;background:var(--bg);border:1px solid var(--card-border);border-radius:8px;color:var(--text);font-size:.95rem;transition:border-color .15s}.form-input:focus{outline:none;border-color:var(--accent)}.btn-primary{display:block;width:100%;padding:.7rem;background:var(--accent);border:none;border-radius:8px;color:#fff;font-size:.95rem;font-weight:600;cursor:pointer;transition:background .15s;margin-top:.5rem}.btn-primary:hover:not(:disabled){background:var(--accent-hover)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-primary:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.auth-switch{display:block;width:100%;margin-top:1rem;background:none;border:none;color:var(--muted);font-size:.85rem;cursor:pointer;text-align:center;padding:0}.auth-switch:hover{color:var(--text)}.app-shell{display:grid;grid-template-columns:220px 1fr;min-height:100vh;background:var(--bg);color:var(--text)}.sidebar{background:var(--sidebar-bg);border-right:1px solid var(--card-border);display:flex;flex-direction:column;position:sticky;top:0;height:100vh;overflow-y:auto}.sidebar-logo{display:flex;align-items:center;gap:8px;padding:1.5rem 1.25rem 1.25rem;font-size:.8rem;font-weight:800;letter-spacing:.18em;color:var(--text);border-bottom:1px solid var(--card-border)}.logo-mark{color:var(--accent);font-size:1.3rem;line-height:1}.auth-title{font-size:1.25rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--text)}.sidebar-nav{flex:1;display:flex;flex-direction:column;padding:.75rem 0}.nav-item{display:flex;align-items:center;gap:10px;padding:10px 16px;background:none;border:none;border-left:3px solid transparent;color:var(--muted);font-size:.875rem;cursor:pointer;text-align:left;transition:background .15s,color .15s;width:100%}.nav-item:hover{background:#ffffff0a;color:var(--text)}.nav-item.active{border-left-color:var(--accent);background:#ef44441a;color:var(--text)}.nav-item:focus-visible{outline:2px solid var(--accent);outline-offset:-2px}.sidebar-footer{padding:1rem 1.25rem;border-top:1px solid var(--card-border)}.sidebar-email{font-size:.75rem;color:var(--muted);margin-bottom:.5rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-logout{background:none;border:1px solid var(--card-border);color:var(--muted);font-size:.8rem;padding:.35rem .75rem;border-radius:6px;cursor:pointer;transition:color .15s,border-color .15s}.sidebar-logout:hover{color:var(--text);border-color:var(--muted)}.sidebar-logout:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.content{padding:2rem 2.5rem;min-height:100vh;overflow-y:auto;max-width:1000px}.page-header{margin-bottom:2rem}.page-title{font-size:1.4rem;font-weight:700;margin:0 0 .25rem}.page-subtitle{font-size:.85rem;color:var(--muted);margin:0}.section-label{font-size:.65rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin:0 0 .75rem}.stat-row{display:flex;gap:1rem;margin-bottom:2rem;flex-wrap:wrap}.stat-pill{flex:1;min-width:130px;background:var(--card-bg);border:1px solid var(--card-border);border-radius:10px;padding:1rem 1.25rem}.stat-value{font-size:1.5rem;font-weight:700;font-variant-numeric:tabular-nums;line-height:1;margin-bottom:.3rem}.stat-label{font-size:.7rem;color:var(--muted);text-transform:uppercase;letter-spacing:.08em}.card{background:var(--card-bg);border:1px solid var(--card-border);border-radius:10px;padding:1.5rem;margin-bottom:1.5rem}.cta-card{background:linear-gradient(135deg,#1a0a0a 0%,var(--card-bg) 100%);border:1px solid rgba(239,68,68,.25);border-radius:10px;padding:1.5rem;display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1.5rem}.cta-card h3{margin:0 0 .25rem;font-size:1rem;font-weight:600}.cta-card p{margin:0;font-size:.85rem;color:var(--muted)}.data-table-wrap{overflow-x:auto}.data-table{width:100%;border-collapse:collapse;font-size:.875rem}.data-table th{padding:.5rem .875rem;text-align:left;font-size:.65rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);border-bottom:1px solid var(--card-border)}.data-table td{padding:.65rem .875rem;border-bottom:1px solid rgba(30,30,46,.6)}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover td{background:#ffffff06}.lap-time{font-variant-numeric:tabular-nums;font-weight:600;letter-spacing:.02em}.rank-1 td:first-child{border-left:3px solid var(--gold)}.rank-2 td:first-child{border-left:3px solid var(--silver)}.rank-3 td:first-child{border-left:3px solid var(--bronze)}.rank-badge{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;font-size:.7rem;font-weight:700}.rank-badge.gold{background:#fbbf2426;color:var(--gold)}.rank-badge.silver{background:#94a3b826;color:var(--silver)}.rank-badge.bronze{background:#c97b3526;color:var(--bronze)}.filter-row{display:flex;gap:.75rem;margin-bottom:1.25rem;flex-wrap:wrap;align-items:center}.select-input{padding:.5rem .75rem;background:var(--bg);border:1px solid var(--card-border);border-radius:8px;color:var(--text);font-size:.875rem;transition:border-color .15s}.select-input:focus{outline:none;border-color:var(--accent)}.btn{padding:.5rem 1rem;border-radius:8px;border:none;font-size:.875rem;font-weight:600;cursor:pointer;transition:opacity .15s,background .15s;white-space:nowrap}.btn:disabled{opacity:.45;cursor:not-allowed}.btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.btn-green{background:var(--green);color:#080810}.btn-green:hover:not(:disabled){background:#16a34a}.btn-red{background:var(--accent);color:#fff}.btn-red:hover:not(:disabled){background:var(--accent-hover)}.btn-ghost{background:none;border:1px solid var(--card-border);color:var(--muted)}.btn-ghost:hover:not(:disabled){color:var(--text);border-color:var(--muted)}.btn-link{background:none;border:none;color:var(--accent);font-size:.85rem;cursor:pointer;padding:0}.btn-link:hover{text-decoration:underline}.btn-link:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.upload-zone{border:2px dashed rgba(239,68,68,.4);border-radius:12px;padding:2.5rem;display:flex;flex-direction:column;align-items:center;gap:.75rem;cursor:pointer;transition:border-color .15s,background .15s;margin-bottom:1.5rem;text-align:center}.upload-zone:hover,.upload-zone.drag-over{border-color:var(--accent);background:#ef44440a}.upload-zone input{display:none}.upload-icon{color:var(--muted);transition:color .15s}.upload-zone:hover .upload-icon,.upload-zone.drag-over .upload-icon{color:var(--accent)}.upload-label{font-size:.9rem;font-weight:500}.upload-hint{font-size:.8rem;color:var(--muted)}.upload-options{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:var(--muted);cursor:pointer;margin-bottom:1rem}.toggle{position:relative;display:inline-block;width:36px;height:20px;flex-shrink:0}.toggle input{display:none}.toggle-slider{position:absolute;inset:0;background:var(--card-border);border-radius:20px;cursor:pointer;transition:background .2s}.toggle-slider:before{content:"";position:absolute;width:14px;height:14px;left:3px;top:3px;background:#fff;border-radius:50%;transition:transform .2s}.toggle input:checked+.toggle-slider{background:var(--accent)}.toggle input:checked+.toggle-slider:before{transform:translate(16px)}.error-msg{color:var(--red);font-size:.85rem;margin-top:.75rem}.success-msg{color:var(--green);font-size:.85rem;margin-top:.75rem}.hint-text{font-size:.85rem;color:var(--muted)}.empty-state{text-align:center;padding:3rem 1rem;color:var(--muted);font-size:.9rem}.compare-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1.5rem}.compare-lap-card{background:var(--card-bg);border:1px solid var(--card-border);border-radius:10px;padding:1.25rem;min-height:110px}.compare-lap-card.selected{border-color:#ef444466}.clc-header{font-size:.65rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:.75rem}.clc-info .track{font-weight:600;font-size:.9rem;margin-bottom:.2rem}.clc-info .time{font-variant-numeric:tabular-nums;color:var(--accent);font-weight:700;font-size:1.1rem}.clc-info .meta{font-size:.75rem;color:var(--muted);margin-top:.2rem}.clc-empty{color:var(--muted);font-size:.85rem}.result-hero{display:flex;flex-direction:column;align-items:center;padding:2rem;margin-bottom:1rem;border-bottom:1px solid var(--card-border)}.delta-value{font-size:3.5rem;font-weight:800;font-variant-numeric:tabular-nums;line-height:1;margin-bottom:.4rem}.delta-value.faster{color:var(--green)}.delta-value.slower{color:var(--red)}.delta-label{font-size:.75rem;color:var(--muted);text-transform:uppercase;letter-spacing:.12em}.sector-bars{padding:1.25rem 1.5rem;margin-bottom:1.5rem}.sector-row{display:grid;grid-template-columns:26px 1fr 72px;align-items:center;gap:.75rem;margin-bottom:.6rem}.sector-row-label{font-size:.7rem;font-weight:700;color:var(--muted);text-align:right}.sector-bar-track{height:8px;background:var(--card-border);border-radius:4px;overflow:hidden}.sector-bar-fill{height:100%;border-radius:4px;transition:width .4s ease}.sector-bar-fill.faster{background:var(--green)}.sector-bar-fill.slower{background:var(--red)}.sector-delta{font-size:.8rem;font-variant-numeric:tabular-nums;font-weight:600;text-align:right}.sector-delta.faster{color:var(--green)}.sector-delta.slower{color:var(--red)}.chart-wrap img{max-width:100%;border-radius:8px;display:block}.lap-detail-header{display:flex;align-items:center;gap:1rem;padding-bottom:1.25rem;border-bottom:1px solid var(--card-border);margin-bottom:1.5rem;flex-wrap:wrap}.lap-detail-back{background:none;border:none;color:var(--muted);cursor:pointer;font-size:.9rem;padding:.25rem .5rem;border-radius:4px;transition:color .15s}.lap-detail-back:hover{color:var(--text)}.lap-detail-back:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.lap-detail-info{display:flex;gap:1.5rem;align-items:baseline;flex-wrap:wrap}.lap-detail-title{font-size:1.1rem;font-weight:700;color:var(--text)}.lap-detail-meta{font-size:.85rem;color:var(--muted)}.lap-detail-time{font-size:1.25rem;font-weight:700;color:var(--accent);font-variant-numeric:tabular-nums}.track-map-container{background:var(--card-bg);border:1px solid var(--card-border);border-radius:8px;padding:1.25rem;margin-bottom:1.25rem}.track-map-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;flex-wrap:wrap;gap:.5rem}.track-map-toggle{display:flex;gap:0;border:1px solid var(--card-border);border-radius:6px;overflow:hidden}.track-map-toggle button{background:none;border:none;color:var(--muted);padding:.35rem .75rem;font-size:.75rem;cursor:pointer;transition:background .15s,color .15s}.track-map-toggle button.active{background:var(--accent);color:#fff}.track-map-toggle button:focus-visible{outline:2px solid var(--accent);outline-offset:-2px}.track-map-svg{display:block;width:100%;height:auto;border-radius:4px;background:#0a0a12}.track-map-legend{display:flex;gap:1.25rem;margin-top:.75rem;font-size:.72rem;color:var(--muted)}.track-map-legend span{display:flex;align-items:center;gap:.35rem}.legend-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.telemetry-trace-card{background:var(--card-bg);border:1px solid var(--card-border);border-radius:8px;padding:1.25rem;margin-bottom:1.25rem}.telemetry-trace-chart{display:block;width:100%;height:auto;background:#0a0a12;border-radius:4px}.trace-legend{display:flex;gap:1.25rem;margin-top:.6rem;font-size:.72rem;color:var(--muted)}.trace-legend span{display:flex;align-items:center;gap:.35rem}.trace-line{width:18px;height:2px;border-radius:1px;flex-shrink:0}.detail-cards-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem;margin-bottom:1.25rem}@media(max-width:768px){.detail-cards-grid{grid-template-columns:1fr}}.insights-card,.coaching-card{background:var(--card-bg);border:1px solid var(--card-border);border-radius:8px;padding:1.25rem}.insights-list{list-style:none;padding:0;margin:.75rem 0 0}.insight-item{font-size:.83rem;color:var(--text);padding:.5rem 0;border-bottom:1px solid var(--card-border);line-height:1.5}.insight-item:last-child{border-bottom:none}.insight-item:before{content:"›  ";color:var(--accent);font-weight:700}.coaching-text{font-size:.83rem;color:var(--text);line-height:1.7;white-space:pre-wrap;margin-top:.75rem}@media(max-width:768px){.app-shell{grid-template-columns:1fr}.sidebar{position:static;height:auto}.sidebar-nav{flex-direction:row;flex-wrap:wrap;padding:.5rem}.nav-item{border-left:none;border-bottom:3px solid transparent;padding:8px 12px;flex:none}.nav-item.active{border-left-color:transparent;border-bottom-color:var(--accent)}.compare-grid{grid-template-columns:1fr}.content{padding:1.5rem}}.client-status{display:flex;align-items:center;gap:6px;padding:6px 0 4px;border-top:1px solid rgba(255,255,255,.06);margin-bottom:6px}.client-status-dot{width:7px;height:7px;border-radius:50%;background:#4a4a5a;flex-shrink:0;transition:background .3s}.client-status-dot.connected{background:#22c55e;box-shadow:0 0 5px #22c55e80}.client-status-label{font-size:11px;color:var(--muted, #888);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
