@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600&display=swap";
:root{--bg-root:#0a0a0a;--bg-raised:#141414;--bg-overlay:#1a1a1a;--bg-hover:#1f1f1f;--bg-active:#262626;--border-subtle:#1f1f1f;--border-default:#262626;--border-strong:#333;--text-primary:#ededed;--text-secondary:#a1a1a1;--text-tertiary:#6f6f6f;--accent:#06c;--accent-hover:#05a;--accent-muted:#0066cc1a;--accent-text:#4d9fff;--success:#0f7b3e;--success-bg:#0f7b3e1a;--success-text:#2ea55a;--warning:#b54708;--warning-bg:#b547081a;--warning-text:#d97706;--danger:#b42318;--danger-bg:#b423181a;--danger-text:#f04438;--info-bg:#0066cc14;--info-text:#4d9fff;--font-sans:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;--font-mono:"JetBrains Mono", "Consolas", "SF Mono", ui-monospace, monospace;--text-xs:.6875rem;--text-sm:.75rem;--text-base:.8125rem;--text-md:.875rem;--text-lg:1rem;--text-xl:1.125rem;--radius:4px;--sidebar-w:240px;--topbar-h:48px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}body{font-family:var(--font-sans);font-size:var(--text-base);font-variant-numeric:tabular-nums;color:var(--text-primary);background:var(--bg-root);line-height:1.5;overflow:hidden}a{color:var(--accent-text);text-decoration:none}a:hover{text-decoration:underline}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.app-layout{width:100vw;height:100vh;display:flex;overflow:hidden}.app-sidebar{width:var(--sidebar-w);min-width:var(--sidebar-w);background:var(--bg-raised);border-right:1px solid var(--border-subtle);z-index:50;flex-direction:column;height:100vh;display:flex}.app-main{flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}.app-topbar{height:var(--topbar-h);min-height:var(--topbar-h);background:var(--bg-raised);border-bottom:1px solid var(--border-subtle);font-size:var(--text-sm);align-items:center;gap:12px;padding:0 24px;display:flex}.app-topbar h1{font-size:var(--text-md);color:var(--text-primary);font-weight:600}.app-header{height:var(--topbar-h);min-height:var(--topbar-h);background:var(--bg-raised);border-bottom:1px solid var(--border-subtle);align-items:center;gap:12px;padding:0 24px;display:flex}.app-header h1{font-size:var(--text-md);font-weight:600}.app-content{flex:1;padding:24px;overflow:hidden auto}.sidebar-logo{height:var(--topbar-h);border-bottom:1px solid var(--border-subtle);align-items:center;gap:10px;padding:0 16px;display:flex}.sidebar-logo-icon{background:var(--accent);border-radius:var(--radius);width:24px;height:24px;font-size:var(--text-sm);color:#fff;flex-shrink:0;justify-content:center;align-items:center;font-weight:700;display:flex}.sidebar-logo-text{font-size:var(--text-md);color:var(--text-primary);letter-spacing:-.01em;font-weight:600}.sidebar-nav{flex-direction:column;flex:1;gap:1px;padding:8px;display:flex;overflow-y:auto}.sidebar-section-title{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em;padding:16px 10px 4px;font-size:11px;font-weight:500}.sidebar-link{border-radius:var(--radius);color:var(--text-secondary);font-size:var(--text-base);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:10px;width:100%;padding:6px 10px;font-weight:450;text-decoration:none;transition:color .1s,background .1s;display:flex;position:relative}.sidebar-link:hover{background:var(--bg-hover);color:var(--text-primary);text-decoration:none}.sidebar-link.active{background:var(--accent-muted);color:var(--accent-text);font-weight:500}.sidebar-link.active:before{content:"";background:var(--accent);border-radius:0 1px 1px 0;width:2px;position:absolute;top:6px;bottom:6px;left:0}.sidebar-link-icon{opacity:.6;width:16px;height:16px;color:var(--text-tertiary);flex-shrink:0;justify-content:center;align-items:center;font-size:14px;display:inline-flex}.sidebar-link.active .sidebar-link-icon{opacity:1;color:var(--accent-text)}.sidebar-badge{background:var(--danger-bg);color:var(--danger-text);border-radius:var(--radius);text-align:center;min-width:16px;margin-left:auto;padding:0 5px;font-size:11px;font-weight:600;line-height:18px}.sidebar-footer{border-top:1px solid var(--border-subtle);padding:8px}.sidebar-org{font-size:var(--text-xs);color:var(--text-tertiary);border-radius:var(--radius);background:var(--bg-overlay);align-items:center;gap:8px;margin:4px 8px 0;padding:6px 10px;display:flex}.sidebar-org-name{color:var(--text-secondary);text-overflow:ellipsis;white-space:nowrap;font-weight:500;overflow:hidden}.page-container{flex:1;padding:24px;overflow:hidden auto}.page-header{justify-content:space-between;align-items:center;gap:12px;margin-bottom:20px;display:flex}.page-title{font-size:var(--text-lg);color:var(--text-primary);letter-spacing:-.01em;font-weight:600}.page-subtitle{font-size:var(--text-sm);color:var(--text-secondary);margin-top:2px}.page-loading{text-align:center;color:var(--text-tertiary);font-size:var(--text-sm);padding:48px 24px}.stat-grid{background:var(--border-subtle);border:1px solid var(--border-subtle);border-radius:var(--radius);grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1px;margin-bottom:24px;display:grid;overflow:hidden}.stat-card{background:var(--bg-raised);padding:14px 16px}.stat-label{font-size:var(--text-xs);color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.04em;margin-bottom:4px;font-weight:500}.stat-value{font-size:var(--text-xl);color:var(--text-primary);font-weight:600;line-height:1.2}.stat-value .stat-secondary{font-size:var(--text-sm);color:var(--text-tertiary);font-weight:400}.card{background:var(--bg-raised);border:1px solid var(--border-subtle);border-radius:var(--radius);overflow:hidden}.card-header{border-bottom:1px solid var(--border-subtle);justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.card-title{font-size:var(--text-md);color:var(--text-primary);font-weight:600}.card-body{padding:16px}.table-container{overflow-x:auto}.table,.data-table{border-collapse:collapse;width:100%;font-size:var(--text-base)}.table th,.data-table th{text-align:left;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.04em;background:var(--bg-overlay);border-bottom:1px solid var(--border-subtle);white-space:nowrap;height:36px;padding:8px 16px;font-size:11px;font-weight:500}.table td,.data-table td{color:var(--text-primary);border-bottom:1px solid var(--border-subtle);vertical-align:middle;height:40px;font-size:var(--text-base);padding:8px 16px}.table tbody tr:hover,.data-table tbody tr:hover{background:var(--bg-hover)}.table tbody tr:last-child td,.data-table tbody tr:last-child td{border-bottom:none}.col-num{text-align:right}.btn{border-radius:var(--radius);font-family:var(--font-sans);font-size:var(--text-base);cursor:pointer;white-space:nowrap;border:1px solid #0000;justify-content:center;align-items:center;gap:6px;height:32px;padding:6px 12px;font-weight:500;line-height:1;text-decoration:none;transition:background .1s,border-color .1s;display:inline-flex}.btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}.btn-primary:hover{background:var(--accent-hover);border-color:var(--accent-hover)}.btn-secondary{background:var(--bg-overlay);color:var(--text-primary);border-color:var(--border-default)}.btn-secondary:hover{background:var(--bg-hover);border-color:var(--border-strong)}.btn-ghost{color:var(--text-secondary);background:0 0}.btn-ghost:hover{background:var(--bg-hover);color:var(--text-primary)}.btn-danger{background:var(--danger-bg);color:var(--danger-text)}.btn-danger:hover{background:var(--danger);color:#fff}.btn-sm{font-size:var(--text-sm);height:28px;padding:3px 8px}.btn-icon{width:32px;height:32px;padding:0}.badge,.status-badge{border-radius:var(--radius);white-space:nowrap;align-items:center;gap:6px;padding:2px 8px;font-size:11px;font-weight:500;line-height:18px;display:inline-flex}.badge-success,.status-active{background:var(--success-bg);color:var(--success-text)}.badge-warning,.status-inactive{background:var(--warning-bg);color:var(--warning-text)}.badge-danger{background:var(--danger-bg);color:var(--danger-text)}.badge-info{background:var(--info-bg);color:var(--info-text)}.badge-neutral,.status-offline{background:var(--bg-active);color:var(--text-secondary)}.status-dot{border-radius:50%;flex-shrink:0;width:6px;height:6px;display:inline-block}.status-dot.online{background:var(--success-text)}.status-dot.idle{background:var(--warning-text)}.status-dot.offline{background:var(--text-tertiary)}.status-dot.alert{background:var(--danger-text)}.form-group{flex-direction:column;gap:4px;display:flex}.form-label{font-size:var(--text-sm);color:var(--text-secondary);font-weight:500}.form-input,.form-select,.form-textarea{background:var(--bg-root);border:1px solid var(--border-default);border-radius:var(--radius);height:32px;color:var(--text-primary);font-family:var(--font-sans);font-size:var(--text-base);outline:none;padding:0 10px;transition:border-color .1s}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--accent)}.form-input::placeholder{color:var(--text-tertiary)}.form-textarea{resize:vertical;height:auto;min-height:64px;padding:8px 10px}.form-select{cursor:pointer}.notice{border:1px solid var(--border-default);border-radius:var(--radius);font-size:var(--text-sm);align-items:flex-start;gap:10px;margin-bottom:20px;padding:10px 14px;display:flex}.notice-warning{border-color:var(--warning);background:var(--warning-bg);color:var(--warning-text)}.notice-danger{border-color:var(--danger);background:var(--danger-bg);color:var(--danger-text)}.notice-info{border-color:var(--accent);background:var(--accent-muted);color:var(--accent-text)}.empty-state{text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:48px 24px;display:flex}.empty-state-title{font-size:var(--text-md);color:var(--text-secondary);margin-bottom:4px;font-weight:500}.empty-state-text{font-size:var(--text-sm);color:var(--text-tertiary);max-width:320px;line-height:1.5}.modal-overlay{z-index:100;background:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--bg-raised);border:1px solid var(--border-default);border-radius:var(--radius);width:100%;max-width:480px;max-height:85vh;overflow-y:auto;box-shadow:0 16px 48px #00000080}.modal-header{border-bottom:1px solid var(--border-subtle);justify-content:space-between;align-items:center;padding:14px 20px;display:flex}.modal-title{font-size:var(--text-md);font-weight:600}.modal-body{padding:20px}.modal-footer{border-top:1px solid var(--border-subtle);justify-content:flex-end;align-items:center;gap:8px;padding:12px 20px;display:flex}.mono{font-family:var(--font-mono);font-size:var(--text-sm)}.text-secondary{color:var(--text-secondary)}.text-success{color:var(--success-text)}.text-danger{color:var(--danger-text)}.text-warning{color:var(--warning-text)}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.grid-2{grid-template-columns:1fr 1fr;gap:16px;display:grid}.login-page{background:var(--bg-root);justify-content:center;align-items:center;min-height:100vh;display:flex}.login-card{background:var(--bg-raised);border:1px solid var(--border-default);border-radius:var(--radius);width:100%;max-width:360px;padding:32px}.login-header{text-align:center;margin-bottom:24px}.login-mark{background:var(--accent);border-radius:var(--radius);width:32px;height:32px;font-weight:700;font-size:var(--text-sm);color:#fff;justify-content:center;align-items:center;margin-bottom:12px;display:inline-flex}.login-title{font-size:var(--text-lg);color:var(--text-primary);margin-bottom:4px;font-weight:600}.login-subtitle{font-size:var(--text-sm);color:var(--text-tertiary)}.leaflet-container{background:var(--bg-root)!important;font-family:var(--font-sans)!important}.leaflet-popup-content-wrapper{background:var(--bg-raised)!important;color:var(--text-primary)!important;border:1px solid var(--border-default)!important;border-radius:var(--radius)!important}.leaflet-popup-tip{background:var(--bg-raised)!important;border:1px solid var(--border-default)!important}.leaflet-control-zoom a{background:var(--bg-raised)!important;color:var(--text-primary)!important;border-color:var(--border-default)!important}.leaflet-control-zoom a:hover{background:var(--bg-hover)!important}.map-layout{display:flex;position:absolute;inset:0}.map-sidebar{background:var(--bg-raised);border-right:1px solid var(--border-subtle);z-index:1000;flex-direction:column;width:280px;min-width:280px;display:flex}.map-sidebar-header{border-bottom:1px solid var(--border-subtle);padding:14px 16px 10px}.map-sidebar-title{font-size:var(--text-md);color:var(--text-primary);margin-bottom:4px;font-weight:600}.map-sidebar-stats{font-size:var(--text-xs);color:var(--text-secondary);align-items:center;gap:4px;display:flex}.map-sidebar-search{border-bottom:1px solid var(--border-subtle);padding:8px 12px}.map-sidebar-list{flex:1;padding:4px;overflow-y:auto}.map-sidebar-empty{text-align:center;color:var(--text-tertiary);font-size:var(--text-sm);padding:24px 16px}.map-vehicle-item{text-align:left;cursor:pointer;border-radius:var(--radius);width:100%;font-family:var(--font-sans);color:var(--text-primary);background:0 0;border:none;align-items:center;gap:10px;padding:8px 12px;transition:background .1s;display:flex}.map-vehicle-item:hover{background:var(--bg-hover)}.map-vehicle-item.active{background:var(--accent-muted)}.map-vehicle-info{flex:1;min-width:0}.map-vehicle-name{font-size:var(--text-base);white-space:nowrap;text-overflow:ellipsis;font-weight:500;overflow:hidden}.map-vehicle-meta{font-size:var(--text-xs);color:var(--text-tertiary);gap:8px;margin-top:1px;display:flex}.map-vehicle-reg{font-family:var(--font-mono);color:var(--accent-text);font-weight:500}.map-container{flex:1;position:relative}.vehicle-tooltip.leaflet-tooltip{max-width:240px;background:var(--bg-raised)!important;border:1px solid var(--border-default)!important;font-family:var(--font-sans)!important;color:var(--text-primary)!important;border-radius:6px!important;padding:0!important;box-shadow:0 8px 24px #00000080!important}.vehicle-tooltip.leaflet-tooltip:before{border-top-color:var(--border-default)!important}.vt-container{padding:10px 12px}.vt-header{justify-content:space-between;align-items:center;gap:8px;margin-bottom:4px;display:flex}.vt-name{white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.vt-status{color:#fff;text-transform:uppercase;letter-spacing:.03em;border-radius:3px;flex-shrink:0;padding:1px 6px;font-size:10px;font-weight:600}.vt-reg{font-family:var(--font-mono);color:var(--accent-text);margin-bottom:8px;font-size:11px;font-weight:600}.vt-address{color:var(--text-secondary);margin-bottom:8px;font-size:11px;line-height:1.3}.vt-grid{grid-template-columns:1fr 1fr;gap:6px 12px;display:grid}.vt-cell{flex-direction:column;display:flex}.vt-label{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.04em;font-size:10px}.vt-value{color:var(--text-primary);font-size:12px;font-weight:500}.vt-mono{font-family:var(--font-mono);font-size:10px}.vehicle-marker{background:0 0!important;border:none!important}@keyframes pulse-ring{0%{opacity:.4;transform:scale(1)}to{opacity:0;transform:scale(1.8)}}.map-loading{color:var(--text-secondary);font-size:var(--text-sm);z-index:1000;background:#0a0a0ab3;justify-content:center;align-items:center;gap:10px;display:flex;position:absolute;inset:0}.map-loading-spinner{border:2px solid var(--border-strong);border-top-color:var(--accent-text);border-radius:50%;width:16px;height:16px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.map-layer-toggle{z-index:1000;background:var(--bg-raised);border:1px solid var(--border-default);border-radius:6px;gap:2px;padding:3px;display:flex;position:absolute;bottom:20px;right:12px;box-shadow:0 4px 12px #0000004d}.map-layer-btn{color:var(--text-secondary);font-size:11px;font-family:var(--font-sans);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-radius:4px;align-items:center;gap:4px;padding:5px 10px;font-weight:500;transition:all .1s;display:flex}.map-layer-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.map-layer-btn.active{background:var(--accent);color:#fff}.replay-layout{display:flex;position:absolute;inset:0}.replay-sidebar{background:var(--bg-raised);border-right:1px solid var(--border-subtle);flex-direction:column;gap:12px;width:280px;min-width:280px;padding:16px;display:flex;overflow-y:auto}.replay-back{font-size:var(--text-sm);color:var(--text-tertiary);text-decoration:none}.replay-back:hover{color:var(--accent-text);text-decoration:none}.replay-title{font-size:var(--text-lg);color:var(--text-primary);margin:0;font-weight:600}.replay-reg{font-family:var(--font-mono);font-size:var(--text-sm);color:var(--accent-text);margin-top:-8px;font-weight:600}.replay-driver{font-size:var(--text-sm);color:var(--text-secondary);margin-top:-8px}.replay-meta-grid{grid-template-columns:1fr 1fr;gap:8px;display:grid}.replay-meta-item{flex-direction:column;display:flex}.replay-meta-label{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.04em;font-size:10px;font-weight:500}.replay-meta-value{font-size:var(--text-sm);color:var(--text-primary);font-weight:500}.replay-events{flex-direction:column;gap:4px;display:flex}.replay-event-chips{flex-wrap:wrap;gap:4px;display:flex}.replay-chip{border-radius:3px;padding:2px 8px;font-size:10px;font-weight:500}.replay-chip.danger{background:var(--danger-bg);color:var(--danger-text)}.replay-chip.warning{background:var(--warning-bg);color:var(--warning-text)}.replay-chip.info{background:var(--info-bg);color:var(--info-text)}.replay-current{background:var(--bg-overlay);border:1px solid var(--border-subtle);border-radius:var(--radius);padding:10px}.replay-legend{flex-direction:column;gap:4px;display:flex}.replay-legend-items{color:var(--text-secondary);flex-wrap:wrap;gap:8px;font-size:10px;display:flex}.replay-legend-dot{vertical-align:middle;border-radius:50%;width:8px;height:8px;margin-right:3px;display:inline-block}.replay-map-area{flex-direction:column;flex:1;display:flex;position:relative}.replay-map-area .leaflet-container{flex:1}.replay-controls{background:var(--bg-raised);border-top:1px solid var(--border-subtle);padding:0}.replay-controls-inner{align-items:center;gap:8px;padding:8px 16px;display:flex}.replay-btn{border:1px solid var(--border-default);background:var(--bg-overlay);width:32px;height:32px;color:var(--text-primary);border-radius:var(--radius);cursor:pointer;justify-content:center;align-items:center;font-size:14px;transition:background .1s;display:flex}.replay-btn:hover{background:var(--bg-hover)}.replay-btn-play{background:var(--accent);border-color:var(--accent);color:#fff;width:40px}.replay-btn-play:hover{background:var(--accent-hover)}.replay-slider{appearance:none;background:var(--border-default);cursor:pointer;border-radius:2px;outline:none;height:4px}.replay-slider::-webkit-slider-thumb{-webkit-appearance:none;background:var(--accent);cursor:pointer;border:2px solid #fff;border-radius:50%;width:14px;height:14px;box-shadow:0 1px 4px #0000004d}.replay-time{font-family:var(--font-mono);font-size:var(--text-sm);color:var(--text-primary);text-align:center;min-width:65px}.replay-speed-select{background:var(--bg-overlay);border:1px solid var(--border-default);color:var(--text-primary);font-family:var(--font-sans);font-size:var(--text-sm);border-radius:var(--radius);cursor:pointer;padding:4px 6px}.replay-point-count{color:var(--text-tertiary);font-size:10px;font-family:var(--font-mono);text-align:right;min-width:55px}.replay-progress-bg{background:var(--border-subtle);height:3px}.replay-progress-bar{background:var(--accent);height:100%;transition:width .1s linear}@media (max-width:768px){.app-sidebar{z-index:100;position:fixed;left:-100%}.app-sidebar.open{left:0}.app-content{padding:16px}.stat-grid{grid-template-columns:1fr 1fr}.grid-2{grid-template-columns:1fr}}@media (max-width:480px){.stat-grid{grid-template-columns:1fr}}.league-table{flex-direction:column;display:flex}.league-row{border-bottom:1px solid var(--border-subtle);align-items:center;gap:16px;padding:14px 16px;transition:background .1s;display:flex}.league-row:hover{background:var(--bg-hover)}.league-row:last-child{border-bottom:none}.league-row-gold{background:#ffd7000a}.league-row-silver{background:#c0c0c008}.league-row-bronze{background:#cd7f3208}.league-rank{font-size:var(--text-xl);text-align:center;min-width:36px;color:var(--text-tertiary);font-weight:700}.league-driver{flex-direction:column;gap:2px;min-width:160px;display:flex}.league-name{font-weight:600;font-size:var(--text-base);color:var(--text-primary)}.league-badge{border-radius:3px;align-items:center;gap:3px;width:fit-content;padding:1px 8px;font-size:10px;font-weight:600;display:inline-flex}.league-score-section{flex-direction:column;gap:4px;min-width:120px;display:flex}.league-score{font-size:var(--text-2xl);font-weight:800;font-family:var(--font-mono);line-height:1}.league-score-bar-bg{background:var(--border-subtle);border-radius:2px;height:4px;overflow:hidden}.league-score-bar{border-radius:2px;height:100%;transition:width .6s ease-out}.league-metrics{gap:16px;margin-left:auto;display:flex}.league-metric{flex-direction:column;align-items:center;min-width:50px;display:flex}.league-metric-label{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.04em;font-size:10px}.league-metric-value{font-family:var(--font-mono);font-size:var(--text-sm);color:var(--text-primary);font-weight:600}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:0s!important;animation-duration:0s!important}}.app-content:has(.route-layout){flex-direction:column;padding:0;display:flex}.route-layout{flex:1;gap:0;min-height:0;display:flex}.route-sidebar{background:var(--bg-raised);border-right:1px solid var(--border-subtle);flex-direction:column;gap:12px;width:320px;min-width:320px;padding:16px;display:flex;overflow-y:auto}.route-title{font-size:var(--text-lg);color:var(--text-primary);margin:0;font-weight:600}.route-subtitle{font-size:var(--text-sm);color:var(--text-tertiary);margin:-8px 0 0}.route-add{gap:6px;display:flex}.route-add .form-input{font-size:var(--text-sm);flex:1}.route-stops{border:1px solid var(--border-subtle);border-radius:var(--radius);flex-direction:column;display:flex;overflow:hidden}.route-stop-item{border-bottom:1px solid var(--border-subtle);align-items:center;gap:8px;padding:8px 10px;display:flex}.route-stop-item:last-child{border-bottom:none}.route-stop-num{background:var(--accent);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;font-size:11px;font-weight:700;display:flex}.route-stop-info{flex-direction:column;flex:1;min-width:0;display:flex}.route-stop-name{font-size:var(--text-sm);color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;font-weight:500;overflow:hidden}.route-stop-coords{font-size:10px;font-family:var(--font-mono);color:var(--text-tertiary)}.route-stop-actions{gap:2px;display:flex}.route-stop-btn{border:1px solid var(--border-default);background:var(--bg-overlay);width:22px;height:22px;color:var(--text-secondary);cursor:pointer;border-radius:3px;justify-content:center;align-items:center;font-size:12px;display:flex}.route-stop-btn:hover{background:var(--bg-hover)}.route-stop-remove:hover{background:var(--danger-bg);color:var(--danger-text)}.route-option{font-size:var(--text-sm);color:var(--text-secondary);cursor:pointer;align-items:center;gap:8px;display:flex}.route-map-area{flex:1;position:relative;overflow:hidden}.route-result{border:1px solid var(--border-default);border-radius:var(--radius);overflow:hidden}.route-result-stats{border-bottom:1px solid var(--border-subtle);gap:12px;padding:10px 12px;display:flex}.route-result-stat{flex-direction:column;display:flex}.route-result-stat-label{color:var(--text-tertiary);text-transform:uppercase;font-size:10px}.route-result-stat-value{font-size:var(--text-lg);font-weight:700;font-family:var(--font-mono);color:var(--text-primary)}.route-legs{flex-direction:column;display:flex}.route-leg{border-bottom:1px solid var(--border-subtle);font-size:var(--text-sm);justify-content:space-between;align-items:center;padding:6px 12px;display:flex}.route-leg:last-child{border-bottom:none}.route-leg-label{color:var(--text-primary);font-weight:500}.route-leg-meta{color:var(--text-tertiary);font-size:11px;font-family:var(--font-mono)}.route-section-label{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.04em;margin-bottom:6px;font-size:11px;font-weight:600;display:block}.route-vehicle-section{flex-direction:column;display:flex}.route-vehicle-grid{grid-template-columns:1fr 1fr;gap:4px;display:grid}.route-vehicle-option{border:1px solid var(--border-subtle);border-radius:var(--radius);background:var(--bg-overlay);cursor:pointer;text-align:left;flex-direction:column;padding:8px 10px;transition:all .12s;display:flex}.route-vehicle-option:hover{border-color:var(--border-default);background:var(--bg-hover)}.route-vehicle-option.active{border-color:var(--accent);background:#0066cc14}.route-vehicle-label{color:var(--text-primary);font-size:12px;font-weight:600}.route-vehicle-desc{color:var(--text-tertiary);margin-top:1px;font-size:10px}.route-result-header{border-bottom:1px solid var(--border-subtle);justify-content:space-between;align-items:center;padding:8px 12px;display:flex}.route-result-vehicle{color:var(--text-secondary);font-size:11px;font-weight:500}.route-vehicle-specs{border-bottom:1px solid var(--border-subtle);flex-wrap:wrap;gap:4px;padding:8px 12px;display:flex}.route-spec-badge{color:var(--text-secondary);background:var(--bg-hover);border:1px solid var(--border-subtle);border-radius:3px;padding:2px 8px;font-size:10px;font-weight:600}.route-restrictions{border-bottom:1px solid var(--border-subtle);background:#f59e0b0a;padding:8px 12px}.route-restrictions-title{color:var(--warning-text,#f59e0b);margin-bottom:4px;font-size:11px;font-weight:600;display:block}.route-restriction-item{color:var(--text-secondary);padding-left:4px;font-size:11px;line-height:1.5}.route-legs-header{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--border-subtle);padding:6px 12px;font-size:10px;font-weight:600}.carbon-table{flex-direction:column;display:flex}.carbon-row{border-bottom:1px solid var(--border-subtle);align-items:center;gap:16px;padding:12px 16px;transition:background .1s;display:flex}.carbon-row:hover{background:var(--bg-hover)}.carbon-row:last-child{border-bottom:none}.carbon-rank{font-size:var(--text-sm);color:var(--text-tertiary);text-align:center;min-width:28px;font-weight:700}.carbon-vehicle{flex-direction:column;gap:2px;min-width:160px;display:flex}.carbon-vehicle-name{font-weight:600;font-size:var(--text-base);color:var(--text-primary)}.carbon-vehicle-reg{font-family:var(--font-mono);color:var(--accent-text);font-size:11px}.carbon-fuel-badge{border-radius:3px;width:fit-content;padding:1px 6px;font-size:10px;font-weight:600;display:inline-flex}.carbon-bar-section{flex-direction:column;flex:1;gap:4px;min-width:140px;display:flex}.carbon-co2-value{font-family:var(--font-mono);font-size:var(--text-sm);color:var(--text-primary);font-weight:700}.carbon-bar-bg{background:var(--border-subtle);border-radius:3px;height:6px;overflow:hidden}.carbon-bar{border-radius:3px;height:100%;transition:width .6s ease-out}.carbon-metrics{gap:16px;display:flex}.carbon-metric{flex-direction:column;align-items:center;min-width:50px;display:flex}.carbon-metric-label{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.04em;font-size:10px}.carbon-metric-value{font-family:var(--font-mono);font-size:var(--text-sm);color:var(--text-primary);font-weight:600}.public-track-layout{background:var(--bg-root);flex-direction:column;height:100vh;display:flex}.public-track-header{background:var(--bg-raised);border-bottom:1px solid var(--border-subtle);flex-wrap:wrap;align-items:center;gap:16px;padding:10px 20px;display:flex}.public-track-brand{align-items:center;gap:8px;display:flex}.public-track-logo{background:var(--accent);border-radius:var(--radius);color:#fff;justify-content:center;align-items:center;width:28px;height:28px;font-size:13px;font-weight:700;display:flex}.public-track-brand-text{font-size:var(--text-md);color:var(--text-primary);font-weight:600}.public-track-info{align-items:center;gap:10px;margin-left:auto;display:flex}.public-track-vehicle{align-items:center;gap:8px;display:flex}.public-track-vehicle-name{font-weight:600;font-size:var(--text-base);color:var(--text-primary)}.public-track-vehicle-reg{font-family:var(--font-mono);font-size:var(--text-sm);color:var(--accent-text);font-weight:500}.public-track-status{color:#fff;text-transform:uppercase;border-radius:3px;padding:2px 8px;font-size:10px;font-weight:600}.public-track-meta{font-size:var(--text-xs);color:var(--text-tertiary);align-items:center;gap:12px;display:flex}.public-track-map{flex:1;position:relative}.public-track-footer{background:var(--bg-raised);border-top:1px solid var(--border-subtle);font-size:var(--text-xs);justify-content:space-between;align-items:center;padding:8px 20px;display:flex}.public-track-footer-stats{color:var(--text-secondary);gap:16px;display:flex}.public-track-powered{color:var(--text-tertiary);font-size:10px}.public-track-loading{height:100vh;color:var(--text-secondary);font-size:var(--text-sm);background:var(--bg-root);justify-content:center;align-items:center;gap:10px;display:flex}.public-track-error{text-align:center;background:var(--bg-root);height:100vh;color:var(--text-primary);flex-direction:column;justify-content:center;align-items:center;padding:24px;display:flex}.public-track-error-icon{margin-bottom:16px;font-size:48px}.public-track-error h1{font-size:var(--text-xl);margin-bottom:8px;font-weight:600}.public-track-error p{font-size:var(--text-sm);color:var(--text-secondary);margin-bottom:20px}.public-track-link{color:var(--accent-text);font-size:var(--text-sm)}.public-track-no-position{text-align:center;height:100%;color:var(--text-secondary);flex-direction:column;justify-content:center;align-items:center;padding:24px;display:flex}.public-track-no-position h2{font-size:var(--text-lg);color:var(--text-primary);margin-bottom:8px;font-weight:600}.public-track-no-position p{font-size:var(--text-sm);max-width:360px}
