:root{--navy:#10233f;--blue:#1263e6;--blue2:#084ebc;--gold:#c69847;--ink:#132238;--muted:#6f7d90;--line:#e6eaf0;--bg:#f3f6fa;--green:#14a875;--white:#fff}*{box-sizing:border-box}body{margin:0;font-family:'DM Sans',sans-serif;color:var(--ink);background:var(--bg)}button,input,select{font:inherit}button{cursor:pointer}.hidden{display:none!important}.login-screen{min-height:100vh;display:grid;grid-template-columns:56% 44%;background:#fff}.login-art{position:relative;overflow:hidden;padding:52px 7vw;color:#fff;background:linear-gradient(135deg,rgba(7,19,38,.86),rgba(9,39,79,.84)),url('assets/tep-logo.jpeg') center/cover}.login-art:after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 70% 35%,rgba(30,111,236,.25),transparent 30%)}.login-brand,.brand,.mobile-brand{position:relative;z-index:1;display:flex;align-items:center;gap:12px;font-family:Manrope;font-weight:800;letter-spacing:2px}.brand-mark{display:grid;place-items:center;width:42px;height:42px;background:linear-gradient(135deg,#317cf2,#0645a6);clip-path:polygon(15% 0,100% 0,85% 100%,0 100%);font-size:24px;color:white}.login-brand b,.brand b{color:#79aaff}.art-copy{position:relative;z-index:1;margin-top:20vh}.eyebrow{font-size:11px;letter-spacing:2.2px;color:#2766c8;font-weight:800}.eyebrow.light{color:#8fb9ff}.art-copy h1{font-family:Manrope;font-size:clamp(44px,5vw,76px);line-height:1.03;margin:22px 0}.art-copy h1 em{font-style:normal;color:#8bb6ff}.art-copy p{color:#c9d4e4;font-size:18px}.route-line{position:absolute;z-index:2;bottom:8%;left:8%;right:8%;height:2px;background:#4c76aa}.route-line i{position:absolute;width:11px;height:11px;border:2px solid #86aff1;border-radius:50%;background:#193c6d;top:-5px}.route-line i:nth-child(2){left:33%}.route-line i:nth-child(3){left:66%}.route-line i:nth-child(4){right:0}.login-panel{display:flex;flex-direction:column;justify-content:center;align-items:center;padding:50px;position:relative}.login-box{width:min(420px,100%)}.login-box h2{font:800 32px Manrope;margin:12px 0 8px}.login-box>p{color:var(--muted);margin-bottom:32px}.login-box>label,.modal-box label{display:block;font-size:13px;font-weight:700;margin:18px 0 7px}.login-box input,.modal-box input,.modal-box select{width:100%;padding:14px 15px;border:1px solid #dce2e9;border-radius:8px;outline:none;background:#fbfcfd}.login-box input:focus{border-color:var(--blue)}.password{display:flex;position:relative}.password button{position:absolute;right:8px;top:8px;border:0;background:none;color:#8c98a8}.login-meta{display:flex;justify-content:space-between;align-items:center;margin:18px 0;font-size:12px}.check{display:flex!important;align-items:center;gap:8px;margin:0!important}.check input{width:auto}.login-meta a,.text-btn{color:var(--blue);text-decoration:none}.primary{border:0;border-radius:7px;color:white;background:linear-gradient(90deg,var(--blue2),var(--blue));padding:13px 18px;font-weight:700}.login-btn{width:100%;display:flex;justify-content:space-between}.demo-access{margin-top:26px;padding-top:20px;border-top:1px solid var(--line);font-size:12px;color:var(--muted)}.demo-access>div{display:flex;gap:7px;margin-top:9px}.demo-access button{border:1px solid #dbe2eb;background:#fff;padding:7px 10px;border-radius:6px;color:#516176}.login-panel>small{position:absolute;bottom:25px;color:#9aa5b3}.mobile-brand{display:none}
.app{min-height:100vh;display:flex}.sidebar{position:fixed;z-index:20;width:240px;inset:0 auto 0 0;background:var(--navy);color:#c7d2e1;padding:27px 18px;display:flex;flex-direction:column}.brand{color:white;margin:0 8px 30px}.brand small{display:block;font:600 7px 'DM Sans';letter-spacing:1.7px;color:#778ba9;margin-top:2px}.sidebar nav button,.side-bottom>button{border:0;background:none;color:#aab8ca;width:100%;padding:12px;border-radius:7px;text-align:left;margin:2px 0;font-size:13px;display:flex;gap:12px;align-items:center}.sidebar nav button.active,.sidebar nav button:hover{background:#1f3960;color:white}.sidebar .badge{margin-left:auto;background:#286bd7;padding:2px 7px;border-radius:10px;font-size:10px}.side-bottom{margin-top:auto}.support{margin-top:18px;padding:16px;background:#193354;border-radius:8px;display:flex;flex-direction:column;gap:5px}.support b{font-size:12px;color:#fff}.support span{font-size:10px;color:#89a0bb}.support button{border:0;border-radius:5px;background:#2b66bf;color:#fff;padding:8px;margin-top:5px;font-size:11px}.workspace{margin-left:240px;width:calc(100% - 240px)}header{height:78px;background:#fff;border-bottom:1px solid var(--line);padding:0 30px;display:flex;align-items:center;justify-content:space-between}header h2{font:700 16px Manrope;margin:0}header p{font-size:11px;color:#8290a2;margin:4px 0}.header-actions{display:flex;align-items:center;gap:10px}.icon-btn{border:1px solid var(--line);background:white;border-radius:7px;width:36px;height:36px;position:relative}.icon-btn i{position:absolute;width:6px;height:6px;background:#e24a54;border-radius:50%;top:6px;right:6px}.company{display:flex;align-items:center;gap:9px;margin-left:8px;padding-left:15px;border-left:1px solid var(--line)}.company img{width:36px;height:36px;object-fit:contain;border-radius:50%;background:#eef4ff}.company span{display:flex;flex-direction:column}.company b{font-size:12px}.company small{font-size:10px;color:#8794a6}.company button{border:0;background:none}.menu-btn{display:none}.content{padding:28px 30px}.welcome,.section-top{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:24px}.welcome h1,.section-top h1{font:800 27px Manrope;margin:6px 0}.welcome p,.section-top p{margin:0;color:var(--muted);font-size:13px}.live-chip{background:#e8f8f2;color:#168363;border:1px solid #c9eee1;border-radius:20px;padding:8px 13px;font-size:11px}.live-chip i,.driver-status i{display:inline-block;width:7px;height:7px;background:#16ad7b;border-radius:50%;margin-right:6px;box-shadow:0 0 0 4px #c9f0e4}.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:18px}.stats article{background:white;border:1px solid var(--line);border-radius:9px;padding:17px;display:flex;gap:13px}.stat-icon{width:39px;height:39px;display:grid;place-items:center;border-radius:8px;font-weight:bold}.stat-icon.blue{background:#e8f0ff;color:var(--blue)}.stat-icon.gold{background:#fbf2e3;color:#bb8733}.stat-icon.green{background:#e6f8f1;color:var(--green)}.stat-icon.purple{background:#f0ebfb;color:#7d5bb7}.stats article>div:last-child{display:flex;flex-direction:column}.stats span{font-size:11px;color:var(--muted)}.stats strong{font:800 24px Manrope;margin:3px 0}.stats strong em{font-style:normal;font-size:11px;color:#98a4b2}.stats small{font-size:9px;color:#8b97a6}.stats small b{color:var(--green)}.control-grid{display:grid;grid-template-columns:minmax(0,1.65fr) minmax(280px,.75fr);gap:18px}.map-card,.routes-card,.table-card,.settings-card{background:white;border:1px solid var(--line);border-radius:9px;overflow:hidden}.card-head{height:70px;padding:15px 18px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--line)}.card-head h3{font:700 14px Manrope;margin:0}.card-head p{font-size:10px;color:#8b98a9;margin:4px 0}.filter{border:0;background:white;padding:7px 10px;font-size:10px;color:#718094}.filter.active{background:#eef4fe;color:var(--blue);border-radius:5px}.filter b{background:var(--blue);color:#fff;border-radius:9px;padding:1px 5px}.text-btn{border:0;background:none;font-size:10px}.map{height:424px;position:relative;overflow:hidden;background-color:#edf1f4;background-image:linear-gradient(30deg,#e3e8ec 12%,transparent 12.5%,transparent 87%,#e3e8ec 87.5%),linear-gradient(150deg,#e3e8ec 12%,transparent 12.5%,transparent 87%,#e3e8ec 87.5%);background-size:80px 140px}.map svg{position:absolute;width:100%;height:100%}.road{fill:none;stroke:#fff;stroke-width:31}.road.thin{stroke-width:13}.route-path{fill:none;stroke:#1f70e5;stroke-width:7;stroke-dasharray:4 3}.map-label{position:absolute;font-size:9px;color:#83909d;background:rgba(255,255,255,.65);padding:2px}.l1{top:70%;left:33%;transform:rotate(-18deg)}.l2{top:35%;left:52%}.l3{top:16%;right:10%;font-weight:bold;color:#4d5a68}.vehicle{position:absolute;width:30px;height:30px;border:3px solid white;border-radius:50%;background:#1b6de2;box-shadow:0 2px 8px #54708d;border:0}.vehicle span{color:white;font-size:9px;font-weight:bold}.vehicle.selected{background:#102c53;box-shadow:0 0 0 5px rgba(18,99,230,.2)}.v1{left:40%;top:45%}.v2{left:18%;top:63%}.v3{left:63%;top:36%}.v4{left:76%;top:63%}.v5{left:53%;top:67%}.v6{left:83%;top:28%}.map-controls{position:absolute;right:12px;top:12px;display:flex;flex-direction:column}.map-controls button{width:29px;height:29px;background:#fff;border:1px solid #dfe4e9}.unit-pop{position:absolute;left:44%;top:25%;background:#fff;padding:11px 13px;border-radius:7px;box-shadow:0 5px 22px rgba(27,43,64,.2);font-size:10px;min-width:175px}.unit-pop:after{content:"";position:absolute;bottom:-7px;left:20px;border:7px solid transparent;border-top-color:white;border-bottom:0}.unit-pop>div{display:flex;align-items:center;gap:7px}.unit-pop button{margin-left:auto;border:0;background:none}.unit-pop p{margin:7px 0 3px}.unit-pop p i{display:inline-block;width:6px;height:6px;background:var(--green);border-radius:50%}.unit-pop small{color:#8895a4}.bus-dot{color:var(--blue)}.route-list{padding:4px 16px}.route-row{padding:13px 0;border-bottom:1px solid var(--line);display:grid;grid-template-columns:31px 1fr auto;gap:10px;align-items:center}.route-row:last-child{border:0}.route-num{width:30px;height:30px;background:#eaf2ff;color:var(--blue);display:grid;place-items:center;border-radius:6px;font-size:10px;font-weight:bold}.route-row b{font-size:11px;display:block}.route-row small{font-size:9px;color:#8d99a8}.route-row>span:last-child{font-size:9px;color:var(--green)}
.route-cards,.stops-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.route-card,.stop-card{background:#fff;border:1px solid var(--line);border-radius:9px;padding:18px}.route-card-head{display:flex;justify-content:space-between}.route-card h3,.stop-card h3{margin:0;font:700 15px Manrope}.route-card p,.stop-card p{color:var(--muted);font-size:11px}.mini-progress{height:5px;background:#edf0f4;border-radius:4px;margin:16px 0}.mini-progress i{display:block;height:100%;background:var(--blue);border-radius:4px}.route-meta{display:flex;justify-content:space-between;font-size:10px}.route-meta span{display:flex;flex-direction:column;color:#8793a3}.route-meta b{font-size:13px;color:var(--ink);margin-top:4px}.status{padding:4px 8px;border-radius:12px;font-size:9px;font-weight:bold}.status.live{background:#e5f7ef;color:#16815f}.status.done{background:#e9f1ff;color:#2363bf}.report-filters{display:flex;align-items:end;gap:12px;background:white;border:1px solid var(--line);padding:14px;margin-bottom:16px;border-radius:9px}.report-filters label{font-size:10px;color:var(--muted);display:flex;flex-direction:column;gap:5px}.report-filters input,.report-filters select{border:1px solid var(--line);padding:8px;border-radius:5px;color:#526175;background:#fff}.report-filters button{border:1px solid #bdd0eb;color:#1758b5;background:#eef4fd;padding:8px 14px;border-radius:5px}table{width:100%;border-collapse:collapse;font-size:11px}th{text-align:left;color:#7c8999;font-size:9px;letter-spacing:.4px;background:#f9fafc}th,td{padding:14px 16px;border-bottom:1px solid var(--line)}td button{border:0;background:none;color:var(--blue)}.stop-card{position:relative}.stop-card:before{content:"◇";display:grid;place-items:center;width:34px;height:34px;color:var(--blue);background:#edf4ff;border-radius:7px;margin-bottom:15px}.stop-card button{position:absolute;right:13px;top:13px;border:0;background:none}.stop-card small{font-size:9px;color:#8a97a7}.settings-card{padding:22px;max-width:680px}.settings-card h3{margin-top:0}.settings-card label{padding:15px 0;border-bottom:1px solid var(--line);display:flex;justify-content:space-between;font-size:12px}.driver-top{background:var(--navy);color:white;margin:-28px -30px 22px;padding:26px 32px;display:flex;justify-content:space-between;align-items:center}.driver-top span{font-size:10px;letter-spacing:1.5px;color:#7fa7dc}.driver-top h1{font:800 25px Manrope;margin:7px 0}.driver-top p{margin:0;color:#aebed0}.driver-status{border:1px solid #2d9c7a;border-radius:20px;padding:8px 13px;font-size:10px;background:#163c44}.driver-grid{display:grid;grid-template-columns:1.4fr .6fr;gap:18px}.driver-map{height:485px;border-radius:9px}.gps-pill{position:absolute;left:15px;bottom:15px;background:white;color:#278264;border-radius:20px;padding:8px 13px;font-size:10px}.driver-panel{background:white;border:1px solid var(--line);border-radius:9px;padding:22px}.driver-panel h2{font:800 22px Manrope;margin:8px 0}.driver-panel>p{font-size:12px;color:var(--muted)}.progress{height:5px;background:#e9edf1;border-radius:3px;margin:22px 0}.progress i{display:block;width:60%;height:100%;background:var(--blue)}.driver-panel label{font-size:11px;font-weight:bold;display:block;margin:20px 0}.counter{display:grid;grid-template-columns:45px 1fr 45px;margin-top:9px;border:1px solid var(--line);border-radius:7px;overflow:hidden}.counter button{border:0;background:#f5f7fa;font-size:22px}.counter strong{display:grid;place-items:center;font-size:21px}.photo-btn{display:block;width:100%;margin-top:9px;border:1px dashed #a9bdd8;background:#f5f9ff;color:#2262bd;padding:13px;border-radius:7px}.complete-stop{width:100%;margin-top:7px}.driver-panel>small{display:block;text-align:center;color:#8995a4;font-size:9px;margin-top:9px}.driver-stops{background:white;border:1px solid var(--line);border-radius:9px;padding:20px;margin-top:18px}.driver-stops h3{margin-top:0}.driver-stops>div{display:flex}.driver-stops article{flex:1;display:flex;gap:10px;position:relative}.driver-stops article:not(:last-child):after{content:"";position:absolute;height:2px;background:#dce2e8;left:27px;right:0;top:12px}.driver-stops article>i{z-index:1;width:25px;height:25px;display:grid;place-items:center;border-radius:50%;background:#e9edf2;font-style:normal;font-size:10px}.driver-stops article.completed>i{background:#dff5ed;color:var(--green)}.driver-stops article.current>i{background:var(--blue);color:#fff}.driver-stops article span{display:flex;flex-direction:column}.driver-stops article b{font-size:11px}.driver-stops article small{font-size:9px;color:#8995a4;margin-top:4px}.toast{position:fixed;z-index:100;right:25px;bottom:-80px;background:#15304d;color:white;padding:14px 20px;border-radius:8px;box-shadow:0 8px 25px #19385d55;transition:.3s;font-size:12px}.toast.show{bottom:25px}.modal{position:fixed;z-index:90;inset:0;background:#0c1e36aa;display:grid;place-items:center}.modal-box{background:white;width:min(430px,90vw);border-radius:10px;padding:25px;position:relative}.modal-close{position:absolute;right:15px;top:15px;border:0;background:none;font-size:22px}.modal-box h2{font:800 24px Manrope}.modal-box .primary{width:100%;margin-top:15px}
.leaflet-map{position:absolute!important;inset:0;z-index:3;background:#e9eef3}.leaflet-map~svg,.leaflet-map~.map-label,.leaflet-map~.vehicle,.leaflet-map~.map-controls,.leaflet-map~.unit-pop{display:none}.unit-marker{width:38px;height:38px;border-radius:50% 50% 50% 8px;background:#1263e6;border:3px solid #fff;box-shadow:0 3px 12px #10233f55;color:#fff;display:grid;place-items:center;transform:rotate(-45deg)}.unit-marker span{transform:rotate(45deg);font:800 10px Manrope}.leaflet-popup-content{font:12px 'DM Sans',sans-serif;line-height:1.5}.leaflet-popup-content b{font:700 13px Manrope}.map-fresh{color:#128463;font-weight:700}.map-stale{color:#b7791f;font-weight:700}
.card-actions,.row-actions{display:flex;gap:6px}.card-actions button,.row-actions button{border:1px solid var(--line);background:#fff;border-radius:5px;padding:6px 9px;color:#43607e;font-size:10px}.card-actions button.danger,.row-actions button.danger{color:#bd3945;border-color:#f0cbd0}.secondary{border:1px solid var(--line);background:#fff;color:#526175;border-radius:7px;padding:12px 18px;font-weight:700}.modal-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:22px}.crud-grid{display:grid;grid-template-columns:1fr 1fr;gap:0 12px}.crud-grid label{margin-top:12px}.crud-grid label.full{grid-column:1/-1}.delete-warning{background:#fff2f3;color:#962d38;border:1px solid #f4cbd0;border-radius:8px;padding:14px;font-size:12px;line-height:1.5}.delete-mode #crudSave{background:#c63d49}
@media(max-width:1050px){.stats{grid-template-columns:repeat(2,1fr)}.control-grid{grid-template-columns:1fr}.route-cards,.stops-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:750px){.login-screen{grid-template-columns:1fr}.login-art{display:none}.login-panel{padding:30px}.mobile-brand{display:flex;position:absolute;top:25px;left:25px}.sidebar{transform:translateX(-100%);transition:.25s}.sidebar.open{transform:none}.workspace{margin-left:0;width:100%}.menu-btn{display:block;border:0;background:none;font-size:19px}header{padding:0 15px}header>div:nth-child(2){display:none}.company span,.icon-btn{display:none}.content{padding:20px 15px}.welcome{align-items:flex-start}.stats{grid-template-columns:1fr 1fr}.control-grid{grid-template-columns:1fr}.map{height:360px}.route-cards,.stops-grid{grid-template-columns:1fr}.report-filters{overflow:auto}.table-card{overflow:auto}.driver-grid{grid-template-columns:1fr}.driver-top{margin:-20px -15px 18px;padding:23px 16px}.driver-stops>div{flex-direction:column;gap:15px}.driver-stops article:after{display:none}}@media(max-width:480px){.stats{grid-template-columns:1fr}.live-chip{display:none}.map-card .card-head>div:last-child{display:none}.login-panel{justify-content:flex-start;padding-top:100px}.driver-map{height:340px}}
