:root{--ink:#15251f;--muted:#718078;--line:#dfe6e2;--bg:#f4f7f5;--panel:#fff;--green:#105f48;--green-2:#16785a;--mint:#e4f1ec;--coral:#f26b54;--purple:#7357c8;--blue:#3d80d4;--shadow:0 12px 30px rgba(22,50,40,.07)}
*{box-sizing:border-box}body{margin:0;background:var(--bg);color:var(--ink);font-family:"DM Sans",sans-serif}.shell{display:grid;grid-template-columns:240px 1fr;min-height:100vh}.sidebar{position:sticky;top:0;height:100vh;background:#0f4939;color:#d8ebe5;padding:26px 18px 20px;display:flex;flex-direction:column}.brand{display:flex;align-items:center;gap:11px;padding:0 8px 30px;color:#fff;text-decoration:none;font:800 20px Manrope}.brand-mark{display:grid;place-items:center;width:33px;height:33px;border-radius:10px;background:#d4f067;color:#174a39}.sidebar nav{display:grid;gap:6px}.nav-item{border:0;background:transparent;color:#bcd4cc;padding:12px 14px;border-radius:9px;text-align:left;font:600 14px "DM Sans";cursor:pointer}.nav-item span{display:inline-block;width:26px;font-size:17px}.nav-item:hover,.nav-item.active{background:#1c5c4a;color:#fff}.sidebar-card{margin-top:auto;padding:16px;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.06);border-radius:12px}.sidebar-card .spark{color:#d8ee72;margin-bottom:10px}.sidebar-card strong{display:block;font-size:13px;color:#fff}.sidebar-card p{font-size:11px;line-height:1.5;color:#b6d0c8;margin:6px 0 0}.profile{display:flex;align-items:center;gap:9px;border-top:1px solid rgba(255,255,255,.12);margin-top:20px;padding:18px 4px 0}.avatar{display:grid;place-items:center;background:#e2ed9d;color:#224c3e;width:34px;height:34px;border-radius:50%;font-size:11px;font-weight:700}.profile div{display:flex;flex-direction:column;flex:1}.profile strong{font-size:11px;color:#fff}.profile small{font-size:10px;color:#9fbab1}.profile button{background:none;border:0;color:#b6cec6}
main{padding:34px 38px 50px;max-width:1500px;width:100%;margin:auto}header{display:flex;justify-content:space-between;align-items:center;margin-bottom:25px}.eyebrow{margin:0 0 7px;color:#8b9892;font-size:10px;font-weight:700;letter-spacing:1.6px}h1,h2{font-family:Manrope;margin:0}h1{font-size:27px;letter-spacing:-.8px}h2{font-size:16px}.subtitle{color:var(--muted);font-size:13px;margin:7px 0 0}.header-actions{display:flex;gap:10px}.button{border:0;border-radius:8px;padding:11px 16px;font:600 12px "DM Sans";cursor:pointer;transition:.18s transform,.18s background}.button:hover{transform:translateY(-1px)}.button.primary{background:var(--green);color:white}.button.primary:hover,.optimize-button:hover{background:var(--green-2)}.button.secondary{background:#fff;border:1px solid var(--line);color:var(--ink)}
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:16px}.stats article{display:flex;align-items:center;gap:13px;background:#fff;border:1px solid var(--line);border-radius:11px;padding:15px 17px}.stat-icon{width:36px;height:36px;border-radius:10px;display:grid;place-items:center;font-size:18px}.stat-icon.coral{background:#ffebe7;color:var(--coral)}.stat-icon.purple{background:#eee9fb;color:var(--purple)}.stat-icon.blue{background:#e6f0fb;color:var(--blue)}.stat-icon.green{background:#e4f3e9;color:#318058}.stats small{display:block;font-size:8px;letter-spacing:1px;color:#8a9690;font-weight:700;margin-bottom:4px}.stats strong{font:700 17px Manrope}
.workspace{display:grid;grid-template-columns:minmax(380px,.82fr) minmax(470px,1.18fr);gap:16px;align-items:start}.panel{background:#fff;border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow);overflow:hidden}.panel-head{display:flex;align-items:center;justify-content:space-between;padding:18px 20px;border-bottom:1px solid var(--line)}.panel-head p{margin:4px 0 0;color:var(--muted);font-size:10px}.text-button{background:none;border:0;color:var(--green-2);font:600 11px "DM Sans";cursor:pointer}.depot-row{display:flex;align-items:center;gap:12px;padding:15px 20px;background:#fafcfb;border-bottom:1px solid var(--line)}.pin{width:27px;height:27px;border-radius:50%;display:grid;place-items:center;flex:none}.pin.depot{background:#d9eee6;color:var(--green)}.pin.add{background:#e5f0ec;color:var(--green);font-size:18px}.depot-row div{flex:1}.depot-row small{display:block;font-size:8px;font-weight:700;letter-spacing:.9px;color:#89958f}.depot-row input{width:100%;border:0;background:transparent;color:var(--ink);font:600 12px "DM Sans";outline:0;margin-top:3px}.stop-list{max-height:250px;overflow:auto}.stop-row{display:grid;grid-template-columns:28px 1fr auto;align-items:center;gap:11px;padding:13px 20px;border-bottom:1px solid #edf1ef}.stop-number{display:grid;place-items:center;width:25px;height:25px;border-radius:50%;background:#f1ede3;color:#735f3a;font-size:10px;font-weight:700}.stop-row strong{display:block;font-size:11px}.stop-row small{font-size:9px;color:var(--muted)}.priority{font-size:8px;border-radius:10px;padding:3px 7px;background:#f0f3f2;color:#6d7973}.priority.High{background:#ffebe7;color:#b34331}.remove-stop{border:0;background:none;color:#9ca7a2;cursor:pointer;font-size:16px}.add-stop-form{padding:17px 20px 20px;background:#fbfcfc}.form-title{display:flex;align-items:center;gap:9px;margin-bottom:14px;font-size:12px}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.form-grid label{font-size:9px;color:#65736c;font-weight:600}.form-grid label.wide{grid-column:1/-1}.form-grid input,.form-grid select,.driver-select select{display:block;width:100%;border:1px solid #dce4df;background:white;border-radius:7px;margin-top:5px;padding:8px 9px;font:500 10px "DM Sans";color:var(--ink);outline:none}.form-grid input:focus,.form-grid select:focus{border-color:#65a08e;box-shadow:0 0 0 3px #e9f3ef}.add-button{width:100%;margin-top:12px;background:#e4f1ec;color:var(--green)}
.driver-select{position:relative}.driver-select select{padding:7px 28px 7px 28px;margin:0;appearance:none}.driver-dot{position:absolute;width:8px;height:8px;background:#5f63cf;border-radius:50%;left:11px;top:11px;z-index:2}.map{height:340px;position:relative;overflow:hidden;background:#eef2f0}.map svg{width:100%;height:100%}.roads path{fill:none;stroke:#fff;stroke-width:13;opacity:.95}.route-line{fill:none;stroke:#5e63cc;stroke-width:5;stroke-linecap:round;stroke-linejoin:round;stroke-dasharray:10 7;filter:drop-shadow(0 2px 2px rgba(67,70,150,.2))}.marker circle{stroke:white;stroke-width:3}.marker text{font:700 11px "DM Sans";fill:white;text-anchor:middle;dominant-baseline:middle}.map-legend{position:absolute;left:13px;bottom:13px;display:flex;gap:12px;background:rgba(255,255,255,.92);padding:8px 11px;border-radius:7px;font-size:9px;box-shadow:0 3px 12px rgba(20,40,30,.12)}.map-legend span{display:flex;align-items:center;gap:5px}.map-legend i{display:inline-block;width:9px;height:9px}.legend-depot{background:var(--green);border-radius:50%}.legend-route{border-top:2px dashed #5e63cc}.empty-map{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:rgba(241,245,243,.88)}.empty-map span{font-size:27px;color:#7a9389}.empty-map strong{font-size:13px;margin-top:8px}.empty-map p{font-size:10px;color:var(--muted);margin:4px}.route-summary{padding:17px 20px 20px}.summary-title,.summary-title>div{display:flex;align-items:center;justify-content:space-between}.summary-title>div{justify-content:flex-start;gap:9px}.summary-title span:not(.route-badge){display:flex;flex-direction:column}.summary-title strong{font-size:11px}.summary-title small{color:var(--muted);font-size:9px;margin-top:2px}.route-badge{display:grid;place-items:center;width:27px;height:27px;background:#eceafa;color:#5d5ebf;border-radius:7px;font-size:9px;font-weight:700}.icon-button{border:0;background:none;color:#849089}.sequence{display:flex;align-items:center;gap:5px;overflow-x:auto;padding:15px 0 13px}.sequence-node{white-space:nowrap;border:1px solid var(--line);border-radius:6px;padding:6px 8px;font-size:9px;background:#fff}.sequence-node.depot-node{background:#e3f1eb;color:var(--green);border-color:#cfe5dc}.sequence-arrow{color:#9aa49f;font-size:10px}.sequence-empty{font-size:10px;color:#929d98}.optimize-button{width:100%;background:var(--green);color:#fff}.toast{position:fixed;bottom:22px;right:22px;padding:11px 15px;color:white;background:#1b3028;border-radius:8px;font-size:11px;opacity:0;transform:translateY(8px);pointer-events:none;transition:.2s}.toast.show{opacity:1;transform:none}
@media(max-width:1000px){.shell{grid-template-columns:78px 1fr}.sidebar{padding:24px 12px}.brand>span:last-child,.nav-item:not(.active){font-size:0}.brand{justify-content:center;padding-left:0;padding-right:0}.nav-item{padding:12px;text-align:center}.nav-item span{width:auto;font-size:18px}.sidebar-card,.profile div,.profile button{display:none}.profile{justify-content:center}.workspace{grid-template-columns:1fr}.stats{grid-template-columns:1fr 1fr}}
@media(max-width:680px){.shell{display:block}.sidebar{display:none}main{padding:22px 15px}header{align-items:flex-start;gap:16px}.header-actions{flex-direction:column}.stats{grid-template-columns:1fr 1fr}.workspace{display:block}.route-panel{margin-top:16px}.map{height:300px}h1{font-size:23px}.subtitle{max-width:270px}}
.nav-item:disabled{cursor:not-allowed;opacity:.55}.route-card+.route-card{border-top:1px solid var(--line);padding-top:14px;margin-top:3px}.route-actions{display:grid;grid-template-columns:auto auto 1fr;gap:8px;margin-top:10px}.route-actions .optimize-button{width:auto}.button:disabled{cursor:not-allowed;opacity:.45;transform:none}.privacy-note{text-align:center;color:#86928c;font-size:10px;margin:14px 0 0}.header-actions{flex-wrap:wrap}.route-line:nth-child(2){stroke-dasharray:5 5}.route-line:nth-child(3){stroke-dasharray:15 6}
@media(max-width:680px){.route-actions{grid-template-columns:1fr 1fr}.route-actions .optimize-button{grid-column:1/-1}.header-actions{display:grid;grid-template-columns:1fr 1fr;width:100%}}
@media print{.sidebar,header,.stats,.stops-panel,.map,.route-actions,.privacy-note,.toast{display:none!important}.shell{display:block}.workspace{display:block}.route-panel{border:0;box-shadow:none}.route-summary{padding:0}.route-card{break-inside:avoid;margin-bottom:28px}.route-card+.route-card{border-top:2px solid #222;padding-top:20px}.sequence{white-space:normal;overflow:visible;flex-wrap:wrap}main{padding:20px}.panel-head{padding-left:0}.button{display:none}}

/* Real street map and driver navigation controls. */
.map #streetMap{position:absolute;inset:0;width:100%;height:100%}
.mapboxgl-canvas{outline:none}
.map-legend{z-index:2}
.empty-map{z-index:3}
.map-marker{width:27px;height:27px;border:3px solid #fff;border-radius:50%;display:grid;place-items:center;color:#fff;font:700 10px "DM Sans";box-shadow:0 2px 8px rgba(18,38,29,.28)}
.map-marker.depot-marker{width:31px;height:31px;background:var(--green)}
.summary-title{gap:10px}
.navigate-link{margin-left:auto;text-decoration:none;background:#edf4f1;color:var(--green);border-radius:6px;padding:6px 9px;font-size:9px;font-weight:700;white-space:nowrap}
.navigate-link:hover{background:#dcece6}
.modal-backdrop{position:fixed;inset:0;z-index:20;background:rgba(13,31,24,.58);display:grid;place-items:center;padding:20px;backdrop-filter:blur(3px)}
.modal-backdrop[hidden]{display:none}
.account-card{position:relative;width:min(410px,100%);background:#fff;border-radius:15px;padding:28px;box-shadow:0 24px 70px rgba(8,27,19,.28)}
.account-card h2{margin:20px 0 7px;font-size:21px}
.account-card>p{color:var(--muted);font-size:11px;line-height:1.55;margin:0 0 18px}
.auth-brand{color:var(--green);padding:0}
.account-card form{display:grid;gap:11px}
.account-card label{font-size:10px;font-weight:700;color:#596860}
.account-card input{display:block;width:100%;border:1px solid #d7e1dc;border-radius:8px;padding:10px 11px;margin-top:5px;font:500 11px "DM Sans";outline:none}
.account-card input:focus{border-color:#65a08e;box-shadow:0 0 0 3px #e9f3ef}
.account-card form .button{width:100%;justify-content:center;padding:10px}
.account-message{min-height:17px!important;color:#a24435!important;margin:10px 0 0!important}
.guest-button,.signout-button{display:block;margin:8px auto 0}
.modal-close{position:absolute;right:15px;top:14px;border:0;background:#edf2f0;color:#65736c;width:28px;height:28px;border-radius:50%;cursor:pointer}
.invite-box{display:grid;grid-template-columns:1fr auto;gap:6px 12px;align-items:center;background:#f0f6f3;border:1px solid #dce9e3;border-radius:10px;padding:13px;margin-bottom:18px}
.invite-box small{grid-column:1/-1;font-size:8px;letter-spacing:1px;color:#77857e;font-weight:700}
.invite-box strong{font:800 19px "Manrope";letter-spacing:2px;color:var(--green)}
.invite-box .button{padding:7px 10px}
#syncStatus span{font-size:8px}
.route-settings{display:flex;gap:8px;align-items:flex-start}
.route-settings label{font-size:7px;font-weight:700;letter-spacing:.6px;color:#74817b}
.route-settings input{display:block;width:70px;border:1px solid #dce4df;background:white;border-radius:7px;margin-top:3px;padding:7px 8px;font:600 10px "DM Sans";color:var(--ink);outline:none}
.route-settings small{display:block;margin-top:2px;font-size:7px;letter-spacing:0;color:#9aa49f}
.bulk-drop-active:after{content:"Drop address file to import";position:fixed;inset:18px;z-index:50;display:grid;place-items:center;border:3px dashed #fff;border-radius:18px;background:rgba(16,95,72,.9);color:#fff;font:800 22px "Manrope"}
.stop-row small.address-error{color:#b34331;font-weight:700}
