@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";
:root{--navy-dark:#0f1e35;--navy-mid:#1a3a5c;--blue-action:#2563a8;--blue-light:#3b82c4;--bg-page:#f0f4f8;--bg-surface:#e8edf3;--white:#fff;--text-primary:#0f1e35;--text-secondary:#475569;--text-muted:#94a3b8;--text-disabled:#cbd5e1;--border-light:#e2e8f0;--border-mid:#cbd5e1;--green:#16a34a;--green-bg:#dcfce7;--amber:#d97706;--amber-bg:#fef3c7;--red:#dc2626;--red-bg:#fee2e2;--blue-info:#2563a8;--blue-bg:#dbeafe;--sidebar-w:220px;--topbar-h:52px;--detail-w:300px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;color:var(--text-primary);background:var(--bg-page);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;font-size:13px;line-height:1.5}.tabular-nums,.kpi-value,.km-value,[data-numeric]{font-variant-numeric:tabular-nums}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border-mid);border-radius:99px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}@keyframes pulse-badge{0%,to{opacity:1}50%{opacity:.55}}.pulse{animation:2s ease-in-out infinite pulse-badge}.app-shell{height:100vh;display:flex;overflow:hidden}.sidebar{width:var(--sidebar-w);min-width:var(--sidebar-w);background:var(--navy-dark);z-index:50;flex-direction:column;height:100vh;display:flex;position:fixed;top:0;left:0;overflow-y:auto}.sidebar-logo{align-items:center;gap:10px;padding:16px 14px 14px;display:flex}.sidebar-logo-icon{background:var(--blue-action);border-radius:5px;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;display:flex}.sidebar-logo-text{flex-direction:column;gap:1px;display:flex}.sidebar-logo-name{color:#fff;letter-spacing:.03em;font-size:13px;font-weight:700}.sidebar-logo-sub{text-transform:uppercase;letter-spacing:.08em;color:#ffffff59;font-size:10px;font-weight:500}.sidebar-divider{background:#ffffff14;height:1px;margin:0 14px}.sidebar-nav{flex-direction:column;flex:1;gap:2px;padding:8px 10px;display:flex}.sidebar-group-label{text-transform:uppercase;letter-spacing:.08em;color:#ffffff40;padding:10px 6px 4px;font-size:10px;font-weight:500}.sidebar-item{cursor:pointer;color:#ffffff8c;-webkit-user-select:none;user-select:none;border-radius:5px;align-items:center;gap:8px;padding:7px 10px;font-size:13px;font-weight:400;text-decoration:none;transition:background 80ms,color 80ms;display:flex}.sidebar-item:hover{color:#ffffffd9;background:#ffffff0f}.sidebar-item.active{background:var(--blue-action);color:#fff;font-weight:500}.sidebar-item-icon{opacity:.8;flex-shrink:0;width:15px;height:15px}.sidebar-item.active .sidebar-item-icon{opacity:1}.sidebar-item-label{flex:1}.sidebar-badge{color:#ffffffbf;text-align:center;background:#ffffff26;border-radius:999px;min-width:18px;padding:1px 6px;font-size:10px;font-weight:500}.sidebar-badge.alert{background:var(--red);color:#fff}.sidebar-footer{border-top:1px solid #ffffff14;align-items:center;gap:10px;padding:12px 14px;display:flex}.sidebar-avatar{background:var(--navy-mid);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:11px;font-weight:600;display:flex}.sidebar-user-name{color:#ffffffbf;font-size:12px;font-weight:500}.sidebar-user-role{color:#ffffff59;font-size:10.5px}.main-area{margin-left:var(--sidebar-w);flex-direction:column;flex:1;min-width:0;height:100vh;display:flex;overflow:hidden}.topbar{height:var(--topbar-h);min-height:var(--topbar-h);background:var(--white);border-bottom:1px solid var(--border-light);z-index:40;justify-content:space-between;align-items:center;padding:0 20px;display:flex}.breadcrumb{align-items:center;gap:6px;font-size:13px;display:flex}.breadcrumb-sep{color:var(--text-muted);font-size:12px}.breadcrumb-link{color:var(--text-muted)}.breadcrumb-current{color:var(--text-primary);font-weight:500}.topbar-actions{align-items:center;gap:8px;display:flex}.btn{cursor:pointer;white-space:nowrap;border:none;border-radius:4px;align-items:center;gap:6px;height:32px;padding:0 12px;font-family:inherit;font-size:13px;font-weight:500;transition:background 80ms;display:inline-flex}.btn-primary{background:var(--blue-action);color:#fff}.btn-primary:hover{background:#1e4f8c}.btn-ghost{color:var(--text-secondary);border:1px solid var(--border-mid);background:0 0}.btn-ghost:hover{background:var(--bg-surface)}.btn-icon{width:26px;height:26px;color:var(--text-muted);cursor:pointer;background:0 0;border:1px solid #0000;border-radius:4px;justify-content:center;align-items:center;padding:0;transition:background 80ms,color 80ms;display:inline-flex}.btn-icon:hover{background:var(--bg-surface);color:var(--text-secondary);border-color:var(--border-light)}.btn-notif{border:1px solid var(--border-light);width:32px;height:32px;color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:4px;justify-content:center;align-items:center;padding:0;transition:background 80ms;display:flex;position:relative}.btn-notif:hover{background:var(--bg-surface)}.notif-badge{background:var(--red);border:1.5px solid var(--white);border-radius:50%;width:7px;height:7px;position:absolute;top:4px;right:4px}.content-area{flex:1;min-width:0;display:flex;overflow-y:auto}.content-main{flex:1;min-width:0;padding:20px;overflow-x:hidden}.section-header{margin-bottom:16px}.section-title{color:var(--text-primary);font-size:16px;font-weight:600}.section-sub{color:var(--text-muted);margin-top:2px;font-size:12px}.kpi-grid{grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:16px;display:grid}.kpi-card{background:var(--white);border:1px solid var(--border-light);border-radius:6px;padding:14px 16px}.kpi-label{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-bottom:6px;font-size:10px;font-weight:500}.kpi-value{color:var(--text-primary);font-variant-numeric:tabular-nums;font-size:22px;font-weight:700;line-height:1.1}.kpi-value.green{color:var(--green)}.kpi-value.amber{color:var(--amber)}.kpi-value.red{color:var(--red)}.kpi-sub{color:var(--text-muted);margin-top:4px;font-size:11px}.kpi-sub.green{color:var(--green)}.kpi-sub.amber{color:var(--amber)}.kpi-sub.red{color:var(--red)}.panel{background:var(--white);border:1px solid var(--border-light);border-radius:8px;overflow:hidden}.tab-bar{border-bottom:1px solid var(--border-light);align-items:stretch;gap:0;padding:0 16px;display:flex}.tab{color:var(--text-muted);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px;padding:12px 14px 11px;font-family:inherit;font-size:13px;font-weight:400;transition:color 80ms}.tab:hover{color:var(--text-secondary)}.tab.active{color:var(--blue-action);border-bottom-color:var(--blue-action);font-weight:500}.toolbar{border-bottom:1px solid var(--border-light);flex-wrap:wrap;align-items:center;gap:8px;padding:10px 16px;display:flex}.search-input-wrap{flex:1;max-width:260px;position:relative}.search-icon{color:var(--text-muted);width:14px;height:14px;position:absolute;top:50%;left:9px;transform:translateY(-50%)}.search-input{border:1px solid var(--border-mid);background:var(--bg-page);width:100%;height:32px;color:var(--text-primary);border-radius:4px;outline:none;padding:0 10px 0 30px;font-family:inherit;font-size:13px;transition:border 80ms,background 80ms,box-shadow 80ms}.search-input::placeholder{color:var(--text-muted)}.search-input:focus{border:2px solid var(--blue-action);background:var(--white);box-shadow:0 0 0 3px #2563a81f}.select-filter{border:1px solid var(--border-mid);background:var(--bg-page);height:32px;color:var(--text-secondary);cursor:pointer;border-radius:4px;outline:none;padding:0 10px;font-family:inherit;font-size:13px;transition:border 80ms}.select-filter:focus{border-color:var(--blue-action)}.toolbar-count{color:var(--text-muted);white-space:nowrap;margin-left:auto;font-size:12px}.data-table{border-collapse:collapse;width:100%}.data-table thead th{background:var(--bg-surface);text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);text-align:left;border-bottom:1px solid var(--border-light);white-space:nowrap;padding:9px 14px;font-size:11px;font-weight:600}.data-table thead th:first-child{width:36px}.data-table tbody tr{border-bottom:1px solid var(--border-light);cursor:pointer;transition:background 80ms}.data-table tbody tr:last-child{border-bottom:none}.data-table tbody tr:hover{background:#f8fafc}.data-table tbody tr.selected{background:var(--blue-bg);border-left:2px solid var(--blue-action)}.data-table tbody td{color:var(--text-secondary);vertical-align:middle;padding:11px 14px;font-size:13px}.row-checkbox{opacity:0;transition:opacity 80ms}.data-table tbody tr:hover .row-checkbox,.data-table tbody tr.selected .row-checkbox{opacity:1}input[type=checkbox]{cursor:pointer;width:14px;height:14px}.vehicle-cell{align-items:center;gap:10px;display:flex}.vehicle-icon{background:var(--bg-surface);border:1px solid var(--border-light);width:32px;height:32px;color:var(--text-secondary);border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.vehicle-name{color:var(--text-primary);font-size:13px;font-weight:500}.vehicle-plate{color:var(--text-muted);font-family:Courier New,monospace;font-size:11px}.driver-cell{align-items:center;gap:7px;display:flex}.driver-avatar{background:var(--navy-mid);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;font-size:9px;font-weight:600;display:flex}.badge{white-space:nowrap;border-radius:999px;align-items:center;gap:5px;padding:2px 8px;font-size:11px;font-weight:500;display:inline-flex}.badge-dot{border-radius:50%;flex-shrink:0;width:6px;height:6px}.badge-green{background:var(--green-bg);color:#15803d}.badge-green .badge-dot{background:var(--green)}.badge-amber{background:var(--amber-bg);color:#b45309}.badge-amber .badge-dot{background:var(--amber)}.badge-red{background:var(--red-bg);color:var(--red)}.badge-red .badge-dot{background:var(--red)}.badge-gray{background:var(--bg-surface);color:var(--text-muted)}.badge-gray .badge-dot{background:var(--border-mid)}.badge-blue{background:var(--blue-bg);color:var(--blue-action)}.fuel-cell{align-items:center;gap:8px;display:flex}.fuel-bar-wrap{background:var(--bg-surface);border-radius:99px;width:60px;height:4px;overflow:hidden}.fuel-bar{border-radius:99px;height:100%}.fuel-bar.green{background:var(--green)}.fuel-bar.amber{background:var(--amber)}.fuel-bar.red{background:var(--red)}.fuel-pct{color:var(--text-muted);font-variant-numeric:tabular-nums;font-size:12px}.revision-text{font-size:12px;font-weight:500}.revision-text.green{color:var(--green)}.revision-text.amber{color:var(--amber)}.revision-text.red{color:var(--red)}.km-value{color:var(--text-primary);font-variant-numeric:tabular-nums;font-size:13px;font-weight:500}.row-actions{align-items:center;gap:4px;display:flex}.pagination{border-top:1px solid var(--border-light);justify-content:space-between;align-items:center;padding:10px 16px;display:flex}.pagination-info{color:var(--text-muted);font-size:12px}.pagination-btns{align-items:center;gap:4px;display:flex}.page-btn{border:1px solid var(--border-light);width:28px;height:28px;color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:3px;justify-content:center;align-items:center;font-family:inherit;font-size:12px;transition:background 80ms;display:flex}.page-btn:hover{background:var(--bg-surface)}.page-btn.active{background:var(--blue-action);color:#fff;border-color:var(--blue-action)}.page-btn:disabled{opacity:.4;cursor:not-allowed}.detail-panel{width:var(--detail-w);min-width:var(--detail-w);background:var(--white);border-left:1px solid var(--border-light);flex-direction:column;height:100%;display:flex;overflow-y:auto}.detail-panel-header{border-bottom:1px solid var(--border-light);justify-content:space-between;align-items:center;padding:14px 16px 10px;display:flex}.detail-panel-title{color:var(--text-primary);font-size:13px;font-weight:600}.detail-vehicle-info{border-bottom:1px solid var(--border-light);align-items:center;gap:12px;padding:14px 16px;display:flex}.detail-vehicle-icon{background:var(--navy-dark);color:#fff;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:42px;height:42px;display:flex}.detail-vehicle-name{color:var(--text-primary);font-size:14px;font-weight:600}.detail-vehicle-sub{color:var(--text-muted);margin-top:2px;font-size:11.5px}.detail-section{border-bottom:1px solid var(--border-light);padding:14px 16px}.detail-section-label{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-bottom:10px;font-size:10px;font-weight:500}.detail-row{justify-content:space-between;align-items:flex-start;gap:8px;margin-bottom:8px;display:flex}.detail-row:last-child{margin-bottom:0}.detail-row-label{color:var(--text-muted);white-space:nowrap;font-size:12px}.detail-row-value{color:var(--text-primary);text-align:right;font-size:12px;font-weight:500}.detail-row-value.mono{font-family:Courier New,monospace;font-size:11px}.driver-chip{background:var(--bg-page);border-radius:5px;align-items:center;gap:9px;padding:8px 10px;display:flex}.driver-chip-avatar{background:var(--navy-mid);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:10px;font-weight:600;display:flex}.driver-chip-name{color:var(--text-primary);font-size:13px;font-weight:500}.driver-chip-sub{color:var(--text-muted);font-size:11px}.progress-row{margin-top:8px}.progress-meta{color:var(--text-muted);justify-content:space-between;margin-bottom:4px;font-size:11px;display:flex}.progress-bar-wrap{background:var(--bg-surface);border-radius:99px;height:6px;overflow:hidden}.progress-bar{border-radius:99px;height:100%}.progress-bar.green{background:var(--green)}.progress-bar.amber{background:var(--amber)}.progress-bar.red{background:var(--red)}.doc-item{border-bottom:1px solid var(--border-light);align-items:center;gap:10px;padding:8px 0;display:flex}.doc-item:last-child{border-bottom:none;padding-bottom:0}.doc-icon{background:var(--bg-surface);width:26px;height:26px;color:var(--text-muted);border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.doc-name{color:var(--text-primary);font-size:12px;font-weight:500}.doc-date{color:var(--text-muted);font-size:11px}.doc-badge{margin-left:auto}.detail-footer{border-top:1px solid var(--border-light);gap:8px;margin-top:auto;padding:12px 16px;display:flex}.detail-footer .btn{flex:1;justify-content:center}.modal-overlay{z-index:100;background:#00000073;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal-card{background:var(--white);border-radius:8px;flex-direction:column;width:100%;max-width:560px;max-height:90vh;display:flex;overflow-y:auto}.modal-header{border-bottom:1px solid var(--border-light);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.modal-title{color:var(--text-primary);font-size:16px;font-weight:600}.modal-body{flex:1;padding:20px}.form-section-label{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);border-bottom:1px solid var(--border-light);margin-bottom:12px;padding-bottom:6px;font-size:10px;font-weight:500}.form-grid{grid-template-columns:1fr 1fr;gap:12px 16px;margin-bottom:20px;display:grid}.form-group{flex-direction:column;gap:4px;display:flex}.form-group.full{grid-column:1/-1}.form-label{color:var(--text-secondary);font-size:12px;font-weight:500}.form-label .required{color:var(--red);margin-left:2px}.form-input,.form-select{border:1px solid var(--border-mid);background:var(--bg-page);height:36px;color:var(--text-primary);border-radius:4px;outline:none;width:100%;padding:0 12px;font-family:inherit;font-size:13px;transition:border 80ms,background 80ms,box-shadow 80ms}.form-input::placeholder{color:var(--text-muted)}.form-input:focus,.form-select:focus{border:2px solid var(--blue-action);background:var(--white);box-shadow:0 0 0 3px #2563a81f}.doc-upload-row{border-bottom:1px solid var(--border-light);align-items:center;gap:10px;padding:8px 0;display:flex}.doc-upload-row:last-child{border-bottom:none}.doc-upload-label{color:var(--text-secondary);flex:1;min-width:120px;font-size:13px;font-weight:500}.doc-upload-btn{border:1px solid var(--border-mid);background:var(--bg-page);height:32px;color:var(--text-secondary);cursor:pointer;white-space:nowrap;border-radius:4px;align-items:center;gap:5px;padding:0 10px;font-family:inherit;font-size:12px;display:flex}.doc-upload-btn:hover{background:var(--bg-surface)}.doc-upload-date{flex:1;max-width:140px}.doc-upload-date input{border:1px solid var(--border-mid);background:var(--bg-page);width:100%;height:32px;color:var(--text-secondary);border-radius:4px;outline:none;padding:0 8px;font-family:inherit;font-size:12px}.doc-upload-date input:focus{border-color:var(--blue-action)}.modal-footer{border-top:1px solid var(--border-light);justify-content:flex-end;gap:8px;padding:14px 20px;display:flex}.sidebar-toggle-btn,.sidebar-close-btn{display:none}@media (max-width:1280px){.sidebar{transition:transform .2s;transform:translate(-100%)}.sidebar.open{transform:translate(0)}.main-area{margin-left:0}.kpi-grid{grid-template-columns:repeat(2,1fr)}.detail-panel{display:none}.topbar{padding-left:56px}.sidebar-toggle-btn{background:var(--white);border:1px solid var(--border-mid);width:36px;height:36px;color:var(--text-primary);cursor:pointer;z-index:44;border-radius:4px;justify-content:center;align-items:center;transition:background 80ms,border-color 80ms;display:flex;position:fixed;top:8px;left:8px;box-shadow:0 1px 3px #0000000d}.sidebar-toggle-btn:hover{background:var(--bg-surface)}.sidebar-close-btn{color:#ffffff8c;cursor:pointer;background:#ffffff14;border:none;border-radius:4px;justify-content:center;align-items:center;width:28px;height:28px;transition:background 80ms,color 80ms;display:flex;position:absolute;top:12px;right:12px}.sidebar-close-btn:hover{color:#fff;background:#ffffff26}}.notif-container{display:inline-block;position:relative}.notif-dropdown{background:var(--white);border:1px solid var(--border-light);z-index:100;box-sizing:border-box;border-radius:8px;flex-direction:column;width:320px;max-height:400px;display:flex;position:absolute;top:calc(100% + 6px);right:0}.notif-header{border-bottom:1px solid var(--border-light);justify-content:space-between;align-items:center;padding:10px 12px;display:flex}.notif-title{color:var(--text-primary);font-size:12px;font-weight:600}.notif-clear-btn{color:var(--blue-action);cursor:pointer;background:0 0;border:none;border-radius:3px;padding:2px 4px;font-size:11px;font-weight:500;transition:color 80ms,background-color 80ms}.notif-clear-btn:hover{color:var(--blue-light);background-color:var(--bg-page)}.notif-list{flex-direction:column;flex:1;max-height:320px;display:flex;overflow-y:auto}.notif-item{border-bottom:1px solid var(--border-light);cursor:pointer;gap:10px;padding:10px 12px;text-decoration:none;transition:background-color 80ms;display:flex;position:relative}.notif-item:hover{background-color:var(--bg-page)}.notif-item.unread{background-color:#f8fafc}.notif-item:before{content:"";width:3px;position:absolute;top:0;bottom:0;left:0}.notif-item.info:before{background-color:var(--blue-info)}.notif-item.success:before{background-color:var(--green)}.notif-item.warning:before{background-color:var(--amber)}.notif-item.critical:before{background-color:var(--red)}.notif-item-content{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.notif-item-header{justify-content:space-between;align-items:baseline;gap:4px;display:flex}.notif-item-title{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:11.5px;font-weight:600;overflow:hidden}.notif-item-time{color:var(--text-muted);white-space:nowrap;flex-shrink:0;font-size:10px}.notif-item-message{color:var(--text-secondary);word-wrap:break-word;font-size:11px;line-height:1.4}.notif-read-dot{background-color:var(--blue-action);border-radius:50%;flex-shrink:0;width:6px;height:6px;margin-top:4px}.notif-read-dot.critical{background-color:var(--red)}.notif-empty{text-align:center;color:var(--text-muted);padding:24px;font-size:12px}
