.pickup-marker{z-index:500;filter:drop-shadow(0 0 4px #ffb30088)}*{box-sizing:border-box;margin:0;padding:0}:root{--c-bg:#0b1628;--c-surface:#0f1d35;--c-surface-2:#152440;--c-surface-3:#1a2d4f;--c-border:#1e3355;--c-border-2:#2a4570;--c-text:#e8f4ff;--c-text-muted:#6b90b8;--c-text-dim:#3a5270;--c-cyan:#00e5ff;--c-cyan-10:#00e5ff1a;--c-cyan-20:#00e5ff38;--c-green:#00e87a;--c-green-10:#00e87a1a;--c-amber:#ffbc00;--c-amber-10:#ffbc001a;--c-red:#ff4d4d;--c-red-10:#ff4d4d1a;--c-blue:#4da6ff;--c-blue-10:#4da6ff1a;--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:"Rajdhani", "Segoe UI", system-ui, sans-serif;--font-mono:"Space Mono", "Courier New", monospace;--font-body:system-ui, -apple-system, "Segoe UI", Roboto, sans-serif}body{font-family:var(--font-body);background-color:var(--c-bg);background-image:radial-gradient(circle, var(--c-border) 1px, transparent 1px);color:var(--c-text);background-size:28px 28px;min-height:100vh;font-size:18px}.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,.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 #00e5ff14}}#app{min-height:100vh;display:flex}#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}.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-icon{color:var(--c-cyan);filter:drop-shadow(0 0 6px #00e5ff80);flex-shrink:0;align-items:center;display:flex}.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;padding:10px 0}.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 #00e5ff66}.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-icon,.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 #00e87a80}.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: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 h1{letter-spacing:2.5px;text-transform:uppercase;color:var(--c-cyan);text-shadow:0 0 16px #00e5ff59;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 #00e5ff0a}.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 #00e87a0a}.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 #00e5ff80)}.kpi-card.efficiency .kpi-icon{color:var(--c-green);filter:drop-shadow(0 0 5px #00e87a80)}.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 #00e5ff26}#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 #00e5ff59}.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 #00e87a4d}.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);transform:translateY(-2px);box-shadow:0 4px 16px #00e5ff1a}.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 #00e5ff1f}#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 #00e5ff26;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 #00e5ff1f}.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 #00e5ff1a}.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 #00e87a40}.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 #00e5ff4d;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);transform:translateY(-2px);box-shadow:0 4px 16px #00e5ff1a}.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 #00e87a40}.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 #00e87a40}.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 #00e5ff26}.raw-telem-btn:disabled{opacity:.4;cursor:not-allowed}.raw-telem-exhausted{color:var(--c-text-muted);font-size:13px;font-style:italic}#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-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 #00e5ff4d}.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-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:#00e5ff33;box-shadow:0 0 12px #00e5ff33}.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}::-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:#eef3f9;--c-surface:#fff;--c-surface-2:#f4f7fc;--c-surface-3:#e8eff8;--c-border:#c0d0e4;--c-border-2:#96b4d0;--c-text:#0a1820;--c-text-muted:#4a6882;--c-text-dim:#96b4d0;--c-cyan:#006faa;--c-cyan-10:#006faa14;--c-cyan-20:#006faa29;--c-green:#00884a;--c-green-10:#00884a14;--c-amber:#b60;--c-amber-10:#bb660014;--c-red:#b20;--c-red-10:#bb220014;--c-blue:#0050bb;--c-blue-10:#0050bb14}.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 #00e5ff26}@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}.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 #00e5ff26}.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);background-image:radial-gradient(circle at 50% 30%, var(--c-cyan-10), transparent 55%), radial-gradient(circle, var(--c-border) 1px, transparent 1px);color:var(--c-text);font-family:var(--font-body);background-size:auto,28px 28px;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;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;height:2px;position:absolute;top:0;left:0;right:0}.login-brand{font-family:var(--font-ui);text-transform:uppercase;letter-spacing:.16em;color:var(--c-cyan);align-items:center;gap:10px;margin-bottom:18px;font-size:14px;font-weight:600;display:flex}.login-brand .login-brand-icon{border:1px solid var(--c-cyan);width:28px;height:28px;color:var(--c-cyan);background:var(--c-cyan-10);border-radius:6px;justify-content:center;align-items:center;display:inline-flex}.login-title{font-family:var(--font-ui);letter-spacing:.04em;color:var(--c-text);margin-bottom:4px;font-size:22px;font-weight:600}.login-subtitle{color:var(--c-text-muted);margin-bottom:22px;font-size:13px}.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 #00e5ff4d}.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 #00e5ff33}.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:#00e87a66;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;text-shadow:0 0 8px #00e5ff40;border-radius:5px;flex:1;min-width:0;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);transform:translateY(-2px);box-shadow:0 4px 16px #00e5ff1a}.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}
