@import"https://fonts.googleapis.com/css2?family=DM+Sans:wght@400;500;600;700&display=swap";:root{font-family:DM Sans,Inter,system-ui,sans-serif;color:#172033;background:#f3f8f6;font-synthesis:none;--navy:#123c32;--brand:#34b27b;--muted:#6b7280;--line:#e2ebe7;--amber:#f6b91b;--green:#1f9d73;--blue:#3977da;--red:#df5d5d}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;background:#f3f8f6}button,input,select,textarea{font:inherit}button{cursor:pointer}.icon{display:block}.app-shell{min-height:100vh}.sidebar{position:fixed;left:0;top:0;bottom:0;width:246px;background:var(--navy);color:#c3d5ce;padding:26px 16px 19px;display:flex;flex-direction:column;z-index:20}.brand{height:55px;display:flex;align-items:center;gap:12px;padding:0 10px;color:#fff;font-size:18px;font-weight:700;letter-spacing:-.5px}.brand>div{line-height:18px}.brand span{color:#80ddb4}.brand small{display:block;color:#8bb1a4;font-size:9px;letter-spacing:1.25px;text-transform:uppercase;font-weight:600}.brand-mark{height:38px;width:38px;border-radius:11px;display:grid;place-items:center;background:var(--brand);color:#0b2f27!important}.nav-label{font-size:10px;text-transform:uppercase;letter-spacing:1.5px;color:#5f6b7e;font-weight:700;margin:28px 12px 10px}.sidebar nav{display:flex;flex-direction:column;gap:4px}.sidebar nav button,.sidebar-bottom>button{height:44px;width:100%;border:0;border-radius:8px;background:transparent;color:#8995a8;display:flex;align-items:center;gap:13px;padding:0 13px;font-size:13px;font-weight:500;text-align:left}.sidebar nav button:hover,.sidebar-bottom>button:hover{background:#19483d;color:#fff}.sidebar nav button.active{background:#1d5144;color:#fff;position:relative}.sidebar nav button.active:before{content:"";position:absolute;left:-16px;width:3px;height:22px;background:var(--brand);border-radius:0 3px 3px 0}.sidebar nav button.active .icon{color:var(--brand)}.sidebar nav button b{margin-left:auto;display:grid;place-items:center;width:20px;height:20px;background:#34b27b24;color:#80ddb4;border-radius:6px;font-size:10px}.sidebar-bottom{margin-top:auto}.support{margin:14px 2px;padding:13px 11px;border:1px solid #2b5b4f;border-radius:10px;display:flex;align-items:center;gap:9px}.support>span{width:30px;height:30px;border-radius:8px;display:grid;place-items:center;color:var(--brand);background:#34b27b1f}.support div{display:flex;flex-direction:column;flex:1}.support strong,.profile strong{font-size:11px;color:#dbe2ec}.support small,.profile small{font-size:9px;color:#6f7b8e;margin-top:2px}.profile{display:flex;align-items:center;gap:9px;border-top:1px solid #285548;padding:16px 6px 0}.profile>div:nth-child(2){display:flex;flex-direction:column;flex:1}.avatar{width:34px;height:34px;flex:none;border-radius:50%;display:grid;place-items:center;background:#e8effa;color:#315882;font-size:10px;font-weight:700}.avatar.dark{background:#2c3a4f;color:#fff}.close-menu{display:none}.sidebar-bottom>button{margin-bottom:6px}main{margin-left:246px;min-height:100vh}header{height:89px;background:#fff;border-bottom:1px solid var(--line);padding:0 32px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:10}.header-title{display:flex;align-items:center;gap:12px}.header-title h1{font-size:21px;margin:0;color:#111827;letter-spacing:-.4px}.header-title p{font-size:11px;color:#8a93a1;margin:5px 0 0}.header-actions{display:flex;align-items:center;gap:10px}.global-search,.table-search{height:38px;display:flex;align-items:center;gap:8px;border:1px solid #e2e6ed;border-radius:8px;padding:0 10px;color:#8b95a4;background:#fff}.global-search{width:226px}.global-search input,.table-search input{border:0;outline:0;width:100%;font-size:11px;color:#273244;background:transparent}.global-search kbd{white-space:nowrap;font-size:9px;background:#f3f5f8;border:1px solid #e7e9ee;border-radius:4px;padding:3px 5px;color:#9aa1ad}.icon-btn{width:38px;height:38px;border:1px solid #e2e6ed;border-radius:8px;background:#fff;display:grid;place-items:center;position:relative;color:#647084}.icon-btn i{position:absolute;right:3px;top:2px;background:#e85d5d;color:#fff;font-style:normal;font-size:7px;width:13px;height:13px;border-radius:50%;display:grid;place-items:center;border:2px solid #fff}.primary-btn{border:0;background:var(--navy);color:#fff;height:38px;border-radius:8px;padding:0 14px;display:inline-flex;align-items:center;gap:7px;font-size:11px;font-weight:600}.menu-btn{display:none;background:transparent;border:0}.content{padding:25px 28px 35px;max-width:1650px;margin:auto}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:15px;margin-bottom:17px}.stat-card{height:112px;background:#fff;border:1px solid var(--line);border-radius:11px;padding:19px;display:flex;align-items:flex-start;gap:14px;box-shadow:0 2px 3px #1c2b4210}.stat-icon{width:39px;height:39px;display:grid;place-items:center;border-radius:9px}.stat-icon.amber{background:#fff5d8;color:#d89900}.stat-icon.blue{background:#eaf1ff;color:#3d76d0}.stat-icon.green{background:#e6f7f1;color:#16815f}.stat-icon.red{background:#fdeaea;color:#d84b4b}.stat-copy{display:flex;flex-direction:column}.stat-copy>span{font-size:10px;color:#7a8493;margin-bottom:5px}.stat-copy strong{font-size:22px;letter-spacing:-.5px;color:#141c2a}.stat-copy small{margin-top:5px;color:#8e96a3;font-size:9px}.stat-copy small.up{color:#13946a}.stat-copy small em{font-style:normal;color:#929aa7;margin-left:2px}.dashboard-grid{display:grid;grid-template-columns:minmax(0,1.55fr) minmax(330px,.9fr);gap:17px}.panel{background:#fff;border:1px solid var(--line);border-radius:11px;box-shadow:0 2px 3px #1c2b4210;overflow:hidden}.panel-head{height:67px;padding:0 19px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid #edf0f4}.panel-head h2,.table-toolbar h2{margin:0 0 4px;font-size:13px;color:#172033}.panel-head p,.table-toolbar p{margin:0;font-size:9px;color:#8c95a3}.text-btn,.more{border:0;background:transparent;color:#526176;font-size:10px;display:flex;align-items:center;gap:5px}.more{font-weight:700;letter-spacing:2px;font-size:14px}.map{height:342px;position:relative;overflow:hidden;background-color:#eef2f2;background-image:linear-gradient(25deg,transparent 48%,#dbe5e1 49%,#dbe5e1 51%,transparent 52%),linear-gradient(-12deg,transparent 47%,#fff 48%,#fff 52%,transparent 53%);background-size:190px 150px,160px 130px}.map-grid{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,transparent 32%,#fff 32%,#fff 34%,transparent 34%,transparent 69%,#fff 69%,#fff 71%,transparent 71%),linear-gradient(0deg,transparent 29%,#fff 29%,#fff 32%,transparent 32%,transparent 74%,#fff 74%,#fff 77%,transparent 77%);opacity:.75}.route-line{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;overflow:visible;fill:none;stroke:#34b27b;stroke-width:1.3;filter:drop-shadow(0 1px 1px #fff);stroke-linecap:round}.route-line .route-secondary{stroke:#a6b9c5;stroke-width:.9;stroke-dasharray:2 1.5}.map-marker{position:absolute;transform:translate(-50%,-50%);border:3px solid white;width:31px;height:31px;border-radius:50%;display:grid;place-items:center;z-index:2;box-shadow:0 2px 7px #27364b38}.map-marker.green{background:#22b282;color:#fff}.map-marker.blue{background:#4784e5;color:#fff}.map-marker.gray{background:#718096;color:#fff}.map-marker>span{position:absolute;left:35px;top:-12px;width:116px;background:#123c32;color:#fff;padding:7px 9px;border-radius:6px;display:flex;flex-direction:column;text-align:left}.map-marker>span:before{content:"";position:absolute;left:-4px;top:16px;width:8px;height:8px;background:#123c32;transform:rotate(45deg)}.map-marker>span strong{font-size:8px}.map-marker>span small{font-size:7px;color:#aeb7c5;margin-top:2px}.school-pin{position:absolute;left:45%;top:67%;display:flex;align-items:center;gap:5px;font-size:8px;font-weight:600;color:#344154}.school-pin span{width:25px;height:25px;border-radius:7px;background:#fff;display:grid;place-items:center;box-shadow:0 2px 7px #35445b30}.map-controls{position:absolute;right:12px;top:13px;display:flex;flex-direction:column;box-shadow:0 2px 7px #33455b25}.map-controls button{width:26px;height:26px;border:0;background:#fff;color:#536175;font-weight:500}.map-controls button+button{border-top:1px solid #e5e9ee}.map-legend{position:absolute;left:13px;bottom:11px;background:#fffffff2;border-radius:6px;padding:7px 10px;box-shadow:0 2px 10px #35445b20;display:flex;gap:11px;font-size:7px;color:#576477}.map-legend span{display:flex;align-items:center;gap:4px}.map-legend i{width:6px;height:6px;background:#7b8796;border-radius:50%}.map-legend i.green-dot{background:#22b282}.map-legend i.blue-dot{background:#4784e5}.fleet-list{padding:2px 16px}.fleet-row{min-height:67px;border-bottom:1px solid #eff1f4;display:grid;grid-template-columns:38px 1fr 1.2fr auto 55px;gap:9px;align-items:center}.vehicle-tile{width:35px;height:35px;border-radius:8px;display:grid;place-items:center}.vehicle-tile.green{background:#e4f7f0;color:#178761}.vehicle-tile.blue{background:#e8f0ff;color:#3a71ca}.vehicle-tile.gray{background:#eef0f3;color:#7c8795}.fleet-row>div,.fleet-route{display:flex;flex-direction:column}.fleet-row strong{font-size:10px;color:#283346}.fleet-row small{font-size:8px;color:#929aa6;margin-top:3px}.fleet-row .fleet-route span{font-size:9px;color:#536074}.pill{display:inline-flex;width:max-content;align-items:center;padding:4px 7px;border-radius:10px;background:#eef0f3;color:#687485;font-size:7px;font-weight:600;white-space:nowrap}.pill.green,.pill.on-route,.pill.on-duty,.pill.verified,.pill.paid,.pill.picked-up,.pill.collected{background:#e4f7f0;color:#16815f}.pill.blue,.pill.at-school,.pill.dropped{background:#e7effe;color:#3973cf}.pill.amber,.pill.pending,.pill.due,.pill.expiring{background:#fff3d2;color:#bd8200}.pill.overdue{background:#fde9e9;color:#d64747}.fleet-row>b{font-size:8px;color:#5d6979;text-align:right}.panel-footer{height:40px;border:0;border-top:1px solid #edf0f4;background:#fff;width:100%;color:#566477;font-size:9px;display:flex;gap:5px;align-items:center;justify-content:center}.activity-list{padding:3px 19px 10px}.activity-row{height:57px;border-bottom:1px solid #edf0f4;display:grid;grid-template-columns:34px 1fr auto 48px;gap:9px;align-items:center}.activity-row>div:nth-child(2){display:flex;flex-direction:column}.activity-row strong{font-size:9px}.activity-row span{font-size:8px;color:#9099a7;margin-top:3px}.activity-row time{font-size:8px;color:#697587;text-align:right}.filter-btn{height:32px;padding:0 10px;border:1px solid #e0e4ea;background:#fff;border-radius:7px;color:#596679;font-size:9px;display:inline-flex;align-items:center;gap:6px}.revenue-summary{height:105px;display:flex;align-items:center;justify-content:space-between;padding:8px 24px 0}.revenue-summary>div:first-child{display:flex;flex-direction:column}.revenue-summary strong{font-size:23px}.revenue-summary span{font-size:8px;color:#929ba8;margin-top:7px}.revenue-summary span b{color:#16926a}.donut{width:70px;height:70px;border-radius:50%;background:conic-gradient(#23a47b 0,#23a47b 68%,#edf0f3 68%);display:grid;place-items:center;position:relative}.donut:after{content:"";position:absolute;width:51px;height:51px;border-radius:50%;background:#fff}.donut span{z-index:1;margin:0;color:#172033;font-size:16px;font-weight:700}.donut small{font-size:8px}.progress{margin:0 24px;height:5px;background:#edf0f3;border-radius:5px;overflow:hidden}.progress i{display:block;height:100%;background:#24a47b;border-radius:5px}.revenue-legend{display:grid;grid-template-columns:repeat(3,1fr);gap:7px;padding:16px 24px}.revenue-legend span{display:grid;grid-template-columns:7px 1fr;align-items:center;column-gap:5px}.revenue-legend i{width:6px;height:6px;border-radius:50%;background:#22a27a}.revenue-legend i.pending-dot{background:#f2b728}.revenue-legend i.overdue-dot{background:#e26666}.revenue-legend b{font-size:9px}.revenue-legend small{grid-column:2;font-size:7px;color:#909aa8}.data-page{display:flex;flex-direction:column;gap:17px}.table-panel{min-height:540px}.table-toolbar{padding:17px 19px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--line)}.toolbar-actions{display:flex;gap:8px}.table-search{height:34px;width:190px}.table-search.full{margin:14px 16px;width:auto}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse;min-width:800px}thead{background:#f8f9fb}th{height:39px;text-align:left;text-transform:uppercase;letter-spacing:.5px;font-size:8px;color:#8490a0;font-weight:600;padding:0 15px;border-bottom:1px solid var(--line)}td{height:62px;padding:0 15px;border-bottom:1px solid #edf0f4;font-size:10px;color:#4a5668}td strong{color:#273244;font-size:10px}.person-cell,.vehicle-cell{display:flex;align-items:center;gap:10px}.person-cell>div:last-child,.vehicle-cell>div:last-child{display:flex;flex-direction:column}.person-cell small,.vehicle-cell small,.block-small{font-size:8px;color:#929ba8;margin-top:3px}.block-small{display:block}.time-inline{font-size:8px;color:#9099a7;margin-left:6px}.table-footer{height:54px;display:flex;align-items:center;justify-content:space-between;padding:0 17px;font-size:9px;color:#7f8998}.table-footer div{display:flex}.table-footer button{width:28px;height:27px;border:1px solid #e1e5eb;background:#fff;color:#687586}.table-footer button.current{background:var(--navy);color:#fff;border-color:var(--navy)}.table-footer button:disabled{color:#c8ced6}.empty{text-align:center;padding:70px;color:#8c96a5;font-size:12px}.compact{margin:0}.alert-banner{background:#fff9e7;border:1px solid #f5df9e;border-radius:10px;padding:16px 18px;display:flex;align-items:center;gap:12px}.alert-banner>span{width:40px;height:40px;border-radius:9px;background:#fff0c5;color:#bd8200;display:grid;place-items:center}.alert-banner>div{flex:1}.alert-banner strong{font-size:11px}.alert-banner p{font-size:9px;color:#7d7360;margin:4px 0 0}.alert-banner button{border:0;background:transparent;color:#9f7100;font-size:10px;font-weight:600}.tracking-page{height:calc(100vh - 150px);min-height:590px;display:grid;grid-template-columns:minmax(0,1fr) 345px;gap:17px}.tracking-map,.tracking-list{height:100%}.expanded-map{height:calc(100% - 67px)}.segmented{background:#f0f2f5;padding:3px;border-radius:7px;display:flex}.segmented button{height:27px;border:0;background:transparent;border-radius:5px;font-size:8px;color:#6b7686}.segmented button.active{background:#fff;box-shadow:0 1px 3px #1f304020;color:#263245}.live-dot{display:inline-block;width:5px;height:5px;background:#22a379;border-radius:50%;margin-right:3px}.tracking-vehicle{width:100%;height:88px;border:0;border-bottom:1px solid #edf0f4;background:#fff;display:grid;grid-template-columns:40px 1fr 15px;align-items:center;gap:10px;padding:0 16px;text-align:left;color:#758194}.tracking-vehicle.selected{background:#ecf8f2;box-shadow:inset 3px 0 #34b27b}.tracking-vehicle>div{display:flex;flex-direction:column;gap:4px}.tracking-vehicle strong{display:flex;align-items:center;gap:6px;color:#2a3548;font-size:10px}.tracking-vehicle small{font-size:8px;color:#7d8897}.tracking-vehicle div>span{font-size:8px;color:#667286}.tracking-vehicle div>span b{color:#b0b7c0;margin:0 4px}.notification-layout{display:grid;grid-template-columns:minmax(0,1.2fr) minmax(330px,.8fr);gap:17px}.composer{padding-bottom:20px}.composer>label{display:flex;flex-direction:column;gap:8px;margin:17px 20px}.composer label>span{font-size:9px;font-weight:600;color:#4c5869}.composer select,.composer textarea{border:1px solid #dfe4eb;border-radius:8px;background:#fff;padding:0 11px;outline:none;font-size:10px;color:#344054}.composer select{height:39px}.composer textarea{height:126px;padding:12px;resize:none;line-height:1.6}.composer label>small{text-align:right;font-size:8px;color:#9ba3af}.choice-row{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.choice-row button{height:57px;border:1px solid #e0e4ea;background:#fff;border-radius:8px;display:flex;align-items:center;justify-content:center;gap:8px;font-size:9px;color:#667286}.choice-row button.active{border-color:#34b27b;background:#ecf8f2;color:#176747}.composer-actions{display:flex;justify-content:flex-end;gap:8px;margin:0 20px}.notice-row{height:75px;margin:0 18px;display:grid;grid-template-columns:35px 1fr auto;align-items:center;gap:10px;border-bottom:1px solid #edf0f4}.notice-row>span{width:34px;height:34px;border-radius:8px;background:#f0f4fa;color:#567297;display:grid;place-items:center}.notice-row>div{display:flex;flex-direction:column}.notice-row strong{font-size:9px;color:#2d3849}.notice-row small,.notice-row time{font-size:8px;color:#929ba7;margin-top:4px}.notice-row time{white-space:nowrap}.placeholder{padding:60px;text-align:center}.placeholder .stat-icon{margin:0 auto 15px}.placeholder h2{font-size:16px}.placeholder p{font-size:11px;color:#7c8795}.placeholder .primary-btn{margin-top:10px}footer{text-align:center;font-size:9px;color:#9aa2ad;padding:0 0 25px}.backdrop{display:none}@media (max-width:1180px){.stats-grid{grid-template-columns:repeat(2,1fr)}.global-search{display:none}.dashboard-grid{grid-template-columns:1fr}.activity-panel,.revenue-panel{min-height:300px}.compact{grid-template-columns:repeat(4,1fr)}.compact .stat-card{padding:14px}.tracking-page{grid-template-columns:1fr 300px}.notification-layout{grid-template-columns:1fr}.recent-notices{min-height:350px}}@media (max-width:800px){.sidebar{transform:translate(-100%);transition:transform .25s ease}.sidebar.open{transform:translate(0)}.close-menu{display:block;position:absolute;right:12px;top:15px;background:transparent;color:#96a2b4;border:0}.backdrop{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#07101dbd;z-index:19}main{margin-left:0}header{padding:0 18px}.menu-btn{display:block}.header-actions .primary-btn{display:none}.content{padding:18px}.tracking-page{height:auto;display:flex;flex-direction:column}.tracking-map{height:580px}.tracking-list{height:auto}.compact{grid-template-columns:repeat(2,1fr)}.table-toolbar{align-items:flex-start;gap:12px}.toolbar-actions{flex-wrap:wrap;justify-content:flex-end}.table-search{width:160px}.choice-row{grid-template-columns:1fr}}@media (max-width:520px){header{height:75px}.header-title p{display:none}.header-title h1{font-size:18px}.stats-grid{grid-template-columns:1fr 1fr;gap:10px}.stat-card{height:105px;padding:14px;gap:10px}.stat-copy strong{font-size:18px}.stat-copy small em{display:none}.stat-icon{width:34px;height:34px}.content{padding:13px}.dashboard-grid{gap:12px}.fleet-row{grid-template-columns:34px 1fr auto}.fleet-route,.fleet-row>b{display:none}.compact{grid-template-columns:1fr 1fr}.compact .stat-card{height:100px}.table-toolbar{flex-direction:column}.toolbar-actions{justify-content:flex-start}.toolbar-actions .filter-btn{display:none}.notification-layout{display:block}.recent-notices{margin-top:12px}.notice-row time{display:none}.global-search{display:none}}body{font-size:15px}.brand{font-size:20px}.brand small,.nav-label{font-size:11px}.sidebar nav button,.sidebar-bottom>button{font-size:15px}.support strong,.profile strong,.header-title p,.global-search input,.table-search input,.primary-btn,.text-btn,.filter-btn,.panel-footer,.composer select,.composer textarea{font-size:13px}.support small,.profile small,.panel-head p,.table-toolbar p,.stat-copy>span,.stat-copy small,.fleet-row small,.activity-row span,.activity-row time,.person-cell small,.vehicle-cell small,.block-small,.time-inline,.table-footer,.empty,.notice-row small,.notice-row time,footer{font-size:11px}.header-title h1{font-size:26px}.panel-head h2,.table-toolbar h2{font-size:17px}.stat-copy strong,.revenue-summary strong{font-size:28px}.fleet-row strong,td strong,.notice-row strong{font-size:13px}.fleet-row .fleet-route span,td,.tracking-vehicle strong,.tracking-vehicle small,.tracking-vehicle div>span,.composer label>span{font-size:13px}.pill{font-size:10px;padding:5px 9px;border-radius:12px}th{font-size:10px}table{min-width:1180px}td{height:68px}.table-search{width:230px}.primary-btn{height:42px}.filter-btn{height:36px}.global-search{height:42px;width:270px}.icon-btn{width:42px;height:42px}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;background:#07101dc2;display:flex;align-items:center;justify-content:center;padding:22px}.record-modal{width:min(760px,100%);max-height:calc(100vh - 44px);overflow:auto;background:#fff;border:1px solid var(--line);border-radius:10px;box-shadow:0 24px 70px #06101f55}.modal-head{height:78px;padding:0 20px;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;gap:16px}.modal-head h2{font-size:20px;margin:0 0 5px;color:#172033}.modal-head p{font-size:13px;margin:0;color:#7b8594}.form-grid{padding:20px;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.form-grid label{display:flex;flex-direction:column;gap:7px}.form-grid label.full{grid-column:1/-1}.form-grid span{font-size:12px;font-weight:700;color:#4b5667}.form-grid input,.form-grid select,.form-grid textarea{width:100%;border:1px solid #dfe4eb;border-radius:8px;background:#fff;color:#273244;outline:none;font-size:14px;padding:0 12px}.form-grid input,.form-grid select{height:42px}.form-grid textarea{min-height:104px;padding:12px;resize:vertical}.modal-actions{padding:0 20px 20px;display:flex;justify-content:flex-end;gap:10px}@media (max-width:700px){.form-grid{grid-template-columns:1fr}.record-modal{max-height:calc(100vh - 22px)}.modal-backdrop{padding:11px}.table-search{width:180px}}
