:root,:host{--ol-background-color: white;--ol-accent-background-color: #F5F5F5;--ol-subtle-background-color: rgba(128, 128, 128, .25);--ol-partial-background-color: rgba(255, 255, 255, .75);--ol-foreground-color: #333333;--ol-subtle-foreground-color: #666666;--ol-brand-color: #00AAFF}.ol-box{box-sizing:border-box;border-radius:2px;border:1.5px solid var(--ol-background-color);background-color:var(--ol-partial-background-color)}.ol-mouse-position{top:8px;right:8px;position:absolute}.ol-scale-line{background:var(--ol-partial-background-color);border-radius:4px;bottom:8px;left:8px;padding:2px;position:absolute}.ol-scale-line-inner{border:1px solid var(--ol-subtle-foreground-color);border-top:none;color:var(--ol-foreground-color);font-size:10px;text-align:center;margin:1px;will-change:contents,width;transition:all .25s}.ol-scale-bar{position:absolute;bottom:8px;left:8px}.ol-scale-bar-inner{display:flex}.ol-scale-step-marker{width:1px;height:15px;background-color:var(--ol-foreground-color);float:right;z-index:10}.ol-scale-step-text{position:absolute;bottom:-5px;font-size:10px;z-index:11;color:var(--ol-foreground-color);text-shadow:-1.5px 0 var(--ol-partial-background-color),0 1.5px var(--ol-partial-background-color),1.5px 0 var(--ol-partial-background-color),0 -1.5px var(--ol-partial-background-color)}.ol-scale-text{position:absolute;font-size:12px;text-align:center;bottom:25px;color:var(--ol-foreground-color);text-shadow:-1.5px 0 var(--ol-partial-background-color),0 1.5px var(--ol-partial-background-color),1.5px 0 var(--ol-partial-background-color),0 -1.5px var(--ol-partial-background-color)}.ol-scale-singlebar{position:relative;height:10px;z-index:9;box-sizing:border-box;border:1px solid var(--ol-foreground-color)}.ol-scale-singlebar-even{background-color:var(--ol-subtle-foreground-color)}.ol-scale-singlebar-odd{background-color:var(--ol-background-color)}.ol-unsupported{display:none}.ol-viewport,.ol-unselectable{-webkit-touch-callout:none;-webkit-user-select:none;-moz-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.ol-viewport canvas{all:unset;overflow:hidden}.ol-viewport{touch-action:pan-x pan-y}.ol-selectable{-webkit-touch-callout:default;-webkit-user-select:text;-moz-user-select:text;user-select:text}.ol-grabbing{cursor:-webkit-grabbing;cursor:-moz-grabbing;cursor:grabbing}.ol-grab{cursor:move;cursor:-webkit-grab;cursor:-moz-grab;cursor:grab}.ol-control{position:absolute;background-color:var(--ol-subtle-background-color);border-radius:4px}.ol-zoom{top:.5em;left:.5em}.ol-rotate{top:.5em;right:.5em;transition:opacity .25s linear,visibility 0s linear}.ol-rotate.ol-hidden{opacity:0;visibility:hidden;transition:opacity .25s linear,visibility 0s linear .25s}.ol-zoom-extent{top:4.643em;left:.5em}.ol-full-screen{right:.5em;top:.5em}.ol-control button{display:block;margin:1px;padding:0;color:var(--ol-subtle-foreground-color);font-weight:700;text-decoration:none;font-size:inherit;text-align:center;height:1.375em;width:1.375em;line-height:.4em;background-color:var(--ol-background-color);border:none;border-radius:2px}.ol-control button::-moz-focus-inner{border:none;padding:0}.ol-zoom-extent button{line-height:1.4em}.ol-compass{display:block;font-weight:400;will-change:transform}.ol-touch .ol-control button{font-size:1.5em}.ol-touch .ol-zoom-extent{top:5.5em}.ol-control button:hover,.ol-control button:focus{text-decoration:none;outline:1px solid var(--ol-subtle-foreground-color);color:var(--ol-foreground-color)}.ol-zoom .ol-zoom-in{border-radius:2px 2px 0 0}.ol-zoom .ol-zoom-out{border-radius:0 0 2px 2px}.ol-attribution{text-align:right;bottom:.5em;right:.5em;max-width:calc(100% - 1.3em);display:flex;flex-flow:row-reverse;align-items:center}.ol-attribution a{color:var(--ol-subtle-foreground-color);text-decoration:none}.ol-attribution ul{margin:0;padding:1px .5em;color:var(--ol-foreground-color);text-shadow:0 0 2px var(--ol-background-color);font-size:12px}.ol-attribution li{display:inline;list-style:none}.ol-attribution li:not(:last-child):after{content:" "}.ol-attribution img{max-height:2em;max-width:inherit;vertical-align:middle}.ol-attribution button{flex-shrink:0}.ol-attribution.ol-collapsed ul{display:none}.ol-attribution:not(.ol-collapsed){background:var(--ol-partial-background-color)}.ol-attribution.ol-uncollapsible{bottom:0;right:0;border-radius:4px 0 0}.ol-attribution.ol-uncollapsible img{margin-top:-.2em;max-height:1.6em}.ol-attribution.ol-uncollapsible button{display:none}.ol-zoomslider{top:4.5em;left:.5em;height:200px}.ol-zoomslider button{position:relative;height:10px}.ol-touch .ol-zoomslider{top:5.5em}.ol-overviewmap{left:.5em;bottom:.5em}.ol-overviewmap.ol-uncollapsible{bottom:0;left:0;border-radius:0 4px 0 0}.ol-overviewmap .ol-overviewmap-map,.ol-overviewmap button{display:block}.ol-overviewmap .ol-overviewmap-map{border:1px solid var(--ol-subtle-foreground-color);height:150px;width:150px}.ol-overviewmap:not(.ol-collapsed) button{bottom:0;left:0;position:absolute}.ol-overviewmap.ol-collapsed .ol-overviewmap-map,.ol-overviewmap.ol-uncollapsible button{display:none}.ol-overviewmap:not(.ol-collapsed){background:var(--ol-subtle-background-color)}.ol-overviewmap-box{border:1.5px dotted var(--ol-subtle-foreground-color)}.ol-overviewmap .ol-overviewmap-box:hover{cursor:move}.ol-overviewmap .ol-viewport:hover{cursor:pointer}:root{--color-green: #1f7a3f;--color-green-700: #176032;--color-green-50: #e9f5ee;--color-blue: #3366cc;--color-orange: #ff6600;--color-danger: #d9534f;--color-warn: #e0a800;--bg-app: #eef1f4;--bg-surface: #ffffff;--bg-muted: #f4f6f8;--border: #e2e6ea;--border-strong: #cdd3da;--text: #1c2430;--text-muted: #687284;--text-soft: #97a0ad;--r-sm: 6px;--r-md: 10px;--r-lg: 14px;--shadow-sm: 0 1px 2px rgba(16, 24, 40, .06), 0 1px 3px rgba(16, 24, 40, .1);--shadow-md: 0 4px 12px rgba(16, 24, 40, .1), 0 2px 4px rgba(16, 24, 40, .06);--shadow-lg: 0 12px 32px rgba(16, 24, 40, .16);--t-fast: .12s ease;--t: .18s cubic-bezier(.4, 0, .2, 1);--ring: 0 0 0 3px rgba(31, 122, 63, .25)}*{box-sizing:border-box}html,body,#root{margin:0;height:100%;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;color:var(--text);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}body{background:var(--bg-app)}button{font-family:inherit}button:focus-visible,input:focus-visible,select:focus-visible,a:focus-visible{outline:none;box-shadow:var(--ring)}.app{display:flex;flex-direction:column;height:100%}.app-header{padding:0 20px;height:56px;background:linear-gradient(95deg,var(--color-green) 0%,var(--color-green-700) 100%);color:#fff;font-weight:600;font-size:15px;letter-spacing:.2px;display:flex;align-items:center;justify-content:space-between;box-shadow:var(--shadow-md);z-index:10}.app-header small{font-weight:500;opacity:.8;padding:2px 8px;margin-left:6px;background:#ffffff29;border-radius:999px;font-size:11px}.app-user{display:flex;align-items:center;gap:14px;font-weight:500;font-size:14px}.btn-logout{background:#ffffff1f;color:#fff;border:1px solid rgba(255,255,255,.35);border-radius:var(--r-sm);padding:6px 14px;cursor:pointer;font-size:13px;font-weight:500;transition:background var(--t-fast),transform var(--t-fast)}.btn-logout:hover{background:#ffffff42}.btn-logout:active{transform:scale(.97)}.map-container{flex:1;min-height:0}.map-wrap{position:relative;width:100%;height:100%}.map-legend{position:absolute;bottom:18px;left:18px;z-index:1000;background:var(--bg-surface);padding:12px 14px;border-radius:var(--r-md);box-shadow:var(--shadow-lg);border:1px solid var(--border);font-size:13px;line-height:1.9;color:var(--text)}.map-legend-warn{margin-top:6px;max-width:220px;color:#9a6a00;background:#fff8e6;padding:6px 8px;border-radius:var(--r-sm);font-size:12px;line-height:1.4}.map-legend .dot,.eco-dot span{display:inline-block;width:12px;height:12px;border-radius:50%;border:2px solid #fff;box-shadow:0 0 2px #00000080;vertical-align:middle}.map-error{position:absolute;top:18px;left:50%;transform:translate(-50%);z-index:1000;background:var(--color-danger);color:#fff;padding:10px 16px;border-radius:var(--r-sm);font-size:13px;font-weight:500;box-shadow:var(--shadow-md);animation:toast-in var(--t)}@keyframes toast-in{0%{opacity:0;transform:translate(-50%,-8px)}to{opacity:1;transform:translate(-50%)}}.veh-arrow{background:none;border:none}.veh-arrow .veh-arrow-inner{width:0;height:0;border-left:8px solid transparent;border-right:8px solid transparent;border-bottom:20px solid var(--veh-color, #0066ff);filter:drop-shadow(0 0 2px rgba(0,0,0,.7));transform-origin:50% 60%}.login-wrap{display:flex;align-items:center;justify-content:center;height:100%;background:radial-gradient(1200px 600px at 80% -10%,rgba(31,122,63,.12),transparent 60%),radial-gradient(900px 500px at -10% 110%,rgba(51,102,204,.1),transparent 60%),var(--bg-app);padding:20px}.login-card{background:var(--bg-surface);padding:36px 32px;border-radius:var(--r-lg);box-shadow:var(--shadow-lg);border:1px solid var(--border);width:360px;max-width:100%;display:flex;flex-direction:column;gap:16px;animation:card-in var(--t)}@keyframes card-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.login-card h1{margin:0;color:var(--color-green);text-align:center;font-size:30px;letter-spacing:-.5px}.login-sub{margin:-6px 0 10px;text-align:center;color:var(--text-muted);font-size:14px}.login-card label{display:flex;flex-direction:column;gap:6px;font-size:13px;font-weight:500;color:var(--text)}.login-card input{padding:11px 12px;border:1px solid var(--border-strong);border-radius:var(--r-sm);font-size:14px;transition:border-color var(--t-fast),box-shadow var(--t-fast)}.login-card input:focus{outline:none;border-color:var(--color-green);box-shadow:var(--ring)}.login-card button{margin-top:8px;padding:12px;background:var(--color-green);color:#fff;border:none;border-radius:var(--r-sm);font-size:15px;font-weight:600;cursor:pointer;transition:background var(--t-fast),transform var(--t-fast),box-shadow var(--t-fast)}.login-card button:hover:not(:disabled){background:var(--color-green-700);box-shadow:var(--shadow-md)}.login-card button:active:not(:disabled){transform:scale(.98)}.login-card button:disabled{opacity:.6;cursor:default}.login-error{background:#fde8e8;color:#b3261e;padding:10px 12px;border-radius:var(--r-sm);border:1px solid #f7c5c2;font-size:13px}.panel-tabs{position:absolute;top:16px;right:16px;z-index:1001;display:flex;gap:4px;background:var(--bg-surface);padding:5px;border-radius:var(--r-md);box-shadow:var(--shadow-lg);border:1px solid var(--border)}.panel-tabs .tab{border:none;background:transparent;color:var(--text-muted);padding:7px 14px;border-radius:var(--r-sm);cursor:pointer;font-size:13px;font-weight:500;transition:background var(--t-fast),color var(--t-fast)}.panel-tabs .tab:hover{background:var(--bg-muted);color:var(--text)}.panel-tabs .tab.on{background:var(--color-green);color:#fff;box-shadow:var(--shadow-sm)}.panel-tabs~.planner{top:64px}.veh-list{list-style:none;margin:4px 0;padding:0;max-height:200px;overflow-y:auto}.veh-list li{padding:4px 0}.veh-list label{display:flex;align-items:center;gap:8px;cursor:pointer;padding:4px 6px;border-radius:var(--r-sm);transition:background var(--t-fast)}.veh-list label:hover{background:var(--bg-muted)}.veh-cap{margin-left:auto;color:var(--text-soft);font-size:12px}.planner{position:absolute;top:16px;right:16px;z-index:1000;background:var(--bg-surface);width:340px;max-height:calc(100% - 32px);overflow-y:auto;padding:16px 18px;border-radius:var(--r-md);box-shadow:var(--shadow-lg);border:1px solid var(--border);font-size:13px}.planner h3{margin:0 0 12px;color:var(--text);font-size:15px;font-weight:700;display:flex;align-items:center;gap:8px}.planner h3:before{content:"";width:4px;height:16px;border-radius:2px;background:var(--color-green)}.btn-toggle{width:100%;padding:9px;border:1px solid var(--color-green);background:var(--bg-surface);color:var(--color-green);border-radius:var(--r-sm);cursor:pointer;font-size:13px;font-weight:600;margin-bottom:12px;transition:background var(--t-fast),color var(--t-fast)}.btn-toggle:hover{background:var(--color-green-50)}.btn-toggle.on{background:var(--color-green);color:#fff}.planner-field{display:flex;flex-direction:column;gap:5px;margin-bottom:12px;font-weight:500;color:var(--text)}.planner-field input,.planner-field select{padding:8px 10px;border:1px solid var(--border-strong);border-radius:var(--r-sm);font-size:13px;background:var(--bg-surface);transition:border-color var(--t-fast),box-shadow var(--t-fast)}.planner-field input:focus,.planner-field select:focus{outline:none;border-color:var(--color-green);box-shadow:var(--ring)}.planner-stops-head{display:flex;justify-content:space-between;align-items:center;font-weight:600;margin-bottom:6px}.planner-hint{color:var(--text-soft);font-size:12px;margin:4px 0}.planner-stops ol{margin:4px 0;padding-left:20px}.planner-stops li{display:flex;justify-content:space-between;align-items:center;gap:8px;padding:4px 0}.btn-link{background:none;border:none;color:var(--color-blue);cursor:pointer;font-size:12px;font-weight:500;padding:0;transition:opacity var(--t-fast)}.btn-link:hover{opacity:.7;text-decoration:underline}.btn-link.danger{color:var(--color-danger)}.planner-error{background:#fde8e8;color:#b3261e;border:1px solid #f7c5c2;padding:8px 10px;border-radius:var(--r-sm);margin:8px 0}.planner-actions{margin:12px 0}.btn-primary{width:100%;padding:11px;background:var(--color-orange);color:#fff;border:none;border-radius:var(--r-sm);font-size:14px;font-weight:600;cursor:pointer;transition:filter var(--t-fast),transform var(--t-fast),box-shadow var(--t-fast)}.btn-primary:hover:not(:disabled){filter:brightness(1.05);box-shadow:var(--shadow-md)}.btn-primary:active:not(:disabled){transform:scale(.99)}.btn-primary:disabled{opacity:.5;cursor:default}.route-result{border-top:1px solid var(--border);margin-top:12px;padding-top:12px}.route-summary b{color:var(--color-orange)}.route-summary div{margin:4px 0;color:var(--text)}.instructions{margin:10px 0 0;padding-left:0;list-style:none;max-height:240px;overflow-y:auto}.instructions li{display:flex;align-items:center;gap:10px;padding:7px 4px;border-bottom:1px solid var(--border);transition:background var(--t-fast)}.instructions li:hover{background:var(--bg-muted)}.ins-sign{font-size:16px;width:26px;height:26px;flex:none;display:inline-flex;align-items:center;justify-content:center;background:var(--color-green-50);color:var(--color-green);border-radius:50%}.ins-text{flex:1}.ins-dist{color:var(--text-soft);font-size:12px;white-space:nowrap}.live-status{padding:8px 11px;border-radius:var(--r-sm);background:var(--bg-muted);color:var(--text-muted);font-size:12px;font-weight:500;margin-bottom:12px;display:flex;align-items:center;gap:8px}.live-status:before{content:"";width:8px;height:8px;border-radius:50%;background:var(--text-soft);flex:none}.live-status.on{background:var(--color-green-50);color:var(--color-green);font-weight:600}.live-status.on:before{background:var(--color-green);box-shadow:0 0 #1f7a3f80;animation:pulse 1.8s infinite}@keyframes pulse{0%{box-shadow:0 0 #1f7a3f73}70%{box-shadow:0 0 0 7px #1f7a3f00}to{box-shadow:0 0 #1f7a3f00}}.alert-list{list-style:none;margin:4px 0;padding:0;max-height:200px;overflow-y:auto}.alert-list li{padding:7px 10px;margin:4px 0;border-radius:var(--r-sm);font-size:12px;border-left:3px solid var(--text-soft);background:var(--bg-muted)}.alert-list li.alert-warning{border-left-color:var(--color-warn);background:#fff8e6}.alert-list li.alert-critical{border-left-color:var(--color-danger);background:#fde8e8}.alert-list li.alert-info{border-left-color:var(--color-blue);background:#eef3fc}.kpi-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:12px 0}.kpi-card{background:var(--bg-surface);border:1px solid var(--border);border-left:4px solid var(--color-green);border-radius:var(--r-md);padding:10px 12px;box-shadow:var(--shadow-sm);transition:transform var(--t-fast),box-shadow var(--t-fast)}.kpi-card:hover{transform:translateY(-1px);box-shadow:var(--shadow-md)}.kpi-value{font-size:22px;font-weight:700;line-height:1.1;color:var(--text)}.kpi-unit{font-size:12px;font-weight:500;color:var(--text-muted)}.kpi-label{font-size:11px;color:var(--text-muted);margin-top:3px;text-transform:uppercase;letter-spacing:.3px}.report-table{width:100%;border-collapse:collapse;font-size:12px;border-radius:var(--r-sm);overflow:hidden}.report-table th{background:var(--bg-muted);padding:7px 8px;text-align:left;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.3px;font-size:11px;border-bottom:1px solid var(--border);white-space:nowrap;position:sticky;top:0}.report-table td{padding:6px 8px;border-bottom:1px solid var(--border);color:var(--text)}.report-table tr:hover td{background:var(--color-green-50)}.subtabs{display:flex;gap:5px;flex-wrap:wrap;margin-bottom:10px}.subtabs button{border:1px solid var(--border-strong);background:var(--bg-surface);color:var(--text-muted);padding:5px 11px;border-radius:999px;cursor:pointer;font-size:12px;font-weight:500;transition:background var(--t-fast),color var(--t-fast),border-color var(--t-fast)}.subtabs button:hover{border-color:var(--color-green);color:var(--color-green)}.subtabs button.on{background:var(--color-green);color:#fff;border-color:var(--color-green)}.row-actions{display:flex;gap:6px;align-items:center;flex-wrap:wrap;margin-top:6px}.ol-popup{position:absolute;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--r-md);box-shadow:var(--shadow-lg);padding:12px 14px;min-width:180px;max-width:260px;font-size:13px;line-height:1.5;bottom:14px;left:-50%}.ol-popup:after{content:"";position:absolute;bottom:-9px;left:50%;transform:translate(-50%);border:9px solid transparent;border-top-color:var(--bg-surface);width:0;height:0}.ol-popup-close{position:absolute;top:4px;right:6px;border:none;background:none;font-size:18px;line-height:1;color:var(--text-soft);cursor:pointer;padding:2px 4px}.ol-popup-close:hover,.ol-popup-content b{color:var(--text)}.ol-layerswitcher{bottom:18px;right:18px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--r-md);box-shadow:var(--shadow-lg);padding:10px 12px;font-size:13px;max-width:220px}.ol-layerswitcher-title{font-weight:700;color:var(--text);margin-bottom:6px;font-size:12px;text-transform:uppercase;letter-spacing:.3px}.ol-layerswitcher label{display:flex;align-items:center;gap:8px;padding:2px 0;cursor:pointer;color:var(--text)}.ol-layerswitcher input{accent-color:var(--color-green);cursor:pointer}.ol-zoom{top:12px;left:12px}.ol-control button{background:var(--color-green);transition:background var(--t-fast)}.ol-control button:hover{background:var(--color-green-700)}.planner::-webkit-scrollbar,.instructions::-webkit-scrollbar,.alert-list::-webkit-scrollbar,.veh-list::-webkit-scrollbar{width:8px}.planner::-webkit-scrollbar-thumb,.instructions::-webkit-scrollbar-thumb,.alert-list::-webkit-scrollbar-thumb,.veh-list::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:999px}.planner::-webkit-scrollbar-thumb:hover,.instructions::-webkit-scrollbar-thumb:hover,.alert-list::-webkit-scrollbar-thumb:hover,.veh-list::-webkit-scrollbar-thumb:hover{background:var(--text-soft)}.floating-header-container,.floating-user-container,.custom-layers-panel,.planner{backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);background:#ffffffd9;border:1px solid rgba(255,255,255,.5);box-shadow:0 8px 32px #10182814}.floating-header-container{position:absolute;top:18px;left:50%;transform:translate(-50%);z-index:1000;border-radius:14px;padding:10px 24px;display:flex;flex-direction:column;align-items:center;gap:8px;min-width:380px;transition:transform .25s ease}.brand-logo-title{display:flex;align-items:center;gap:8px;margin-bottom:2px}.eco-logo-svg{width:22px;height:22px;fill:var(--color-green);animation:eco-spin 20s linear infinite}@keyframes eco-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.brand-title{font-weight:700;color:#1a202c;font-size:15px;letter-spacing:-.2px}.brand-title small,.brand-subtitle{font-weight:500;color:var(--text-muted);font-size:13px;margin-left:4px}.nav-tabs-row{display:flex;gap:8px}.tab-btn{border:none;background:transparent;color:var(--text-muted);padding:6px 14px;border-radius:8px;cursor:pointer;font-size:13px;font-weight:600;transition:all var(--t-fast)}.tab-btn:hover{background:#1f7a3f14;color:var(--color-green)}.tab-btn.active{background:transparent;color:var(--color-green);box-shadow:none;position:relative}.tab-btn.active:after{content:"";position:absolute;bottom:-2px;left:14px;right:14px;height:3px;background:var(--color-green);border-radius:99px}.floating-user-container{position:absolute;top:18px;right:18px;z-index:1000;border-radius:12px;display:flex;align-items:center;gap:10px;padding:8px 12px}.user-profile-box{display:flex;align-items:center;gap:10px;cursor:pointer}.user-avatar-circle{width:32px;height:32px;border-radius:50%;background:#edf2f7;display:flex;align-items:center;justify-content:center;border:1px solid var(--border)}.user-info{display:flex;flex-direction:column;text-align:left}.user-display-name{font-size:12px;font-weight:600;color:var(--text);line-height:1.2}.user-role-label{font-size:10px;color:var(--text-muted)}.dropdown-arrow-svg{margin-left:2px}.btn-sign-out{border:1px solid var(--border-strong);background:var(--bg-surface);color:var(--text);border-radius:8px;padding:6px 12px;cursor:pointer;font-size:12px;font-weight:600;box-shadow:var(--shadow-sm);transition:all var(--t-fast)}.btn-sign-out:hover{background:#f7fafc;border-color:var(--text-soft)}.btn-sign-out:active{transform:scale(.97)}.custom-layers-panel{position:absolute;bottom:24px;left:24px;z-index:1000;border-radius:14px;padding:14px 18px;min-width:240px;text-align:left}.layers-panel-header{display:flex;justify-content:space-between;align-items:center;font-weight:700;font-size:13px;color:#1a202c;margin-bottom:12px;border-bottom:1px solid rgba(0,0,0,.05);padding-bottom:8px}.layers-panel-list{display:flex;flex-direction:column;gap:8px}.layer-checkbox-row{display:flex;align-items:center;gap:8px;font-size:12px;font-weight:500;color:#4a5568;cursor:pointer;position:relative;-webkit-user-select:none;user-select:none}.layer-checkbox-row input{position:absolute;opacity:0;cursor:pointer;height:0;width:0}.checkbox-custom{height:16px;width:16px;background-color:#fff;border:1.5px solid #cbd5e0;border-radius:4px;transition:all .15s ease;display:inline-block;flex-shrink:0}.layer-checkbox-row:hover input~.checkbox-custom{border-color:var(--color-green)}.layer-checkbox-row input:checked~.checkbox-custom{background-color:var(--color-green);border-color:var(--color-green)}.checkbox-custom:after{content:"";position:absolute;display:none}.layer-checkbox-row input:checked~.checkbox-custom:after{display:block}.layer-checkbox-row .checkbox-custom:after{left:5px;top:2px;width:4px;height:8px;border:solid white;border-width:0 2px 2px 0;transform:rotate(45deg)}.planner{border-radius:16px;top:86px;right:18px;max-height:calc(100% - 104px);transition:all .3s cubic-bezier(.4,0,.2,1)}.panel-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.panel-header h3{margin:0;font-size:15px;font-weight:700;color:#1a202c}.btn-close-panel{border:none;background:#1f7a3f1a;color:var(--color-green);width:24px;height:24px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:15px;font-weight:700;transition:all var(--t-fast)}.btn-close-panel:hover{background:var(--color-green);color:#fff}.fleet-stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:20px}.stat-card{background:#f7fafc;border:1px solid var(--border);border-radius:10px;padding:10px 12px;display:flex;flex-direction:column;gap:4px}.stat-label{font-size:11px;font-weight:600;color:var(--text-muted);display:flex;align-items:center;gap:4px}.stat-icon{font-size:13px}.stat-val{font-size:20px;font-weight:700;color:var(--text)}.stat-card.active .stat-val{color:var(--color-green)}.stat-card.warning .stat-val{color:var(--color-warn)}.stat-card.danger .stat-val{color:var(--color-danger)}.live-route-progress{background:#fff;border:1px solid var(--border);border-radius:12px;padding:14px;margin-bottom:20px}.progress-header{display:flex;justify-content:space-between;align-items:center;font-weight:700;font-size:12px;color:var(--text-muted);margin-bottom:12px}.more-actions{cursor:pointer;font-size:12px;color:var(--text-soft)}.progress-item{display:flex;flex-direction:column;gap:4px;margin-bottom:12px}.progress-item:last-child{margin-bottom:0}.progress-item-title{font-weight:600;font-size:12px;color:var(--text)}.progress-bar-container{height:8px;background:#edf2f7;border-radius:4px;overflow:hidden;width:100%}.progress-bar-fill{height:100%;background:var(--color-green);border-radius:4px;transition:width .4s ease}.progress-meta{display:flex;justify-content:space-between;font-size:10px;font-weight:500;color:var(--text-muted)}.panel-section{margin-bottom:16px}.panel-section:last-child{margin-bottom:0}.progress-list-scroll{max-height:180px;overflow-y:auto;padding-right:2px}.vehicle-popup-info{display:flex;flex-direction:column;gap:6px;text-align:left}.vehicle-popup-info h4{margin:0 0 2px;font-size:13px;font-weight:700;color:var(--text);border-bottom:1px solid rgba(0,0,0,.05);padding-bottom:4px}.vehicle-popup-info p{margin:0;font-size:11px;color:#4a5568}.btn-msg-driver{margin-top:6px;background:#fff;border:1px solid var(--color-green);color:var(--color-green);font-weight:600;font-size:11px;padding:5px;border-radius:6px;cursor:pointer;transition:all var(--t-fast)}.btn-msg-driver:hover{background:var(--color-green);color:#fff}.driver-chat-modal{position:absolute;bottom:20px;right:360px;width:320px;height:420px;background:#fff;border-radius:12px;box-shadow:0 8px 30px #00000026;display:flex;flex-direction:column;z-index:1000;overflow:hidden;animation:slideUp .3s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.chat-header{background:var(--color-green);color:#fff;padding:12px 16px;display:flex;justify-content:space-between;align-items:center}.chat-header-info{display:flex;align-items:center;gap:12px}.driver-avatar-circle{width:36px;height:36px;background:#fff3;border-radius:50%;display:flex;align-items:center;justify-content:center}.chat-title{font-weight:600;font-size:14px}.chat-subtitle{font-size:11px;opacity:.8}.chat-close-btn{background:transparent;border:none;color:#fff;font-size:24px;cursor:pointer;line-height:1;opacity:.8}.chat-close-btn:hover{opacity:1}.chat-messages-container{flex:1;padding:16px;overflow-y:auto;background:#f4f6f8;display:flex;flex-direction:column;gap:12px}.chat-message-row{display:flex;width:100%}.chat-message-row.sent{justify-content:flex-end}.chat-message-row.received{justify-content:flex-start}.chat-bubble{max-width:80%;padding:10px 14px;border-radius:16px;font-size:13px;line-height:1.4;position:relative;box-shadow:0 1px 2px #0000000d}.chat-message-row.sent .chat-bubble{background:var(--color-green);color:#fff;border-bottom-right-radius:4px}.chat-message-row.received .chat-bubble{background:#fff;color:var(--text-main);border-bottom-left-radius:4px;border:1px solid var(--border-color)}.chat-timestamp{display:block;font-size:10px;margin-top:4px;opacity:.7;text-align:right}.chat-message-row.received .chat-timestamp{text-align:left}.chat-input-container{display:flex;padding:12px;background:#fff;border-top:1px solid var(--border-color);gap:8px}.chat-input-field{flex:1;border:1px solid var(--border-color);border-radius:20px;padding:8px 16px;font-size:13px;outline:none;transition:border-color .2s}.chat-input-field:focus{border-color:var(--color-green)}.chat-send-btn{width:36px;height:36px;border-radius:50%;background:var(--color-green);color:#fff;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s}.chat-send-btn:disabled{background:#ccc;cursor:not-allowed}.chat-send-btn:hover:not(:disabled){background:#176030}
