:root{--bg:#090f1d;--panel:#151c2d;--panel-2:#1a2336;--panel-3:#202b42;--line:rgba(148,163,184,.16);--line-strong:rgba(148,163,184,.28);--text:#eef4ff;--muted:#98a6bc;--brand:#4c7dff;--brand-dark:#365de9;--green:#6bd47c;--orange:#ff9d2e;--purple:#9b63ff;--danger:#ff5d6c;--ok:#6bd47c;--warn:#f1c84b}*{box-sizing:border-box}body,html{margin:0;min-height:100%;overflow-x:hidden;background:radial-gradient(circle at 70% -10%,rgba(76,125,255,.18),transparent 34%),linear-gradient(180deg,#0a1020,#090f1d);color:var(--text);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}a{color:inherit;text-decoration:none}button,input,select,textarea{font:inherit}button{cursor:pointer}.app-shell{min-height:100vh;display:grid;grid-template-columns:240px minmax(0,1fr);max-width:100vw;overflow-x:hidden}.sidebar{position:relative;min-height:100vh;height:auto;overflow:visible;background:rgba(18,25,40,.96);border-right:1px solid var(--line);color:#fff;padding:16px 12px;align-self:stretch}.brand-row{min-height:58px;justify-content:space-between;gap:8px;margin-bottom:12px}.brand-lockup,.brand-row{display:flex;align-items:center}.brand-lockup{gap:9px}.brand-mark{width:36px;height:36px;border-radius:12px;display:grid;place-items:center;background:linear-gradient(135deg,#4c7dff,#6f9dff);color:#fff;box-shadow:0 14px 30px rgba(76,125,255,.28)}.brand{font-size:16px;font-weight:800;letter-spacing:0}.brand-subtitle{margin-top:3px;font-size:12px;color:var(--muted)}.menu-button{width:34px;min-height:34px;border:0;border-radius:8px;background:hsla(0,0%,100%,.06);color:#d8e1f1}.nav,.nav-section{display:grid;grid-gap:4px;gap:4px}.nav-section{margin-top:14px}.nav-title{padding:8px 8px 3px;color:#7f8ba1;font-size:12px;font-weight:800;text-transform:uppercase}.nav a,.nav button{width:100%;min-height:39px;display:flex;align-items:center;gap:9px;border:0;border-radius:8px;padding:0 11px;background:transparent;color:#cfd8e8;text-align:left;font-size:14px}.nav a:hover,.nav button:hover{background:hsla(0,0%,100%,.07);color:#fff}.nav-section:first-child a:first-of-type{background:linear-gradient(135deg,#4b76ff,#3f6fff);color:#fff;box-shadow:0 10px 24px rgba(76,125,255,.22)}.nav-badge{margin-left:auto;min-width:24px;height:24px;border-radius:999px;display:inline-grid;place-items:center;background:#ef4354;color:#fff;font-size:12px;font-weight:800}.sidebar-user{margin-top:18px;padding:12px;border:1px solid var(--line);border-radius:10px;background:hsla(0,0%,100%,.04);display:flex;align-items:center;gap:10px}.avatar{width:42px;height:42px;border-radius:999px;display:grid;place-items:center;background:linear-gradient(135deg,#4c7dff,#8f66ff);color:#fff;font-weight:800}.main{min-width:0;overflow-x:hidden}.topbar{min-height:80px;background:rgba(9,15,29,.72);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);display:grid;grid-template-columns:minmax(210px,1fr) minmax(220px,390px) auto;align-items:center;grid-gap:14px;gap:14px;padding:14px 22px 10px}.topbar h1{margin:0;font-size:26px}.search-box{width:100%;min-height:46px;border-radius:14px;background:var(--panel);border:1px solid var(--line);display:flex;align-items:center;gap:12px;padding:0 16px;color:var(--muted)}.search-wrapper{position:relative;min-width:0;width:100%}.search-box input{min-width:0;flex:1 1;border:0;outline:0;background:transparent;color:var(--text);font:inherit}.search-box input::placeholder{color:var(--muted)}.search-submit{width:32px;min-height:32px;border:0;border-radius:10px;display:grid;place-items:center;background:transparent;color:#aab8d4}.search-submit:focus-visible,.search-submit:hover{background:hsla(0,0%,100%,.07);color:#fff}.search-results{position:absolute;top:calc(100% + 8px);left:0;right:0;z-index:30;border:1px solid var(--line);border-radius:12px;background:rgba(15,23,42,.98);box-shadow:0 22px 60px rgba(0,0,0,.34);padding:8px;display:grid;grid-gap:6px;gap:6px;max-height:380px;overflow-y:auto}.search-result{display:grid;grid-template-columns:36px minmax(0,1fr) auto;grid-gap:10px;gap:10px;align-items:center;border-radius:10px;padding:8px;color:var(--text)}.search-result:hover{background:rgba(76,125,255,.13)}.search-result-icon{width:36px;height:36px;border-radius:10px;display:grid;place-items:center;background:rgba(76,125,255,.16);color:#a9c0ff}.search-result-copy{min-width:0;display:grid;grid-gap:3px;gap:3px}.search-result-copy small,.search-result-copy strong{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.search-result-copy small{color:var(--muted)}.search-result-badge{border-radius:999px;padding:5px 8px;background:hsla(0,0%,100%,.08);color:#dbe7ff;font-size:11px;font-weight:800;white-space:nowrap}.search-empty{padding:12px;color:var(--muted);font-size:13px}.search-open-first{min-height:34px;border:1px solid var(--line);border-radius:10px;display:flex;align-items:center;justify-content:center;gap:8px;background:hsla(0,0%,100%,.06);color:#dce7ff;font-weight:800}.spin{animation:spin .9s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}.top-actions{display:flex;align-items:center;justify-content:flex-end;gap:10px}.icon-button{position:relative;width:38px;min-height:38px;border:0;border-radius:12px;background:transparent;color:#d9e4f4}.notification-dot{position:absolute;top:3px;right:2px;min-width:18px;height:18px;border-radius:999px;display:grid;place-items:center;background:#ef4354;color:#fff;font-size:11px;font-weight:800}.content{padding:8px 22px 22px;display:grid;grid-gap:14px;gap:14px;max-width:100%;overflow-x:hidden}.panel{background:linear-gradient(180deg,rgba(32,43,66,.92),rgba(20,28,45,.96));border:1px solid var(--line);border-radius:12px;box-shadow:0 18px 45px rgba(0,0,0,.22)}.panel-pad{padding:18px}.grid{display:grid;grid-gap:14px;gap:14px}.grid-5{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.grid-4{grid-template-columns:repeat(auto-fit,minmax(190px,1fr))}.grid-3{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}.dashboard-grid{display:grid;grid-template-columns:minmax(0,1.15fr) minmax(0,1fr);grid-gap:14px;gap:14px;min-width:0}.dashboard-top-grid{grid-template-columns:minmax(0,1.55fr) minmax(300px,.7fr);grid-gap:14px}.dashboard-analysis-grid,.dashboard-top-grid{display:grid;gap:14px;min-width:0;align-items:stretch}.dashboard-analysis-grid{grid-template-columns:minmax(0,1.15fr) minmax(300px,.85fr);grid-gap:14px}.bottom-dashboard-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-gap:14px;gap:14px;min-width:0}.stat{min-height:112px;padding:14px;display:grid;grid-template-columns:48px minmax(0,1fr);align-items:center;grid-gap:14px;gap:14px}.stat-icon{width:48px;height:48px;border-radius:14px;display:grid;place-items:center;color:#fff}.stat strong{display:block;margin-top:5px;font-size:24px;overflow-wrap:anywhere}.stat small{display:block;margin-top:6px;color:var(--green);font-weight:800}.drill-link,.drill-row,.mini-metric-link{transition:border-color .18s ease,transform .18s ease,background .18s ease}.drill-link:hover,.drill-row:hover,.mini-metric-link:hover{border-color:rgba(76,125,255,.56);background:rgba(76,125,255,.08);transform:translateY(-1px)}.detail-hint{display:inline-flex;align-items:center;width:-moz-fit-content;width:fit-content;margin-top:9px;color:#8fb0ff;font-size:12px;font-weight:800}.inline-link{color:#9bb7ff;font-weight:800}.inline-link:hover{color:#fff}.muted{color:var(--muted)}.button{min-height:40px;border:1px solid transparent;border-radius:8px;padding:0 12px;display:inline-flex;align-items:center;justify-content:center;gap:8px;font-weight:750}.button-primary{background:var(--brand);color:#fff}.button-primary:hover{background:var(--brand-dark)}.button-secondary{background:hsla(0,0%,100%,.06);color:var(--text);border-color:var(--line)}.button-danger{background:rgba(255,93,108,.13);color:#ffb8bf;border-color:rgba(255,93,108,.28)}.input,.select,.textarea{width:100%;min-height:42px;border:1px solid var(--line-strong);border-radius:8px;padding:0 11px;background:hsla(0,0%,100%,.06);color:var(--text)}.select option{background:#111827;color:var(--text)}.textarea{min-height:84px;padding-top:9px}.form-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));grid-gap:12px;gap:12px;align-items:end}.vehicle-form-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.vehicle-form-submit{min-width:0;width:100%}.section-heading{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.section-actions{display:flex;gap:8px;flex-wrap:wrap}.field{display:grid;grid-gap:5px;gap:5px}.field span{font-size:13px;color:var(--muted)}.table-wrap{overflow-x:auto}.vehicle-card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));grid-gap:12px;gap:12px;margin-top:12px;min-width:0}.vehicle-card{min-width:0;border:1px solid var(--line);border-radius:10px;background:hsla(0,0%,100%,.035);padding:14px}.vehicle-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding-bottom:12px;border-bottom:1px solid rgba(148,163,184,.12)}.vehicle-plate-link{display:inline-block;font-size:20px;line-height:1.2}.vehicle-card-fields{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));grid-gap:10px;gap:10px;margin-top:12px}.vehicle-field{min-width:0;display:grid;grid-gap:4px;gap:4px;border-radius:8px;padding:9px;background:hsla(0,0%,100%,.035)}.vehicle-field span{color:var(--muted);font-size:12px;font-weight:750}.vehicle-field strong{min-width:0;color:var(--text);font-size:14px;overflow-wrap:anywhere}table{width:100%;border-collapse:collapse;min-width:680px}th{text-align:left;color:#aab6c8;font-size:13px;font-weight:800}td,th{padding:12px 10px;border-top:1px solid rgba(148,163,184,.11)}thead th{border-top:0}.metric-strip{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));grid-gap:0;gap:0;overflow:hidden}.metric-strip>div{padding:18px 22px;border-right:1px solid var(--line)}.metric-strip>div:last-child{border-right:0}.detail-toolbar{display:flex;flex-wrap:wrap;gap:10px}.vehicle-hero{display:flex;align-items:center;justify-content:space-between;gap:16px}.vehicle-hero h2{margin:4px 0 5px;font-size:34px}.info-tile{display:grid;grid-gap:8px;gap:8px}.info-tile small,.info-tile span{color:var(--muted)}.info-tile strong{font-size:21px;overflow-wrap:anywhere}.report-download-card{width:100%;min-height:138px;border:1px solid var(--line);color:var(--text);text-align:left;display:grid;align-content:center;grid-gap:8px;gap:8px}.report-download-card:hover{border-color:rgba(76,125,255,.56);background:rgba(76,125,255,.08)}.mini-metric-link{display:block;min-height:100%;padding:16px 18px;border-right:1px solid var(--line)}.metric-strip .mini-metric-link:last-child{border-right:0}.chart-card{min-height:280px;min-width:0}.line-chart{height:195px;margin-top:14px}.donut-wrap{display:flex;align-items:center;gap:18px;min-height:220px;flex-wrap:wrap}.donut{width:148px;height:148px;border-radius:50%;display:grid;place-items:center;background:conic-gradient(var(--green) 0 68%,#71b7ff 68% 75%,var(--orange) 75% 88%,#6b7280 88% 100%);position:relative}.donut:after{content:"";position:absolute;width:84px;height:84px;border-radius:50%;background:#151c2d}.donut-center{position:relative;z-index:1;text-align:center}.legend{grid-gap:8px;color:#d7deea;min-width:170px;flex:1 1}.legend,.legend-row{display:grid;gap:8px}.legend-row{grid-template-columns:12px minmax(0,1fr) auto;grid-gap:8px;align-items:center;min-height:30px;border-radius:8px;padding:0 6px}.legend-dot{width:12px;height:12px;border-radius:999px}.map-panel{min-height:300px;position:relative;overflow:hidden}.dashboard-map{min-height:360px}.dashboard-map .map-canvas{height:292px}.dashboard-side-panel{min-height:360px}.dashboard-monthly-card{min-height:310px}.map-canvas{position:relative;height:225px;border-radius:10px;overflow:hidden;background:#111827}.real-map-canvas{border:1px solid rgba(148,163,184,.22);background:radial-gradient(circle at 32% 42%,rgba(76,125,255,.18),transparent 34%),#101827;box-shadow:inset 0 0 0 1px hsla(0,0%,100%,.03)}.map-tiles{position:absolute;inset:0;overflow:hidden;filter:brightness(.8) contrast(1.18) saturate(.78)}.map-tiles img{position:absolute;object-fit:cover;-webkit-user-select:none;-moz-user-select:none;user-select:none}.map-shade{position:absolute;inset:0;background:radial-gradient(circle at 28% 44%,rgba(76,125,255,.18),transparent 28%),radial-gradient(circle at 64% 52%,rgba(107,212,124,.08),transparent 22%),linear-gradient(180deg,rgba(9,15,29,.1),rgba(9,15,29,.42));pointer-events:none}.vehicle-count-marker{position:absolute;z-index:4;display:grid;justify-items:center;grid-gap:8px;gap:8px;transform:translate(-50%,-50%);outline:none}.vehicle-count-pin{position:relative;min-width:54px;height:54px;border-radius:18px;display:inline-grid;grid-template-columns:1fr;align-items:center;justify-content:center;place-items:center;padding:0;color:#fff;border:1px solid hsla(0,0%,100%,.72);box-shadow:0 18px 36px rgba(0,0,0,.42),0 0 0 8px rgba(76,125,255,.12);transition:transform .18s ease,box-shadow .18s ease}.vehicle-count-pin:after{content:"";position:absolute;left:50%;bottom:-9px;width:16px;height:16px;background:inherit;border-right:1px solid hsla(0,0%,100%,.72);border-bottom:1px solid hsla(0,0%,100%,.72);transform:translateX(-50%) rotate(45deg);border-bottom-right-radius:4px}.vehicle-count-pin svg{position:relative;z-index:1}.vehicle-count-pin strong{position:absolute;z-index:2;right:-9px;top:-9px;min-width:25px;height:25px;padding:0 7px;border-radius:999px;display:grid;place-items:center;background:#eef4ff;color:#111827;border:2px solid rgba(17,24,39,.9);font-size:13px;line-height:1;box-shadow:0 10px 18px rgba(0,0,0,.28)}.vehicle-count-label{max-width:130px;padding:6px 10px;border-radius:10px;background:rgba(9,15,29,.82);color:#eef4ff;border:1px solid rgba(148,163,184,.22);box-shadow:0 14px 30px rgba(0,0,0,.3);font-size:12px;font-weight:900;white-space:nowrap;text-align:center;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.vehicle-count-marker:focus-visible,.vehicle-count-marker:hover{z-index:9}.vehicle-count-marker:focus-visible .vehicle-count-pin,.vehicle-count-marker:hover .vehicle-count-pin{transform:translateY(-2px) scale(1.05);box-shadow:0 22px 42px rgba(0,0,0,.46),0 0 0 10px rgba(76,125,255,.16)}.map-marker{position:absolute;width:34px;height:34px;border-radius:999px;display:grid;place-items:center;color:#fff;box-shadow:0 8px 18px rgba(0,0,0,.26)}.map-location-link .map-marker{position:static}.map-marker small{right:-6px;top:-6px;min-width:18px;height:18px;padding:0 4px;border-radius:999px;background:#f05b6b;place-items:center;font-size:10px;font-weight:900}.map-empty,.map-marker small{position:absolute;display:grid}.map-empty{inset:0;place-items:center;z-index:5;background:rgba(9,15,29,.42)}.bar-list{grid-gap:12px;margin-top:14px}.bar-list,.bar-row{display:grid;gap:12px}.bar-row{grid-template-columns:84px minmax(0,1fr) 62px;align-items:center;grid-gap:12px;min-height:34px;border-radius:8px;padding:0 6px}.bar-track{height:10px;border-radius:999px;background:hsla(0,0%,100%,.07);overflow:hidden}.bar-fill{height:100%;border-radius:inherit;background:linear-gradient(90deg,#4c7dff,#73a2ff)}.activity-list{display:grid;grid-gap:12px;gap:12px;margin-top:14px}.activity-row{display:grid;grid-template-columns:38px minmax(0,1fr);grid-gap:12px;gap:12px;align-items:center}.activity-icon{width:38px;height:38px;border-radius:12px;display:grid;place-items:center;color:#fff}.login-page{min-height:100vh;display:grid;place-items:center;padding:20px}.login-card{width:min(430px,100%);padding:24px}.upload-box{min-height:210px;display:grid;place-items:center;text-align:center;padding:18px;border:1px dashed var(--line-strong);border-radius:10px;background:hsla(0,0%,100%,.04)}@media (max-width:1240px){.bottom-dashboard-grid,.dashboard-analysis-grid,.dashboard-grid,.dashboard-top-grid,.grid-5,.metric-strip{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width:1480px){.bottom-dashboard-grid,.dashboard-analysis-grid,.dashboard-grid,.dashboard-top-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width:980px){.app-shell{grid-template-columns:1fr}.sidebar{position:relative;height:auto}.nav{grid-template-columns:repeat(2,minmax(0,1fr))}.bottom-dashboard-grid,.dashboard-analysis-grid,.dashboard-grid,.dashboard-top-grid,.form-grid,.grid-2,.grid-3,.grid-4,.grid-5,.metric-strip{grid-template-columns:1fr}.dashboard-map,.dashboard-side-panel{min-height:0}.dashboard-map .map-canvas,.map-canvas{height:240px}.topbar{grid-template-columns:1fr;padding:18px}.top-actions{justify-content:flex-start}.content{padding:8px 18px 18px}}