@import "https://fonts.googleapis.com/css2?family=Rajdhani:wght@400;500;600;700&family=Inter:wght@400;500;600;700&display=swap";:root{--slate-950:#0a0c10;--slate-900:#111318;--slate-800:#1a1d24;--slate-700:#282d38;--slate-600:#3d4451;--slate-500:#5a6377;--slate-400:#8b95a8;--slate-300:#b4bcc9;--slate-200:#d8dce4;--slate-100:#eef0f4;--slate-50:#f7f8fa;--safety-green:#22c55e;--safety-green-dim:#166534;--safety-red:#ef4444;--safety-red-dim:#991b1b;--safety-amber:#f59e0b;--safety-amber-dim:#92400e;--accent:#f97316;--accent-bright:#fb923c;--accent-dim:#c2410c;--bg-primary:var(--slate-50);--bg-secondary:#fff;--bg-elevated:#fff;--text-primary:var(--slate-900);--text-secondary:var(--slate-600);--text-muted:var(--slate-400);--border:var(--slate-200);--border-focus:var(--slate-800);--font-industrial:"Rajdhani", "Inter", system-ui, sans-serif;--font-sans:"Inter", -apple-system, BlinkMacSystemFont, sans-serif;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:20px;--space-6:24px;--space-8:32px;--touch-min:48px;--touch-preferred:52px;--radius:4px;--radius-lg:8px;--tab-bar-height:64px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:transparent;scroll-behavior:smooth;overflow-x:hidden}body{font-family:var(--font-industrial);color:var(--text-primary);background:var(--bg-primary);min-height:100vh;background-image:linear-gradient(var(--slate-100) 1px, transparent 1px), linear-gradient(90deg, var(--slate-100) 1px, transparent 1px);background-position:-1px -1px;background-size:24px 24px;min-height:100dvh;font-size:16px;font-weight:500;line-height:1.5;overflow-x:hidden}.app{min-height:100vh;flex-direction:column;min-height:100dvh;display:flex}.main-content{width:100%;max-width:640px;padding-bottom:calc(var(--tab-bar-height) + env(safe-area-inset-bottom) + var(--space-4));flex:1;margin:0 auto;overflow-x:hidden}.header{z-index:100;background:var(--slate-900);color:#fff;padding:var(--space-3) var(--space-4);padding-top:calc(var(--space-3) + env(safe-area-inset-top));border-bottom:3px solid var(--accent);justify-content:space-between;align-items:center;display:flex;position:sticky;top:0}.header-left{align-items:baseline;gap:var(--space-2);display:flex}.header-title{font-family:var(--font-industrial);letter-spacing:1px;text-transform:uppercase;color:#fff;font-size:18px;font-weight:700}.header-version{font-family:var(--font-industrial);color:var(--slate-400);letter-spacing:.5px;font-size:10px;font-weight:500}.header-right{align-items:center;gap:var(--space-3);display:flex}.province-badge{padding:var(--space-1) var(--space-3);background:var(--accent);font-family:var(--font-industrial);letter-spacing:1px;color:#fff;cursor:pointer;border:none;border-radius:2px;justify-content:center;align-items:center;min-width:44px;min-height:32px;font-size:14px;font-weight:700;transition:all .15s;display:flex}.province-badge:hover{background:var(--accent-bright)}.province-badge:active{transform:scale(.95)}.status-badge{align-items:center;gap:var(--space-2);padding:var(--space-1) var(--space-3);font-family:var(--font-industrial);letter-spacing:.5px;text-transform:uppercase;border:none;border-radius:2px;font-size:13px;font-weight:700;display:flex}.status-badge.online{background:var(--safety-green);color:#fff}.status-badge.offline{background:var(--safety-red);color:#fff}.status-dot{background:currentColor;border-radius:50%;width:6px;height:6px;animation:2s ease-in-out infinite pulse-dot}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.4}}.province-selector{background:var(--bg-secondary);border-bottom:1px solid var(--border);animation:.2s slideDown}.province-selector-header{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;display:flex}.province-selector-title{font-family:var(--font-industrial);text-transform:uppercase;letter-spacing:1px;color:var(--text-secondary);font-size:13px;font-weight:700}.province-selector-close{width:32px;height:32px;color:var(--text-muted);cursor:pointer;border-radius:var(--radius);background:0 0;border:none;justify-content:center;align-items:center;transition:all .15s;display:flex}.province-selector-close:hover{background:var(--slate-100);color:var(--text-secondary)}.province-selector-grid{gap:var(--space-2);padding:var(--space-3) var(--space-4);-webkit-overflow-scrolling:touch;scrollbar-width:none;display:flex;overflow-x:auto}.province-selector-grid::-webkit-scrollbar{display:none}.province-option{padding:var(--space-2) var(--space-1);background:var(--slate-50);border:2px solid var(--border);border-radius:var(--radius);cursor:pointer;min-height:var(--touch-min);flex-direction:column;flex:1 0 56px;align-items:center;gap:2px;transition:all .15s;display:flex}.province-option:hover{border-color:var(--slate-300)}.province-option:active{transform:scale(.95)}.province-option.active{background:var(--slate-900);border-color:var(--slate-900);color:#fff}.province-option-code{font-family:var(--font-industrial);letter-spacing:1px;font-size:16px;font-weight:700}.province-option-name{text-transform:uppercase;letter-spacing:.3px;opacity:.7;white-space:nowrap;text-overflow:ellipsis;max-width:100%;font-size:9px;font-weight:600;overflow:hidden}.bottom-tabs{z-index:100;height:var(--tab-bar-height);padding-bottom:env(safe-area-inset-bottom);background:var(--slate-900);border-top:1px solid var(--slate-700);align-items:stretch;display:flex;position:fixed;bottom:0;left:0;right:0}.bottom-tab{justify-content:center;align-items:center;gap:var(--space-1);padding:var(--space-2);color:var(--slate-400);cursor:pointer;background:0 0;border:none;flex-direction:column;flex:1;transition:all .15s;display:flex;position:relative}.bottom-tab:active{transform:scale(.95)}.bottom-tab.active{color:var(--accent)}.bottom-tab.active:before{content:"";background:var(--accent);border-radius:0 0 2px 2px;height:3px;position:absolute;top:0;left:25%;right:25%}.bottom-tab-label{font-family:var(--font-industrial);letter-spacing:.5px;text-transform:uppercase;font-size:11px;font-weight:600}.tab-content{padding:var(--space-4)}.tab-placeholder{text-align:center;min-height:50vh;color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;display:flex}.tab-placeholder h2{font-family:var(--font-industrial);text-transform:uppercase;letter-spacing:1px;color:var(--text-secondary);margin-bottom:var(--space-2);font-size:24px;font-weight:700}.tab-placeholder p{max-width:280px;font-size:14px}.sub-nav{gap:var(--space-2);padding:var(--space-3) var(--space-4);-webkit-overflow-scrolling:touch;scrollbar-width:none;background:var(--bg-secondary);border-bottom:1px solid var(--border);display:flex;overflow-x:auto}.sub-nav::-webkit-scrollbar{display:none}.sub-nav-btn{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--slate-50);border:1px solid var(--border);border-radius:var(--radius);font-family:var(--font-industrial);color:var(--text-secondary);cursor:pointer;white-space:nowrap;font-size:13px;font-weight:600;transition:all .15s;display:flex}.sub-nav-btn:hover{border-color:var(--slate-300)}.sub-nav-btn.active{background:var(--slate-900);border-color:var(--slate-900);color:#fff}.expandable-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:var(--space-2);overflow:hidden}.expandable-card-header{width:100%;padding:var(--space-3) var(--space-4);cursor:pointer;text-align:left;min-height:var(--touch-min);background:0 0;border:none;justify-content:space-between;align-items:center;transition:background .15s;display:flex}.expandable-card-header:hover{background:var(--slate-50)}.expandable-card-title{font-family:var(--font-industrial);color:var(--text-primary);flex:1;font-size:15px;font-weight:700}.expandable-card-chevron{color:var(--text-muted);flex-shrink:0;transition:transform .2s}.expandable-card-chevron.open{transform:rotate(180deg)}.expandable-card-body{padding:0 var(--space-4) var(--space-4);animation:.2s slideDown}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.province-deviation-badge{align-items:center;gap:var(--space-1);font-family:var(--font-industrial);letter-spacing:.5px;text-transform:uppercase;white-space:nowrap;border-radius:2px;padding:2px 8px;font-size:11px;font-weight:700;display:inline-flex}.province-deviation-badge.major{color:var(--safety-red);background:#ef44441a;border:1px solid #ef44444d}.province-deviation-badge.minor{color:var(--safety-amber-dim);background:#f59e0b1a;border:1px solid #f59e0b4d}.province-deviation-badge.info{color:#1d4ed8;background:#3b82f61a;border:1px solid #3b82f64d}.defect-section{margin-bottom:var(--space-3)}.defect-section:last-child{margin-bottom:0}.defect-label{font-family:var(--font-industrial);text-transform:uppercase;letter-spacing:.5px;margin-bottom:var(--space-2);padding:var(--space-1) var(--space-2);border-radius:2px;font-size:11px;font-weight:700;display:inline-block}.defect-label.minor{color:var(--safety-amber-dim);background:#f59e0b1a}.defect-label.major{color:var(--safety-red);background:#ef44441a}.defect-list{padding:0;list-style:none}.defect-list li{padding:var(--space-1) 0 var(--space-1) var(--space-5);color:var(--text-secondary);font-size:14px;line-height:1.4;position:relative}.defect-list li:before{content:"";left:var(--space-2);background:var(--slate-300);border-radius:50%;width:5px;height:5px;position:absolute;top:10px}.link-list{margin:0;padding:0;list-style:none}.link-list li{align-items:center;gap:var(--space-2);padding:var(--space-1) 0;display:flex}.data-table-wrapper{-webkit-overflow-scrolling:touch;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-secondary);overflow-x:auto}.data-table{border-collapse:collapse;width:100%;font-size:14px}.data-table th{background:var(--slate-100);font-family:var(--font-industrial);text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary);padding:var(--space-3) var(--space-3);text-align:left;white-space:nowrap;border-bottom:2px solid var(--border);font-size:12px;font-weight:700;position:sticky;top:0}.data-table td{padding:var(--space-3) var(--space-3);border-bottom:1px solid var(--border);color:var(--text-primary)}.data-table tr:last-child td{border-bottom:none}.data-table th:first-child,.data-table td:first-child{z-index:1;background:inherit;position:sticky;left:0}.data-table th:first-child{background:var(--slate-100);z-index:2}.data-table td:first-child{background:var(--bg-secondary);font-weight:600}.data-table th.highlight,.data-table td.highlight{background:#f973160f}.data-table th.highlight{color:var(--accent-dim)}.calc-form{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius);padding:var(--space-4);overflow:hidden}.calc-group{margin-bottom:var(--space-4)}.calc-group:last-child{margin-bottom:0}.calc-label{font-family:var(--font-industrial);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:var(--space-2);font-size:13px;font-weight:700;display:block}.calc-input{width:100%;min-width:0;min-height:var(--touch-preferred);padding:var(--space-3) var(--space-4);font-family:var(--font-industrial);color:var(--text-primary);background:var(--bg-secondary);border:2px solid var(--border);border-radius:var(--radius);font-size:18px;font-weight:600;transition:all .15s}.calc-input:focus{border-color:var(--slate-800);outline:none;box-shadow:0 0 0 3px #1a1d241a}.calc-input::placeholder{color:var(--text-muted);font-weight:500}.calc-input[type=date]{-webkit-appearance:none;appearance:none;max-width:100%;height:var(--touch-preferred)}.calc-row{gap:var(--space-3);margin-bottom:var(--space-4);grid-template-columns:1fr 1fr;display:grid}.calc-row>.calc-group{margin-bottom:0}.calc-row>*{min-width:0}@media (max-width:400px){.calc-row{row-gap:var(--space-4);grid-template-columns:1fr}}.calc-toggle{align-items:center;gap:var(--space-3);padding:var(--space-3);background:var(--slate-50);border:2px solid var(--border);border-radius:var(--radius);cursor:pointer;min-height:var(--touch-min);font-family:var(--font-industrial);color:var(--text-secondary);font-size:15px;font-weight:600;transition:all .15s;display:flex}.calc-toggle.active{background:var(--slate-900);border-color:var(--slate-900);color:#fff}.calc-results{background:var(--slate-900);border-radius:var(--radius);padding:var(--space-4);margin-top:var(--space-4)}.calc-result-row{padding:var(--space-2) 0;border-bottom:1px solid var(--slate-700);justify-content:space-between;align-items:center;display:flex}.calc-result-row:last-child{border-bottom:none}.calc-result-label{font-family:var(--font-industrial);color:var(--slate-400);text-transform:uppercase;letter-spacing:.5px;font-size:13px;font-weight:600}.calc-result-value{font-family:var(--font-industrial);color:#fff;font-size:18px;font-weight:700}.calc-warning{border:1px solid #f59e0b59;border-left:3px solid var(--safety-amber);border-radius:var(--radius);color:var(--text-secondary);margin-bottom:var(--space-3);padding:var(--space-3);background:#f59e0b1a;font-size:13px;line-height:1.45}.pass-fail-badge{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);border-radius:var(--radius);font-family:var(--font-industrial);letter-spacing:1px;text-transform:uppercase;font-size:16px;font-weight:700;display:inline-flex}.pass-fail-badge.pass{background:var(--safety-green);color:#fff}.pass-fail-badge.fail{background:var(--safety-red);color:#fff}.unit-toggle{border:2px solid var(--border);border-radius:var(--radius);display:inline-flex;overflow:hidden}.unit-toggle-btn{padding:var(--space-1) var(--space-3);background:var(--bg-secondary);font-family:var(--font-industrial);color:var(--text-secondary);cursor:pointer;text-transform:uppercase;letter-spacing:.5px;border:none;font-size:12px;font-weight:700;transition:all .15s}.unit-toggle-btn.active{background:var(--slate-900);color:#fff}.unit-toggle-btn:not(:last-child){border-right:1px solid var(--border)}.setup-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius);padding:var(--space-4);margin-bottom:var(--space-3);cursor:pointer;transition:all .15s}.setup-card:hover{border-color:var(--slate-300);box-shadow:0 2px 8px #0000000f}.setup-card:active{transform:scale(.99)}.setup-card-title{font-family:var(--font-industrial);color:var(--text-primary);margin-bottom:var(--space-1);font-size:16px;font-weight:700}.setup-card-desc{color:var(--text-secondary);font-size:13px;line-height:1.4}.setup-card-meta{gap:var(--space-2);margin-top:var(--space-2);flex-wrap:wrap;display:flex}.setup-card-tag{font-family:var(--font-industrial);background:var(--slate-100);color:var(--text-muted);text-transform:uppercase;letter-spacing:.3px;border-radius:2px;padding:2px 8px;font-size:11px;font-weight:600}.condition-card{background:var(--bg-secondary);border:1px solid var(--border);border-left:3px solid var(--safety-red);border-radius:var(--radius);padding:var(--space-4);margin-bottom:var(--space-3)}.condition-card-title{font-family:var(--font-industrial);color:var(--text-primary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:var(--space-2);font-size:14px;font-weight:700}.rules-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.rules-card-header{background:var(--slate-900);color:#fff;padding:var(--space-3) var(--space-4);justify-content:space-between;align-items:center;display:flex}.rules-card-province{font-family:var(--font-industrial);letter-spacing:1px;font-size:18px;font-weight:700}.rules-card-reg{color:var(--slate-400);font-size:12px}.rules-card-body{padding:var(--space-4)}.rules-row{padding:var(--space-3) 0;border-bottom:1px solid var(--border);justify-content:space-between;align-items:flex-start;gap:var(--space-3);display:flex}.rules-row:last-child{border-bottom:none}.rules-label{font-family:var(--font-industrial);color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;flex-shrink:0;min-width:120px;font-size:12px;font-weight:700}.rules-value{color:var(--text-primary);text-align:right;font-size:14px;line-height:1.4}.dvir-item{align-items:flex-start;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--border);display:flex}.dvir-item:last-child{border-bottom:none}.dvir-number{background:var(--slate-100);border-radius:var(--radius);width:28px;height:28px;font-family:var(--font-industrial);color:var(--accent);flex-shrink:0;justify-content:center;align-items:center;font-size:13px;font-weight:700;display:flex}.dvir-text{color:var(--text-primary);padding-top:3px;font-size:14px;line-height:1.5}.connectivity-badge{align-items:center;gap:var(--space-1);font-family:var(--font-industrial);text-transform:uppercase;letter-spacing:.5px;border-radius:2px;padding:2px 6px;font-size:10px;font-weight:600;display:inline-flex}.connectivity-badge.requires-online{color:var(--safety-red);background:#ef44441a}.connectivity-badge.available{color:var(--safety-green);background:#22c55e1a}.spring-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius);padding:var(--space-4);margin-bottom:var(--space-3)}.spring-card-header{margin-bottom:var(--space-3);justify-content:space-between;align-items:center;display:flex}.spring-card-province{font-family:var(--font-industrial);color:var(--text-primary);font-size:16px;font-weight:700}.spring-card-window{font-family:var(--font-industrial);color:var(--safety-amber-dim);background:#f59e0b1a;border-radius:2px;padding:2px 8px;font-size:12px;font-weight:600}.spring-card-detail{color:var(--text-secondary);margin-bottom:var(--space-2);font-size:14px;line-height:1.4}.spring-card-link{align-items:center;gap:var(--space-1);font-family:var(--font-industrial);color:var(--accent);font-size:13px;font-weight:600;text-decoration:none;display:inline-flex}.spring-card-link:hover{text-decoration:underline}.section-header{font-family:var(--font-industrial);text-transform:uppercase;letter-spacing:1px;color:var(--text-muted);padding:var(--space-4) var(--space-4) var(--space-2);font-size:12px;font-weight:700}.toast{bottom:calc(var(--tab-bar-height) + var(--space-4) + env(safe-area-inset-bottom));padding:var(--space-3) var(--space-5);background:var(--slate-900);color:#fff;font-family:var(--font-industrial);border-radius:var(--radius);border-left:3px solid var(--accent);z-index:1000;opacity:0;visibility:hidden;max-width:calc(100% - var(--space-8));font-size:13px;font-weight:500;transition:all .3s;position:fixed;left:50%;transform:translate(-50%)}.toast.visible{opacity:1;visibility:visible}.toast.success{border-left-color:var(--safety-green)}.toast.error{border-left-color:var(--safety-red)}.visually-hidden{clip:rect(0, 0, 0, 0);border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.selector-grid{gap:var(--space-2);grid-template-columns:repeat(2,1fr);display:grid}.selector-option{padding:var(--space-3);background:var(--bg-secondary);border:2px solid var(--border);border-radius:var(--radius);cursor:pointer;min-height:var(--touch-min);font-family:var(--font-industrial);flex-direction:column;align-items:center;gap:2px;transition:all .15s;display:flex}.selector-option:hover{border-color:var(--slate-300)}.selector-option.active{background:var(--slate-900);border-color:var(--slate-900);color:#fff}.selector-option-label{font-size:14px;font-weight:700}.selector-option-detail{opacity:.7;font-size:11px;font-weight:500}.divider{background:var(--border);height:1px;margin:var(--space-4) 0}.calc-history{margin-top:var(--space-4)}.calc-history-title{font-family:var(--font-industrial);text-transform:uppercase;letter-spacing:1px;color:var(--text-muted);margin-bottom:var(--space-2);font-size:12px;font-weight:700}.calc-history-item{padding:var(--space-2) var(--space-3);background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:var(--space-1);cursor:pointer;justify-content:space-between;align-items:center;font-size:13px;transition:background .15s;display:flex}.calc-history-item:hover{background:var(--slate-50)}.reinspection-banner{background:#f59e0b14;border-bottom:1px solid #f59e0b33}.reinspection-banner-header{justify-content:space-between;align-items:center;gap:var(--space-2);width:100%;padding:var(--space-2) var(--space-4);cursor:pointer;font-family:var(--font-industrial);color:var(--safety-amber-dim);text-align:left;background:0 0;border:none;min-height:36px;font-size:12px;font-weight:500;display:flex}.reinspection-banner-header:hover{background:#f59e0b0d}.reinspection-banner-body{padding:0 var(--space-4) var(--space-3);animation:.2s slideDown}.jump-to-btn{align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-3);background:var(--slate-100);border:1px solid var(--border);border-radius:var(--radius);font-family:var(--font-industrial);color:var(--accent);cursor:pointer;white-space:nowrap;font-size:12px;font-weight:600;transition:all .15s;display:inline-flex}.jump-to-btn:hover{background:var(--slate-200);border-color:var(--slate-300)}.jump-to-btn:active{transform:scale(.97)}.mode-toggle{border:1px solid var(--slate-600);border-radius:2px;display:inline-flex;overflow:hidden}.mode-toggle-btn{padding:var(--space-1) var(--space-3);font-family:var(--font-industrial);letter-spacing:.5px;color:var(--slate-400);cursor:pointer;background:0 0;border:none;min-height:28px;font-size:11px;font-weight:700;transition:all .15s}.mode-toggle-btn.active{background:var(--accent);color:#fff}.mode-toggle-btn:not(.active):hover{color:var(--slate-200)}.main-content.fleet-mode{padding-bottom:var(--space-4);max-width:720px}.fleet-app{min-height:60vh}.fleet-loading,.fleet-error,.fleet-empty{text-align:center;justify-content:center;align-items:center;gap:var(--space-3);flex-direction:column;min-height:40vh;display:flex}.fleet-loading-text{font-family:var(--font-industrial);color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:14px;font-weight:600}.fleet-error-text{color:var(--safety-red);font-size:14px}.fleet-retry-btn{padding:var(--space-2) var(--space-4);background:var(--slate-900);color:#fff;border-radius:var(--radius);font-family:var(--font-industrial);cursor:pointer;min-height:var(--touch-min);border:none;font-size:13px;font-weight:600}.fleet-empty-text{font-family:var(--font-industrial);color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:14px}.vehicle-card{width:100%;padding:var(--space-3) var(--space-4);background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:var(--space-2);cursor:pointer;text-align:left;justify-content:space-between;align-items:center;gap:var(--space-3);transition:all .15s;display:flex}.vehicle-card:hover{border-color:var(--slate-300);box-shadow:0 2px 8px #0000000f}.vehicle-card:active{transform:scale(.99)}.vehicle-card-left{flex-direction:column;gap:2px;min-width:0;display:flex}.vehicle-card-unit{font-family:var(--font-industrial);color:var(--text-primary);font-size:16px;font-weight:700}.vehicle-card-info{color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;font-size:13px;overflow:hidden}.vehicle-card-meta{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;font-size:12px;overflow:hidden}.vehicle-card-right{align-items:center;gap:var(--space-2);flex-shrink:0;display:flex}.vehicle-card-chevron{color:var(--text-muted)}.compliance-dots{gap:var(--space-1);display:flex}.compliance-dot{width:22px;height:22px;font-family:var(--font-industrial);color:#fff;border-radius:50%;justify-content:center;align-items:center;font-size:11px;font-weight:700;display:flex}.compliance-dot.green{background:var(--safety-green)}.compliance-dot.yellow{background:var(--safety-amber)}.compliance-dot.orange{background:#f97316}.compliance-dot.red{background:var(--safety-red)}.vehicle-list{padding:0 var(--space-4) var(--space-4)}.login-screen{min-height:60vh;padding:var(--space-4);justify-content:center;align-items:center;display:flex}.login-card{background:var(--bg-secondary);border:1px solid var(--border);border-top:3px solid var(--accent);border-radius:var(--radius);width:100%;max-width:380px;padding:var(--space-8) var(--space-6) var(--space-6);animation:.45s cubic-bezier(.16,1,.3,1) both login-card-in;box-shadow:0 18px 40px -24px #11131859}@keyframes login-card-in{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.login-eyebrow{text-align:center;font-family:var(--font-industrial);letter-spacing:3px;text-transform:uppercase;color:var(--accent-dim);margin-bottom:var(--space-4);font-size:11px;font-weight:700}.login-icon{width:56px;height:56px;margin:0 auto var(--space-4);color:var(--accent);border-radius:var(--radius);background:#f9731614;border:1px solid #f9731640;justify-content:center;align-items:center;display:flex}.login-heading{text-align:center;font-family:var(--font-industrial);text-transform:uppercase;letter-spacing:1px;color:var(--text-primary);margin:0 0 var(--space-2);font-size:26px;font-weight:700}.login-subtext{text-align:center;color:var(--text-muted);margin:0 0 var(--space-5);font-size:14px}.login-form{margin-top:var(--space-2)}.login-email-display{text-align:center;font-family:var(--font-industrial);color:var(--text-primary);background:var(--slate-100);border:1px solid var(--border);border-radius:var(--radius);padding:var(--space-2) var(--space-3);margin:0 auto var(--space-5);word-break:break-all;font-size:15px;font-weight:600}.code-input-row{gap:var(--space-2);margin-bottom:var(--space-4);grid-template-columns:repeat(6,1fr);display:grid}.code-input-row.is-verifying{opacity:.55;pointer-events:none}.code-input-row.has-error{animation:.4s code-shake}@keyframes code-shake{0%,to{transform:translate(0)}20%,60%{transform:translate(-5px)}40%,80%{transform:translate(5px)}}.code-input-box{aspect-ratio:3/4;text-align:center;width:100%;font-family:var(--font-industrial);text-transform:uppercase;color:var(--text-primary);background:var(--bg-secondary);border:2px solid var(--border);border-radius:var(--radius);caret-color:var(--accent);padding:0;font-size:26px;font-weight:700;transition:border-color .15s,box-shadow .15s,background .15s}.code-input-box.filled{border-color:var(--slate-800);background:var(--slate-50)}.code-input-box:focus{border-color:var(--accent);outline:none;box-shadow:0 0 0 3px #f973162e}.code-input-box.error{border-color:var(--safety-red);color:var(--safety-red)}.code-error-message{justify-content:center;align-items:center;gap:var(--space-2);font-family:var(--font-industrial);color:var(--safety-red);margin-bottom:var(--space-3);font-size:13px;font-weight:600;display:flex}.login-expiry-notice{text-align:center;letter-spacing:.3px;color:var(--text-muted);margin:0 0 var(--space-4);font-size:12px}.login-retry-btn{width:100%;min-height:44px;padding:var(--space-2) var(--space-4);color:var(--text-secondary);border:1px solid var(--border);border-radius:var(--radius);font-family:var(--font-industrial);text-transform:uppercase;letter-spacing:.5px;cursor:pointer;background:0 0;font-size:13px;font-weight:700;transition:all .15s}.login-retry-btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent-dim)}.login-retry-btn:disabled{opacity:.5;cursor:not-allowed}.login-alt-link{width:100%;margin-top:var(--space-3);padding:var(--space-2);font-family:var(--font-industrial);text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);cursor:pointer;background:0 0;border:none;font-size:13px;font-weight:600;transition:color .15s;display:block}.login-alt-link:hover{color:var(--text-secondary)}.login-btn{width:100%;padding:var(--space-3) var(--space-4);background:var(--slate-900);color:#fff;border-radius:var(--radius);font-family:var(--font-industrial);text-transform:uppercase;letter-spacing:.5px;cursor:pointer;min-height:var(--touch-preferred);margin-top:var(--space-2);border:none;font-size:15px;font-weight:700;transition:all .15s}.login-btn:hover:not(:disabled){background:var(--slate-800)}.login-btn:disabled{opacity:.5;cursor:not-allowed}.fleet-toolbar{padding:var(--space-2) var(--space-4);background:var(--slate-100);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;display:flex}.fleet-user{font-family:var(--font-industrial);color:var(--text-secondary);font-size:13px;font-weight:600}.fleet-logout-btn{padding:var(--space-1) var(--space-3);border:1px solid var(--border);border-radius:var(--radius);font-family:var(--font-industrial);color:var(--text-muted);cursor:pointer;background:0 0;font-size:12px;font-weight:600;transition:all .15s}.fleet-logout-btn:hover{border-color:var(--safety-red);color:var(--safety-red)}.fleet-back-btn{align-items:center;gap:var(--space-1);padding:var(--space-2) var(--space-3);font-family:var(--font-industrial);color:var(--accent);cursor:pointer;margin-bottom:var(--space-2);background:0 0;border:none;font-size:13px;font-weight:600;display:inline-flex}.fleet-back-btn:hover{text-decoration:underline}.fleet-action-btn{padding:var(--space-2) var(--space-4);background:var(--slate-900);color:#fff;border-radius:var(--radius);font-family:var(--font-industrial);cursor:pointer;border:none;min-height:36px;font-size:13px;font-weight:600;transition:all .15s}.fleet-action-btn:hover{background:var(--slate-800)}.fleet-action-btn-sm{padding:var(--space-1) var(--space-3);background:var(--slate-100);border:1px solid var(--border);border-radius:var(--radius);font-family:var(--font-industrial);color:var(--text-secondary);cursor:pointer;font-size:11px;font-weight:600;transition:all .15s}.fleet-action-btn-sm:hover{border-color:var(--slate-300)}.fleet-action-btn-sm.accent{background:var(--accent);border-color:var(--accent);color:#fff}.fleet-action-btn-sm.accent:hover{background:var(--accent-bright)}.vehicle-detail-header{background:var(--slate-900);color:#fff;padding:var(--space-4);border-radius:var(--radius);margin-bottom:var(--space-4)}.vehicle-detail-unit{font-family:var(--font-industrial);letter-spacing:1px;margin-bottom:var(--space-1);font-size:24px;font-weight:700;display:block}.vehicle-detail-info{color:var(--slate-300);margin-bottom:var(--space-2);font-size:14px;display:block}.vehicle-detail-meta{gap:var(--space-3);color:var(--slate-400);flex-wrap:wrap;font-size:12px;display:flex}.compliance-section-header{padding:0 0 var(--space-2);justify-content:space-between;align-items:center;display:flex}.compliance-badge{align-items:center;gap:var(--space-1);font-family:var(--font-industrial);letter-spacing:.3px;text-transform:uppercase;white-space:nowrap;border-radius:2px;padding:2px 8px;font-size:11px;font-weight:700;display:inline-flex}.compliance-badge.green{color:var(--safety-green);background:#22c55e1a;border:1px solid #22c55e4d}.compliance-badge.yellow{color:var(--safety-amber-dim);background:#f59e0b1a;border:1px solid #f59e0b4d}.compliance-badge.orange{color:var(--accent-dim);background:#f973161a;border:1px solid #f973164d}.compliance-badge.red{color:var(--safety-red);background:#ef44441a;border:1px solid #ef44444d}.compliance-badge-days{opacity:.8;font-weight:500}.compliance-timeline{gap:var(--space-2);flex-direction:column;display:flex}.compliance-timeline-item{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius);padding:var(--space-3) var(--space-4)}.compliance-timeline-header{justify-content:space-between;align-items:center;gap:var(--space-2);margin-bottom:var(--space-1);display:flex}.compliance-timeline-type{font-family:var(--font-industrial);color:var(--text-primary);font-size:14px;font-weight:700}.compliance-timeline-ref{color:var(--text-muted);margin-bottom:var(--space-1);font-size:12px;display:block}.compliance-timeline-dates{color:var(--text-secondary);margin-bottom:var(--space-1);font-size:13px}.compliance-timeline-notes{color:var(--text-muted);margin-bottom:var(--space-2);font-size:12px;font-style:italic;display:block}.compliance-timeline-actions{gap:var(--space-2);display:flex}.fleet-textarea{resize:vertical;min-height:80px;font-family:var(--font-sans);font-size:14px;font-weight:400}.dashboard-summary{gap:var(--space-3);padding:var(--space-4);justify-content:center;display:flex}.summary-circle{border:3px solid;border-radius:50%;flex-direction:column;justify-content:center;align-items:center;width:72px;height:72px;display:flex}.summary-circle.green{border-color:var(--safety-green);color:var(--safety-green)}.summary-circle.yellow{border-color:var(--safety-amber);color:var(--safety-amber-dim)}.summary-circle.orange{color:var(--accent-dim);border-color:#f97316}.summary-circle.red{border-color:var(--safety-red);color:var(--safety-red)}.summary-count{font-family:var(--font-industrial);font-size:22px;font-weight:700;line-height:1}.summary-label{font-family:var(--font-industrial);text-transform:uppercase;letter-spacing:.5px;opacity:.8;font-size:9px;font-weight:600}.upcoming-list,.overdue-list{padding:0 var(--space-4) var(--space-2)}.upcoming-items{gap:var(--space-1);flex-direction:column;display:flex}.upcoming-item{width:100%;padding:var(--space-2) var(--space-3);background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;text-align:left;justify-content:space-between;align-items:center;transition:all .15s;display:flex}.upcoming-item:hover{border-color:var(--slate-300)}.upcoming-item.overdue{border-left:3px solid var(--safety-red)}.upcoming-item-left{align-items:center;gap:var(--space-2);display:flex}.upcoming-item-unit{font-family:var(--font-industrial);color:var(--text-primary);font-size:14px;font-weight:700}.upcoming-item-type{font-family:var(--font-industrial);color:var(--text-muted);text-transform:uppercase;font-size:12px;font-weight:600}.upcoming-item-right{flex-shrink:0}.renewal-old-info{background:var(--slate-100);border:1px solid var(--border);border-radius:var(--radius);padding:var(--space-3) var(--space-4);margin-bottom:var(--space-4);gap:var(--space-1);color:var(--text-secondary);flex-direction:column;font-size:13px;display:flex}.renewal-old-label{font-family:var(--font-industrial);text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);font-size:11px;font-weight:700}.document-section{margin-top:var(--space-6)}.document-upload{margin-bottom:var(--space-3)}.document-upload-input{width:100%;padding:var(--space-2);font-family:var(--font-sans);font-size:13px}.document-list{gap:var(--space-2);flex-direction:column;display:flex}.document-item{padding:var(--space-2) var(--space-3);background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius);justify-content:space-between;align-items:center;gap:var(--space-2);display:flex}.document-item-info{flex-direction:column;min-width:0;display:flex}.document-item-name{font-family:var(--font-industrial);color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.document-item-meta{color:var(--text-muted);font-size:11px}.document-item-actions{gap:var(--space-1);flex-shrink:0;display:flex}.fleet-nav{gap:var(--space-2);padding:var(--space-2) var(--space-4);background:var(--bg-secondary);border-bottom:1px solid var(--border);display:flex}.fleet-nav-btn{padding:var(--space-2) var(--space-3);background:var(--slate-50);border:1px solid var(--border);border-radius:var(--radius);font-family:var(--font-industrial);color:var(--text-secondary);cursor:pointer;font-size:13px;font-weight:600;transition:all .15s}.fleet-nav-btn.active{background:var(--slate-900);border-color:var(--slate-900);color:#fff}.reminder-list{gap:var(--space-1);margin-bottom:var(--space-4);flex-direction:column;display:flex}.reminder-item{padding:var(--space-2) var(--space-3);background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius);justify-content:space-between;align-items:center;display:flex}.reminder-item-left,.reminder-item-right{align-items:center;gap:var(--space-2);display:flex}.reminder-threshold{font-family:var(--font-industrial);color:var(--accent);font-size:12px;font-weight:600}.reminder-date{color:var(--text-muted);font-size:11px}@media (min-width:1024px){.main-content{max-width:1040px;padding-left:var(--space-5);padding-right:var(--space-5)}.main-content.fleet-mode{max-width:1040px}.tab-content{padding:var(--space-5) 0}.bottom-tabs{border-left:1px solid var(--slate-700);border-right:1px solid var(--slate-700);width:min(100%,1040px);left:50%;right:auto;transform:translate(-50%)}.rules-card,.condition-card,.data-table-wrapper,.calculator-card,.info-card{width:100%}}
