@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&family=JetBrains+Mono:wght@400;500&display=swap";:root{--bg-base: #0c0f1a;--bg-primary: #0f1220;--bg-secondary: #161b2e;--bg-tertiary: #1e2540;--bg-card: #161b2e;--bg-elevated: #1e2540;--accent: #4f8ef7;--accent-rgb: 79, 142, 247;--accent-dark: #3b7de8;--accent-light: #74a8f9;--accent-glow: rgba(79, 142, 247, .12);--accent-glow-strong: rgba(79, 142, 247, .2);--status-active: #22c55e;--status-idle: #f59e0b;--status-offline: #ef4444;--status-maintenance: #a855f7;--text-primary: #e2e8f0;--text-secondary: #94a3b8;--text-muted: #4b5675;--border-subtle: rgba(255, 255, 255, .05);--border-light: rgba(255, 255, 255, .09);--border-medium: rgba(255, 255, 255, .14);--border-accent: rgba(79, 142, 247, .3);--shadow-sm: 0 1px 3px rgba(0,0,0,.4);--shadow-md: 0 4px 16px rgba(0,0,0,.5);--shadow-lg: 0 12px 40px rgba(0,0,0,.6);--shadow-xl: 0 20px 60px rgba(0,0,0,.7);--r-xs: 4px;--r-sm: 6px;--r-md: 8px;--r-lg: 12px;--r-xl: 16px;--r-2xl: 20px;--r-full: 9999px;--t-fast: .12s ease;--t-base: .2s ease;--t-slow: .35s ease}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html,body{height:100%;overflow:hidden}body{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;background:var(--bg-base);color:var(--text-primary);line-height:1.6;-webkit-font-smoothing:antialiased}#app{height:100vh;width:100vw;overflow:hidden}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--bg-elevated);border-radius:var(--r-full)}::-webkit-scrollbar-thumb:hover{background:var(--border-medium)}.app-layout{display:flex;height:100vh;width:100vw;overflow:hidden}.main-content{flex:1;display:flex;flex-direction:column;overflow:hidden;background:var(--bg-primary)}.sidebar{width:240px;min-width:240px;background:var(--bg-secondary);border-right:1px solid var(--border-subtle);display:flex;flex-direction:column;height:100vh;z-index:100}.sidebar-header{padding:20px 16px;border-bottom:1px solid var(--border-subtle);display:flex;align-items:center;gap:10px}.sidebar-logo{width:36px;height:36px;background:var(--accent);border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:#fff}.sidebar-brand{font-size:16px;font-weight:700;color:var(--text-primary);letter-spacing:-.3px}.sidebar-tagline{font-size:10px;color:var(--text-muted);letter-spacing:1.5px;text-transform:uppercase}.sidebar-nav{flex:1;padding:12px 8px;overflow-y:auto}.nav-section{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:1.5px;color:var(--text-muted);padding:12px 8px 6px}.nav-item{display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:var(--r-md);color:var(--text-secondary);font-size:13px;font-weight:500;cursor:pointer;transition:all var(--t-fast);margin-bottom:2px;border:1px solid transparent}.nav-item:hover{background:var(--bg-elevated);color:var(--text-primary)}.nav-item.active{background:var(--accent-glow);color:var(--accent-light);border-color:var(--border-accent);font-weight:600}.nav-icon{width:18px;height:18px;display:flex;align-items:center;justify-content:center;flex-shrink:0;opacity:.7}.nav-item.active .nav-icon,.nav-item:hover .nav-icon{opacity:1}.nav-label{flex:1}.nav-badge{background:var(--accent);color:#fff;font-size:10px;font-weight:700;padding:1px 7px;border-radius:var(--r-full);min-width:20px;text-align:center}.sidebar-user{padding:12px;border-top:1px solid var(--border-subtle);display:flex;align-items:center;gap:10px}.user-avatar{width:34px;height:34px;border-radius:var(--r-md);background:linear-gradient(135deg,#4f46e5,#7c3aed);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:12px;color:#fff;flex-shrink:0}.user-info{flex:1;min-width:0}.user-name{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role{font-size:11px;color:var(--text-muted);text-transform:capitalize}.logout-btn{width:32px;height:32px;padding:0;border-radius:var(--r-sm);background:transparent;border:1px solid var(--border-subtle);color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--t-fast)}.logout-btn:hover{background:rgba(239,68,68,.12);border-color:#ef444440;color:#ef4444}.topbar{display:flex;align-items:center;justify-content:space-between;padding:0 28px;border-bottom:1px solid var(--border-subtle);background:var(--bg-secondary);height:60px;flex-shrink:0}.topbar-title{font-size:18px;font-weight:700;color:var(--text-primary);letter-spacing:-.3px}.topbar-subtitle{font-size:12px;color:var(--text-muted);margin-top:1px}.topbar-right{display:flex;align-items:center;gap:12px}.search-box{display:flex;align-items:center;gap:8px;background:var(--bg-tertiary);border:1px solid var(--border-subtle);border-radius:var(--r-md);padding:7px 14px;width:240px;transition:all var(--t-base)}.search-box:focus-within{border-color:var(--border-accent);box-shadow:0 0 0 3px var(--accent-glow)}.search-icon{color:var(--text-muted);flex-shrink:0}.search-input{background:none;border:none;outline:none;color:var(--text-primary);font-family:inherit;font-size:13px;width:100%}.search-input::placeholder{color:var(--text-muted)}.notification-bell{width:36px;height:36px;border-radius:var(--r-md);background:var(--bg-tertiary);border:1px solid var(--border-subtle);display:flex;align-items:center;justify-content:center;cursor:pointer;position:relative;color:var(--text-secondary);transition:all var(--t-fast)}.notification-bell:hover{background:var(--bg-elevated);color:var(--text-primary)}.notif-dot{position:absolute;top:7px;right:7px;width:7px;height:7px;background:#ef4444;border-radius:50%;border:1.5px solid var(--bg-secondary)}.page-content{flex:1;overflow-y:auto;padding:24px 28px 40px}.card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--r-xl);padding:24px;transition:border-color var(--t-fast)}.card:hover{border-color:var(--border-light)}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}.stat-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--r-xl);padding:20px;transition:all var(--t-base)}.stat-card:hover{border-color:var(--border-light);transform:translateY(-2px);box-shadow:var(--shadow-md)}.stat-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.stat-label{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:1px;font-weight:600}.stat-icon{width:36px;height:36px;border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;background:var(--bg-elevated);color:var(--text-secondary)}.stat-value{font-size:34px;font-weight:800;letter-spacing:-1px;line-height:1;margin-bottom:6px;color:var(--text-primary)}.stat-footer{font-size:12px;color:var(--text-muted);display:flex;align-items:center;gap:4px}.table-wrapper{overflow-x:auto}.data-table{width:100%;border-collapse:collapse}.data-table thead{background:var(--bg-elevated)}.data-table th{text-align:left;padding:12px 16px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--text-muted);border-bottom:1px solid var(--border-subtle);white-space:nowrap}.data-table td{padding:14px 16px;font-size:13px;border-bottom:1px solid var(--border-subtle);vertical-align:middle}.data-table tbody tr{transition:background var(--t-fast)}.data-table tbody tr:hover{background:var(--bg-elevated)}.data-table tbody tr:last-child td{border-bottom:none}.data-table code{font-family:JetBrains Mono,monospace;font-size:11px;color:var(--text-secondary);background:var(--bg-elevated);padding:2px 7px;border-radius:var(--r-xs)}.status-badge{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:var(--r-full);font-size:11px;font-weight:600;letter-spacing:.3px;white-space:nowrap}.btn-primary{display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:10px 20px;border:none;border-radius:var(--r-md);font-family:inherit;font-size:13px;font-weight:600;cursor:pointer;color:#fff;background:var(--accent);transition:all var(--t-fast)}.btn-primary:hover{background:var(--accent-dark);transform:translateY(-1px);box-shadow:0 4px 16px rgba(var(--accent-rgb),.35)}.btn-primary:active{transform:translateY(0)}.btn-primary:disabled{opacity:.4;cursor:not-allowed;transform:none;box-shadow:none}.btn-outline{display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:9px 18px;background:transparent;border:1px solid var(--border-medium);border-radius:var(--r-md);color:var(--text-secondary);font-family:inherit;font-size:13px;font-weight:500;cursor:pointer;transition:all var(--t-fast)}.btn-outline:hover{background:var(--bg-elevated);border-color:var(--border-accent);color:var(--accent-light)}.btn-icon{width:34px;height:34px;padding:0;border-radius:var(--r-sm);background:var(--bg-elevated);border:1px solid var(--border-subtle);color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px;transition:all var(--t-fast)}.btn-icon:hover{background:var(--accent-glow);border-color:var(--border-accent);color:var(--accent-light)}.btn-danger{display:inline-flex;align-items:center;gap:7px;padding:9px 18px;background:rgba(239,68,68,.08);border:1px solid rgba(239,68,68,.2);border-radius:var(--r-md);color:#ef4444;font-family:inherit;font-size:13px;font-weight:600;cursor:pointer;transition:all var(--t-fast)}.btn-danger:hover{background:rgba(239,68,68,.15);border-color:#ef444459}.form-group{margin-bottom:16px;flex:1}.form-group label{display:block;font-size:11px;font-weight:600;color:var(--text-muted);margin-bottom:6px;text-transform:uppercase;letter-spacing:.5px}.form-input,.form-select{width:100%;padding:10px 14px;background:var(--bg-tertiary);border:1px solid var(--border-light);border-radius:var(--r-md);color:var(--text-primary);font-family:inherit;font-size:13px;transition:all var(--t-fast);outline:none}.form-input:focus,.form-select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow);background:var(--bg-elevated)}.form-input::placeholder{color:var(--text-muted)}.form-select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath d='M6 8L1 3h10z' fill='%234b5675'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px}.form-select option{background:var(--bg-secondary);color:var(--text-primary)}.form-row{display:flex;gap:14px}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-base)}.login-container{width:100%;max-width:400px;padding:0 24px}.login-logo{width:52px;height:52px;background:var(--accent);border-radius:var(--r-xl);display:flex;align-items:center;justify-content:center;margin:0 auto 20px;color:#fff}.login-title{text-align:center;font-size:28px;font-weight:800;color:var(--text-primary);letter-spacing:-.5px;margin-bottom:4px}.login-subtitle{text-align:center;color:var(--text-muted);font-size:13px;margin-bottom:32px}.login-card{background:var(--bg-secondary);border:1px solid var(--border-light);border-radius:var(--r-2xl);padding:32px;box-shadow:var(--shadow-xl)}.login-card h2{font-size:18px;font-weight:700;margin-bottom:4px}.login-error{background:rgba(239,68,68,.08);border:1px solid rgba(239,68,68,.2);border-radius:var(--r-md);padding:10px 14px;margin-bottom:16px;color:#f87171;font-size:13px}.activity-item{display:flex;gap:12px;padding:12px 0;border-bottom:1px solid var(--border-subtle);transition:all var(--t-fast)}.activity-item:hover{background:rgba(255,255,255,.02);padding-left:6px;border-radius:var(--r-sm)}.activity-item:last-child{border-bottom:none}.activity-item strong{color:var(--text-primary)}.modal{position:fixed;inset:0;background:rgba(0,0,0,.65);backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:center;justify-content:center;animation:fadeIn .15s ease}.modal-content{background:var(--bg-secondary);border:1px solid var(--border-light);border-radius:var(--r-2xl);padding:28px;width:90%;max-width:520px;max-height:85vh;overflow-y:auto;box-shadow:var(--shadow-xl);animation:modalSlideUp .25s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes modalSlideUp{0%{transform:translateY(20px) scale(.97);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:22px}.modal-header h3{font-size:18px;font-weight:700}.modal-close{width:32px;height:32px;border-radius:var(--r-sm);background:var(--bg-elevated);border:1px solid var(--border-subtle);color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:16px;transition:all var(--t-fast)}.modal-close:hover{background:rgba(239,68,68,.12);border-color:#ef444440;color:#ef4444}.toast{position:fixed;bottom:24px;right:24px;background:var(--bg-elevated);border:1px solid var(--border-light);border-radius:var(--r-lg);padding:14px 20px;display:flex;align-items:center;gap:10px;font-size:13px;font-weight:500;z-index:3000;box-shadow:var(--shadow-xl);max-width:380px;transform:translate(120%);opacity:0;transition:all .3s cubic-bezier(.34,1.3,.64,1);color:var(--text-primary)}.toast.show{transform:translate(0);opacity:1}.toast-success{border-left:3px solid var(--status-active)}.toast-error{border-left:3px solid var(--status-offline)}.toast-info{border-left:3px solid var(--accent)}.settings-tabs{display:flex;gap:4px;margin-bottom:24px;padding:4px;background:var(--bg-secondary);border-radius:var(--r-lg);border:1px solid var(--border-subtle)}.tab-btn{flex:1;padding:9px 14px;border:none;border-radius:var(--r-md);background:transparent;color:var(--text-muted);font-family:inherit;font-size:13px;font-weight:500;cursor:pointer;transition:all var(--t-fast);white-space:nowrap}.tab-btn:hover{color:var(--text-primary);background:var(--bg-elevated)}.tab-btn.active{background:var(--accent-glow);color:var(--accent-light);font-weight:600}.tab-content{display:none}.tab-content.active{display:block;animation:fadeSlideIn .2s ease}@keyframes fadeSlideIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.setting-row{display:flex;align-items:center;justify-content:space-between;padding:14px 0;border-bottom:1px solid var(--border-subtle);gap:16px}.setting-row:last-child{border-bottom:none}.setting-row strong{font-size:13px;font-weight:600;display:block;margin-bottom:2px}.toggle{position:relative;width:44px;height:24px;flex-shrink:0}.toggle input{opacity:0;width:0;height:0;position:absolute}.toggle-slider{position:absolute;cursor:pointer;inset:0;background:var(--bg-elevated);border:1px solid var(--border-light);border-radius:var(--r-full);transition:all var(--t-base)}.toggle-slider:before{content:"";position:absolute;width:18px;height:18px;left:2px;bottom:2px;background:var(--text-muted);border-radius:50%;transition:all var(--t-base)}.toggle input:checked+.toggle-slider{background:var(--accent);border-color:var(--accent-dark)}.toggle input:checked+.toggle-slider:before{transform:translate(20px);background:white}.map-page-layout{display:grid;grid-template-columns:360px 1fr;height:100vh}.map-sidebar{background:var(--bg-secondary);border-right:1px solid var(--border-subtle);display:flex;flex-direction:column;overflow-y:auto}.map-sidebar-header{padding:20px;border-bottom:1px solid var(--border-subtle)}.map-sidebar-header h3{font-size:15px;font-weight:700;display:flex;align-items:center;gap:8px}.map-form{padding:16px 20px;border-bottom:1px solid var(--border-subtle)}.map-vehicle-list{flex:1;overflow-y:auto;padding:6px 10px}.map-vehicle-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:var(--r-md);border:1px solid transparent;cursor:pointer;transition:all var(--t-fast);margin-bottom:3px}.map-vehicle-item:hover{background:var(--bg-elevated);border-color:var(--border-subtle)}.map-container{height:100%;position:relative}#full-map{height:100%;width:100%}.route-upload-area{border:1px dashed var(--border-medium);border-radius:var(--r-lg);padding:24px 16px;text-align:center;cursor:pointer;transition:all var(--t-base);background:var(--bg-elevated);margin-bottom:12px}.route-upload-area:hover,.route-upload-area.drag-over{border-color:var(--accent);background:var(--accent-glow)}.upload-icon{font-size:28px;margin-bottom:8px;line-height:1}.upload-title{font-size:13px;font-weight:600;color:var(--text-primary);margin-bottom:2px}.upload-subtitle{font-size:11px;color:var(--text-muted)}.upload-info{display:flex;align-items:flex-start;gap:8px;font-size:11px;color:var(--text-muted);background:var(--bg-elevated);border-radius:var(--r-sm);padding:10px 12px;line-height:1.5;margin-bottom:12px}.upload-file-badge{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--accent-glow);border:1px solid var(--border-accent);border-radius:var(--r-md);animation:fadeSlideIn .2s ease}.mapboxgl-popup-content{background:var(--bg-elevated)!important;color:var(--text-primary)!important;border:1px solid var(--border-light)!important;border-radius:var(--r-lg)!important;box-shadow:var(--shadow-xl)!important;padding:14px 18px!important}.mapboxgl-popup-tip{border-top-color:var(--bg-elevated)!important;border-bottom-color:var(--bg-elevated)!important}.mapboxgl-popup-close-button{color:var(--text-muted)!important;font-size:18px!important}.mapboxgl-popup-close-button:hover{color:var(--accent)!important;background:transparent!important}.mapboxgl-ctrl-group{background:var(--bg-elevated)!important;border:1px solid var(--border-subtle)!important;border-radius:var(--r-md)!important;box-shadow:var(--shadow-md)!important;overflow:hidden}.mapboxgl-ctrl-group button{background:var(--bg-elevated)!important;border-color:var(--border-subtle)!important}.mapboxgl-ctrl-group button:hover{background:var(--bg-secondary)!important}.mapboxgl-ctrl-attrib{background:rgba(15,18,32,.8)!important;color:var(--text-muted)!important;font-size:10px!important}.route-history-controls{display:flex;flex-direction:column}.route-history-controls .form-group select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%234b5675' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:32px;cursor:pointer;transition:all var(--t-fast)}.route-history-controls .form-group select:hover:not(:disabled){border-color:var(--accent)}.route-history-controls .form-group select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.route-history-controls .form-group select:disabled{opacity:.4;cursor:not-allowed}.route-history-controls .btn{font-family:inherit;cursor:pointer;transition:all var(--t-fast);border:none;font-weight:600}.route-history-controls .btn-primary{background:var(--accent);color:#fff}.route-history-controls .btn-primary:hover:not(:disabled){background:var(--accent-dark)}.route-history-controls .btn-primary:disabled{opacity:.4;cursor:not-allowed}.route-history-controls .btn-outline{background:transparent;border:1px solid var(--border-medium);color:var(--text-secondary)}.route-history-controls .btn-outline:hover:not(:disabled){border-color:var(--accent);color:var(--accent);background:var(--accent-glow)}.route-history-controls .btn-outline:disabled{opacity:.4;cursor:not-allowed}#history-status .upload-file-badge{background:rgba(37,99,235,.08);border-color:#2563eb33}.vehicle-detail-page{max-width:1400px;padding-bottom:40px}.vd-header{display:flex;align-items:center;gap:14px;margin-bottom:20px;padding:18px 22px;background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--r-xl)}.vd-back-btn{width:36px;height:36px;border-radius:var(--r-md);border:1px solid var(--border-medium);background:var(--bg-elevated);color:var(--text-primary);font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--t-fast);flex-shrink:0}.vd-back-btn:hover{background:var(--accent-glow);border-color:var(--accent);color:var(--accent)}.vd-header-info{flex:1;min-width:0}.vd-title{font-size:20px;font-weight:700;margin-bottom:2px}.vd-subtitle{font-size:12px;color:var(--text-muted)}.vd-status-badge{padding:5px 14px;border-radius:var(--r-full);font-size:11px;font-weight:700;flex-shrink:0}.vd-grid{display:grid;grid-template-columns:1fr 340px;gap:18px}.vd-left{display:flex;flex-direction:column;gap:0}.vd-right{display:flex;flex-direction:column}.vd-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.vd-section-header h3{font-size:16px;font-weight:700}.vd-date-picker{padding:7px 11px;border-radius:var(--r-md);border:1px solid var(--border-medium);background:var(--bg-elevated);color:var(--text-primary);font-family:inherit;font-size:13px;cursor:pointer;transition:all var(--t-fast)}.vd-date-picker:hover,.vd-date-picker:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow);outline:none}.vd-export-btn{padding:7px 13px;border-radius:var(--r-md);border:1px solid rgba(34,197,94,.25);background:rgba(34,197,94,.08);color:#22c55e;font-family:inherit;font-size:13px;font-weight:600;cursor:pointer;transition:all var(--t-fast)}.vd-export-btn:hover{background:rgba(34,197,94,.15)}.vd-map-wrapper{position:relative;border-radius:var(--r-xl);overflow:hidden;border:1px solid var(--border-subtle)}.vd-map{width:100%;height:400px}.vd-map-overlay{position:absolute;bottom:14px;right:14px;z-index:10}.vd-map-position{background:rgba(22,27,46,.92);backdrop-filter:blur(8px);border-radius:var(--r-lg);border:1px solid var(--border-light);padding:12px 16px;box-shadow:var(--shadow-lg);min-width:190px}.vd-pos-header{font-size:12px;font-weight:700;margin-bottom:8px}.vd-pos-row{display:flex;justify-content:space-between;align-items:center;gap:12px;font-size:12px;padding:2px 0}.vd-pos-row span{color:var(--text-muted)}.vd-playback-bar{background:var(--bg-card);border:1px solid var(--border-subtle);border-top:none;border-radius:0 0 var(--r-xl) var(--r-xl);padding:12px 16px}.vd-playback-controls{display:flex;align-items:center;gap:8px;margin-bottom:10px}.vd-play-btn{width:38px;height:38px;border-radius:50%;border:none;background:#3b82f6;color:#fff;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--t-fast)}.vd-play-btn:hover:not(:disabled){background:#2563eb;transform:scale(1.05)}.vd-play-btn:disabled{opacity:.3;cursor:not-allowed}.vd-control-btn{width:32px;height:32px;border-radius:var(--r-sm);border:1px solid var(--border-medium);background:var(--bg-elevated);color:var(--text-secondary);font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--t-fast)}.vd-control-btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent);background:var(--accent-glow)}.vd-control-btn:disabled{opacity:.3;cursor:not-allowed}.vd-speed-control{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--text-muted);margin-left:auto}.vd-speed-select{padding:4px 8px;border-radius:var(--r-sm);border:1px solid var(--border-medium);background:var(--bg-elevated);color:var(--text-primary);font-family:inherit;font-size:13px;cursor:pointer}.vd-playback-slider{display:flex;align-items:center;gap:10px}.vd-slider{flex:1;-webkit-appearance:none;appearance:none;height:4px;background:var(--bg-elevated);border-radius:2px;outline:none;cursor:pointer}.vd-slider::-webkit-slider-thumb{-webkit-appearance:none;width:16px;height:16px;border-radius:50%;background:#3b82f6;border:2px solid var(--bg-secondary);cursor:pointer;transition:transform .12s}.vd-slider::-webkit-slider-thumb:hover{transform:scale(1.2)}.vd-slider:disabled{opacity:.3;cursor:not-allowed}.vd-point-counter{font-size:12px;font-weight:600;color:var(--text-muted);white-space:nowrap;min-width:60px;text-align:right}.vd-point-info{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:10px}.vd-info-card{display:flex;align-items:center;gap:10px;padding:12px 14px;background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--r-lg)}.vd-info-icon{font-size:20px;flex-shrink:0}.vd-info-label{font-size:10px;text-transform:uppercase;letter-spacing:.8px;color:var(--text-muted);font-weight:600;margin-bottom:2px}.vd-info-value{font-size:14px;font-weight:700}.vd-trip-summary{padding:18px!important}.vd-summary-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.vd-summary-card{display:flex;align-items:center;gap:10px;padding:12px;background:var(--bg-primary);border:1px solid var(--border-subtle);border-radius:var(--r-lg)}.vd-summary-icon{width:38px;height:38px;border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}.vd-summary-label{font-size:10px;text-transform:uppercase;letter-spacing:.8px;color:var(--text-muted);font-weight:600;margin-bottom:2px}.vd-summary-value{font-size:15px;font-weight:800}.vd-vehicle-info-list{display:flex;flex-direction:column}.vd-vi-row{display:flex;justify-content:space-between;align-items:center;padding:9px 0;border-bottom:1px solid var(--border-subtle);font-size:13px}.vd-vi-row:last-child{border-bottom:none}.vd-vi-row span{color:var(--text-muted)}.vd-alerts-list{max-height:190px;overflow-y:auto}.ss-wrap{position:relative}.ss-input{cursor:text;padding-right:36px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath d='M6 8L1 3h10z' fill='%234b5675'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center}.ss-list{display:none;position:absolute;top:100%;left:0;right:0;background:var(--bg-secondary);border:1px solid var(--border-accent);border-top:none;border-bottom-left-radius:var(--r-md);border-bottom-right-radius:var(--r-md);max-height:200px;overflow-y:auto;z-index:9999;box-shadow:var(--shadow-lg)}.ss-item{padding:9px 14px;cursor:pointer;font-size:13px;color:var(--text-primary);transition:background .1s;display:flex;align-items:center;gap:8px}.ss-item:hover{background:var(--bg-elevated)}.ss-item.ss-selected{color:var(--accent-light);background:var(--accent-glow)}.ss-plate{font-size:11px;color:var(--text-muted);font-family:JetBrains Mono,monospace}.page-content>*{animation:entranceFade .25s ease backwards}.page-content>*:nth-child(1){animation-delay:.03s}.page-content>*:nth-child(2){animation-delay:.06s}.page-content>*:nth-child(3){animation-delay:.09s}.page-content>*:nth-child(4){animation-delay:.12s}.stat-card{animation:entranceFade .25s ease backwards}.stats-grid .stat-card:nth-child(1){animation-delay:.04s}.stats-grid .stat-card:nth-child(2){animation-delay:.08s}.stats-grid .stat-card:nth-child(3){animation-delay:.12s}.stats-grid .stat-card:nth-child(4){animation-delay:.16s}@keyframes entranceFade{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 1200px){.stats-grid{grid-template-columns:repeat(2,1fr)}.map-page-layout{grid-template-columns:300px 1fr}}@media (max-width: 1100px){.vd-grid{grid-template-columns:1fr}}@media (max-width: 768px){.sidebar{position:fixed;left:0;top:0;transform:translate(-100%)}.sidebar.open{transform:translate(0)}.stats-grid{grid-template-columns:1fr 1fr}.settings-tabs{flex-wrap:wrap}.map-page-layout{grid-template-columns:1fr}}@media (max-width: 600px){.vd-point-info,.vd-summary-grid{grid-template-columns:1fr}}.nav-icon svg,.sidebar-logo svg,.login-logo svg,.logout-btn svg,.search-icon svg,.notification-bell svg,.toast-icon svg{display:block}.spin{animation:rotate .8s linear infinite}@keyframes rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}
