:root{--bg:#f2f4f8;--sidebar-bg:#243f95;--sidebar-bg-deeper:#233a88;--sidebar-text:#f4f7ff;--sidebar-text-muted:#c7d2f5;--sidebar-hover:#ffffff1a;--nav-active-start:#7e49ec;--nav-active-end:#b93ef3;--panel:#fff;--line:#dce3ee;--line-dark:#c7d1e0;--text:#1c2738;--muted:#66758d;--blue:#2d62e6;--blue-soft:#edf3ff;--green:#1f9853;--amber:#c67510;--red:#c93434}*{box-sizing:border-box}html,body{background:var(--bg);min-height:100%;color:var(--text);margin:0;padding:0;font-family:Plus Jakarta Sans,Segoe UI,sans-serif}a{color:inherit;text-decoration:none}button,input,select{font:inherit}.app-shell{grid-template-columns:212px 1fr;min-height:100vh;display:grid}.app-shell.sidebar-collapsed{grid-template-columns:76px 1fr}.sidebar{background:linear-gradient(180deg,var(--sidebar-bg)0%,var(--sidebar-bg-deeper)100%);border-right:none;flex-direction:column;align-self:start;gap:10px;height:100dvh;padding:12px 9px;display:flex;position:sticky;top:0}.sidebar.collapsed{padding:12px 8px}.brand-row{justify-content:space-between;align-items:center;gap:8px;display:flex;position:relative}.brand{align-items:center;gap:8px;padding:7px 8px;display:flex}.sidebar-toggle{width:28px;height:28px;color:var(--sidebar-text);cursor:pointer;background:#ffffff14;border:1px solid #fff3;border-radius:8px;font-weight:700}.sidebar.collapsed .brand-row{justify-content:center}.sidebar.collapsed .sidebar-toggle{border-radius:6px;width:20px;height:20px;padding:0;font-size:11px;position:absolute;top:12px;right:6px}.brand-pin{width:20px;height:20px;color:var(--blue);background:#fffffff0;border-radius:999px;place-items:center;font-size:14px;display:grid}.brand-title{color:var(--sidebar-text);margin:0;font-size:14px;font-weight:700}.brand-subtitle{color:var(--sidebar-text-muted);margin:0;font-size:11px}.nav{flex-direction:column;gap:3px;display:flex}.nav-link{color:var(--sidebar-text);border:1px solid #0000;border-radius:10px;align-items:center;gap:9px;padding:8px 10px;font-size:14px;font-weight:600;display:flex}.nav-icon{justify-content:center;align-items:center;width:18px;height:18px;display:inline-flex}.nav-icon svg{fill:currentColor;width:18px;height:18px}.nav-link:hover{background:var(--sidebar-hover)}.nav-link.active{color:#fff;background:linear-gradient(90deg,var(--nav-active-start)0%,var(--nav-active-end)100%);border-color:#ffffff1f;box-shadow:0 6px 14px #7136e657}.sidebar.collapsed .nav-link{justify-content:center;padding:8px 0}.nav-label{white-space:nowrap}.sidebar-footer{margin-top:auto;padding:8px 2px 2px;font-size:12px;position:relative}.profile-menu{position:relative}.sidebar-meta{text-overflow:ellipsis;white-space:nowrap;color:var(--sidebar-text-muted);font-size:12px;display:block;overflow:hidden}.profile-trigger{width:100%;min-height:40px;color:var(--sidebar-text);background:#ffffff12;border:1px solid #ffffff2e;border-radius:10px;align-items:center;gap:8px;padding:6px 8px;display:flex}.profile-trigger.collapsed{justify-content:center;padding:6px}.profile-avatar{color:#fff;background:linear-gradient(145deg,#7d4eeb,#b743ef);border-radius:999px;justify-content:center;align-items:center;width:26px;height:26px;font-size:11px;font-weight:700;display:inline-flex}.profile-meta-wrap{text-align:left;flex:1;min-width:0}.profile-chevron{color:var(--sidebar-text-muted);font-size:11px}.profile-dropdown{border:1px solid var(--line);z-index:20;background:#fff;border-radius:10px;position:absolute;bottom:calc(100% + 8px);left:0;right:0;overflow:hidden;box-shadow:0 12px 24px #0f172a26}.profile-dropdown.collapsed{min-width:170px;left:0;right:auto}.profile-dropdown-item{text-align:left;color:#334155;background:0 0;border:none;width:100%;padding:9px 10px;font-size:13px;display:block}.profile-dropdown-item:hover{background:#f8fafc}.profile-dropdown-item.danger{color:#b91c1c}.content-shell{padding:0}.page{padding:18px 22px}.page-header{justify-content:space-between;align-items:center;gap:14px;margin-bottom:14px;display:flex}.page-header h1{letter-spacing:-.03em;color:var(--text);margin:0;font-size:31px;font-weight:700}.page-actions{align-items:center;gap:8px;display:flex}.button{border:1px solid var(--line-dark);background:var(--panel);color:#334155;border-radius:10px;align-items:center;gap:8px;height:38px;padding:0 13px;font-size:14px;font-weight:600;display:inline-flex}.button:hover{cursor:pointer;background:#f7f9fc}.button-primary{background:var(--blue);border-color:var(--blue);color:#fff}.button-primary:hover{background:#2958d0}.button-danger-subtle{color:#b91c1c;background:#fff5f5;border-color:#fecaca}.button-danger-subtle:hover{background:#fee2e2}.button-subtle{color:#2959d2;background:#f6f9ff;border-color:#d5d9e2}.top-row{align-items:center;gap:10px;margin-bottom:10px;display:flex}.spacer{margin-left:auto}.control,.field,.select{border:1px solid var(--line-dark);color:#334155;background:#fff;border-radius:10px;min-width:170px;height:38px;padding:0 11px}.control-compact{min-width:140px}.search-field{flex:1;min-width:280px}.places-lookup-wrap{position:relative}.places-lookup-menu{border:1px solid var(--line-dark);z-index:30;background:#fff;border-radius:10px;max-height:220px;position:absolute;top:calc(100% + 6px);left:0;right:0;overflow:auto;box-shadow:0 12px 22px #0f172a1f}.places-lookup-item{text-align:left;color:#334155;background:0 0;border:none;width:100%;padding:9px 11px;font-size:13px;display:block}button.places-lookup-item{cursor:pointer}.places-lookup-item+.places-lookup-item{border-top:1px solid #edf1f6}button.places-lookup-item:hover{background:#f7f9ff}.places-lookup-item.muted{color:#64748b}.places-lookup-item.error{color:#9f1239;background:#fff1f2}.status-tabs{align-items:center;gap:6px;display:flex}.status-tab{color:#4b5563;background:0 0;border:1px solid #0000;border-radius:999px;height:32px;padding:0 12px;font-size:13px;font-weight:600}.status-tab.active{background:var(--blue-soft);color:#234fcd;border-color:#ced7ff}.filters-row,.toolbar{border:1px solid var(--line);background:var(--panel);border-radius:12px;flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:10px;padding:10px;display:flex}.chip{border:1px solid var(--line-dark);color:#4b5563;background:#fff;border-radius:9px;height:34px;padding:0 10px;font-size:13px;font-weight:600}.table-card,.table-wrap,.panel,.card{border:1px solid var(--line);background:var(--panel);border-radius:14px;overflow:hidden}.table{border-collapse:collapse;width:100%}.table th,.table td{text-align:left;vertical-align:middle;border-bottom:1px solid #edf1f6;padding:10px 12px;font-size:13px}.table th{color:#5f6d86;background:#f7f9fd;font-weight:600}.table tr:last-child td{border-bottom:none}.table-title{color:#111827;font-weight:600}.table-sub{color:#6b7280;margin-top:2px;font-size:12px}.status-dot{background:#94a3b8;border-radius:999px;width:8px;height:8px;margin-right:6px;display:inline-block}.badge{border:1px solid var(--line-dark);border-radius:999px;align-items:center;height:24px;padding:0 9px;font-size:12px;font-weight:600;display:inline-flex}.badge.unassigned{color:#475569;background:#f8fafc}.badge.assigned{color:#1d4ed8;background:#edf4ff;border-color:#bfdbfe}.badge.in_progress{color:#b45309;background:#fff7ed;border-color:#fdba74}.badge.completed{color:#166534;background:#f0fdf4;border-color:#86efac}.badge.failed{color:#991b1b;background:#fef2f2;border-color:#fca5a5}.route-pill{color:#475569;background:#f9fbff;border:1px solid #d8deea;border-radius:999px;padding:4px 10px;font-size:12px}.avatar{color:#3b4a67;background:#e9ecf5;border-radius:999px;justify-content:center;align-items:center;width:28px;height:28px;font-size:12px;font-weight:700;display:inline-flex}.grid-2{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.grid-3{grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;display:grid}.kpi-strip{border:1px solid var(--line);background:#fff;border-radius:12px;grid-template-columns:repeat(4,minmax(0,1fr));gap:0;display:grid;overflow:hidden}.kpi-item{border-right:1px solid #edf1f6;padding:14px}.kpi-item:last-child{border-right:none}.kpi-value{letter-spacing:-.02em;font-size:26px;font-weight:700;line-height:1}.kpi-label{color:var(--muted);margin-top:6px;font-size:12px}.kpi-mini{color:var(--muted);font-size:12px}.dashboard-date-picker{align-items:center;gap:8px;display:inline-flex}.dashboard-kpi-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;display:grid}.routes-kpi-grid{grid-template-columns:repeat(4,minmax(0,1fr));margin-bottom:12px}.routes-detail-kpis{grid-template-columns:repeat(5,minmax(0,1fr))}.dashboard-kpi-card{border:1px solid var(--line);background:#fff;border-radius:12px;padding:14px}.dashboard-kpi-card .kpi-value{margin-bottom:4px}.dashboard-section-header{justify-content:space-between;align-items:center;gap:10px;display:flex}.dashboard-driver-list{border:1px solid #edf1f6;border-radius:12px;max-height:360px;margin-top:10px;overflow:auto}.dashboard-driver-row{border-bottom:1px solid #edf1f6;align-items:center;gap:8px;padding:10px 12px;display:flex}.dashboard-driver-row:last-child{border-bottom:none}.dashboard-driver-link{color:#1e293b;flex:1;font-weight:600}.dashboard-route-grid{gap:10px;margin-top:10px;display:grid}.dashboard-route-card{border:1px solid var(--line);cursor:pointer;background:#fff;border-radius:12px;padding:12px}.dashboard-route-card:hover{border-color:#c8d2e5;box-shadow:0 6px 16px #1f293714}.dashboard-route-head{justify-content:space-between;align-items:flex-start;gap:10px;display:flex}.dashboard-route-title{letter-spacing:-.02em;font-size:18px;font-weight:700}.dashboard-route-sub{color:#64748b;margin-top:4px;font-size:12px}.dashboard-route-trash{background:#fff;border:1px solid #e2e8f0;border-radius:8px;min-width:30px;height:30px}.dashboard-route-metrics{flex-wrap:wrap;align-items:center;gap:8px;margin-top:10px;display:flex}.dashboard-status-badge{border:1px solid #e2e8f0;border-radius:999px;padding:3px 9px;font-size:12px;font-weight:700}.dashboard-status-badge.scheduled{color:#475569;background:#f8fafc;border-color:#cbd5e1}.dashboard-status-badge.in_progress{color:#1d4ed8;background:#eef4ff;border-color:#bfdbfe}.dashboard-status-badge.completed{color:#166534;background:#f0fdf4;border-color:#86efac}.dashboard-status-badge.failed{color:#991b1b;background:#fef2f2;border-color:#fca5a5}.dashboard-stop-icon{font-size:12px;font-weight:700}.dashboard-stop-icon.completed{color:#15803d}.dashboard-stop-icon.failed{color:#b91c1c}.dashboard-stop-icon.pending{color:#64748b}.dashboard-progress{background:#e2e8f0;border-radius:999px;height:8px;margin-top:10px;overflow:hidden}.dashboard-progress-bar{background:var(--blue);height:100%}.dashboard-progress-label{color:#64748b;margin-top:5px;font-size:12px}.dashboard-stop-links{gap:5px;margin-top:10px;display:grid}.dashboard-stop-link{color:#244ecd;font-size:13px}.dashboard-stop-link:hover{text-decoration:underline}.routes-filter-bar{grid-template-columns:minmax(240px,1.8fr) repeat(3,minmax(150px,1fr)) auto;gap:8px;margin-bottom:12px;display:grid}.routes-search{min-width:0}.routes-card-grid{gap:10px;display:grid}.routes-card{border:1px solid var(--line);cursor:pointer;background:#fff;border-radius:12px;padding:12px}.routes-card:hover{border-color:#c8d2e5;box-shadow:0 6px 16px #1f293714}.routes-card-head{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.routes-card-head h3{letter-spacing:-.02em;margin:0;font-size:18px}.routes-card-sub{color:#64748b;margin-top:4px;font-size:12px}.routes-card-actions{gap:8px;display:inline-flex}.routes-card-badges{flex-wrap:wrap;gap:8px;margin-top:10px;display:flex}.routes-card-footer{margin-top:10px}.routes-driver-picker{border:1px solid #edf1f6;border-radius:12px;width:min(100%,700px);max-height:220px;overflow:auto}.routes-driver-option{border-bottom:1px solid #edf1f6;align-items:center;gap:8px;padding:10px 12px;display:flex}.routes-driver-option:last-child{border-bottom:none}.routes-radio-group{gap:8px;width:min(100%,700px);display:grid}.routes-radio-group label{color:#334155;align-items:center;gap:8px;font-size:14px;display:flex}.routes-tabs{gap:8px;margin-bottom:12px;display:inline-flex}.routes-manual-list{gap:10px;display:grid}.routes-manual-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:10px}.routes-manual-head{justify-content:space-between;align-items:center;gap:8px;margin-bottom:8px;display:flex}.routes-import-panel{gap:10px;display:grid}.routes-import-controls{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.routes-inline-toggle{color:#334155;align-items:center;gap:7px;font-size:13px;display:inline-flex}.routes-import-preview{gap:10px;display:grid}.routes-mapping-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;display:grid}.routes-mapping-grid label{gap:5px;display:grid}.routes-detail-meta{flex-wrap:wrap;align-items:center;gap:8px;margin-top:10px;display:flex}.route-map-live{background:linear-gradient(145deg,#f8fbff 0%,#edf2fb 100%);border:1px solid #e2e8f0;border-radius:12px;height:320px;margin-top:12px;position:relative;overflow:hidden}.route-map-live svg{width:100%;height:100%;display:block}.route-stop-dot{stroke:#fff;stroke-width:.8px}.route-stop-dot.unassigned{fill:#94a3b8}.route-stop-dot.in_progress{fill:var(--blue)}.route-stop-dot.completed{fill:#16a34a}.route-stop-dot.failed{fill:#dc2626}.route-stop-dot.cancelled{fill:#64748b}.route-stop-marker{color:#1e293b;cursor:pointer;background:#fff;border:1px solid #0f172a33;border-radius:999px;place-items:center;width:24px;height:24px;margin:0;font-size:11px;font-weight:700;display:grid;position:absolute;transform:translate(-50%,-50%)}.route-stop-marker:hover{border-color:var(--blue);color:#1d4ed8}.route-driver-marker{border:2px solid var(--blue);color:#1e293b;cursor:pointer;z-index:2;background:#fff;border-radius:999px;place-items:center;width:26px;height:26px;font-size:10px;font-weight:700;display:grid;position:absolute;transform:translate(-50%,-50%)}.routes-driver-metrics{gap:6px;margin-top:10px;display:grid}.routes-driver-metric{color:#334155;align-items:center;gap:6px;font-size:13px;display:flex}.confirm-overlay{z-index:70;background:#0f172a59;place-items:center;padding:16px;display:grid;position:fixed;inset:0}.confirm-modal{border:1px solid var(--line);background:#fff;border-radius:12px;width:min(100%,430px);padding:16px;box-shadow:0 20px 40px #0f172a33}.confirm-modal h3{margin:0 0 8px}.confirm-modal p{color:#475569;margin:0;font-size:14px}.confirm-error{color:#b91c1c!important;margin-top:10px!important}.confirm-actions{justify-content:flex-end;gap:8px;margin-top:14px;display:flex}.route-map-placeholder{background:linear-gradient(145deg,#f8fbff 0%,#edf2fb 100%);border:1px solid #e2e8f0;border-radius:12px;margin-top:12px;padding:8px}.route-map-placeholder svg{width:100%;height:220px;display:block}.card{padding:14px}.card h3,.panel h3{margin:0 0 10px;font-size:18px}.panel{padding:0}.panel-body{padding:14px}.list{margin:0;padding:0;list-style:none}.list li{border-bottom:1px solid #edf1f6;padding:10px 0}.list li:last-child{border-bottom:none}.empty-state{color:#6b7280;text-align:center;background:#fbfcfe;border:1px dashed #d5dbe7;border-radius:14px;padding:48px 16px}.layout-main-side{grid-template-columns:minmax(0,2fr) minmax(300px,1fr);gap:12px;display:grid}.calendar-grid{grid-template-columns:repeat(7,minmax(0,1fr));gap:6px;margin-top:10px;display:grid}.calendar-cell{text-align:center;color:#64748b;border:1px solid #e7ebf2;border-radius:8px;padding:8px 0;font-size:12px}.calendar-cell.active{color:#fff;background:#2d5de8;border-color:#2d5de8;font-weight:600}.driver-line{border-bottom:1px solid #edf1f6;align-items:center;gap:10px;padding:8px 0;display:flex}.driver-line:last-child{border-bottom:none}.driver-line-main{flex:1}.driver-line-name{font-size:14px;font-weight:600}.driver-line-sub{color:#6b7280;margin-top:2px;font-size:12px}.metric-grid{border-top:1px solid #edf1f6;grid-template-columns:repeat(3,minmax(0,1fr));margin-top:10px;display:grid}.metric-cell{border-right:1px solid #edf1f6;padding:12px}.metric-cell:last-child{border-right:none}.sparkline{width:100%;height:34px;margin-top:8px;display:block}.sparkline path{fill:none;stroke:var(--blue);stroke-width:2px}.controls-tiles{grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;display:grid}.tile{border:1px solid var(--line);background:#fff;border-radius:14px;flex-direction:column;gap:8px;padding:16px;display:flex}.tile h3{letter-spacing:-.02em;margin:0;font-size:22px}.tile p{color:#6b7280;margin:0;font-size:14px;line-height:1.45}.tile-link{color:var(--blue);margin-top:4px;font-size:14px;font-weight:600}.settings-section-nav{margin:0 0 14px}.settings-section-nav-list{border:1px solid var(--line);background:#eef2f8;border-radius:10px;align-items:center;gap:2px;width:100%;max-width:100%;padding:3px;display:flex;overflow-x:auto}.settings-section-actions{justify-content:flex-end;margin:0 0 14px;display:flex}.settings-section-link{color:#5c6678;white-space:nowrap;border-radius:8px;align-items:center;height:32px;padding:0 12px;font-size:14px;font-weight:600;display:inline-flex}.settings-section-link:hover{color:#334155;background:#ffffff94}.settings-section-link.active{color:#111827;background:#fff;box-shadow:0 1px 2px #0f172a1a}.control-tabs{border-bottom:1px solid var(--line);width:100%;margin-bottom:10px;display:inline-flex}.control-tab{color:#4b5563;background:0 0;border:none;border-bottom:2px solid #0000;height:40px;padding:0 18px 10px;font-weight:600}.control-tab.active{color:var(--blue);border-bottom-color:var(--blue)}.driver-detail-tab-nav{margin:0 0 12px}.driver-detail-tab-list{border:1px solid var(--line);background:#eef2f8;border-radius:10px;align-items:center;gap:2px;padding:3px;display:inline-flex}.driver-detail-tab{color:#5c6678;white-space:nowrap;background:0 0;border:none;border-radius:8px;align-items:center;height:32px;padding:0 12px;font-size:14px;font-weight:600;display:inline-flex}.driver-detail-tab:hover{color:#334155;cursor:pointer;background:#ffffff94}.driver-detail-tab.active{color:#111827;background:#fff;box-shadow:0 1px 2px #0f172a1a}.settings-block{border:1px solid var(--line);background:#fff;border-radius:12px;margin-bottom:10px;overflow:hidden}.settings-title{border-bottom:1px solid #edf1f6;padding:12px 14px;font-weight:700}.settings-row{border-bottom:1px solid #edf1f6;justify-content:space-between;align-items:center;gap:10px;padding:12px 14px;display:flex}.settings-row:last-child{border-bottom:none}.settings-row-label{font-size:14px;font-weight:600}.settings-row-sub{color:#6b7280;margin-top:2px;font-size:12px}.toggle{background:#e5e7eb;border:1px solid #d0d7e3;border-radius:999px;width:38px;height:22px;position:relative}.toggle:after{content:"";background:#fff;border-radius:999px;width:16px;height:16px;position:absolute;top:2px;left:2px;box-shadow:0 1px 2px #0000002e}.toggle.on{background:var(--blue);border-color:var(--blue)}.toggle.on:after{left:18px}.accordion{border:1px solid var(--line);background:#fff;border-radius:12px;margin-bottom:10px}.accordion summary{cursor:pointer;justify-content:space-between;align-items:center;padding:12px 14px;font-weight:700;list-style:none;display:flex}.accordion summary::-webkit-details-marker{display:none}.accordion-content{border-top:1px solid #edf1f6}.event-table{border:1px solid var(--line);background:#fff;border-radius:12px;overflow:hidden}.event-row{border-bottom:1px solid #edf1f6;grid-template-columns:minmax(0,1fr) 190px;align-items:center;gap:10px;padding:10px 14px;display:grid}.event-row:last-child{border-bottom:none}.event-name{font-size:14px;font-weight:600}.event-sub{color:#6b7280;margin-top:2px;font-size:12px}.event-row-header{background:#f8fafc}.event-send-header{color:#6b7280;justify-self:end;font-size:12px;font-weight:600}.event-channel-options{justify-content:flex-end;gap:12px;display:flex}.event-channel-option{color:#4b5563;align-items:center;gap:6px;font-size:13px;display:flex}.event-channel-option input{accent-color:#2f65d9}.channel-pills{gap:6px;display:flex}.channel-pill{color:#4b5563;background:#f8fafc;border:1px solid #d5dce9;border-radius:999px;padding:2px 7px;font-size:12px}.recipient-choices{gap:8px;display:grid}.choice{align-items:flex-start;gap:9px;padding:6px 0;display:flex}.choice .dot{border:1.5px solid #9aa3b2;border-radius:999px;width:14px;height:14px;margin-top:4px}.choice.active .dot{background:#2563eb;border-color:#2563eb;box-shadow:inset 0 0 0 3px #fff}.choice-title{font-size:14px;font-weight:600}.choice-sub{color:#6b7280;margin-top:2px;font-size:12px}.info-banner{color:#345;background:#eef4ff;border:1px solid #d8e4ff;border-radius:10px;padding:11px 12px;font-size:13px}.inset-note{color:#6b7280;margin-top:8px;font-size:12px}.auth-page{min-height:100vh;padding:0}.auth-layout{background:var(--bg);grid-template-columns:minmax(450px,40%) 1fr;min-height:100vh;display:grid}.auth-left{justify-content:center;align-items:center;padding:40px 36px;display:flex}.auth-left-inner{width:min(100%,392px)}.auth-icon-wrap{background:#eef3ff;border:1px solid #d8e0ee;border-radius:16px;place-items:center;width:76px;height:76px;margin-bottom:34px;display:grid}.auth-icon-dot{background:var(--blue);color:#fff;border-radius:999px;place-items:center;width:36px;height:36px;font-size:20px;font-weight:700;display:grid}.auth-title{letter-spacing:-.04em;color:var(--text);margin:0;font-size:42px;line-height:1.08}.auth-subtitle{letter-spacing:-.01em;color:#50607a;margin:8px 0 0;font-size:19px;font-weight:500}.auth-form{margin-top:22px}.auth-form-row{justify-content:space-between;align-items:center;gap:12px;display:flex}.auth-label{color:#37425a;font-size:14px;font-weight:600;display:block}.auth-quick-action{color:#fff;background:#06070a;border:none;border-radius:999px;height:30px;padding:0 12px;font-size:14px;font-weight:700}.auth-input{border-color:var(--line-dark);color:#1f2937;background:#fff;border-radius:10px;width:100%;min-width:0;height:44px;margin-top:8px;padding:0 12px;font-size:14px}.auth-input::placeholder{color:#8994a8}.auth-link{color:var(--blue);cursor:pointer;background:0 0;border:none;padding:0;font-size:13px;font-weight:600}.auth-link:hover{text-decoration:underline}.auth-link:disabled{opacity:.65;cursor:not-allowed;text-decoration:none}.auth-password-wrap{margin-top:8px;position:relative}.auth-password-wrap .auth-input{margin-top:0}.auth-input-password{padding-right:84px}.auth-eye{color:#465670;background:#f8fafc;border:1px solid #d5dce9;border-radius:8px;justify-content:center;align-items:center;height:24px;padding:0 8px;font-size:12px;font-weight:700;display:inline-flex;position:absolute;top:50%;right:8px;transform:translateY(-50%)}.auth-submit,.auth-google{border-radius:10px;justify-content:center;width:100%;height:42px;margin-top:12px;font-size:14px;font-weight:600}.auth-submit{border-color:var(--blue);background:var(--blue);color:#fff}.auth-submit:disabled,.auth-google:disabled{opacity:.7}.auth-google{border:1px solid var(--line-dark);color:#30415c;background:#fff;gap:12px}.auth-google-icon{color:#fff;background:linear-gradient(45deg,#ea4335 0%,#fbbc05 46%,#34a853 74%,#4285f4 100%);border-radius:999px;place-items:center;width:18px;height:18px;font-size:10px;font-weight:700;display:grid}.auth-link-center{margin:12px auto 0;display:block}.auth-status{color:#475569;margin:12px 0 0;font-size:13px}.auth-status-error{color:#b91c1c;font-weight:700}.auth-status-success{color:#166534;font-weight:600}.auth-divider{border-top:1px solid #d7deea;margin-top:18px}.auth-signup-note{text-align:center;color:#4a566b;margin:14px 0 0;font-size:14px}.auth-signup-note span{color:#2d65d9;font-weight:700}.auth-right{color:#f4f8ff;background:radial-gradient(circle at 68% 82%,#4f76e65c,#4f76e600 44%),linear-gradient(134deg,#244698 0%,#1f3f8b 48%,#1e3a80 100%);border-radius:28px;flex-direction:column;margin:20px 20px 20px 0;padding:36px 34px 22px;display:flex}.auth-quote-block{max-width:760px}.auth-quote{letter-spacing:-.03em;margin:0;font-size:28px;line-height:1.28}.auth-dots{align-items:center;gap:10px;margin-top:30px;display:inline-flex}.auth-dots span{background:#e5ecff80;border-radius:999px;width:14px;height:14px}.auth-dots .active{background:#f2f7ff;border-radius:999px;width:40px}.auth-showcase{grid-template-columns:260px minmax(0,1fr);align-items:end;gap:18px;margin-top:auto;display:grid}.auth-phone-card{background:#f6f9ff;border:2px solid #d4dff1;border-radius:38px;overflow:hidden;box-shadow:0 16px 36px #0f254f66}.auth-mini-map{background:linear-gradient(135deg,#ecf1f9 0%,#d7e2f3 100%);height:252px;position:relative}.auth-mini-map:after{content:"";opacity:.8;border:3px solid #3a73e9;border-radius:12px;position:absolute;inset:20px}.auth-mini-list{padding:14px}.auth-mini-list div{background:linear-gradient(90deg,#e6edf8 0%,#d8e3f4 100%);border-radius:8px;height:32px;margin-bottom:8px}.auth-desktop-map{background:linear-gradient(135deg,#edf2fb 0%,#e2eaf8 38%,#d5e2f5 100%);border:1px solid #e3ebff80;border-radius:18px;height:450px;box-shadow:inset 0 0 0 1px #fff6}.depot-create-overlay{z-index:60;background:#12234252;place-items:center;padding:16px;display:grid;position:fixed;inset:0}.depot-create-modal{background:#fff;border:1px solid #d8dfeb;border-radius:14px;width:min(100%,520px);box-shadow:0 24px 48px #0f172a38}.depot-create-header{border-bottom:1px solid #e8edf5;justify-content:space-between;align-items:center;gap:12px;padding:14px 16px;display:flex}.depot-create-header h3{letter-spacing:-.01em;margin:0;font-size:20px}.depot-create-close{color:#3b4b62;background:#f8fafd;border:1px solid #d2dae6;border-radius:9px;height:34px;padding:0 10px;font-weight:600}.depot-create-form{padding:16px}.depot-create-label{color:#516178;margin-bottom:6px;font-size:13px;font-weight:600;display:block}.depot-create-input{color:#273447;background:#fff;border:1px solid #ced7e4;border-radius:10px;width:100%;height:40px;margin-bottom:12px;padding:0 12px}.depot-create-message{color:#c0392b;margin:0 0 12px;font-size:13px;font-weight:600}.depot-create-actions{justify-content:flex-end;gap:8px;margin-top:10px;display:flex}.depot-create-checkbox-row{gap:8px;margin-bottom:12px;display:grid}.depot-create-checkbox-row label{color:#46566f;font-size:13px}.depot-edit-actions{justify-content:flex-end;gap:8px;padding:8px 0 14px;display:flex}.driver-inline-meta{color:#64748b;align-items:center;gap:6px;margin-top:3px;font-size:12px;display:flex}.presence-dot{border-radius:999px;width:8px;height:8px;display:inline-block}.presence-dot.online{background:#16a34a}.presence-dot.offline{background:#dc2626}.driver-color-chip{border:1px solid #0f172a26;border-radius:999px;width:12px;height:12px;display:inline-block}.driver-color-row{align-items:center;gap:8px;display:flex}.driver-color-input{background:#fff;border:1px solid #cfd6e1;border-radius:10px;width:52px;height:38px;padding:4px}.driver-delete-wrap{flex-direction:column;gap:4px;display:flex}.driver-delete-error{color:#b91c1c;max-width:180px;font-size:11px}.driver-polyline-preview{background:#fcfdff;border:1px solid #edf1f6;border-radius:12px;margin-top:12px;padding:10px}.driver-polyline-preview svg{width:100%;height:140px;display:block}.driver-polyline-bg{fill:#f4f8ff;stroke:#dbe4f3}.driver-polyline-legend{grid-template-columns:repeat(2,minmax(0,1fr));gap:6px;margin-top:8px;display:grid}.driver-polyline-legend-item{color:#334155;align-items:center;gap:6px;font-size:12px;display:flex}.settings-textarea{resize:vertical;color:#273447;background:#fff;border:1px solid #ced7e4;border-radius:10px;width:100%;min-height:74px;margin-top:6px;padding:10px 12px}.company-logo-preview{object-fit:contain;background:#fff;border:1px solid #d7e0ea;border-radius:10px;max-width:220px;max-height:72px;margin-top:8px}.profile-logo-file-input{display:none}.profile-settings-inner{padding:14px}.profile-settings-intro{color:#56667f;margin:0 0 20px;font-size:15px}.profile-field{margin-bottom:22px}.profile-field-last{margin-bottom:0}.profile-control-full{width:100%}.profile-logo-row{align-items:flex-start;gap:14px;margin-top:10px;display:flex}.profile-logo-tile{color:#95a3b8;background:#f8fafd;border:2px dashed #d4dbe7;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:92px;height:92px;display:flex}.profile-logo-tile svg{width:28px;height:28px}.profile-logo-tile-image{object-fit:cover;border-radius:10px;width:100%;height:100%}.profile-logo-upload-actions{flex-direction:column;justify-content:center;min-height:92px;display:flex}.profile-logo-choose{border-radius:9px;width:fit-content;height:34px;padding:0 14px}.profile-logo-file-name{color:#334155;margin-top:8px;font-size:13px}.profile-logo-file-name.muted{color:#64748b}.profile-upgrade-note{color:#2d62e6;margin-top:10px;font-size:14px;font-weight:500}.profile-phone-row{grid-template-columns:96px minmax(0,1fr);gap:8px;display:grid}.profile-phone-country{min-width:96px}.profile-phone-input{width:100%;min-width:0}.billing-tier-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;display:grid}.billing-tier-card{color:#334155;background:#fff;border:1px solid #d5dbe6;border-radius:12px;place-items:center;min-height:74px;display:grid}.billing-tier-card.active{color:#1d4ed8;background:#eef4ff;border-color:#2563eb}.billing-tier-title{letter-spacing:.03em;font-weight:700}.depot-create-grid-two{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;display:grid}.team-add-member-layout{gap:18px;display:grid}.team-settings-panel{margin-top:8px}.team-heading-row{align-items:center;gap:8px;margin:0 0 12px;display:flex}.team-heading{letter-spacing:-.03em;color:#1f2937;margin:0;font-size:30px}.team-heading-info{color:#7f8da3;border:1px solid #c7d0dd;border-radius:999px;justify-content:center;align-items:center;width:18px;height:18px;font-size:11px;font-weight:700;display:inline-flex}.team-owner-card{margin-bottom:12px}.team-owner-card-body{padding:22px 24px}.team-owner-header{justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:16px;display:flex}.team-owner-title{color:#111827;font-size:18px;font-weight:700}.team-owner-copy{color:#5f6d86;margin-top:4px;font-size:14px}.team-owner-transfer{color:#0f766e;white-space:nowrap;background:0 0;border:none;font-size:16px;font-weight:600}.team-owner-transfer:disabled{opacity:1}.team-user-meta{align-items:center;gap:12px;display:flex}.team-avatar{color:#fff;background:linear-gradient(135deg,#0d9488 0%,#14b8a6 100%);border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:17px;font-weight:700;display:inline-flex}.team-user-name{color:#111827;font-size:16px;font-weight:600;line-height:1.2}.team-user-email{color:#5f6d86;margin-top:3px;font-size:14px}.team-members-card-body{padding:18px 22px 24px;overflow:visible}.team-members-card{overflow:visible}.team-members-toolbar{justify-content:space-between;align-items:center;gap:10px;margin-bottom:12px;display:flex}.team-members-count{color:#374151;font-size:16px;font-weight:500}.team-members-filters{align-items:center;gap:10px;display:flex}.team-filter-control{min-width:160px}.team-add-member-trigger{justify-content:center;min-width:150px}.team-add-member-panel{background:#fdfefe;border:1px solid #e6ebf3;border-radius:12px;margin-bottom:12px;padding:14px}.team-add-member-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.team-add-actions{justify-content:flex-end;gap:8px;margin-top:10px;display:flex}.team-role-checkbox-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;margin-top:8px;display:grid}.team-role-checkbox{color:#334155;align-items:center;gap:8px;font-size:13px;display:inline-flex}.team-depot-scope-row{flex-wrap:wrap;gap:14px;margin-top:8px;display:flex}.team-depot-checkbox-grid{gap:8px;margin-top:10px;display:grid}.team-members-table-card{border-radius:10px;overflow:visible}.team-members-table-card .table{overflow:visible}.team-members-table-card .table th,.team-members-table-card .table td{padding:14px 16px}.team-role-stack{gap:8px;display:grid}.team-role-badges{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.team-role-pill{border-radius:999px;align-items:center;height:24px;padding:0 10px;font-size:12px;font-weight:700;display:inline-flex}.team-role-pill.owner{color:#7e22ce;background:#f3e8ff}.team-role-pill.admin{color:#1d4ed8;background:#dbeafe}.team-role-pill.dispatcher{color:#475569;background:#f1f5f9}.team-role-pill.driver{color:#0369a1;background:#e0f2fe}.team-role-pill.inactive{color:#be123c;background:#fff1f2}.team-depot-meta{color:#3c4a61;align-items:center;gap:6px;font-size:15px;display:inline-flex}.team-depot-meta svg{color:#64748b;width:17px;height:17px}.team-row-actions-cell{text-align:right;width:80px;overflow:visible}.team-row-actions{display:inline-block;position:relative}.team-kebab-button{color:#74839a;background:#fff;border:1px solid #d5dbe6;border-radius:9px;width:34px;height:34px;font-size:16px;font-weight:700;line-height:1}.team-kebab-button:hover{cursor:pointer;background:#f8fafc}.team-row-menu{z-index:30;background:#fff;border:1px solid #d7deea;border-radius:10px;width:296px;padding:10px;position:absolute;top:calc(100% + 6px);right:0;box-shadow:0 10px 20px #0f172a1f}.team-row-menu-label{color:#5f6d86;margin-bottom:5px;font-size:12px;font-weight:700;display:block}.team-row-menu-section-title{color:#5f6d86;margin-bottom:6px;font-size:12px;font-weight:700}.team-row-menu-checkbox-grid{gap:6px;display:grid}.team-row-menu-option{color:#334155;align-items:center;gap:8px;font-size:13px;display:inline-flex}.team-row-menu-divider{border-top:1px solid #edf1f6;margin:10px 0}.team-row-menu-select{width:100%;min-width:0}.team-row-menu-actions{justify-content:flex-end;gap:8px;margin-top:10px;display:flex}.team-row-menu-button{justify-content:center;width:100%;margin-top:8px}@media (max-width:1180px){.layout-main-side{grid-template-columns:1fr}.controls-tiles,.kpi-strip,.dashboard-kpi-grid,.routes-kpi-grid,.routes-detail-kpis,.routes-mapping-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width:980px){.app-shell{grid-template-columns:1fr}.sidebar{border-right:none;border-bottom:1px solid var(--line);height:auto;position:static}.nav{flex-flow:wrap}.page{padding:14px}.grid-2,.grid-3,.controls-tiles,.depot-create-grid-two,.team-add-member-grid,.billing-tier-grid,.dashboard-kpi-grid,.routes-kpi-grid,.routes-detail-kpis,.routes-mapping-grid,.routes-filter-bar{grid-template-columns:1fr}.profile-logo-row{align-items:center}.profile-phone-row{grid-template-columns:1fr}.team-heading{font-size:24px}.team-owner-title{font-size:17px}.team-user-name{font-size:15px}.team-owner-header,.team-members-toolbar{flex-direction:column;align-items:flex-start}.team-members-filters{flex-wrap:wrap;width:100%}.team-filter-control{flex:180px;min-width:160px}.team-add-member-trigger{width:100%}.team-role-checkbox-grid,.event-row,.auth-layout{grid-template-columns:1fr}.auth-right{display:none}.auth-left{padding:28px 20px}.auth-left-inner{width:min(100%,560px)}.auth-title{font-size:38px}.auth-subtitle{font-size:18px}.auth-label{font-size:16px}.auth-input,.auth-submit,.auth-google{height:42px;font-size:14px}.auth-signup-note{font-size:14px}}@media (max-width:640px){.auth-left{padding:20px 14px}.auth-title{font-size:32px}.auth-subtitle{font-size:17px}.auth-form-row{flex-direction:column;align-items:flex-start;gap:8px}.auth-quick-action{align-self:flex-start}.auth-submit,.auth-google{font-size:14px}}
