@charset "UTF-8";:root{--bg-base: #0a0d14;--bg-panel: #0f1520;--bg-card: #141b28;--bg-card2: #1a2235;--bg-hover: #1f2a3d;--border: #1e2d45;--border2: #253650;--navy: #0d1829;--yellow: #3b82f6;--yellow-dim: #1e3a8a;--orange: #f59e0b;--orange-dim: #b45309;--red: #ef4444;--red-dim: #b91c1c;--green: #10b981;--green-dim: #059669;--blue: #3b82f6;--blue-dim: #1e3a8a;--cyan: #06b6d4;--purple: #a855f7;--gray: #6b7280;--text-primary: #e8edf5;--text-secondary: #8a9bb5;--text-muted: #4a5568;--text-accent: #3b82f6;--font-display: "Inter", "Calibri", "Arial", sans-serif;--font-mono: "Inter", "Calibri", "Arial", sans-serif;--font-body: "Inter", "Calibri", "Arial", sans-serif;--sidebar-w: 220px;--header-h: 52px;--radius: 6px;--radius-lg: 10px}html.light{--bg-base: #f9fafb;--bg-panel: #ffffff;--bg-card: #ffffff;--bg-card2: #f3f4f6;--bg-hover: #eef2ff;--border: #e5e7eb;--border2: #d1d5db;--navy: #e8eefb;--yellow: #1e3a8a;--yellow-dim: #15296b;--orange: #d97706;--orange-dim: #b45309;--red: #ef4444;--red-dim: #b91c1c;--green: #10b981;--green-dim: #059669;--blue: #3b82f6;--blue-dim: #1e3a8a;--cyan: #0891b2;--purple: #7c3aed;--gray: #6b7280;--text-primary: #111827;--text-secondary: #374151;--text-muted: #9ca3af;--text-accent: #1e3a8a}html.light .tb-btn.primary,html.light .btn-login,html.light .sb-logo,html.light .login-logo-icon,html.light .tb-btn.primary:hover{color:#fff}html.light #login-screen{background:radial-gradient(ellipse at 60% 40%,#dde8f7,#f0f2f7 70%)}html.light .login-left{background:linear-gradient(135deg,#1a3a6b,#1e4a8c,#122a55)}html.light .login-right{background:#f0f2f7}html.light .login-form-card{background:#fff;border-color:var(--border)}html.light .form-input{background:#f4f6fb;border-color:var(--border2);color:var(--text-primary)}html.light .form-input::placeholder{color:var(--text-muted)}html.light .login-security-note{background:#2563eb0d}html.light .map-placeholder{background:radial-gradient(ellipse at 50% 40%,#d4e4f7,#c8d8ef)}html.light .map-placeholder:before{background:repeating-linear-gradient(0deg,transparent,transparent 30px,rgba(37,99,235,.06) 30px,rgba(37,99,235,.06) 31px),repeating-linear-gradient(90deg,transparent,transparent 30px,rgba(37,99,235,.06) 30px,rgba(37,99,235,.06) 31px)}html.light .map-route-line{background:#2563eb66}html.light .ev-thumb{background:linear-gradient(135deg,#c8d8ef,#dde8f7)!important}html.light .kpi-card,html.light .card{box-shadow:0 1px 6px #0f18270f}html.light table thead tr{border-bottom-color:var(--border2)}html.light td,html.light .health-row{border-bottom-color:#c8d0e480}html.light .collapsible-body{background:var(--bg-card2)}html.light .conf-chip{background:#f4f6fb}html.light .al-toggle{background:var(--green)}html.light .sidebar{box-shadow:2px 0 12px #0f182714}html.light .topbar{box-shadow:0 1px 8px #0f182714}html.light ::-webkit-scrollbar-track{background:#f0f2f7}html.light ::-webkit-scrollbar-thumb{background:var(--border2)}html.light .alert-item:hover,html.light .vehicle-list-item:hover,html.light .incident-item:hover,html.light .nav-item:hover{background:var(--bg-hover)}html.light .nav-item.active{background:#1e3a8a1a}html.light .bar{opacity:.9}html.light .pin-label{background:#0f1827d9}html.light .audit-row:nth-child(odd){background:#f0f2f780}html.light .login-phase-badge{background:#1e3a8a1f}html.light .lf-item{background:#0000000a}.theme-toggle{display:flex;align-items:center;gap:8px;cursor:pointer;padding:4px 10px;background:var(--bg-card2);border:1px solid var(--border2);border-radius:20px;transition:all .2s;-webkit-user-select:none;user-select:none;flex-shrink:0}.theme-toggle:hover{border-color:var(--yellow)}.theme-toggle-label{font-size:11px;color:var(--text-secondary);letter-spacing:.5px;white-space:nowrap}.toggle-track{width:36px;height:20px;border-radius:10px;background:var(--bg-base);border:1px solid var(--border2);position:relative;transition:background .25s;flex-shrink:0}html.light .toggle-track{background:#1e3a6b}.toggle-thumb{position:absolute;top:2px;left:2px;width:14px;height:14px;border-radius:50%;background:var(--text-muted);transition:all .25s cubic-bezier(.34,1.56,.64,1);display:flex;align-items:center;justify-content:center;font-size:8px;line-height:1}html.light .toggle-thumb{left:18px;background:var(--yellow)}*{margin:0;padding:0;box-sizing:border-box}html,body{height:100%;overflow:hidden;background:var(--bg-base);color:var(--text-primary);font-family:var(--font-body);font-size:13px;transition:background .3s,color .3s}*,*:before,*:after{transition:background-color .25s,border-color .2s,color .2s,box-shadow .2s}.live-dot,.truck-pin,.al-toggle:after,.popup-modal,.toast-item,.toggle-thumb{transition:none!important}.toggle-thumb{transition:all .25s cubic-bezier(.34,1.56,.64,1)!important}::-webkit-scrollbar{width:2px;height:2px}::-webkit-scrollbar-track{background:var(--bg-base)}::-webkit-scrollbar-thumb{background:var(--border2);border-radius:1px}input:-webkit-autofill,input:-webkit-autofill:hover,input:-webkit-autofill:focus,input:-webkit-autofill:active,textarea:-webkit-autofill,select:-webkit-autofill{-webkit-text-fill-color:var(--text-primary);-webkit-box-shadow:0 0 0 1000px var(--bg-base) inset;caret-color:var(--text-primary);transition:background-color 9999s ease-in-out 0s}#login-screen{display:flex;height:100vh;width:100vw;position:fixed;top:0;left:0;z-index:1000;background:radial-gradient(ellipse at 60% 40%,#0d1f3a,#0a0d14 70%)}.login-left{width:55%;background:linear-gradient(135deg,#0d1829,#0f2040,#0a1520);display:flex;flex-direction:column;justify-content:center;align-items:center;padding:48px;position:relative;overflow:hidden}.login-left:before{content:"";position:absolute;inset:0;background:repeating-linear-gradient(0deg,transparent,transparent 40px,rgba(245,197,24,.03) 40px,rgba(245,197,24,.03) 41px),repeating-linear-gradient(90deg,transparent,transparent 40px,rgba(245,197,24,.03) 40px,rgba(245,197,24,.03) 41px)}.login-brand{position:relative;z-index:1;text-align:center}.login-logo-bar{display:flex;align-items:center;gap:16px;margin-bottom:24px}.login-logo-icon{width:56px;height:56px;background:var(--yellow);clip-path:polygon(50% 0%,100% 25%,100% 75%,50% 100%,0% 75%,0% 25%);display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:700;color:#fff;font-family:var(--font-display)}.login-company{font-family:var(--font-display)}.login-company .lt{font-size:36px;font-weight:700;color:var(--yellow);letter-spacing:-1px}.login-company .construction{font-size:13px;color:var(--text-secondary);letter-spacing:3px;text-transform:uppercase}.login-platform-title{font-family:var(--font-display);font-size:28px;font-weight:600;color:var(--text-primary);margin-bottom:8px;line-height:1.2}.login-platform-sub{font-size:12px;color:var(--text-secondary);letter-spacing:2px;text-transform:uppercase}.login-phase-badge{display:inline-block;margin-top:20px;padding:4px 12px;background:#3b82f61f;border:1px solid rgba(59,130,246,.3);border-radius:20px;font-size:11px;color:var(--yellow);letter-spacing:1px}.login-features{position:relative;z-index:1;margin-top:48px;display:grid;grid-template-columns:1fr 1fr;gap:12px;width:100%;max-width:460px}.lf-item{background:#ffffff08;border:1px solid var(--border);border-radius:var(--radius);padding:12px;display:flex;align-items:center;gap:10px}.lf-icon{width:28px;height:28px;border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}.lf-text{font-size:11px;color:var(--text-secondary);line-height:1.4}.lf-text strong{display:block;color:var(--text-primary);font-size:12px;margin-bottom:1px}.login-right{width:45%;display:flex;flex-direction:column;justify-content:center;align-items:center;padding:48px}.login-form-card{width:100%;max-width:380px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:36px}.lfc-title{font-family:var(--font-display);font-size:20px;font-weight:600;margin-bottom:4px}.lfc-sub{font-size:12px;color:var(--text-secondary);margin-bottom:28px}.form-group{margin-bottom:16px}.form-label{display:block;font-size:11px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:1px;margin-bottom:6px}.form-input{width:100%;padding:10px 14px;background:var(--bg-base);border:1px solid var(--border2);border-radius:var(--radius);color:var(--text-primary);font-family:var(--font-body);font-size:13px;outline:none;transition:border-color .2s}.form-input:focus{border-color:var(--yellow)}.form-input::placeholder{color:var(--text-muted)}.btn-login{width:100%;padding:11px;background:var(--yellow);color:#fff;font-family:var(--font-display);font-size:15px;font-weight:700;border:none;border-radius:var(--radius);cursor:pointer;letter-spacing:1px;text-transform:uppercase;margin-top:8px;transition:background .2s}.btn-login:hover{background:var(--yellow-dim)}.login-divider{display:flex;align-items:center;gap:12px;margin:16px 0}.login-divider span{font-size:11px;color:var(--text-muted)}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background:var(--border)}.btn-sso{width:100%;padding:10px;background:transparent;border:1px solid var(--border2);border-radius:var(--radius);color:var(--text-secondary);font-size:13px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:border-color .2s,color .2s}.btn-sso:hover{border-color:var(--blue);color:var(--blue)}.login-security-note{margin-top:20px;padding:10px 12px;background:#3b82f60f;border:1px solid rgba(59,130,246,.2);border-radius:var(--radius);font-size:11px;color:var(--text-secondary);display:flex;align-items:flex-start;gap:8px}.login-security-note svg{flex-shrink:0;color:var(--blue)}.login-footer{margin-top:16px;text-align:center;font-size:11px;color:var(--text-muted)}.login-footer a{color:var(--text-secondary)}#app-shell{display:flex;flex-direction:row;height:100vh;width:100vw;overflow:hidden}.sidebar{width:var(--sidebar-w);background:var(--bg-panel);border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;overflow:hidden}.sidebar-brand{height:var(--header-h);display:flex;align-items:center;gap:10px;padding:0 16px;border-bottom:1px solid var(--border);flex-shrink:0}.sb-logo{width:35px;height:35px;background:var(--yellow);clip-path:polygon(50% 0%,100% 25%,100% 75%,50% 100%,0% 75%,0% 25%);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff;flex-shrink:0;font-family:var(--font-display)}.sb-brand-text{overflow:hidden}.sb-brand-text .lt{font-family:var(--font-display);font-size:20px;font-weight:700;color:var(--yellow);line-height:1}.sb-brand-text .sub{font-size:13px;color:var(--text-muted);letter-spacing:1px;text-transform:uppercase}.sidebar-nav{flex:1;overflow-y:auto;padding:8px 0}.nav-section-label{font-size:13px;color:var(--text-muted);letter-spacing:2px;text-transform:uppercase;padding:12px 16px 4px}.nav-item{display:flex;align-items:center;gap:10px;padding:8px 16px;cursor:pointer;transition:background .15s,color .15s;color:var(--text-secondary);font-size:14px;font-weight:500;border-left:3px solid transparent;position:relative;text-decoration:none}.nav-item:hover{background:var(--bg-hover);color:var(--text-primary)}.nav-item.active{background:#3b82f61a;color:var(--yellow);border-left-color:var(--yellow)}.nav-item .nav-icon{font-size:15px;width:18px;text-align:center;flex-shrink:0}.nav-badge{margin-left:auto;min-width:18px;height:18px;background:var(--red);border-radius:9px;font-size:10px;font-weight:600;color:#fff;display:flex;align-items:center;justify-content:center;padding:0 4px}.nav-badge.yellow{background:var(--orange)}.sidebar-user{border-top:1px solid var(--border);padding:12px 16px;display:flex;align-items:center;gap:10px;flex-shrink:0}.sb-avatar{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,#1e3a5f,#2d5a8e);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;flex-shrink:0}.sb-user-info{overflow:hidden;flex:1}.sb-user-info .name{font-size:16px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sb-user-info .role{font-size:12px;color:var(--text-muted)}.sb-logout{font-size:16px;cursor:pointer;color:var(--text-muted)}.sb-logout:hover{color:var(--red)}.main-area{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}.topbar{height:var(--header-h);background:var(--bg-panel);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 20px;gap:16px;flex-shrink:0}.topbar-title{font-family:var(--font-display);font-size:18px;font-weight:600;flex:1}.topbar-actions{display:flex;align-items:center;gap:8px}.tb-btn{padding:6px 14px;border-radius:var(--radius);font-size:12px;font-weight:500;cursor:pointer;border:1px solid;transition:all .15s;display:flex;align-items:center;gap:6px}.tb-btn.primary{background:var(--yellow);color:#fff;border-color:var(--yellow)}.tb-btn.primary:hover{background:var(--yellow-dim);border-color:var(--yellow-dim);color:#fff}.tb-btn.ghost{background:transparent;color:var(--text-secondary);border-color:var(--border2)}.tb-btn.ghost:hover{color:var(--text-primary);border-color:var(--text-secondary)}.tb-btn.danger{background:#e835351f;color:var(--red);border-color:#e835354d}.topbar-status{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--text-muted)}.live-dot{width:7px;height:7px;border-radius:50%;background:var(--green);animation:pulse 1.5s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.main-area>router-outlet{display:none}.main-area>*:not(.topbar):not(router-outlet){flex:1 1 auto;min-height:0;display:flex;flex-direction:column;overflow:hidden}.screen{display:flex;flex:1;min-height:0;overflow:hidden;flex-direction:column}.screen-body{flex:1;min-height:0;overflow-y:auto;padding:10px}.grid{display:grid;gap:12px}.g2{grid-template-columns:1fr 1fr}.g3{grid-template-columns:1fr 1fr 1fr}.g4{grid-template-columns:1fr 1fr 1fr 1fr}.g5{grid-template-columns:repeat(5,1fr)}.g6{grid-template-columns:repeat(6,1fr)}.g7{grid-template-columns:repeat(7,1fr)}.g8{grid-template-columns:repeat(8,1fr)}.g-auto{grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px;overflow:hidden}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:0}.card-title{font-family:var(--font-display);font-size:20px;font-weight:600;color:var(--text-primary);display:flex;align-items:center;gap:8px}.card-actions{display:flex;gap:6px}.kpi-grid{display:grid;gap:12px;grid-template-columns:repeat(4,1fr)}@media(max-width:1100px){.kpi-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:560px){.kpi-grid{grid-template-columns:1fr}}.kpi-carousel{display:flex;align-items:center;gap:8px}.kpi-track{flex:1;min-width:0;display:flex;gap:10px;overflow-x:auto;scroll-behavior:smooth;scrollbar-width:none;-ms-overflow-style:none}.kpi-track::-webkit-scrollbar{display:none}.kpi-track>.kpi-card{flex:0 0 calc((100% - 48px)/5)}.kpi-arrow{flex-shrink:0;width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:var(--bg-card);border:1px solid var(--border2);color:var(--text-secondary);font-size:20px;line-height:1;cursor:pointer;transition:all .15s;-webkit-user-select:none;user-select:none}.kpi-arrow:hover{color:var(--yellow);border-color:var(--yellow)}@media(max-width:1100px){.kpi-track>.kpi-card{flex:0 0 calc((100% - 24px) / 3)}}@media(max-width:700px){.kpi-track>.kpi-card{flex:0 0 calc((100% - 12px)/2)}}.ag-mono{font-family:var(--font-mono);font-size:11px}.ag-primary{color:var(--text-primary);font-weight:500}.page-header{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:10px 15px;margin-bottom:10px;display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}.page-header .ph-main{min-width:0}.page-header .ph-title{font-family:var(--font-display);font-size:25px;font-weight:700;color:var(--text-primary);line-height:1.2}.page-header .ph-sub{font-size:14px;color:var(--text-secondary);margin-top:3px}.page-header .ph-sub .accent{color:var(--blue)}.page-header .ph-actions{display:flex;gap:8px;align-items:center;flex-shrink:0}.kpi-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:14px 16px;display:flex;flex-direction:row;align-items:center;gap:13px;position:relative;overflow:hidden}.kpi-body{display:flex;flex-direction:column;gap:3px;min-width:0}.kpi-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px}.kpi-card.yellow:before{background:var(--yellow)}.kpi-card.orange:before{background:var(--orange)}.kpi-card.red:before{background:var(--red)}.kpi-card.green:before{background:var(--green)}.kpi-card.blue:before{background:var(--blue)}.kpi-card.cyan:before{background:var(--cyan)}.kpi-card.purple:before{background:var(--purple)}.kpi-label{font-size:14px;color:var(--text-secondary);letter-spacing:1px;text-transform:uppercase}.kpi-value{font-family:var(--font-display);font-size:28px;font-weight:700;line-height:1}.kpi-value.yellow{color:var(--yellow)}.kpi-value.orange{color:var(--orange)}.kpi-value.red{color:var(--red)}.kpi-value.green{color:var(--green)}.kpi-value.blue{color:var(--blue)}.kpi-value.cyan{color:var(--cyan)}.kpi-value.purple{color:var(--purple)}.kpi-sub{font-size:12px;color:var(--text-muted);display:flex;align-items:center;gap:4px}.kpi-icon{width:46px;height:46px;border-radius:13px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:22px;background:#ffffff0d;opacity:1}.kpi-card.green .kpi-icon{background:#10b98124}.kpi-card.blue .kpi-icon{background:#3b82f624}.kpi-card.red .kpi-icon{background:#ef444424}.kpi-card.orange .kpi-icon,.kpi-card.yellow .kpi-icon{background:#f59e0b24}.kpi-card.purple .kpi-icon{background:#a855f724}.kpi-card.cyan .kpi-icon{background:#06b6d424}.pill{align-items:center;gap:4px;padding:2px 8px;border-radius:20px;font-size:12px;font-weight:600;letter-spacing:.5px;text-transform:uppercase;white-space:nowrap}.pill.green{background:#22c55e1f;color:var(--green);border:1px solid rgba(34,197,94,.25)}.pill.red{background:#e835351f;color:var(--red);border:1px solid rgba(232,53,53,.25)}.pill.orange{background:#f078201f;color:var(--orange);border:1px solid rgba(240,120,32,.25)}.pill.yellow{background:#f5c5181f;color:var(--yellow);border:1px solid rgba(245,197,24,.25)}.pill.blue{background:#3b82f61f;color:var(--blue);border:1px solid rgba(59,130,246,.25)}.pill.gray{background:#6b72801f;color:var(--gray);border:1px solid rgba(107,114,128,.25)}.pill.purple{background:#a855f71f;color:var(--purple);border:1px solid rgba(168,85,247,.25)}.pill.cyan{background:#06b6d41f;color:var(--cyan);border:1px solid rgba(6,182,212,.25)}.pill:before{content:"\25cf";font-size:7px}.tbl-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse;font-size:12px}thead tr{border-bottom:1px solid var(--border2)}th{padding:8px 10px;text-align:left;font-size:10px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:1px;white-space:nowrap}td{padding:8px 10px;border-bottom:1px solid rgba(30,45,69,.6);vertical-align:middle;color:var(--text-secondary);white-space:nowrap}tbody tr:hover td{background:var(--bg-hover)}td.primary{color:var(--text-primary);font-weight:500}td.mono{font-family:var(--font-mono);font-size:11px}.conf-chip{display:inline-flex;align-items:center;gap:4px;padding:2px 7px;border-radius:4px;font-family:var(--font-mono);font-size:10px;background:var(--bg-base);border:1px solid var(--border2)}.conf-chip.high{color:var(--green);border-color:#22c55e4d}.conf-chip.med{color:var(--yellow);border-color:#f5c5184d}.conf-chip.low{color:var(--orange);border-color:#f078204d}.alert-item{padding:10px 12px;border-bottom:1px solid var(--border);display:flex;align-items:flex-start;gap:10px;cursor:pointer;transition:background .15s}.alert-item:hover{background:var(--bg-hover)}.alert-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;margin-top:3px}.alert-body{flex:1;min-width:0}.alert-type{font-size:14px;font-weight:600;color:var(--text-primary)}.alert-detail{font-size:12px;color:var(--text-secondary);margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.alert-meta{font-size:12px;color:var(--text-muted);margin-top:2px;font-family:var(--font-mono)}.alert-action{flex-shrink:0}.tabs{display:flex;gap:2px;border-bottom:1px solid var(--border);margin-bottom:16px;flex-wrap:wrap}.tab{padding:8px 14px;font-size:12px;font-weight:500;cursor:pointer;color:var(--text-muted);border-bottom:2px solid transparent;transition:all .15s;white-space:nowrap}.tab:hover{color:var(--text-primary)}.tab.active{color:var(--yellow);border-bottom-color:var(--yellow)}.map-placeholder{background:radial-gradient(ellipse at 50% 40%,#0d1f35,#0a0f1a);border-radius:var(--radius);position:relative;overflow:hidden;border:1px solid var(--border);flex:1;display:flex;align-items:center;justify-content:center;min-height:300px}.map-placeholder:before{content:"";position:absolute;inset:0;background:repeating-linear-gradient(0deg,transparent,transparent 30px,rgba(59,130,246,.04) 30px,rgba(59,130,246,.04) 31px),repeating-linear-gradient(90deg,transparent,transparent 30px,rgba(59,130,246,.04) 30px,rgba(59,130,246,.04) 31px)}.map-grid{position:absolute;inset:0}.map-label{color:var(--text-muted);font-size:12px;z-index:1;display:flex;flex-direction:column;align-items:center;gap:8px}.truck-pin{position:absolute;width:12px;height:12px;border-radius:50%;border:2px solid rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;z-index:2;cursor:pointer;animation:pin-pulse 2s infinite}@keyframes pin-pulse{0%,to{box-shadow:0 0 0 0 currentColor}50%{box-shadow:0 0 0 6px transparent}}.truck-pin.green{background:var(--green);color:var(--green)}.truck-pin.yellow{background:var(--yellow);color:var(--yellow)}.truck-pin.orange{background:var(--orange);color:var(--orange)}.truck-pin.red{background:var(--red);color:var(--red)}.truck-pin.gray{background:var(--gray);color:var(--gray)}.truck-pin .pin-label{position:absolute;top:-22px;left:50%;transform:translate(-50%);white-space:nowrap;font-family:var(--font-mono);font-size:9px;background:#000c;padding:2px 4px;border-radius:3px;color:#fff;pointer-events:none}.map-route-line{position:absolute;height:2px;background:#3b82f680;transform-origin:left center;border-radius:1px}.map-stop-marker{position:absolute;width:8px;height:8px;background:var(--red);border-radius:50%;border:2px solid #fff;z-index:3;cursor:pointer}.progress-bar{height:4px;background:var(--bg-base);border-radius:2px;overflow:hidden;margin-top:4px}.progress-fill{height:100%;border-radius:2px;transition:width .3s}.progress-fill.green{background:var(--green)}.progress-fill.yellow{background:var(--yellow)}.progress-fill.orange{background:var(--orange)}.progress-fill.red{background:var(--red)}.progress-fill.blue{background:var(--blue)}.score-ring{width:80px;height:80px;border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;border:3px solid;font-family:var(--font-display)}.score-ring.excellent{border-color:var(--green);color:var(--green)}.score-ring.good{border-color:var(--blue);color:var(--blue)}.score-ring.coaching{border-color:var(--yellow);color:var(--yellow)}.score-ring.high-risk{border-color:var(--orange);color:var(--orange)}.score-ring.critical{border-color:var(--red);color:var(--red)}.score-ring .score-num{font-size:24px;font-weight:700;line-height:1}.score-ring .score-lbl{font-size:9px;opacity:.7}.tag{display:inline-flex;align-items:center;padding:2px 7px;border-radius:3px;font-size:10px;background:var(--bg-base);border:1px solid var(--border2);color:var(--text-secondary)}.filter-bar{display:flex;gap:8px;margin-bottom:14px;flex-wrap:wrap;align-items:center}.filter-select{padding:10px 12px;background:var(--bg-card);border:1px solid var(--border2);border-radius:var(--radius);color:var(--text-secondary);font-size:12px;outline:none;cursor:pointer;min-width:120px}.filter-select:focus{border-color:var(--yellow)}.filter-search{flex:1;min-width:180px;padding:10px 12px;background:var(--bg-card);border:1px solid var(--border2);border-radius:var(--radius);color:var(--text-primary);font-size:12px;outline:none}.filter-search:focus{border-color:var(--yellow)}.filter-search::placeholder{color:var(--text-muted)}.timeline{position:relative;padding-left:24px}.timeline:before{content:"";position:absolute;left:8px;top:0;bottom:0;width:1px;background:var(--border2)}.tl-item{position:relative;padding-bottom:16px}.tl-dot{position:absolute;left:-20px;top:3px;width:10px;height:10px;border-radius:50%;border:2px solid var(--bg-card);background:var(--gray)}.tl-dot.green{background:var(--green)}.tl-dot.red{background:var(--red)}.tl-dot.orange{background:var(--orange)}.tl-dot.yellow{background:var(--yellow)}.tl-dot.blue{background:var(--blue)}.tl-time{font-size:11px;font-family:var(--font-mono);color:var(--text-muted)}.tl-event{font-size:14px;color:var(--text-primary);font-weight:500;margin-top:1px}.tl-detail{font-size:12px;color:var(--text-secondary);margin-top:2px}.two-panel{display:flex;gap:12px;flex:1;overflow:hidden}.panel-list{width:320px;flex-shrink:0;display:flex;flex-direction:column;gap:0;overflow-y:auto}.panel-list-header{padding:12px 14px;border-bottom:1px solid var(--border);background:var(--bg-card);flex-shrink:0}.panel-main{flex:1;overflow:hidden;display:flex;flex-direction:column;gap:12px;min-width:0}.ev-card{background:var(--bg-card2);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;cursor:pointer;transition:border-color .15s}.ev-card:hover{border-color:var(--orange)}.ev-thumb{height:90px;background:linear-gradient(135deg,#0d1829,#1a2235);display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.ev-thumb:after{content:"\25b6";font-size:20px;color:#ffffff80}.ev-overlay{position:absolute;bottom:0;left:0;right:0;padding:4px 6px;background:linear-gradient(transparent,#000c);font-family:var(--font-mono);font-size:11px;color:#fffc}.ev-info{padding:8px}.ev-type{font-size:124x;font-weight:600;color:var(--text-primary)}.ev-meta{font-size:12px;color:var(--text-muted);margin-top:2px}.role-row{display:flex;align-items:center;padding:10px 0;border-bottom:1px solid var(--border);gap:12px}.role-name{font-size:12px;font-weight:500;width:140px;flex-shrink:0}.perm-cell{width:70px;text-align:center;font-size:12px}.perm-yes{color:var(--green)}.perm-no{color:var(--text-muted)}.perm-part{color:var(--yellow)}.collapsible{border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;margin-bottom:8px}.collapsible-header{padding:10px 14px;background:var(--bg-card);cursor:pointer;display:flex;align-items:center;gap:8px;font-size:13px;font-weight:500;transition:background .15s}.collapsible-header:hover{background:var(--bg-hover)}.collapsible-body{padding:14px;background:var(--bg-base)}.bar-chart{display:flex;align-items:flex-end;gap:6px;height:80px}.bar{flex:1;border-radius:3px 3px 0 0;background:var(--blue);opacity:.8;min-width:14px;position:relative}.bar:hover{opacity:1}.bar .bar-val{position:absolute;top:-16px;left:50%;transform:translate(-50%);font-size:12px;color:var(--text-muted);white-space:nowrap}.bar-labels{display:flex;gap:6px;margin-top:4px}.bar-label{flex:1;text-align:center;font-size:12px;color:var(--text-muted);min-width:14px}.health-row{display:flex;align-items:center;justify-content:space-between;padding:6px 0;border-bottom:1px solid rgba(30,45,69,.4)}.health-label{font-size:13px;color:var(--text-secondary)}.health-val{font-size:13px;font-family:var(--font-mono)}.scroll-panel{overflow-y:auto;flex:1}.audit-row{padding:8px 12px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:12px;font-size:11px}.audit-time{font-family:var(--font-mono);color:var(--text-muted);width:120px;flex-shrink:0}.audit-user{color:var(--blue);width:120px;flex-shrink:0}.audit-action{color:var(--text-primary);flex:1}.audit-level{width:60px;text-align:right}.dashboard-layout{display:grid;grid-template-columns:1fr 300px;gap:10px;align-items:start}.dashboard-left{display:flex;flex-direction:column;gap:12px}.dashboard-right{display:flex;flex-direction:column;gap:12px;height:calc(100vh - var(--header-h) - 40px);overflow:hidden}.alert-feed{overflow-y:auto;flex:1}.map-screen-layout{display:flex;gap:12px;flex:1;overflow:hidden}.map-side-panel{width:280px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);display:flex;flex-direction:column;overflow:hidden;flex-shrink:0}.map-main{flex:1;display:flex;flex-direction:column;gap:8px;overflow:hidden}.vehicle-list-item{padding:10px 12px;border-bottom:1px solid var(--border);cursor:pointer;transition:background .15s}.vehicle-list-item:hover{background:var(--bg-hover)}.vehicle-list-item.selected{background:#3b82f61a;border-left:3px solid var(--yellow)}.vli-top{display:flex;justify-content:space-between;align-items:center}.vli-id{font-family:var(--font-mono);font-size:13px;font-weight:600;color:var(--text-primary)}.vli-driver{font-size:12px;color:var(--text-secondary);margin-top:2px}.vli-site{font-size:11px;color:var(--text-muted)}.vehicle-drawer{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:0;overflow:hidden}.drawer-header{padding:12px 14px;background:var(--bg-card2);border-bottom:1px solid var(--border);display:flex;align-items:center;gap:10px}.drawer-body{padding:14px;display:grid;grid-template-columns:1fr 1fr;gap:10px}.dbi{display:flex;flex-direction:column;gap:2px}.dbi-label{font-size:9px;color:var(--text-muted);text-transform:uppercase;letter-spacing:1px}.dbi-value{font-size:12px;color:var(--text-primary);font-weight:500;font-family:var(--font-mono)}.incident-layout{display:grid;grid-template-columns:320px 1fr;gap:12px;height:100%;min-height:0}.incident-list{display:flex;flex-direction:column;gap:0}.incident-item{padding:10px 12px;border-bottom:1px solid var(--border);cursor:pointer;transition:background .15s}.incident-item:hover{background:var(--bg-hover)}.incident-item.selected{background:#e835350f;border-left:3px solid var(--red)}.ii-type{font-size:14px;font-weight:600;color:var(--text-primary)}.ii-vehicle{font-size:13px;color:var(--text-secondary);margin-top:1px}.ii-time{font-size:12px;color:var(--text-muted);font-family:var(--font-mono)}.score-components{display:flex;flex-direction:column;gap:6px}.sc-row{display:flex;align-items:center;gap:10px}.sc-label{font-size:13px;color:var(--text-secondary);width:160px;flex-shrink:0}.sc-bar{flex:1}.sc-score{font-size:12px;font-weight:600;font-family:var(--font-mono);width:30px;text-align:right}.alert-level-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:14px;display:grid;grid-template-columns:auto 1fr auto;gap:12px;align-items:center}.al-number{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:15px;font-weight:700;border:2px solid;flex-shrink:0}.al-desc{font-size:12px;color:var(--text-secondary);margin-top:2px}.al-name{font-size:13px;font-weight:600}.al-toggle{width:36px;height:20px;border-radius:10px;background:var(--green);position:relative;cursor:pointer;flex-shrink:0}.al-toggle:after{content:"";position:absolute;right:2px;top:2px;width:16px;height:16px;border-radius:50%;background:#fff}.priv-item{padding:12px 14px;border-bottom:1px solid var(--border);display:flex;align-items:flex-start;gap:12px}.priv-icon{font-size:18px;flex-shrink:0;margin-top:2px}.priv-body{flex:1}.priv-title{font-size:12px;font-weight:600;color:var(--text-primary)}.priv-desc{font-size:11px;color:var(--text-secondary);margin-top:2px;line-height:1.5}.priv-status{flex-shrink:0}@media(max-width:1200px){.g8,.g7{grid-template-columns:repeat(4,1fr)}}#modal-overlay{position:fixed;inset:0;background:#000000a6;z-index:2000;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}html.light #modal-overlay{background:#0f182766}.popup-modal{animation:popIn .2s cubic-bezier(.34,1.56,.64,1)}@keyframes popIn{0%{opacity:0;transform:translate(-50%,-48%) scale(.95)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}#popup-critical-alert{animation:slideInRight .25s cubic-bezier(.34,1.56,.64,1)}@keyframes slideInRight{0%{opacity:0;transform:translate(40px)}to{opacity:1;transform:translate(0)}}.toast-item{background:var(--bg-card);border:1px solid var(--border2);border-radius:var(--radius);padding:10px 14px;font-size:12px;display:flex;align-items:center;gap:8px;box-shadow:0 4px 20px #0006;pointer-events:auto;animation:toastIn .25s ease;min-width:260px}@keyframes toastIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.toast-item.out{animation:toastOut .2s ease forwards}@keyframes toastOut{to{opacity:0;transform:translateY(10px)}}html.light .popup-modal>div{background:var(--bg-card)!important}html.light textarea{background:var(--bg-card2)!important;color:var(--text-primary)!important;border-color:var(--border2)!important}html.light #demo-panel,html.light .toast-item{background:var(--bg-card);border-color:var(--border2)}
