.pickup-marker{z-index:500;filter:drop-shadow(0 0 4px rgba(var(--c-accent-rgb), .55))}*{box-sizing:border-box;margin:0;padding:0}:root{--c-bg:#0c0a06;--c-surface:#15110a;--c-surface-2:#1e1810;--c-surface-3:#281f13;--c-border:#322617;--c-border-2:#4a3820;--c-text:#f6efe0;--c-text-muted:#b59b6e;--c-text-dim:#6e5a3a;--c-accent-rgb:254, 219, 107;--c-cyan:#fedb6b;--c-cyan-10:rgba(var(--c-accent-rgb), .1);--c-cyan-20:rgba(var(--c-accent-rgb), .22);--c-success-rgb:0, 232, 122;--c-green:#00e87a;--c-green-10:rgba(var(--c-success-rgb), .1);--c-amber:#ffbc00;--c-amber-10:#ffbc001a;--c-red:#ff4d4d;--c-red-10:#ff4d4d1a;--c-blue:#4da6ff;--c-blue-10:#4da6ff1a;--c-purple:#a06eff;--c-purple-10:#a06eff1a;--c-purple-20:#a06eff33;--c-green-20:rgba(var(--c-success-rgb), .2);--c-amber-20:#ffbc0033;--c-red-20:#ff4d4d2e;--c-blue-20:#4da6ff33;--c-overlay:#00000040;--c-on-solid:#15110a;--color-primary:var(--c-cyan);--color-success:var(--c-green);--color-warning:var(--c-amber);--color-danger:var(--c-red);--color-info:var(--c-blue);--color-purple:#b36eff;--color-text:var(--c-text);--color-text-muted:var(--c-text-muted);--color-bg:var(--c-bg);--color-surface:var(--c-surface);--color-surface-alt:var(--c-surface-2);--color-surface-hover:var(--c-surface-3);--color-border:var(--c-border);--sidebar-width:231px;--sidebar-collapsed-width:62px;--header-h:54px;--radius:9px;--gap:18px;--font-ui:"Poppins", "Segoe UI", system-ui, sans-serif;--font-mono:"Space Mono", "Courier New", monospace;--font-body:"Poppins", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;--bg-pattern-main:url(/patterns/Udexon_Gold_Pattern_6.png);--bg-pattern-sidebar:url(/patterns/Udexon_Gold_Pattern_2.png);--bg-pattern-login:url(/patterns/Udexon_Gold_Pattern_3.png);--bg-pattern-detail:url(/patterns/Udexon_Gold_Pattern_2.png);--bg-pattern-opacity:.28;--bg-pattern-sidebar-opacity:.2;--bg-pattern-login-opacity:.45;--bg-pattern-detail-opacity:.2;--bg-pattern-header-opacity:.2;--bg-pattern-main-blend:screen;--bg-pattern-detail-blend:screen;--bg-pattern-main-filter:saturate(1.35) contrast(1.45) brightness(1.45);--bg-pattern-detail-filter:saturate(1.3) contrast(1.4) brightness(1.38);--bg-pattern-main-size:1600px auto;--bg-pattern-main-position:right 52% bottom 8%;--bg-pattern-tint-main:linear-gradient(160deg, rgba(var(--c-accent-rgb), .12), #0000);--bg-pattern-tint-detail:linear-gradient(140deg, rgba(var(--c-accent-rgb), .1), #0000);--bg-pattern-main-render:var(--bg-pattern-main);--bg-pattern-main-render-size:var(--bg-pattern-main-size);--bg-pattern-main-render-position:var(--bg-pattern-main-position);--bg-pattern-main-mask:none;--bg-pattern-detail-render:var(--bg-pattern-detail);--bg-pattern-sidebar-render:var(--bg-pattern-sidebar);--bg-pattern-sidebar-render-size:320px auto;--bg-pattern-sidebar-render-position:left bottom;--bg-pattern-sidebar-mask:none;--bg-pattern-sidebar-mask-size:320px auto;--bg-pattern-sidebar-mask-position:left bottom;--bg-pattern-header-render:var(--bg-pattern-detail);--bg-pattern-header-render-size:560px auto;--bg-pattern-header-render-position:right -80px center;--bg-pattern-header-mask:none;--bg-pattern-header-mask-size:560px auto;--bg-pattern-header-mask-position:right -80px center;--bg-pattern-login-render:var(--bg-pattern-login);--bg-pattern-login-render-size:contain;--bg-pattern-login-mask:none;--bg-pattern-login-overlay-render:var(--bg-pattern-main);--bg-pattern-login-overlay-render-size:1600px auto;--bg-pattern-login-overlay-render-position:right 52% bottom 8%;--bg-pattern-login-overlay-mask:none;--bg-pattern-login-overlay-opacity:var(--bg-pattern-opacity)}body{font-family:var(--font-body);background-color:var(--c-bg);color:var(--c-text);isolation:isolate;min-height:100vh;font-size:18px;position:relative}body:before{content:"";z-index:0;pointer-events:none;opacity:var(--bg-pattern-opacity);background-image:var(--bg-pattern-main-render);background-size:var(--bg-pattern-main-render-size);background-position:var(--bg-pattern-main-render-position);-webkit-mask-image:var(--bg-pattern-main-mask);-webkit-mask-size:var(--bg-pattern-main-size);-webkit-mask-position:var(--bg-pattern-main-position);-webkit-mask-repeat:no-repeat;-webkit-mask-image:var(--bg-pattern-main-mask);mask-image:var(--bg-pattern-main-mask);-webkit-mask-size:var(--bg-pattern-main-size);mask-size:var(--bg-pattern-main-size);-webkit-mask-position:var(--bg-pattern-main-position);mask-position:var(--bg-pattern-main-position);mix-blend-mode:var(--bg-pattern-main-blend);filter:var(--bg-pattern-main-filter);background-repeat:no-repeat;position:fixed;inset:0;-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat}.brand-text,.nav-link,.status-connected,.status-disconnected,#header h1,.badge,.panel-header h2,.kpi-label,.map-btn,.vehicle-status,.gauge-label,.scorecard-driver-name,.scorecard-label,.hub-name,.hub-status,.hub-demand,.duty-badge,.attention-badge,.raw-telem-label,.raw-telem-btn,.raw-telem-export-summary,.stat-tab,.filter-btn,#footer{font-family:var(--font-ui)}@keyframes pulse-live{0%,to{opacity:1;transform:scale(1)}50%{opacity:.35;transform:scale(1.8)}}@keyframes glow-critical{0%,to{box-shadow:0 0 #ff4d4d00}50%{box-shadow:0 0 18px 3px #ff4d4d52}}@keyframes scan-line{0%{width:40%;left:-40%}to{width:40%;left:110%}}@keyframes fade-in-up{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes slide-in-right{0%{opacity:0;transform:translate(16px)}to{opacity:1;transform:translate(0)}}@keyframes shimmer{0%{background-position:-200%}to{background-position:200%}}@keyframes data-flash{0%{opacity:1}25%{opacity:.5;color:var(--c-cyan)}to{opacity:1}}@keyframes card-glow-in{0%{box-shadow:0 0 0 0 var(--c-cyan-10)}to{box-shadow:0 4px 24px rgba(var(--c-accent-rgb), .08)}}#app{z-index:1;min-height:100vh;display:flex;position:relative}#sidebar-nav{width:var(--sidebar-width);background:var(--c-surface);border-right:1px solid var(--c-border);z-index:10;flex-direction:column;flex-shrink:0;height:100vh;transition:width .25s cubic-bezier(.4,0,.2,1);display:flex;position:sticky;top:0;overflow:hidden}#sidebar-nav:before{content:"";z-index:0;pointer-events:none;opacity:var(--bg-pattern-sidebar-opacity);mix-blend-mode:var(--bg-pattern-detail-blend);background-image:var(--bg-pattern-sidebar-render);background-size:var(--bg-pattern-sidebar-render-size);background-position:var(--bg-pattern-sidebar-render-position);-webkit-mask-image:var(--bg-pattern-sidebar-mask);-webkit-mask-size:var(--bg-pattern-sidebar-mask-size);-webkit-mask-position:var(--bg-pattern-sidebar-mask-position);-webkit-mask-repeat:no-repeat;-webkit-mask-image:var(--bg-pattern-sidebar-mask);mask-image:var(--bg-pattern-sidebar-mask);-webkit-mask-size:var(--bg-pattern-sidebar-mask-size);mask-size:var(--bg-pattern-sidebar-mask-size);-webkit-mask-position:var(--bg-pattern-sidebar-mask-position);mask-position:var(--bg-pattern-sidebar-mask-position);filter:var(--bg-pattern-detail-filter);background-repeat:no-repeat;position:absolute;inset:0;-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat}#sidebar-nav>*{z-index:1;position:relative}.nav-brand{height:var(--header-h);border-bottom:1px solid var(--c-border);flex-shrink:0;align-items:center;gap:10px;padding:0 16px;display:flex}.brand-logo{background-color:var(--c-cyan);min-width:0;height:26px;filter:drop-shadow(0 0 6px rgba(var(--c-accent-rgb), .45));flex:1;-webkit-mask:url(/udexon-logo.png) 0/contain no-repeat;mask:url(/udexon-logo.png) 0/contain no-repeat}.brand-text{letter-spacing:2px;text-transform:uppercase;color:var(--c-text);font-size:17px;font-weight:700;line-height:1}.nav-links{flex:1;min-height:0;padding:10px 0;overflow:hidden auto}.nav-link{color:var(--c-text-muted);letter-spacing:1px;text-transform:uppercase;cursor:pointer;border-left:2px solid #0000;align-items:center;gap:10px;padding:14px 18px;font-size:14px;font-weight:700;text-decoration:none;transition:all .2s;display:flex}.nav-link:hover{color:var(--c-text);background:var(--c-cyan-10);border-left-color:var(--c-text-muted);padding-left:22px}.nav-link.active{color:var(--c-cyan);background:var(--c-cyan-10);border-left-color:var(--c-cyan);text-shadow:0 0 12px rgba(var(--c-accent-rgb), .4)}.nav-section-label{letter-spacing:1.5px;text-transform:uppercase;color:var(--c-text-muted);-webkit-user-select:none;user-select:none;padding:14px 18px 3px;font-size:11px;font-weight:700;display:block}.collapsed .nav-section-label{display:none}.nav-badge{background:var(--c-red);color:var(--c-on-solid);font-size:11px;font-weight:700;font-family:var(--font-mono);text-align:center;border-radius:10px;flex-shrink:0;min-width:18px;margin-left:auto;padding:1px 6px;line-height:1.55}.nav-badge.hidden,.collapsed .nav-badge{display:none}.nav-link--dev{opacity:.65}.nav-link--dev:hover,.nav-link--dev.active{opacity:1}.nav-icon{color:inherit;flex-shrink:0;display:flex}.nav-footer{border-top:1px solid var(--c-border);flex-direction:column;padding:0;display:flex}.nav-footer .status-connected,.nav-footer .status-disconnected{border-top:1px solid var(--c-border);cursor:default;align-items:center;gap:10px;padding:14px 18px;display:flex}.nav-footer .status-connected .nav-icon,.nav-footer .status-disconnected .nav-icon{flex-shrink:0;display:flex}#nav-toggle{color:var(--c-text-muted);cursor:pointer;background:0 0;border:none;border-radius:5px;flex-shrink:0;justify-content:center;align-items:center;margin-left:auto;padding:6px;transition:color .15s,background .15s;display:flex}#nav-toggle:hover{color:var(--c-cyan);background:var(--c-cyan-10)}#sidebar-nav.collapsed{width:var(--sidebar-collapsed-width)}.collapsed .nav-brand{justify-content:center;gap:0}.collapsed .brand-logo,.collapsed .brand-text{display:none}.collapsed #nav-toggle{margin-left:0}.collapsed .nav-link{letter-spacing:0;justify-content:center;padding:14px 0}.collapsed .nav-link span:not(.nav-icon){display:none}.collapsed .nav-link .nav-icon{margin:0}.collapsed .nav-footer{flex-direction:column;padding:0;display:flex}.collapsed .nav-footer .status-connected,.collapsed .nav-footer .status-disconnected{justify-content:center;align-items:center;width:100%;padding:14px 0}.collapsed .nav-footer .status-connected .status-label,.collapsed .nav-footer .status-disconnected .status-label{display:none}.collapsed .nav-footer .status-connected .nav-icon,.collapsed .nav-footer .status-disconnected .nav-icon{margin:0}.status-connected,.status-disconnected{letter-spacing:.8px;text-transform:uppercase;font-size:13px;font-weight:700}.status-connected{color:var(--c-green);text-shadow:0 0 8px rgba(var(--c-success-rgb), .5)}.status-disconnected{color:var(--c-red)}#main-area{flex-direction:column;flex:1;min-width:0;display:flex}#header{height:var(--header-h);background:var(--c-surface);border-bottom:1px solid var(--c-border);flex-shrink:0;justify-content:space-between;align-items:center;padding:0 24px;display:flex;position:relative;overflow:hidden}#header:before{content:"";pointer-events:none;z-index:0;opacity:var(--bg-pattern-header-opacity);mix-blend-mode:var(--bg-pattern-detail-blend);background-image:var(--bg-pattern-header-render);background-size:var(--bg-pattern-header-render-size);background-position:var(--bg-pattern-header-render-position);-webkit-mask-image:var(--bg-pattern-header-mask);-webkit-mask-size:var(--bg-pattern-header-mask-size);-webkit-mask-position:var(--bg-pattern-header-mask-position);-webkit-mask-repeat:no-repeat;-webkit-mask-image:var(--bg-pattern-header-mask);mask-image:var(--bg-pattern-header-mask);-webkit-mask-size:var(--bg-pattern-header-mask-size);mask-size:var(--bg-pattern-header-mask-size);-webkit-mask-position:var(--bg-pattern-header-mask-position);mask-position:var(--bg-pattern-header-mask-position);filter:var(--bg-pattern-detail-filter);background-repeat:no-repeat;position:absolute;inset:0;-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat}#header:after{content:"";background:linear-gradient(90deg, transparent, var(--c-cyan), transparent);width:35%;height:1px;animation:8s linear infinite scan-line;position:absolute;bottom:0}#header>*{z-index:1;position:relative}#header h1{letter-spacing:2.5px;text-transform:uppercase;color:var(--c-cyan);text-shadow:0 0 16px rgba(var(--c-accent-rgb), .35);font-size:16px;font-weight:700}.header-right{align-items:center;gap:14px;display:flex}#clock{font-family:var(--font-mono);color:var(--c-text-muted);letter-spacing:1px;font-size:16px}.badge{background:var(--c-red);color:#fff;font-size:12px;font-weight:700;font-family:var(--font-mono);letter-spacing:.5px;border-radius:10px;padding:3px 10px;animation:2s infinite pulse-live}#page-content{flex-direction:column;flex:1;gap:20px;padding:22px 26px;display:flex;overflow-y:auto}#kpi-bar{gap:var(--gap);grid-template-columns:repeat(4,1fr);display:grid}.kpi-card{background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--radius);padding:22px 24px 20px;transition:transform .2s,border-color .2s,box-shadow .2s;position:relative;overflow:hidden}.kpi-card:hover{border-color:var(--c-border-2);box-shadow:0 12px 32px #0000004d, 0 0 0 1px var(--c-border-2);transform:translateY(-3px)}.kpi-card:before{content:"";opacity:0;height:1px;transition:opacity .2s;position:absolute;top:0;left:0;right:0}.kpi-card:hover:before{opacity:1}.kpi-card:after{content:"";height:2px;position:absolute;bottom:0;left:0;right:0}.kpi-card.utilization{box-shadow:inset 0 0 60px rgba(var(--c-accent-rgb), .04)}.kpi-card.utilization:after{background:linear-gradient(90deg, var(--c-cyan), #0090dd)}.kpi-card.utilization:before{background:linear-gradient(90deg, var(--c-cyan), transparent)}.kpi-card.efficiency{box-shadow:inset 0 0 60px rgba(var(--c-success-rgb), .04)}.kpi-card.efficiency:after{background:linear-gradient(90deg, var(--c-green), #00d060)}.kpi-card.efficiency:before{background:linear-gradient(90deg, var(--c-green), transparent)}.kpi-card.charging{box-shadow:inset 0 0 60px #ffbc000a}.kpi-card.charging:after{background:linear-gradient(90deg, var(--c-amber), #f80)}.kpi-card.charging:before{background:linear-gradient(90deg, var(--c-amber), transparent)}.kpi-card.energy{box-shadow:inset 0 0 60px #ff4d4d0a}.kpi-card.energy:after{background:linear-gradient(90deg, var(--c-red), #c08)}.kpi-card.energy:before{background:linear-gradient(90deg, var(--c-red), transparent)}.kpi-header{align-items:center;gap:11px;margin-bottom:14px;display:flex}.kpi-icon{flex-shrink:0;display:flex}.kpi-card.utilization .kpi-icon{color:var(--c-cyan);filter:drop-shadow(0 0 5px rgba(var(--c-accent-rgb), .5))}.kpi-card.efficiency .kpi-icon{color:var(--c-green);filter:drop-shadow(0 0 5px rgba(var(--c-success-rgb), .5))}.kpi-card.charging .kpi-icon{color:var(--c-amber);filter:drop-shadow(0 0 5px #ffbc0080)}.kpi-card.energy .kpi-icon{color:var(--c-red);filter:drop-shadow(0 0 5px #ff4d4d80)}.kpi-label{letter-spacing:.5px;color:var(--c-text-muted);font-size:12px;font-weight:700;line-height:1.3}.kpi-value-row{align-items:baseline;gap:6px;display:flex}.kpi-value{font-size:35px;font-weight:700;line-height:1;font-family:var(--font-mono);letter-spacing:-1px}.kpi-unit{color:var(--c-text-muted);font-size:14px;font-weight:500}.kpi-trend{font-size:13px;font-family:var(--font-body);letter-spacing:.3px;margin-top:8px;font-weight:400}.kpi-trend.up{color:var(--c-green)}.kpi-trend.down{color:var(--c-red)}.kpi-trend.neutral{color:var(--c-text-muted)}.kpi-sub-row{border-radius:2px;gap:2px;height:4px;margin-top:12px;display:flex;overflow:hidden}.kpi-sub-row span{border-radius:2px;min-width:4px}.fleet-counts{flex-wrap:wrap;gap:10px;margin-top:10px;display:flex}.fleet-count-item{font-size:11px;font-weight:700;font-family:var(--font-mono);align-items:center;gap:4px;display:flex}.fleet-count-item.active-c{color:var(--c-green)}.fleet-count-item.idle-c{color:var(--c-amber)}.fleet-count-item.offline-c{color:var(--c-red)}.fleet-count-item.charging-c{color:var(--c-blue)}#map-row{gap:var(--gap);grid-template-columns:1fr 360px;min-height:420px;animation:.4s .1s both fade-in-up;display:grid}#map-panel{background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--radius);flex-direction:column;display:flex;overflow:hidden}.panel-header{border-bottom:1px solid var(--c-border);background:var(--c-surface);flex-shrink:0;justify-content:space-between;align-items:center;padding:14px 20px;display:flex}.panel-header h2{letter-spacing:.5px;color:var(--c-text-muted);font-size:13px;font-weight:700}.map-controls{gap:6px;display:flex}.map-btn{color:var(--c-text-muted);border:1px solid var(--c-border);font-size:12px;font-weight:700;font-family:var(--font-ui);letter-spacing:.8px;text-transform:uppercase;cursor:pointer;background:0 0;border-radius:5px;padding:6px 13px;transition:all .2s}.map-btn:hover,.map-btn.active{background:var(--c-cyan-10);color:var(--c-cyan);border-color:var(--c-cyan);box-shadow:0 0 10px rgba(var(--c-accent-rgb), .15)}.map-select{background:var(--c-surface-2);color:var(--c-text);border:1px solid var(--c-border);font-size:12px;font-weight:700;font-family:var(--font-ui);letter-spacing:.5px;cursor:pointer;border-radius:5px;padding:6px 10px}#fleet-map{flex:1;min-height:340px}#vehicle-detail{background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--radius);padding:22px;animation:.3s .2s both slide-in-right;overflow-y:auto}#vehicle-detail h2{letter-spacing:.5px;color:var(--c-text-muted);margin-bottom:18px;font-size:13px;font-weight:700}.panel-hint{font-size:15px;font-family:var(--font-body);color:var(--c-text-muted);margin-top:10px;font-weight:400;line-height:1.7}.vehicle-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.vehicle-name{letter-spacing:1.5px;text-transform:uppercase;font-size:19px;font-weight:700;font-family:var(--font-mono);color:var(--c-cyan);text-shadow:0 0 14px rgba(var(--c-accent-rgb), .35)}.vehicle-status{text-transform:uppercase;letter-spacing:1px;border-radius:5px;padding:4px 13px;font-size:12px;font-weight:700}.vehicle-status.active{background:var(--c-green-10);color:var(--c-green);border:1px solid rgba(var(--c-success-rgb), .3)}.vehicle-status.idle{background:var(--c-amber-10);color:var(--c-amber);border:1px solid #ffbc004d}.vehicle-status.offline{background:var(--c-red-10);color:var(--c-red);border:1px solid #ff4d4d4d}.vehicle-status.charging{background:var(--c-blue-10);color:var(--c-blue);border:1px solid #4da6ff4d}.soc-gauge-wrap{justify-content:center;margin-bottom:14px;display:flex}.soc-gauge{width:150px;height:86px;overflow:visible}.soc-gauge-bg{fill:none;stroke:var(--c-border);stroke-width:8px;stroke-linecap:round}.soc-gauge-fill{fill:none;stroke-width:8px;stroke-linecap:round;filter:drop-shadow(0 0 6px);transition:stroke-dasharray .7s cubic-bezier(.4,0,.2,1),stroke .3s}.soc-gauge-num{fill:var(--c-text);font-family:Space Mono,monospace;font-size:19px;font-weight:700}.soc-gauge-sub{letter-spacing:.5px;fill:var(--c-text-muted);font-family:Rajdhani,sans-serif;font-size:11px;font-weight:700}.gauge-grid{grid-template-columns:1fr 1fr;gap:9px;display:grid}.gauge-item{background:var(--c-bg);border:1px solid var(--c-border);border-radius:var(--radius);text-align:center;padding:13px 15px;transition:border-color .2s,transform .2s,box-shadow .2s}.gauge-item:hover{border-color:var(--c-cyan);box-shadow:0 4px 16px rgba(var(--c-accent-rgb), .1);transform:translateY(-2px)}.gauge-label{letter-spacing:.3px;color:var(--c-text-muted);margin-bottom:5px;font-size:11px;font-weight:700}.gauge-value{font-size:23px;font-weight:700;font-family:var(--font-mono);line-height:1}.panel{background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--radius);animation:.4s .15s both fade-in-up;overflow:hidden}.grid-filters{gap:6px;display:flex}.filter-btn{color:var(--c-text-muted);border:1px solid var(--c-border);font-size:12px;font-weight:700;font-family:var(--font-ui);letter-spacing:.8px;text-transform:uppercase;cursor:pointer;background:0 0;border-radius:5px;padding:6px 15px;transition:all .2s}.filter-btn:hover{color:var(--c-text);border-color:var(--c-text-muted)}.filter-btn.active{background:var(--c-cyan-10);color:var(--c-cyan);border-color:var(--c-cyan);box-shadow:0 0 10px rgba(var(--c-accent-rgb), .12)}#telemetry-grid{overflow-x:auto}.telemetry-table{border-collapse:collapse;width:100%;font-size:14px}.telemetry-table thead{background:var(--c-surface-2);z-index:1;position:sticky;top:0}.telemetry-table th{text-align:left;letter-spacing:.3px;color:var(--c-text-muted);border-bottom:1px solid var(--c-border);white-space:nowrap;padding:12px 18px;font-size:11px;font-weight:700}.telemetry-table td{border-bottom:1px solid var(--c-border);white-space:nowrap;font-family:var(--font-mono);padding:11px 18px;font-size:14px;transition:background .15s}.telemetry-table tbody tr{cursor:pointer;transition:background .15s,box-shadow .15s}.telemetry-table tbody tr:nth-child(2n){background:var(--c-surface-2)}.telemetry-table tbody tr:hover{background:var(--c-cyan-10)!important}.telemetry-table tbody tr.selected{box-shadow:inset 2px 0 0 var(--c-cyan), inset -1px 0 0 rgba(var(--c-accent-rgb), .15);background:var(--c-cyan-10)!important}.telemetry-table.refreshing td{background-image:linear-gradient(90deg, transparent 25%, var(--c-cyan-10) 50%, transparent 75%);animation:shimmer 1s ease once;background-size:200% 100%}.vid-tag{background:var(--c-surface-3);color:var(--c-cyan);font-family:var(--font-mono);letter-spacing:.5px;border:1px solid var(--c-border-2);border-radius:4px;padding:3px 10px;font-size:13px;font-weight:700}.status-dot{vertical-align:middle;border-radius:50%;width:8px;height:8px;margin-right:7px;display:inline-block}.status-dot.active{background:var(--c-green);box-shadow:0 0 8px var(--c-green);animation:2s infinite pulse-live}.status-dot.idle{background:var(--c-amber)}.status-dot.offline{background:var(--c-red);opacity:.5}.status-dot.charging{background:var(--c-blue);box-shadow:0 0 7px var(--c-blue)}.mini-bar{align-items:center;gap:7px;min-width:96px;display:inline-flex}.mini-bar-track{background:var(--c-border);border-radius:2px;flex:1;height:4px;overflow:hidden}.mini-bar-fill{border-radius:2px;height:100%;transition:width .5s cubic-bezier(.4,0,.2,1)}.mini-bar-label{text-align:right;min-width:36px;font-size:13px;font-weight:700;font-family:var(--font-mono)}#alerts-section{overflow:hidden}#alerts-section .panel-header{padding:14px 20px}#alert-count{background:var(--c-red)}#alert-list{max-height:352px;padding:13px 20px;overflow-y:auto}.alert-item{background:var(--c-bg);border-radius:var(--radius);cursor:pointer;border-left:3px solid #0000;gap:12px;margin-bottom:8px;padding:12px 15px;transition:background .2s,transform .2s,box-shadow .2s;display:flex}.alert-item:last-child{margin-bottom:0}.alert-item:hover{background:var(--c-surface-3);transform:translate(3px);box-shadow:inset 3px 0}.alert-item.critical{border-left-color:var(--c-red);animation:3s infinite glow-critical}.alert-item.warning{border-left-color:var(--c-amber)}.alert-item.informational{border-left-color:var(--c-blue)}.alert-icon{flex-shrink:0;align-items:flex-start;padding-top:2px;display:flex}.alert-content{flex:1;min-width:0}.alert-message{font-size:14px;font-family:var(--font-body);color:var(--c-text);font-weight:400;line-height:1.55}.alert-time{color:var(--c-text-muted);font-size:12px;font-family:var(--font-mono);margin-top:4px}.tier-dot{border-radius:50%;width:10px;height:10px;display:inline-block}#fleet-stats{padding:20px 22px}.stat-tabs{flex-wrap:wrap;gap:6px;margin-bottom:18px;display:flex}.stat-tab{color:var(--c-text-muted);border:1px solid var(--c-border);font-size:12px;font-weight:700;font-family:var(--font-ui);letter-spacing:.8px;text-transform:uppercase;cursor:pointer;background:0 0;border-radius:5px;padding:6px 15px;transition:all .2s}.stat-tab:hover{color:var(--c-text);border-color:var(--c-text-muted)}.stat-tab.active{background:var(--c-cyan-10);color:var(--c-cyan);border-color:var(--c-cyan);box-shadow:0 0 10px rgba(var(--c-accent-rgb), .12)}.stat-bars{flex-direction:column;gap:10px;display:flex}.stat-bar-row{align-items:center;gap:12px;display:flex}.stat-bar-label{width:90px;font-family:var(--font-mono);color:var(--c-text-muted);white-space:nowrap;text-overflow:ellipsis;flex-shrink:0;font-size:13px;overflow:hidden}.stat-bar-track{background:var(--c-border);border-radius:4px;flex:1;height:7px;overflow:hidden}.stat-bar-fill{border-radius:4px;height:100%;transition:width .6s cubic-bezier(.4,0,.2,1)}.stat-bar-value{text-align:right;width:40px;font-family:var(--font-mono);color:var(--c-text-muted);flex-shrink:0;font-size:13px}.drivers-row{gap:var(--gap);grid-template-columns:1fr 290px;align-items:start;display:grid}#fleet-drivers{overflow-x:auto}.drivers-table{border-collapse:collapse;width:100%;font-size:14px}.drivers-table thead{background:var(--c-surface-2)}.drivers-table th{text-align:left;letter-spacing:.3px;color:var(--c-text-muted);border-bottom:1px solid var(--c-border);white-space:nowrap;padding:12px 18px;font-size:11px;font-weight:700}.drivers-table td{border-bottom:1px solid var(--c-border);vertical-align:middle;padding:12px 18px}.drivers-table tr:last-child td{border-bottom:none}.driver-row{cursor:pointer;transition:background .15s}.driver-row:hover{background:var(--c-cyan-10)}.driver-row.selected{background:var(--c-cyan-10);box-shadow:inset 2px 0 0 var(--c-cyan), inset -1px 0 0 rgba(var(--c-accent-rgb), .1)}.driver-cell{align-items:center;gap:12px;display:flex}.driver-avatar{background:var(--c-surface-3);border:1px solid var(--c-border-2);width:36px;height:36px;color:var(--c-cyan);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:14px;font-weight:700;display:flex}.driver-name{font-size:14px;font-family:var(--font-body);color:var(--c-text);font-weight:500}.driver-id{color:var(--c-text-muted);font-size:12px;font-family:var(--font-mono)}.duty-badge{text-transform:uppercase;letter-spacing:.5px;border-radius:4px;padding:3px 10px;font-size:12px;font-weight:700;display:inline-block}.duty-badge.on-duty{background:var(--c-green-10);color:var(--c-green);border:1px solid rgba(var(--c-success-rgb), .25)}.duty-badge.break{background:var(--c-amber-10);color:var(--c-amber);border:1px solid #ffbc0040}.duty-badge.off-duty{color:var(--c-text-muted);border:1px solid var(--c-border);background:#1a2d4f80}.attention-badge{text-transform:uppercase;letter-spacing:.5px;border-radius:4px;padding:3px 10px;font-size:12px;font-weight:700;display:inline-block}.attention-badge.critical{background:var(--c-red-10);color:var(--c-red)}.attention-badge.good{background:var(--c-green-10);color:var(--c-green)}.score-value{font-family:var(--font-mono);font-size:17px;font-weight:700}.score-value.good{color:var(--c-green)}.score-value.ok{color:var(--c-amber)}.score-value.poor{color:var(--c-red)}.scorecard-driver-name{letter-spacing:.5px;color:var(--c-cyan);border-bottom:1px solid var(--c-border);font-size:14px;font-weight:700;font-family:var(--font-body);text-shadow:0 0 12px rgba(var(--c-accent-rgb), .3);padding:15px 20px 13px}.scorecard-grid{grid-template-columns:1fr 1fr;gap:10px;padding:15px 20px;display:grid}.scorecard-item{background:var(--c-bg);border:1px solid var(--c-border);border-radius:var(--radius);text-align:center;padding:15px;transition:transform .2s,border-color .2s,box-shadow .2s}.scorecard-item:hover{border-color:var(--c-cyan);box-shadow:0 4px 16px rgba(var(--c-accent-rgb), .1);transform:translateY(-2px)}.scorecard-label{letter-spacing:.3px;color:var(--c-text-muted);margin-bottom:8px;font-size:11px;font-weight:700}.scorecard-value{font-size:26px;font-weight:700;font-family:var(--font-mono);color:var(--c-text);line-height:1}.scorecard-value.good{color:var(--c-green)}.scorecard-value.ok{color:var(--c-amber)}.scorecard-value.poor{color:var(--c-red)}.scorecard-trend{font-size:12px;font-family:var(--font-body);color:var(--c-text-muted);margin-top:5px;font-weight:400}.scorecard-trend.up{color:var(--c-green)}.scorecard-trend.down{color:var(--c-red)}.scorecard-trend.stable{color:var(--c-text-muted)}#charging-infra{padding:18px 20px}.hub-grid{grid-template-columns:repeat(auto-fill,minmax(193px,1fr));gap:15px;display:grid}.hub-card{background:var(--c-bg);border:1px solid var(--c-border);border-radius:var(--radius);padding:18px;transition:transform .25s,border-color .2s,box-shadow .2s}.hub-card:hover{border-color:var(--c-border-2);box-shadow:0 8px 24px #00000040, 0 0 0 1px var(--c-border-2);transform:translateY(-3px)}.hub-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.hub-name{color:var(--c-text);font-size:15px;font-weight:700}.hub-status{text-transform:uppercase;letter-spacing:.5px;border-radius:4px;padding:2px 9px;font-size:12px;font-weight:700}.hub-status.success{background:var(--c-green-10);color:var(--c-green);border:1px solid rgba(var(--c-success-rgb), .25)}.hub-status.muted{color:var(--c-text-muted);border:1px solid var(--c-border);background:#1a2d4f66}.hub-type{font-size:13px;font-family:var(--font-body);color:var(--c-text-muted);margin-bottom:12px;font-weight:400}.hub-load{margin-bottom:9px}.hub-load-track{background:var(--c-border);border-radius:3px;height:6px;margin-bottom:5px;overflow:hidden}.hub-load-fill{border-radius:3px;height:100%;transition:width .6s cubic-bezier(.4,0,.2,1)}.hub-load-label{color:var(--c-text-muted);font-size:12px;font-family:var(--font-mono);justify-content:space-between;display:flex}.hub-demand{text-transform:uppercase;letter-spacing:.5px;border-radius:4px;padding:2px 9px;font-size:12px;font-weight:700;display:inline-block}.hub-demand.danger{background:var(--c-red-10);color:var(--c-red);border:1px solid #ff4d4d40}.hub-demand.success{background:var(--c-green-10);color:var(--c-green);border:1px solid rgba(var(--c-success-rgb), .25)}.hub-demand.warning{background:var(--c-amber-10);color:var(--c-amber);border:1px solid #ffbc0040}.raw-telem-toolbar{border-bottom:1px solid var(--c-border);background:var(--c-surface-2);flex-wrap:wrap;align-items:center;gap:16px;padding:12px 18px;display:flex}.raw-telem-label{color:var(--c-text-muted);letter-spacing:.3px;align-items:center;gap:6px;font-size:13px;font-weight:700;display:flex}.raw-telem-select{background:var(--c-bg);border:1px solid var(--c-border);color:var(--c-text);font-size:14px;font-family:var(--font-mono);cursor:pointer;border-radius:5px;padding:6px 11px;transition:border-color .2s}.raw-telem-select:focus{border-color:var(--c-cyan);outline:none}.raw-telem-count{font-family:var(--font-mono);color:var(--c-cyan);margin-left:auto;font-size:13px}.raw-telem-scroll{max-height:462px;overflow:auto}.raw-telem-table{font-size:13px}.raw-telem-footer{border-top:1px solid var(--c-border);text-align:center;padding:12px 18px}.raw-telem-btn{background:var(--c-surface-2);color:var(--c-cyan);border:1px solid var(--c-cyan);font-size:13px;font-weight:700;font-family:var(--font-ui);letter-spacing:1px;text-transform:uppercase;cursor:pointer;border-radius:5px;padding:8px 24px;transition:all .2s}.raw-telem-btn:hover{background:var(--c-cyan-10);box-shadow:0 0 12px rgba(var(--c-accent-rgb), .15)}.raw-telem-btn:disabled{opacity:.4;cursor:not-allowed}.raw-telem-exhausted{color:var(--c-text-muted);font-size:13px;font-style:italic}.raw-telem-tabs{border-bottom:1px solid var(--c-border);background:var(--c-surface-2);gap:4px;padding:8px 18px 0;display:flex}.raw-telem-tab{color:var(--c-text-muted);font-size:12px;font-weight:700;font-family:var(--font-ui);letter-spacing:1px;text-transform:uppercase;cursor:pointer;background:0 0;border:1px solid #0000;border-bottom:none;border-radius:5px 5px 0 0;padding:8px 18px;transition:all .15s}.raw-telem-tab:hover{color:var(--c-cyan)}.raw-telem-tab.active{color:var(--c-cyan);background:var(--c-bg);border-color:var(--c-border);border-bottom:1px solid var(--c-bg);margin-bottom:-1px}.raw-telem-hint{color:var(--c-text-dim);margin-left:12px;font-size:12px;font-style:italic}.raw-bin-empty{text-align:center;color:var(--c-text-muted);padding:40px 20px;font-size:13px;font-style:italic}.raw-bin-table{font-family:var(--font-mono)}.raw-bin-row{cursor:pointer;transition:background .15s}.raw-bin-row:hover{background:var(--c-cyan-10)}.raw-bin-row-fail{background:#ff4d4d0f}.raw-bin-row-fail:hover{background:#ff4d4d1f}.raw-bin-status{letter-spacing:.5px;text-transform:uppercase;white-space:nowrap;border-radius:3px;padding:3px 8px;font-size:11px;font-weight:700}.raw-bin-status-ok{color:var(--c-green);background:var(--c-green-10)}.raw-bin-status-fail{color:var(--c-red);background:var(--c-red-10)}.raw-bin-hex-preview{font-family:var(--font-mono);color:var(--c-text);white-space:nowrap;text-overflow:ellipsis;max-width:480px;font-size:12px;display:block;overflow:hidden}.raw-bin-hex-full{font-family:var(--font-mono);color:var(--c-text);background:var(--c-bg);border:1px solid var(--c-border);white-space:pre;border-radius:4px;max-height:320px;margin:8px 0 0;padding:10px 12px;font-size:12px;display:none;overflow:auto}.raw-bin-row.expanded .raw-bin-hex-preview{display:none}.raw-bin-row.expanded .raw-bin-hex-full{display:block}.raw-telem-export{border-bottom:1px solid var(--c-border)}.raw-telem-export-summary{background:var(--c-surface-2);letter-spacing:1px;text-transform:uppercase;color:var(--c-text-muted);cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:7px;padding:9px 18px;font-size:12px;font-weight:700;list-style:none;transition:color .15s,background .15s;display:flex}.raw-telem-export-summary:before{content:"▸";color:var(--c-text-dim);font-size:10px;line-height:1;transition:transform .15s}details.raw-telem-export[open]>.raw-telem-export-summary:before{transform:rotate(90deg)}.raw-telem-export-summary::-webkit-details-marker{display:none}.raw-telem-export-summary:hover{color:var(--c-cyan);background:var(--c-surface-3)}details.raw-telem-export[open]>.raw-telem-export-summary{color:var(--c-cyan);border-bottom:1px solid var(--c-border)}.raw-telem-export-body{background:var(--c-surface-2);flex-wrap:wrap;align-items:flex-end;gap:12px 20px;padding:12px 18px;display:flex}.raw-telem-input{background:var(--c-bg);border:1px solid var(--c-border);color:var(--c-text);font-size:13px;font-family:var(--font-mono);cursor:pointer;border-radius:5px;margin-top:4px;padding:6px 10px;transition:border-color .2s;display:block}.raw-telem-input:focus{border-color:var(--c-cyan);box-shadow:0 0 0 2px var(--c-cyan-10);outline:none}.raw-telem-input::-webkit-calendar-picker-indicator{filter:invert(.65)sepia()saturate(4)hue-rotate(165deg);cursor:pointer;opacity:.8}.raw-telem-dl-status{font-family:var(--font-mono);margin-bottom:2px;padding:0 2px;font-size:12px}.raw-telem-dl-ok{color:var(--c-green)}.raw-telem-dl-err{color:var(--c-red)}#footer{text-align:center;letter-spacing:.5px;color:var(--c-text-dim);border-top:1px solid var(--c-border);padding:13px 26px;font-size:12px;font-weight:400}.settings-wrap{flex-direction:column;display:flex}.settings-wrap--single{background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--radius)}.settings-tabs-nav{border-bottom:1px solid var(--c-border);background:var(--c-surface-2);gap:8px;padding:16px 20px 0;display:flex}.settings-tab{color:var(--c-text-muted);font-size:13px;font-weight:700;font-family:var(--font-ui);letter-spacing:.8px;text-transform:uppercase;cursor:pointer;background:0 0;border:1px solid #0000;border-bottom:none;border-radius:6px 6px 0 0;align-items:center;gap:7px;padding:9px 20px;transition:all .2s;display:flex;position:relative;bottom:-1px}.settings-tab:hover{color:var(--c-text);background:var(--c-surface-3)}.settings-tab.active{color:var(--c-cyan);background:var(--c-surface);border-color:var(--c-border);border-bottom-color:var(--c-surface);text-shadow:0 0 12px rgba(var(--c-accent-rgb), .3)}.settings-body{padding:20px 22px}.settings-note{font-size:13px;font-family:var(--font-body);color:var(--c-text-muted);margin-bottom:18px;font-weight:400;line-height:1.65}.settings-empty{font-size:14px;font-family:var(--font-body);color:var(--c-text-muted);text-align:center;padding:28px 0;line-height:1.7}.settings-table-wrap{border:1px solid var(--c-border);border-radius:var(--radius);margin-bottom:18px;overflow-x:auto}.settings-table-wrap table{border-collapse:collapse;width:100%;font-size:13px;font-family:var(--font-body)}.settings-table-wrap thead{background:var(--c-surface-2)}.settings-table-wrap th{text-align:left;letter-spacing:.4px;text-transform:uppercase;color:var(--c-text-muted);border-bottom:1px solid var(--c-border);white-space:nowrap;padding:10px 14px;font-size:11px;font-weight:700}.settings-table-wrap td{border-bottom:1px solid var(--c-border);vertical-align:middle;color:var(--c-text);padding:10px 14px}.settings-table-wrap tbody tr:last-child td{border-bottom:none}.settings-table-wrap tbody tr{transition:background .15s}.settings-table-wrap tbody tr:hover{background:var(--c-surface-3)}.settings-assign-table td:last-child{width:45%}.settings-input{background:var(--c-bg);border:1px solid var(--c-border);color:var(--c-text);font-size:13px;font-family:var(--font-body);border-radius:5px;width:100%;max-width:280px;padding:6px 10px;transition:border-color .2s}.settings-input:focus{border-color:var(--c-cyan);box-shadow:0 0 0 2px var(--c-cyan-10);outline:none}.settings-input::placeholder{color:var(--c-text-dim)}.settings-actions{flex-wrap:wrap;gap:10px;display:flex}.settings-save-btn{background:var(--c-cyan-10);color:var(--c-cyan);border:1px solid var(--c-cyan);font-size:13px;font-weight:700;font-family:var(--font-ui);letter-spacing:1px;text-transform:uppercase;cursor:pointer;border-radius:5px;padding:8px 22px;transition:all .2s}.settings-save-btn:hover{background:rgba(var(--c-accent-rgb), .2);box-shadow:0 0 12px rgba(var(--c-accent-rgb), .2)}.settings-save-btn:disabled{opacity:.5;cursor:not-allowed}.settings-clear-btn{color:var(--c-text-muted);border:1px solid var(--c-border);font-size:13px;font-weight:700;font-family:var(--font-ui);letter-spacing:1px;text-transform:uppercase;cursor:pointer;background:0 0;border-radius:5px;padding:8px 18px;transition:all .2s}.settings-clear-btn:hover{color:var(--c-red);border-color:var(--c-red);background:var(--c-red-10)}.settings-mono{font-family:var(--font-mono);color:var(--c-text-muted);font-size:12px}.settings-code{font-family:var(--font-mono);background:var(--c-surface-3);border:1px solid var(--c-border-2);color:var(--c-cyan);border-radius:4px;padding:1px 6px;font-size:12px}.settings-type-badge{font-size:12px;font-weight:700;font-family:var(--font-ui);letter-spacing:.5px;text-transform:uppercase;border-radius:4px;padding:2px 9px;display:inline-block}.settings-type-station{background:var(--c-amber-10);color:var(--c-amber);border:1px solid #ffbc0040}.settings-type-zone{background:var(--c-blue-10);color:var(--c-blue);border:1px solid #4da6ff40}.settings-geo-form{border-top:1px solid var(--c-border);margin-top:22px;padding-top:22px}.settings-form-title{font-size:13px;font-weight:700;font-family:var(--font-ui);letter-spacing:.5px;text-transform:uppercase;color:var(--c-text-muted);margin-bottom:14px}.settings-form-error{background:var(--c-red-10);border-radius:var(--radius);color:var(--c-red);font-size:13px;font-family:var(--font-body);border:1px solid #ff4d4d59;margin-bottom:14px;padding:9px 14px}.settings-form-grid{grid-template-columns:1fr 1fr;gap:14px;margin-bottom:16px;display:grid}.settings-field{flex-direction:column;gap:6px;display:flex}.settings-field-full{grid-column:1/-1}.settings-label{font-size:12px;font-weight:700;font-family:var(--font-ui);letter-spacing:.5px;text-transform:uppercase;color:var(--c-text-muted)}.settings-label-hint{text-transform:none;letter-spacing:0;font-size:11px;font-weight:400;font-family:var(--font-body);color:var(--c-text-dim)}.settings-select{appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' fill='none'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%236B90B8' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;padding-right:28px}.settings-textarea{resize:vertical;min-height:110px;font-family:var(--font-mono);font-size:12px;line-height:1.6}.settings-row-actions{justify-content:flex-end;gap:6px;display:flex}.settings-icon-btn{border:1px solid var(--c-border);cursor:pointer;color:var(--c-text-muted);background:0 0;border-radius:5px;justify-content:center;align-items:center;padding:5px 7px;transition:all .15s;display:flex}.settings-edit-btn:hover{color:var(--c-cyan);border-color:var(--c-cyan);background:var(--c-cyan-10)}.settings-delete-btn:hover{color:var(--c-red);border-color:var(--c-red);background:var(--c-red-10)}.settings-icon-btn:disabled{opacity:.4;cursor:not-allowed}.um-sub-nav{border-bottom:1px solid var(--c-border);gap:6px;margin-bottom:18px;padding-bottom:10px;display:flex}.um-sub-btn{font-size:12px;font-weight:700;font-family:var(--font-ui);letter-spacing:.5px;text-transform:uppercase;color:var(--c-text-muted);cursor:pointer;background:0 0;border:1px solid #0000;border-radius:6px;padding:5px 14px;transition:all .15s}.um-sub-btn.active,.um-sub-btn:hover{color:var(--c-cyan);border-color:var(--c-cyan);background:var(--c-cyan-10)}.um-filter-bar{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:14px;display:flex}.um-filter-bar .settings-input{flex:1;min-width:160px;max-width:260px}.um-add-btn{background:var(--c-cyan-10);border:1px solid var(--c-cyan);color:var(--c-cyan);font-size:12px;font-weight:700;font-family:var(--font-ui);letter-spacing:.5px;text-transform:uppercase;cursor:pointer;border-radius:6px;align-items:center;gap:6px;margin-left:auto;padding:6px 14px;transition:all .15s;display:flex}.um-add-btn:hover{background:var(--c-cyan-20)}.um-badge{font-size:11px;font-weight:700;font-family:var(--font-ui);letter-spacing:.5px;text-transform:uppercase;border-radius:4px;padding:2px 8px;display:inline-block}.um-badge-admin{background:var(--c-purple-10);color:var(--c-purple);border:1px solid var(--c-purple-20)}.um-badge-driver{background:var(--c-amber-10);color:var(--c-amber);border:1px solid var(--c-amber-20)}.um-badge-rider{background:var(--c-blue-10);color:var(--c-blue);border:1px solid var(--c-blue-20)}.um-badge-active{background:var(--c-green-10);color:var(--c-green);border:1px solid var(--c-green-20)}.um-badge-suspended{background:var(--c-red-10);color:var(--c-red);border:1px solid var(--c-red-20)}.um-badge-pending{background:var(--c-amber-10);color:var(--c-amber);border:1px solid var(--c-amber-20)}.um-badge-approved{background:var(--c-green-10);color:var(--c-green);border:1px solid var(--c-green-20)}.um-split{grid-template-columns:1fr;gap:20px;display:grid}.um-split.has-drawer{grid-template-columns:1fr 380px}.um-table-col{min-width:0;overflow:hidden}.um-drawer{background:var(--c-surface-2);border:1px solid var(--c-border);border-radius:var(--radius);flex-direction:column;gap:18px;max-height:700px;padding:18px;display:flex;overflow-y:auto}.um-drawer-header{justify-content:space-between;align-items:center;gap:10px;display:flex}.um-drawer-title{font-size:13px;font-weight:700;font-family:var(--font-ui);letter-spacing:.5px;text-transform:uppercase;color:var(--c-text)}.um-drawer-close{cursor:pointer;color:var(--c-text-muted);background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;padding:4px;transition:color .15s;display:flex}.um-drawer-close:hover{color:var(--c-text)}.um-drawer-section-title{font-size:11px;font-weight:700;font-family:var(--font-ui);letter-spacing:.8px;text-transform:uppercase;color:var(--c-text-dim);border-bottom:1px solid var(--c-border);margin-bottom:10px;padding-bottom:6px}.um-perm-grid{grid-template-columns:1fr 1fr;gap:6px;display:grid}.um-perm-group{font-size:10px;font-weight:700;font-family:var(--font-ui);letter-spacing:.8px;text-transform:uppercase;color:var(--c-text-dim);grid-column:1/-1;margin-top:8px;margin-bottom:2px}.um-perm-row{border:1px solid var(--c-border);cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:5px;align-items:center;gap:8px;padding:5px 8px;transition:border-color .15s,background .15s;display:flex}.um-perm-row:hover{border-color:var(--c-cyan);background:var(--c-cyan-10)}.um-perm-row input[type=checkbox]{accent-color:var(--c-cyan);cursor:pointer;flex-shrink:0;width:14px;height:14px}.um-perm-label{font-size:12px;font-family:var(--font-mono);color:var(--c-text-muted);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.um-perm-row.inherited{opacity:.7;background:var(--c-overlay)}.um-perm-inherited-tag{font-size:10px;font-family:var(--font-ui);color:var(--c-text-dim);white-space:nowrap}.um-group-chips{flex-wrap:wrap;gap:6px;margin-bottom:10px;display:flex}.um-group-chip{background:var(--c-surface-3);border:1px solid var(--c-border);font-size:12px;font-family:var(--font-ui);color:var(--c-text-muted);border-radius:20px;align-items:center;gap:6px;padding:3px 10px;display:flex}.um-group-chip-remove{cursor:pointer;color:var(--c-text-dim);background:0 0;border:none;align-items:center;padding:0;font-size:14px;line-height:1;transition:color .15s;display:flex}.um-group-chip-remove:hover{color:var(--c-red)}.um-group-list{flex-direction:column;gap:6px;max-height:160px;padding-right:4px;display:flex;overflow-y:auto}.um-group-pick-row{border:1px solid var(--c-border);cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:5px;align-items:center;gap:8px;padding:6px 8px;transition:border-color .15s,background .15s;display:flex}.um-group-pick-row:hover{border-color:var(--c-cyan);background:var(--c-cyan-10)}.um-group-pick-row input[type=checkbox]{accent-color:var(--c-cyan);cursor:pointer;flex-shrink:0;width:14px;height:14px}.um-group-pick-name{font-size:12px;font-family:var(--font-ui);color:var(--c-text-muted);font-weight:700}.um-group-pick-perms{font-size:11px;font-family:var(--font-mono);color:var(--c-text-dim);margin-left:auto}.um-group-card{background:var(--c-surface-2);border:1px solid var(--c-border);border-radius:var(--radius);grid-template-columns:1fr auto;align-items:start;gap:8px;padding:14px 16px;display:grid}.um-group-card.editing{border-color:var(--c-cyan)}.um-group-card-name{font-size:14px;font-weight:700;font-family:var(--font-ui);color:var(--c-text)}.um-group-card-meta{color:var(--c-text-dim);font-size:12px;font-family:var(--font-body);margin-top:2px}.um-group-card-perms{flex-wrap:wrap;gap:4px;margin-top:8px;display:flex}.um-perm-chip{background:var(--c-surface-3);border:1px solid var(--c-border);font-size:11px;font-family:var(--font-mono);color:var(--c-text-muted);border-radius:4px;padding:2px 7px}.um-group-card-actions{align-self:start;gap:6px;display:flex}.um-drawer-actions{gap:8px;padding-top:4px;display:flex}.um-drawer-save{background:var(--c-cyan-10);border:1px solid var(--c-cyan);color:var(--c-cyan);font-size:12px;font-weight:700;font-family:var(--font-ui);letter-spacing:.5px;text-transform:uppercase;cursor:pointer;border-radius:6px;flex:1;padding:7px 14px;transition:all .15s}.um-drawer-save:hover{background:var(--c-cyan-20)}.um-drawer-save:disabled{opacity:.45;cursor:not-allowed}.um-drawer-danger{background:var(--c-red-10);border:1px solid var(--c-red);color:var(--c-red);font-size:12px;font-weight:700;font-family:var(--font-ui);letter-spacing:.5px;text-transform:uppercase;cursor:pointer;border-radius:6px;padding:7px 12px;transition:all .15s}.um-drawer-danger:hover{background:var(--c-red-20)}.um-notice{color:var(--c-text-dim);font-size:12px;font-family:var(--font-body);margin-top:4px;font-style:italic}.um-effective-summary{background:var(--c-surface-3);border:1px solid var(--c-border);border-radius:var(--radius);padding:10px 12px}.um-effective-label{font-size:11px;font-weight:700;font-family:var(--font-ui);letter-spacing:.8px;text-transform:uppercase;color:var(--c-text-dim);margin-bottom:8px}.um-effective-chips{flex-wrap:wrap;gap:4px;display:flex}.um-none-text{color:var(--c-text-dim);font-size:12px;font-family:var(--font-body);font-style:italic}.um-section-title{letter-spacing:.08em;text-transform:uppercase;color:var(--c-text-dim);border-bottom:1px solid var(--c-border);margin-bottom:10px;padding-bottom:6px;font-size:11px;font-weight:700}.um-section-hint{letter-spacing:0;text-transform:none;color:var(--c-text-dim);font-weight:400}.um-role-groups{flex-direction:column;gap:6px;display:flex}.um-role-group-card{border:1px solid var(--c-border);border-radius:var(--radius);background:var(--c-surface-2);transition:border-color .15s;overflow:hidden}.um-role-group-header{cursor:pointer;-webkit-user-select:none;user-select:none;justify-content:space-between;align-items:center;padding:10px 14px;display:flex}.um-role-group-header:hover{background:var(--c-surface-3)}.um-role-group-name{color:var(--c-text);font-size:13px;font-weight:600}.um-role-group-body{border-top:1px solid var(--c-border);padding:4px 14px 14px}.um-role-member-list{flex-direction:column;gap:0;margin-bottom:6px;display:flex}.um-role-member-row{border-bottom:1px solid var(--c-border);align-items:center;gap:8px;padding:6px 0;display:flex}.um-role-member-row:last-child{border-bottom:none}.um-role-add-row{border-top:1px solid var(--c-border);align-items:center;gap:8px;margin-top:10px;padding-top:10px;display:flex}.um-notice{color:var(--c-text-muted);margin:6px 0 10px;font-size:12px;line-height:1.5}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--c-border-2);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--c-text-muted)}[data-theme=light]{--c-bg:#f7f2e7;--c-surface:#fff;--c-surface-2:#f3ecdb;--c-surface-3:#e9dec5;--c-border:#ddcea8;--c-border-2:#c4ae7c;--c-text:#2a1d08;--c-text-muted:#7a6234;--c-text-dim:#b09a6a;--c-accent-rgb:168, 119, 52;--c-cyan:#a87734;--c-cyan-10:rgba(var(--c-accent-rgb), .1);--c-cyan-20:rgba(var(--c-accent-rgb), .18);--c-success-rgb:0, 136, 74;--c-green:#00884a;--c-green-10:rgba(var(--c-success-rgb), .08);--c-amber:#b60;--c-amber-10:#bb660014;--c-red:#b20;--c-red-10:#bb220014;--c-blue:#0050bb;--c-blue-10:#0050bb14;--c-overlay:#2a1d0814;--c-on-solid:#fff;--bg-pattern-opacity:.88;--bg-pattern-sidebar-opacity:.52;--bg-pattern-login-opacity:.88;--bg-pattern-detail-opacity:.3;--bg-pattern-header-opacity:.56;--bg-pattern-main-blend:normal;--bg-pattern-detail-blend:normal;--bg-pattern-main-filter:saturate(2.15) contrast(1.75) brightness(.58);--bg-pattern-detail-filter:saturate(2.05) contrast(1.7) brightness(.6);--bg-pattern-main-size:1600px auto;--bg-pattern-main-position:right 52% bottom 8%;--bg-pattern-tint-main:linear-gradient(150deg, #fedb6b9e, #d69c473d);--bg-pattern-tint-detail:linear-gradient(140deg, #fedb6b94, #d69c4738);--bg-pattern-main-render:var(--bg-pattern-tint-main);--bg-pattern-main-render-size:var(--bg-pattern-main-size);--bg-pattern-main-render-position:var(--bg-pattern-main-position);--bg-pattern-main-mask:var(--bg-pattern-main);--bg-pattern-detail-render:var(--bg-pattern-tint-detail);--bg-pattern-sidebar-render:var(--bg-pattern-sidebar);--bg-pattern-sidebar-render-size:320px auto;--bg-pattern-sidebar-render-position:left bottom;--bg-pattern-sidebar-mask:none;--bg-pattern-sidebar-mask-size:320px auto;--bg-pattern-sidebar-mask-position:left bottom;--bg-pattern-header-render:var(--bg-pattern-detail);--bg-pattern-header-render-size:560px auto;--bg-pattern-header-render-position:right -80px center;--bg-pattern-header-mask:none;--bg-pattern-header-mask-size:560px auto;--bg-pattern-header-mask-position:right -80px center;--bg-pattern-login-render:var(--bg-pattern-tint-detail);--bg-pattern-login-mask:var(--bg-pattern-login);--bg-pattern-login-overlay-render:var(--bg-pattern-main);--bg-pattern-login-overlay-render-size:1600px auto;--bg-pattern-login-overlay-render-position:right 52% bottom 8%;--bg-pattern-login-overlay-mask:none;--bg-pattern-login-overlay-opacity:var(--bg-pattern-opacity)}#user-info{font-family:var(--font-mono);letter-spacing:.5px;color:var(--c-text-muted);background:var(--c-surface-2);border:1px solid var(--c-border);border-radius:5px;padding:4px 10px;font-size:12px;font-weight:700}.theme-btn{background:var(--c-surface-2);border:1px solid var(--c-border);width:32px;height:32px;color:var(--c-text);cursor:pointer;border-radius:6px;justify-content:center;align-items:center;transition:all .2s;display:flex}.theme-btn:hover{background:var(--c-cyan-10);border-color:var(--c-cyan);color:var(--c-cyan);box-shadow:0 0 10px rgba(var(--c-accent-rgb), .15)}@media (width<=1200px){#map-row{grid-template-columns:1fr}#kpi-bar{grid-template-columns:repeat(2,1fr)}.drivers-row{grid-template-columns:1fr}}.theme-changing,.theme-changing *,.theme-changing :before,.theme-changing :after{transition:background-color .35s,color .35s,border-color .35s,fill .35s,stroke .35s,box-shadow .35s,text-shadow .35s!important}.animate-in .kpi-card{animation:.35s both fade-in-up}.animate-in .kpi-card:first-child{animation-delay:50ms}.animate-in .kpi-card:nth-child(2){animation-delay:.1s}.animate-in .kpi-card:nth-child(3){animation-delay:.15s}.animate-in .kpi-card:nth-child(4){animation-delay:.2s}.animate-in .alert-item{animation:.25s both slide-in-right}.animate-in .alert-item:first-child{animation-delay:20ms}.animate-in .alert-item:nth-child(2){animation-delay:50ms}.animate-in .alert-item:nth-child(3){animation-delay:80ms}.animate-in .alert-item:nth-child(4){animation-delay:.11s}.animate-in .alert-item:nth-child(5){animation-delay:.14s}.animate-in .stat-bar-row{animation:.25s both fade-in-up}.animate-in .stat-bar-row:first-child{animation-delay:30ms}.animate-in .stat-bar-row:nth-child(2){animation-delay:60ms}.animate-in .stat-bar-row:nth-child(3){animation-delay:90ms}.animate-in .scorecard-item{animation:.3s both fade-in-up}.animate-in .scorecard-item:first-child{animation-delay:30ms}.animate-in .scorecard-item:nth-child(2){animation-delay:70ms}.animate-in .scorecard-item:nth-child(3){animation-delay:.11s}.animate-in .scorecard-item:nth-child(4){animation-delay:.15s}.animate-in .hub-card{animation:.3s both fade-in-up}.animate-in .hub-card:first-child{animation-delay:40ms}.animate-in .hub-card:nth-child(2){animation-delay:90ms}.animate-in .hub-card:nth-child(3){animation-delay:.14s}.hidden{display:none!important}.deck-tooltip{font-family:var(--font-ui), system-ui, sans-serif!important;pointer-events:none!important;z-index:1000!important;font-size:13px!important}.fleet-tooltip-wrap{background:var(--c-surface)!important;border:1px solid var(--c-border)!important;color:var(--c-text)!important;border-radius:6px!important;padding:0!important;box-shadow:0 4px 20px #0006!important}.fleet-tooltip-wrap:before{border-top-color:var(--c-border)!important}.fleet-tooltip{min-width:150px;padding:8px 12px}.fleet-tooltip strong{font-family:var(--font-mono);letter-spacing:1px;color:var(--c-cyan);font-size:13px}.fleet-tooltip .ft-status{font-family:var(--font-ui);letter-spacing:.8px;text-transform:uppercase;margin-bottom:6px;font-size:11px;font-weight:700;display:block}.fleet-tooltip .ft-stats{color:var(--c-text-muted);grid-template-columns:1fr 1fr;gap:3px 12px;font-size:11px;display:grid}.fleet-tooltip .ft-stats b{color:var(--c-text);font-family:var(--font-mono);font-size:11px}.vehicle-more-link{text-align:center;font-family:var(--font-ui);letter-spacing:1.5px;text-transform:uppercase;color:var(--c-cyan);background:var(--c-cyan-10);border:1px solid var(--c-border);cursor:pointer;border-radius:5px;margin-top:18px;padding:10px;font-size:13px;font-weight:700;text-decoration:none;transition:all .2s;display:block}.vehicle-more-link:hover{background:var(--c-cyan-20);border-color:var(--c-cyan);box-shadow:0 2px 14px rgba(var(--c-accent-rgb), .15)}.vdash-empty{text-align:center;padding:40px}.vdash-header{border-bottom:1px solid var(--c-border);flex-wrap:wrap;align-items:center;gap:18px;padding:22px 28px;display:flex}.vdash-title{flex:1;align-items:center;gap:12px;display:flex}.vdash-ts{color:var(--c-text-muted);font-size:12px;font-family:var(--font-mono)}.vdash-back-btn{color:var(--c-cyan);border:1px solid var(--c-border);font-family:var(--font-ui);letter-spacing:.8px;cursor:pointer;background:0 0;border-radius:5px;padding:7px 16px;font-size:12px;font-weight:700;transition:all .2s}.vdash-back-btn:hover{border-color:var(--c-cyan);background:var(--c-cyan-10)}.vdash-grid{gap:var(--gap);grid-template-columns:repeat(auto-fit,minmax(320px,1fr));padding:22px 28px;display:grid}.vdash-card{background:var(--c-bg);border:1px solid var(--c-border);border-radius:var(--radius);padding:20px;animation:.3s both fade-in-up}.vdash-card:nth-child(2){animation-delay:50ms}.vdash-card:nth-child(3){animation-delay:.1s}.vdash-card:nth-child(4){animation-delay:.15s}.vdash-card-title{font-family:var(--font-ui);letter-spacing:.5px;color:var(--c-text-muted);text-transform:uppercase;border-bottom:1px solid var(--c-border);margin-bottom:16px;padding-bottom:8px;font-size:13px;font-weight:700}.vdash-metrics{flex-direction:column;gap:12px;display:flex}.vdash-metric{justify-content:space-between;align-items:center;gap:10px;display:flex}.vdash-metric-label{color:var(--c-text-muted);font-size:13px}.vdash-metric-value{font-family:var(--font-mono);color:var(--c-text);font-size:14px;font-weight:700}.vdash-bar-wrap{background:var(--c-border);border-radius:3px;flex:1;height:6px;overflow:hidden}.vdash-bar{border-radius:3px;height:100%;transition:width .5s}#login-overlay{z-index:9999;background-color:var(--c-bg);color:var(--c-text);font-family:var(--font-body);justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}#login-overlay:before{content:"";pointer-events:none;z-index:0;opacity:var(--bg-pattern-login-overlay-opacity);background-image:var(--bg-pattern-login-overlay-render);background-size:var(--bg-pattern-login-overlay-render-size);background-position:var(--bg-pattern-login-overlay-render-position);mix-blend-mode:var(--bg-pattern-main-blend);filter:var(--bg-pattern-main-filter);background-repeat:no-repeat;position:absolute;inset:0}.login-card{background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--radius);width:100%;max-width:380px;box-shadow:0 0 0 1px var(--c-cyan-10), 0 18px 50px #0000008c, 0 0 32px var(--c-cyan-10);padding:28px 28px 24px;position:relative;overflow:hidden}.login-card:before{content:"";background:linear-gradient(90deg, transparent, var(--c-cyan), transparent);opacity:.7;z-index:2;height:2px;position:absolute;top:0;left:0;right:0}.login-card:after{content:"";pointer-events:none;z-index:0;width:220px;height:220px;opacity:var(--bg-pattern-login-opacity);background-image:var(--bg-pattern-login-render);background-size:var(--bg-pattern-login-render-size);mix-blend-mode:var(--bg-pattern-detail-blend);filter:var(--bg-pattern-detail-filter);-webkit-mask-image:var(--bg-pattern-login-mask);-webkit-mask-position:50%;-webkit-mask-size:contain;-webkit-mask-repeat:no-repeat;-webkit-mask-image:var(--bg-pattern-login-mask);mask-image:var(--bg-pattern-login-mask);background-position:50%;background-repeat:no-repeat;position:absolute;bottom:-52px;right:-62px;-webkit-mask-position:50%;mask-position:50%;-webkit-mask-size:contain;mask-size:contain;-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat}.login-card>*{z-index:1;position:relative}.login-brand{z-index:1;justify-content:center;align-items:center;margin-bottom:22px;display:flex;position:relative}.login-theme-btn{z-index:1;position:absolute;top:14px;right:14px}.login-logo{background-color:var(--c-cyan);width:180px;max-width:70%;height:38px;filter:drop-shadow(0 0 10px rgba(var(--c-accent-rgb), .4));-webkit-mask:url(/udexon-logo.png) 50%/contain no-repeat;mask:url(/udexon-logo.png) 50%/contain no-repeat}.login-title{font-family:var(--font-ui);letter-spacing:.04em;color:var(--c-text);z-index:1;margin-bottom:4px;font-size:22px;font-weight:600;position:relative}.login-subtitle{color:var(--c-text-muted);z-index:1;margin-bottom:22px;font-size:13px;position:relative}.login-field{flex-direction:column;gap:6px;margin-bottom:14px;display:flex}.login-field label{font-family:var(--font-ui);text-transform:uppercase;letter-spacing:.12em;color:var(--c-text-muted);font-size:11px}.login-field input{background:var(--c-surface-2);border:1px solid var(--c-border);width:100%;color:var(--c-text);font-family:var(--font-mono);box-sizing:border-box;border-radius:6px;padding:10px 12px;font-size:14px;transition:border-color .18s,box-shadow .18s,background .18s}.login-field input::placeholder{color:var(--c-text-dim)}.login-field input:focus{border-color:var(--c-cyan);background:var(--c-surface-3);box-shadow:0 0 0 3px var(--c-cyan-10);outline:none}#login-submit{border:1px solid var(--c-cyan);background:var(--c-cyan-10);width:100%;color:var(--c-cyan);font-family:var(--font-ui);letter-spacing:.16em;text-transform:uppercase;cursor:pointer;border-radius:6px;margin-top:10px;padding:11px;font-size:14px;font-weight:700;transition:background .18s,color .18s,box-shadow .18s}#login-submit:hover:not(:disabled){background:var(--c-cyan);color:var(--c-bg);box-shadow:0 0 16px var(--c-cyan-20)}#login-submit:disabled{opacity:.6;cursor:progress}.login-footer{border-top:1px dashed var(--c-border);font-family:var(--font-ui);text-transform:uppercase;letter-spacing:.14em;color:var(--c-text-dim);text-align:center;margin-top:18px;padding-top:14px;font-size:11px}.login-error{background:var(--c-red-10);border:1px solid var(--c-red);color:var(--c-red);word-break:break-word;border-radius:6px;margin-bottom:12px;padding:9px 12px;font-size:13px}#shuttle-panel{padding:0 0 22px}.shuttle-toolbar{background:var(--c-surface-2);border:1px solid var(--c-border);border-radius:var(--radius);flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:18px;padding:14px 20px;display:flex}.shuttle-toolbar-label{font-family:var(--font-ui);letter-spacing:.8px;text-transform:uppercase;color:var(--c-text-muted);font-size:12px;font-weight:700}.shuttle-tabs{border-bottom:1px solid var(--c-border);background:var(--c-surface-2);border-radius:var(--radius) var(--radius) 0 0;gap:8px;padding:16px 20px 0;display:flex;overflow-x:auto}.shuttle-tab{color:var(--c-text-muted);font-family:var(--font-ui);letter-spacing:.8px;text-transform:uppercase;cursor:pointer;white-space:nowrap;background:0 0;border:1px solid #0000;border-bottom:none;border-radius:6px 6px 0 0;padding:9px 20px;font-size:13px;font-weight:700;transition:all .2s;position:relative;bottom:-1px}.shuttle-tab:hover{color:var(--c-text);background:var(--c-surface-3)}.shuttle-tab.active{color:var(--c-cyan);background:var(--c-surface);border-color:var(--c-border);border-bottom-color:var(--c-surface);text-shadow:0 0 12px rgba(var(--c-accent-rgb), .3)}.shuttle-tab-body{background:var(--c-surface);border:1px solid var(--c-border);border-radius:0 0 var(--radius) var(--radius);border-top:none;padding:22px;animation:.3s both fade-in-up}.shuttle-grid-2{gap:var(--gap);grid-template-columns:1fr 1fr;display:grid}@media (width<=1100px){.shuttle-grid-2{grid-template-columns:1fr}}.shuttle-grid-2>div>.panel-header:first-child{border-bottom:1px solid var(--c-border);background:0 0;margin-bottom:14px;padding:0 0 12px}.shuttle-select,.shuttle-form input[type=text],.shuttle-form input[type=number],.shuttle-form input[type=date],.shuttle-form input[type=time],.shuttle-form input[type=color],.shuttle-form textarea,.shuttle-input-sm{background:var(--c-bg);border:1px solid var(--c-border);color:var(--c-text);font-family:var(--font-body);border-radius:5px;padding:7px 11px;font-size:13px;transition:border-color .2s,box-shadow .2s}.shuttle-select:focus,.shuttle-form input:focus,.shuttle-form textarea:focus,.shuttle-input-sm:focus{border-color:var(--c-cyan);box-shadow:0 0 0 2px var(--c-cyan-10);outline:none}.shuttle-input-sm{padding:4px 8px;font-size:12px}.shuttle-form input[type=color]{width:56px;height:32px;padding:2px}.shuttle-form textarea{width:100%;font-family:var(--font-mono);resize:vertical;font-size:12px;line-height:1.5}.shuttle-form{flex-direction:column;gap:12px;display:flex}.shuttle-form label{font-family:var(--font-ui);letter-spacing:.8px;text-transform:uppercase;color:var(--c-text-muted);flex-direction:column;gap:6px;font-size:12px;font-weight:700;display:flex}.shuttle-form-row{gap:12px;display:flex}.shuttle-form-row label{flex:1}.shuttle-form-actions{flex-wrap:wrap;align-items:center;gap:10px;margin-top:6px;display:flex}.shuttle-btn{color:var(--c-text-muted);border:1px solid var(--c-border);font-family:var(--font-ui);letter-spacing:1px;text-transform:uppercase;cursor:pointer;background:0 0;border-radius:5px;padding:7px 16px;font-size:12px;font-weight:700;transition:all .2s}.shuttle-btn:hover{color:var(--c-text);border-color:var(--c-text-muted)}.shuttle-btn.primary{background:var(--c-cyan-10);color:var(--c-cyan);border-color:var(--c-cyan)}.shuttle-btn.primary:hover{background:var(--c-cyan-20);box-shadow:0 0 12px rgba(var(--c-accent-rgb), .2)}.shuttle-btn.danger:hover{color:var(--c-red);border-color:var(--c-red);background:var(--c-red-10)}.shuttle-btn:disabled{opacity:.5;cursor:not-allowed}.shuttle-list-scroll{max-height:460px;overflow:auto}.shuttle-table{border-collapse:collapse;width:100%;font-size:13px;font-family:var(--font-body)}.shuttle-table thead{background:var(--c-surface-2);z-index:1;position:sticky;top:0}.shuttle-table th{font-family:var(--font-ui);letter-spacing:.8px;text-transform:uppercase;color:var(--c-text-muted);text-align:left;border-bottom:1px solid var(--c-border);padding:10px 12px;font-size:11px;font-weight:700}.shuttle-table td{border-bottom:1px solid var(--c-border);color:var(--c-text);padding:9px 12px}.shuttle-table tbody tr{transition:background-color .15s}.shuttle-table tbody tr:nth-child(2n){background:#0f1d3580}.shuttle-table tbody tr:hover{background:var(--c-surface-3)}.shuttle-table td.num,.shuttle-table th.num{text-align:right;font-family:var(--font-mono)}.shuttle-table td.dow,.shuttle-table th.dow{text-align:center;width:36px}.shuttle-table .row-actions{justify-content:flex-end;gap:6px;display:flex}.shuttle-row-muted{opacity:.5}.shuttle-table code{font-family:var(--font-mono);background:var(--c-surface-3);border:1px solid var(--c-border-2);color:var(--c-cyan);border-radius:4px;padding:1px 6px;font-size:12px}.shuttle-map{border:1px solid var(--c-border);border-radius:var(--radius);background:var(--c-bg);height:360px;margin-top:10px}.shuttle-swatch{vertical-align:middle;border:1px solid var(--c-border-2);border-radius:3px;width:14px;height:14px;margin-right:6px;display:inline-block;box-shadow:0 0 6px #0006}.shuttle-banner{border-radius:var(--radius);font-family:var(--font-body);color:var(--c-text);border:1px solid;border-left-width:4px;margin-bottom:18px;padding:14px 18px;font-size:13px}.shuttle-banner strong{font-family:var(--font-ui);letter-spacing:.8px;text-transform:uppercase;font-size:12px;font-weight:700}.shuttle-banner.success{background:var(--c-green-10);border-color:rgba(var(--c-success-rgb), .4);border-left-color:var(--c-green)}.shuttle-banner.error{background:var(--c-red-10);border-color:#ff4d4d66;border-left-color:var(--c-red)}.shuttle-banner small{color:var(--c-text-muted);margin-top:8px;font-size:12px;display:block}.shuttle-banner-row{flex-wrap:wrap;align-items:center;gap:8px;margin-top:10px;display:flex}.shuttle-key{background:var(--c-bg);border:1px solid var(--c-border-2);color:var(--c-cyan);font-family:var(--font-mono);word-break:break-all;min-width:0;text-shadow:0 0 8px rgba(var(--c-accent-rgb), .25);border-radius:5px;flex:1;padding:8px 12px;font-size:12px}.shuttle-quota-card{background:var(--c-bg);border:1px solid var(--c-border);border-radius:var(--radius);padding:18px 20px;transition:border-color .2s,transform .2s,box-shadow .2s}.shuttle-quota-card:hover{border-color:var(--c-cyan);box-shadow:0 4px 16px rgba(var(--c-accent-rgb), .1);transform:translateY(-2px)}.shuttle-quota-label{font-family:var(--font-ui);letter-spacing:.8px;text-transform:uppercase;color:var(--c-text-muted);font-size:11px;font-weight:700}.shuttle-quota-value{font-family:var(--font-mono);color:var(--c-text);margin:10px 0;font-size:24px;font-weight:700}.shuttle-quota-bar{background:var(--c-surface-3);border-radius:3px;height:6px;overflow:hidden}.shuttle-quota-fill{background:linear-gradient(90deg, var(--c-green) 0%, var(--c-amber) 75%, var(--c-red) 100%);height:100%;transition:width .4s}.shuttle-waypoint-list{border:1px solid var(--c-border);border-radius:var(--radius);background:var(--c-bg);flex-direction:column;gap:4px;max-height:220px;padding:6px;display:flex;overflow-y:auto}.shuttle-wp-row{border-radius:4px;align-items:center;gap:6px;padding:4px 6px;display:flex}.shuttle-wp-row:hover{background:var(--c-bg-elevated,#00000008)}.shuttle-wp-num{text-align:center;min-width:22px;color:var(--c-text-secondary,#757d8a);font-weight:600;display:inline-block}.shuttle-wp-label{flex:1;font-size:13px}.shuttle-wp-row .shuttle-btn{min-width:auto;padding:2px 8px}.shuttle-wp-pin{color:#fff;border:2px solid #fff;justify-content:center;align-items:center;font-size:12px;font-weight:700;display:flex;box-shadow:0 1px 4px #0006}.shuttle-wp-pin.stop{background:#1e88e5;border-radius:50%;width:28px;height:28px}.shuttle-wp-pin.transit{background:#fb8c00;border-radius:4px;width:24px;height:24px;font-size:11px;transform:rotate(45deg)}#view-root{flex-direction:column;flex:1;min-height:0;display:flex}.page-section{gap:var(--gap);flex-direction:column;flex:1;min-height:0;display:flex}.animate-in{animation:.3s both fade-in-up}.nav-section+.nav-section{border-top:1px solid var(--c-border);margin-top:4px}.nav-link--dev .nav-label:after{content:"DEV";letter-spacing:1px;color:var(--c-purple);background:var(--c-purple-10);border-radius:3px;margin-left:6px;padding:0 4px;font-size:9px}.collapsed .nav-link--dev .nav-label:after{display:none}.state-block{text-align:center;color:var(--c-text-muted);flex-direction:column;justify-content:center;align-items:center;gap:12px;min-height:160px;padding:48px 24px;display:flex}.state-text{font-size:14px;font-family:var(--font-ui);letter-spacing:.5px;color:var(--c-text-muted)}.state-icon{color:var(--c-text-dim);display:inline-flex}.state-spinner{border:3px solid var(--c-border-2);border-top-color:var(--c-cyan);border-radius:50%;width:26px;height:26px;animation:.8s linear infinite state-spin}@keyframes state-spin{to{transform:rotate(360deg)}}.state-error .state-icon{color:var(--c-red)}.state-retry{background:var(--c-cyan-10);color:var(--c-cyan);border:1px solid var(--c-cyan);font-size:12px;font-weight:700;font-family:var(--font-ui);letter-spacing:.8px;text-transform:uppercase;cursor:pointer;border-radius:5px;padding:7px 18px;transition:all .2s}.state-retry:hover{background:var(--c-cyan-20)}.map-host{width:100%;height:100%;min-height:0;position:relative}.map-host-canvas{position:absolute;inset:0}.overview-grid{gap:var(--gap);flex:1;grid-template-columns:minmax(0,1fr) 360px;min-height:0;display:grid}.overview-side-col{gap:var(--gap);grid-template-rows:auto minmax(0,1fr);min-height:0;display:grid}.overview-vehicle-detail{min-height:240px}.overview-map-panel,.live-map-panel{flex-direction:column;min-height:420px;display:flex}.overview-map-slot,.live-map-slot{flex:1;min-height:0;position:relative}.overview-alerts-panel{flex-direction:column;min-height:0;display:flex}.overview-alert-list{flex:1;min-height:0;overflow-y:auto}@media (width<=1100px){.overview-grid{grid-template-columns:minmax(0,1fr)}.overview-side-col{grid-template-rows:auto}}.vehicles-layout{gap:var(--gap);flex:1;grid-template-columns:minmax(0,1fr) 380px;min-height:0;display:grid}.vehicles-grid-panel,.vehicles-detail-panel{flex-direction:column;min-height:0;display:flex}.vehicles-grid-panel #telemetry-grid{flex:1;min-height:0;overflow:auto}.vehicles-detail-panel{padding-bottom:16px;overflow-y:auto}@media (width<=1100px){.vehicles-layout{grid-template-columns:minmax(0,1fr)}}.vehicle-sub{font-family:var(--font-mono);color:var(--c-text-muted);font-size:12px}.gauge-unit{color:var(--c-text-muted);margin-left:2px;font-size:.7em}.vehicle-more-link{border:none;border-top:1px solid var(--c-border);width:100%;color:var(--c-cyan);font-size:11px;font-weight:700;font-family:var(--font-ui);letter-spacing:1px;cursor:pointer;background:0 0;padding:12px;transition:background .2s;display:block}.vehicle-more-link:hover{background:var(--c-cyan-10)}.vehicle-extended{flex-direction:column;gap:12px;padding:4px 20px 16px;display:flex}.vehicle-ext-card{background:var(--c-surface-2);border:1px solid var(--c-border);border-radius:var(--radius);padding:12px 14px}.vehicle-ext-title{letter-spacing:1px;text-transform:uppercase;color:var(--c-text-muted);margin-bottom:8px;font-size:11px;font-weight:700}.vehicle-ext-row{border-bottom:1px solid var(--c-border);justify-content:space-between;gap:12px;padding:4px 0;font-size:13px;display:flex}.vehicle-ext-row:last-child{border-bottom:none}.vehicle-ext-row span:first-child{color:var(--c-text-muted)}.vehicle-ext-row span:last-child{font-family:var(--font-mono);color:var(--c-text)}.drivers-layout{gap:var(--gap);flex:1;grid-template-columns:minmax(0,1fr);min-height:0;display:grid}.drivers-table-panel,.drivers-scorecard-panel{flex-direction:column;min-height:0;display:flex;overflow-y:auto}@media (width<=1100px){.drivers-layout{grid-template-columns:minmax(0,1fr)}}.charging-panel{flex-direction:column;min-height:0;display:flex}.alerts-panel{flex-direction:column;flex:1;min-height:0;display:flex}.alerts-filters{border-bottom:1px solid var(--c-border);flex-wrap:wrap;gap:16px;padding:12px 20px;display:flex}.filter-group{flex-wrap:wrap;gap:6px;display:flex}.alerts-list{flex-direction:column;flex:1;gap:6px;min-height:0;padding:8px 12px;display:flex;overflow-y:auto}.alert-row{background:var(--c-surface-2);border:1px solid var(--c-border);border-left-width:3px;border-radius:6px;align-items:center;gap:12px;padding:12px 14px;transition:border-color .2s,background .2s;display:flex}.alert-row.critical{border-left-color:var(--c-red)}.alert-row.warning{border-left-color:var(--c-amber)}.alert-row.informational{border-left-color:var(--c-blue)}.alert-tier-dot{border-radius:50%;flex-shrink:0;width:9px;height:9px}.alert-tier-dot.critical{background:var(--c-red);box-shadow:0 0 8px var(--c-red)}.alert-tier-dot.warning{background:var(--c-amber);box-shadow:0 0 8px var(--c-amber)}.alert-tier-dot.informational{background:var(--c-blue);box-shadow:0 0 8px var(--c-blue)}.alert-row-body{flex:1;min-width:0}.alert-row-msg{color:var(--c-text);margin-bottom:4px;font-size:14px}.alert-row-meta{color:var(--c-text-muted);font-size:12px;font-family:var(--font-mono);flex-wrap:wrap;align-items:center;gap:10px;display:flex}.alert-state-badge{font-size:10px;font-weight:700;font-family:var(--font-ui);letter-spacing:.8px;text-transform:uppercase;border:1px solid var(--c-border-2);color:var(--c-text-muted);border-radius:4px;padding:2px 8px}.alert-state-badge.fired{color:var(--c-red);border-color:var(--c-red-20);background:var(--c-red-10)}.alert-state-badge.acknowledged{color:var(--c-amber);border-color:var(--c-amber-20);background:var(--c-amber-10)}.alert-state-badge.resolved{color:var(--c-green);border-color:var(--c-green-20);background:var(--c-green-10)}.alert-row-actions{flex-shrink:0;gap:6px;display:flex}.alert-action{border:1px solid var(--c-border-2);color:var(--c-text-muted);font-size:11px;font-weight:700;font-family:var(--font-ui);letter-spacing:.6px;text-transform:uppercase;cursor:pointer;background:0 0;border-radius:5px;padding:6px 12px;transition:all .2s}.alert-action:hover:not(:disabled){border-color:var(--c-text-muted);color:var(--c-text)}.alert-action.ack:hover:not(:disabled){border-color:var(--c-amber);color:var(--c-amber);background:var(--c-amber-10)}.alert-action.resolve:hover:not(:disabled){border-color:var(--c-green);color:var(--c-green);background:var(--c-green-10)}.alert-action:disabled{opacity:.5;cursor:progress}.telemetry-log-panel,.telemetry-log-body,.shuttle-live-panel{flex-direction:column;flex:1;min-height:0;display:flex}.shuttle-live-toolbar{justify-content:space-between;align-items:center;gap:var(--gap);display:flex}.shuttle-live-controls{align-items:center;gap:8px;display:flex}.shuttle-live-count{font-family:var(--font-mono);color:var(--c-text-muted);font-size:12px}.shuttle-live-map{border-radius:var(--radius);background:var(--c-surface-2);flex:1;min-height:0;overflow:hidden}
