@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap";
:root{--bg-primary:#f8fafc;--bg-secondary:#fff;--bg-card:#fff;--bg-hover:#f1f5f9;--bg-input:#f8fafc;--border:#e2e8f0;--border-light:#cbd5e1;--text-primary:#0f172a;--text-secondary:#475569;--text-muted:#94a3b8;--accent:#4f46e5;--accent-hover:#6366f1;--accent-subtle:#4f46e50f;--accent-glow:#4f46e514;--success:#10b981;--success-subtle:#10b9810f;--warning:#f59e0b;--warning-subtle:#f59e0b0f;--danger:#ef4444;--danger-subtle:#ef44440f;--info:#3b82f6;--info-subtle:#3b82f60f;--sev-low:var(--success);--sev-medium:var(--warning);--sev-high:#f97316;--sev-critical:var(--danger);--space-1:.25rem;--space-2:.5rem;--space-3:.75rem;--space-4:1rem;--space-5:1.25rem;--space-6:1.5rem;--space-8:2rem;--space-10:2.5rem;--space-12:3rem;--space-16:4rem;--radius-sm:.375rem;--radius-md:.625rem;--radius-lg:.875rem;--radius-xl:1.25rem;--radius-full:9999px;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000000d, 0 2px 4px -2px #0000000d;--shadow-lg:0 10px 15px -3px #0000000d, 0 4px 6px -4px #0000000d;--shadow-glow:0 0 20px #4f46e50d;--transition-fast:.15s ease;--transition-base:.25s ease;--transition-slow:.4s ease;--font-sans:"Inter", system-ui, -apple-system, sans-serif;--font-mono:"JetBrains Mono", "Courier New", monospace;--sidebar-width:240px;--header-height:60px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;font-size:16px}body{font-family:var(--font-sans);background-color:var(--bg-primary);color:var(--text-primary);min-height:100vh;line-height:1.6}a{color:inherit;text-decoration:none}button{font-family:var(--font-sans);cursor:pointer}input,textarea,select{font-family:var(--font-sans)}.app-layout{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-width);background:var(--bg-secondary);border-right:1px solid var(--border);z-index:100;min-height:100vh;transition:transform var(--transition-base);flex-direction:column;display:flex;position:fixed;top:0;left:0}.main-content{margin-left:var(--sidebar-width);flex-direction:column;flex:1;min-height:100vh;display:flex}.page-header{height:var(--header-height);background:var(--bg-secondary);border-bottom:1px solid var(--border);padding:0 var(--space-6);z-index:50;justify-content:space-between;align-items:center;display:flex;position:sticky;top:0}.page-body{padding:var(--space-6);flex:1}.sidebar-logo{padding:var(--space-5) var(--space-5);border-bottom:1px solid var(--border);align-items:center;gap:var(--space-3);display:flex}.sidebar-logo-icon{background:var(--accent);border-radius:var(--radius-md);justify-content:center;align-items:center;width:36px;height:36px;font-size:1.1rem;display:flex}.sidebar-logo-text{letter-spacing:-.02em;color:var(--text-primary);font-size:1.1rem;font-weight:700}.sidebar-logo-text span{color:var(--accent)}.sidebar-nav{padding:var(--space-4) var(--space-3);gap:var(--space-1);flex-direction:column;flex:1;display:flex}.nav-section-label{text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);padding:var(--space-3) var(--space-3) var(--space-2);margin-top:var(--space-2);font-size:.65rem;font-weight:600}.nav-item{align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-3);border-radius:var(--radius-md);color:var(--text-secondary);transition:all var(--transition-fast);cursor:pointer;font-size:.875rem;font-weight:500;display:flex;position:relative}.nav-item:hover{background:var(--bg-hover);color:var(--text-primary)}.nav-item.active{background:var(--accent-subtle);color:var(--accent-hover)}.nav-item.active:before{content:"";background:var(--accent);border-radius:0 var(--radius-full) var(--radius-full) 0;width:3px;height:50%;position:absolute;top:25%;left:0}.nav-item-icon{flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;display:flex}.nav-badge{background:var(--danger);color:#fff;border-radius:var(--radius-full);text-align:center;min-width:20px;margin-left:auto;padding:2px 7px;font-size:.65rem;font-weight:700}.sidebar-footer{padding:var(--space-4);border-top:1px solid var(--border)}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-5);transition:border-color var(--transition-fast)}.card:hover{border-color:var(--border-light)}.card-header{margin-bottom:var(--space-4);justify-content:space-between;align-items:center;display:flex}.card-title{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;font-size:.9rem;font-weight:600}.kpi-grid{gap:var(--space-4);margin-bottom:var(--space-6);grid-template-columns:repeat(auto-fit,minmax(200px,1fr));display:grid}.kpi-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-5);gap:var(--space-3);transition:all var(--transition-base);flex-direction:column;display:flex;position:relative;overflow:hidden}.kpi-card:before{content:"";background:var(--accent);opacity:0;height:2px;transition:opacity var(--transition-base);position:absolute;top:0;left:0;right:0}.kpi-card:hover:before{opacity:1}.kpi-card:hover{border-color:var(--accent);box-shadow:var(--shadow-glow);transform:translateY(-2px)}.kpi-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;font-size:.75rem;font-weight:500}.kpi-value{color:var(--text-primary);letter-spacing:-.02em;font-size:1.75rem;font-weight:700;line-height:1.1}.kpi-value.accent{color:var(--accent-hover)}.kpi-value.success{color:var(--success)}.kpi-value.warning{color:var(--warning)}.kpi-value.danger{color:var(--danger)}.kpi-sub{color:var(--text-muted);align-items:center;gap:var(--space-1);font-size:.75rem;display:flex}.kpi-icon{border-radius:var(--radius-md);width:40px;height:40px;top:var(--space-5);right:var(--space-5);justify-content:center;align-items:center;font-size:1.1rem;display:flex;position:absolute}.btn{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);border-radius:var(--radius-md);transition:all var(--transition-fast);cursor:pointer;white-space:nowrap;border:1px solid #0000;font-size:.875rem;font-weight:500;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}.btn-primary:hover:not(:disabled){background:var(--accent-hover);border-color:var(--accent-hover);box-shadow:0 0 16px var(--accent-glow)}.btn-secondary{color:var(--text-secondary);border-color:var(--border);background:0 0}.btn-secondary:hover:not(:disabled){background:var(--bg-hover);color:var(--text-primary);border-color:var(--border-light)}.btn-danger{color:var(--danger);border-color:var(--danger);background:0 0}.btn-danger:hover:not(:disabled){background:var(--danger-subtle)}.btn-sm{padding:var(--space-1) var(--space-3);font-size:.8rem}.btn-lg{padding:var(--space-3) var(--space-6);font-size:1rem}.btn-icon{padding:var(--space-2);aspect-ratio:1}.badge{align-items:center;gap:var(--space-1);border-radius:var(--radius-full);letter-spacing:.03em;padding:3px 10px;font-size:.72rem;font-weight:600;display:inline-flex}.badge-active{background:var(--success-subtle);color:var(--success)}.badge-inactive{background:var(--bg-hover);color:var(--text-muted)}.badge-warning{background:var(--warning-subtle);color:var(--warning)}.badge-danger{background:var(--danger-subtle);color:var(--danger)}.badge-info{background:var(--info-subtle);color:var(--info)}.badge-accent{background:var(--accent-subtle);color:var(--accent-hover)}.badge-dot:before{content:"";background:currentColor;border-radius:50%;flex-shrink:0;width:6px;height:6px}.form-group{gap:var(--space-2);flex-direction:column;display:flex}.form-label{color:var(--text-secondary);font-size:.8rem;font-weight:500}.form-label span{color:var(--danger);margin-left:2px}.form-input,.form-select,.form-textarea{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);color:var(--text-primary);transition:all var(--transition-fast);appearance:none;width:100%;font-size:.875rem}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-subtle);outline:none}.form-input::placeholder,.form-textarea::placeholder{color:var(--text-muted)}.form-textarea{resize:vertical;min-height:90px}.form-error{color:var(--danger);align-items:center;gap:var(--space-1);font-size:.75rem;display:flex}.form-grid{gap:var(--space-4);grid-template-columns:repeat(2,1fr);display:grid}.form-grid-3{gap:var(--space-4);grid-template-columns:repeat(3,1fr);display:grid}.form-full{grid-column:1/-1}.table-container{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.table-toolbar{padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:var(--space-4);display:flex}.table-search{align-items:center;gap:var(--space-3);background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-2) var(--space-4);flex:1;max-width:320px;display:flex}.table-search input{color:var(--text-primary);background:0 0;border:none;outline:none;width:100%;font-size:.875rem}.table-search input::placeholder{color:var(--text-muted)}table{border-collapse:collapse;width:100%}thead tr{border-bottom:1px solid var(--border)}th{padding:var(--space-3) var(--space-5);text-align:left;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;white-space:nowrap;font-size:.72rem;font-weight:600}td{padding:var(--space-4) var(--space-5);color:var(--text-primary);border-bottom:1px solid var(--border);font-size:.875rem}tbody tr:last-child td{border-bottom:none}tbody tr{transition:background var(--transition-fast)}tbody tr:hover{background:var(--bg-hover)}.table-empty{text-align:center;padding:var(--space-16) var(--space-8);color:var(--text-muted);font-size:.875rem}.alert-low{border-left:3px solid var(--sev-low)}.alert-medium{border-left:3px solid var(--sev-medium)}.alert-high{border-left:3px solid var(--sev-high)}.alert-critical{border-left:3px solid var(--sev-critical)}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;padding:var(--space-4);animation:fadeIn var(--transition-base);background:#000000bf;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-xl);padding:var(--space-6);width:100%;max-width:560px;max-height:90vh;animation:slideUp var(--transition-base);box-shadow:var(--shadow-lg);overflow-y:auto}.modal-header{margin-bottom:var(--space-6);justify-content:space-between;align-items:center;display:flex}.modal-title{color:var(--text-primary);font-size:1.1rem;font-weight:600}.modal-footer{justify-content:flex-end;gap:var(--space-3);margin-top:var(--space-6);padding-top:var(--space-5);border-top:1px solid var(--border);display:flex}.page-title{color:var(--text-primary);letter-spacing:-.02em;font-size:1.4rem;font-weight:700}.page-subtitle{color:var(--text-muted);margin-top:var(--space-1);font-size:.875rem}.divider{background:var(--border);height:1px;margin:var(--space-5) 0}.text-muted{color:var(--text-muted)}.text-secondary{color:var(--text-secondary)}.text-success{color:var(--success)}.text-warning{color:var(--warning)}.text-danger{color:var(--danger)}.text-accent{color:var(--accent-hover)}.text-mono{font-family:var(--font-mono);font-size:.85em}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-end{justify-content:flex-end}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.gap-6{gap:var(--space-6)}.w-full{width:100%}.mt-4{margin-top:var(--space-4)}.mt-6{margin-top:var(--space-6)}.mb-4{margin-bottom:var(--space-4)}.mb-6{margin-bottom:var(--space-6)}.ml-auto{margin-left:auto}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.animate-pulse{animation:2s infinite pulse}.skeleton{background:linear-gradient(90deg, var(--bg-hover) 25%, var(--border) 50%, var(--bg-hover) 75%);border-radius:var(--radius-md);background-size:200% 100%;animation:1.5s infinite shimmer}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--border-light);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}@media (max-width:768px){:root{--sidebar-width:0px}.sidebar{transform:translate(-240px)}.sidebar.open{width:240px;transform:translate(0)}.form-grid,.form-grid-3{grid-template-columns:1fr}.kpi-grid{grid-template-columns:repeat(2,1fr)}}.login-page{background:var(--bg-primary);justify-content:center;align-items:center;min-height:100vh;display:flex;position:relative;overflow:hidden}.login-bg-grid{background-image:linear-gradient(var(--border) 1px, transparent 1px), linear-gradient(90deg, var(--border) 1px, transparent 1px);opacity:.4;background-size:40px 40px;position:absolute;inset:0;-webkit-mask-image:radial-gradient(#000 40%,#0000 80%);mask-image:radial-gradient(#000 40%,#0000 80%)}.login-container{width:100%;max-width:420px;padding:var(--space-6);align-items:center;gap:var(--space-4);flex-direction:column;display:flex;position:relative}.login-logo{align-items:center;gap:var(--space-3);margin-bottom:var(--space-2);display:flex}.login-logo-icon{background:var(--accent);border-radius:var(--radius-lg);width:52px;height:52px;box-shadow:0 0 32px var(--accent-glow);justify-content:center;align-items:center;display:flex}.login-logo-text{letter-spacing:-.04em;color:var(--text-primary);font-size:2rem;font-weight:800}.login-logo-text span{color:var(--accent)}.login-tagline{color:var(--text-muted);margin-top:calc(-1 * var(--space-2));font-size:.875rem}.login-card{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-xl);padding:var(--space-8);width:100%;box-shadow:var(--shadow-lg)}.login-card-header{margin-bottom:var(--space-6)}.login-title{letter-spacing:-.02em;margin-bottom:var(--space-1);font-size:1.4rem;font-weight:700}.login-subtitle{color:var(--text-muted);font-size:.875rem}.login-form{gap:var(--space-4);flex-direction:column;display:flex}.input-icon-wrapper{position:relative}.input-icon{color:var(--text-muted);pointer-events:none;position:absolute;top:50%;left:14px;transform:translateY(-50%)}.input-icon-right{color:var(--text-muted);cursor:pointer;border-radius:var(--radius-sm);transition:color var(--transition-fast);background:0 0;border:none;align-items:center;padding:4px;display:flex;position:absolute;top:50%;right:12px;transform:translateY(-50%)}.input-icon-right:hover{color:var(--text-primary)}.form-input.with-icon{padding-left:42px}.form-input.with-icon-right{padding-right:40px}.login-error{align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);background:var(--danger-subtle);border:1px solid var(--danger);border-radius:var(--radius-md);color:var(--danger);font-size:.85rem;display:flex}.btn-spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:18px;height:18px;animation:.7s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.login-demo{margin-top:var(--space-6);padding-top:var(--space-5);border-top:1px solid var(--border)}.login-demo-title{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-bottom:var(--space-3);font-size:.72rem;font-weight:600}.login-demo-creds{gap:var(--space-2);flex-direction:column;font-size:.8rem;display:flex}.login-demo-label{color:var(--text-muted);margin-right:var(--space-2)}.login-demo-creds code{font-family:var(--font-mono);color:var(--accent-hover);font-size:.78rem}.sidebar-user{align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-2);border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast);display:flex}.sidebar-user:hover{background:var(--bg-hover)}.sidebar-avatar{background:var(--accent);border-radius:var(--radius-full);color:#fff;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:.85rem;font-weight:700;display:flex}.sidebar-user-info{flex:1;min-width:0;overflow:hidden}.sidebar-user-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:.825rem;font-weight:600;display:block;overflow:hidden}.sidebar-user-role{color:var(--text-muted);text-transform:capitalize;font-size:.7rem}.sidebar-chevron{color:var(--text-muted);transition:transform var(--transition-fast)}.sidebar-chevron.open{transform:rotate(180deg)}.sidebar-user-menu{gap:var(--space-1);margin-top:var(--space-2);padding:var(--space-2);background:var(--bg-hover);border-radius:var(--radius-md);border:1px solid var(--border);flex-direction:column;display:flex}.sidebar-user-menu-item{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;text-align:left;width:100%;transition:all var(--transition-fast);background:0 0;border:none;font-size:.825rem;display:flex}.sidebar-user-menu-item:hover{background:var(--border);color:var(--text-primary)}.sidebar-user-menu-item.danger:hover{background:var(--danger-subtle);color:var(--danger)}.header-left{align-items:center;gap:var(--space-4);display:flex}.header-right{align-items:center;gap:var(--space-3);display:flex}.header-date{color:var(--text-muted);padding:var(--space-2) var(--space-3);background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-md);white-space:nowrap;font-size:.78rem}.mobile-menu-btn{display:none}@media (max-width:768px){.mobile-menu-btn{display:flex}.header-date{display:none}}.dashboard-content{gap:var(--space-6);flex-direction:column;display:flex}.dashboard-toolbar{justify-content:space-between;align-items:center;display:flex}.dashboard-grid{gap:var(--space-5);grid-template-columns:1.6fr 1fr;display:grid}.dashboard-chart-card{min-height:280px}@media (max-width:900px){.dashboard-grid{grid-template-columns:1fr}}.alerts-list{gap:var(--space-2);flex-direction:column;display:flex}.alert-item{justify-content:space-between;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);background:var(--bg-hover);transition:background var(--transition-fast);border-left:3px solid #0000;display:flex}.alert-item:hover{background:var(--border)}.alert-item-info{flex-direction:column;gap:3px;min-width:0;display:flex}.alert-item-title{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:.85rem;font-weight:500;overflow:hidden}.alert-item-vehicle{color:var(--text-muted);font-size:.75rem}.fleet-grid{gap:var(--space-4);grid-template-columns:repeat(auto-fill,minmax(220px,1fr));display:grid}.fleet-card{background:var(--bg-hover);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-4);gap:var(--space-2);transition:all var(--transition-base);flex-direction:column;display:flex}.fleet-card:hover{border-color:var(--accent);box-shadow:var(--shadow-glow);transform:translateY(-2px)}.fleet-card-header{justify-content:space-between;align-items:center;display:flex}.fleet-plate{color:var(--accent-hover);font-size:.95rem;font-weight:700}.fleet-name{color:var(--text-secondary);font-size:.85rem;font-weight:500}.fleet-meta{margin-top:var(--space-1);justify-content:space-between;align-items:center;display:flex}.fleet-km{align-items:center;gap:var(--space-1);color:var(--text-muted);font-size:.75rem;display:flex}.fleet-driver{color:var(--text-muted);font-size:.72rem}.alerts-inbox{padding:var(--space-3);gap:var(--space-2);flex-direction:column;display:flex}.alert-inbox-item{justify-content:space-between;align-items:flex-start;gap:var(--space-4);padding:var(--space-4) var(--space-5);border-radius:var(--radius-lg);background:var(--bg-hover);transition:background var(--transition-fast);border-left:4px solid #0000;display:flex}.alert-inbox-item:hover{background:var(--border)}.alert-inbox-left{gap:var(--space-2);flex-direction:column;flex:1;min-width:0;display:flex}.alert-inbox-header{align-items:center;gap:var(--space-2);flex-wrap:wrap;display:flex}.alert-inbox-title{color:var(--text-primary);font-size:.9rem;font-weight:600}.alert-inbox-message{color:var(--text-secondary);font-size:.82rem;line-height:1.4}.alert-inbox-meta{align-items:center;gap:var(--space-2);flex-wrap:wrap;font-size:.75rem;display:flex}.alert-inbox-actions{align-items:center;gap:var(--space-2);flex-shrink:0;display:flex}.chart-tooltip{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);box-shadow:var(--shadow-md);font-size:.8rem}.chart-tooltip-label{color:var(--text-secondary);margin-bottom:var(--space-2);text-transform:capitalize;font-weight:600}.mobile-overlay{z-index:90;background:#0009;display:none;position:fixed;inset:0}@media (max-width:768px){.mobile-overlay{display:block}}.driver-action-card{padding:var(--space-6);background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);cursor:pointer;flex-direction:column;text-decoration:none;transition:transform .25s cubic-bezier(.4,0,.2,1),border-color .25s,box-shadow .25s;display:flex}.driver-action-card:hover{border-color:var(--accent-hover);box-shadow:0 12px 20px -8px #4f46e51f, var(--shadow-md);transform:translateY(-4px)scale(1.02)}.driver-action-card.fuel:hover{border-color:var(--warning);box-shadow:0 12px 20px -8px #f59e0b1f, var(--shadow-md)}.driver-action-card.maint:hover{box-shadow:0 12px 20px -8px #a855f71f, var(--shadow-md);border-color:#a855f7}.driver-action-card.alerts:hover{border-color:var(--danger);box-shadow:0 12px 20px -8px #ef44441f, var(--shadow-md)}
