*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--c-nav: #06101e;--c-panel: #0b1628;--c-surface: #111e32;--c-surface-2: #172540;--c-surface-3: #1c2d4e;--nav-w: 96px;--panel-w: 390px;--bdr: rgba(255,255,255,.07);--bdr-2: rgba(255,255,255,.13);--bdr-3: rgba(255,255,255,.2);--blue: #3b82f6;--blue-dim: rgba(59,130,246,.15);--blue-glow: rgba(59,130,246,.3);--green: #22c55e;--green-dim: rgba(34,197,94,.14);--orange: #f59e0b;--orange-dim: rgba(245,158,11,.14);--red: #ef4444;--red-dim: rgba(239,68,68,.14);--purple: #a78bfa;--purple-dim: rgba(167,139,250,.14);--cyan: #22d3ee;--cyan-dim: rgba(34,211,238,.14);--t1: #f0f4f8;--t2: #8fa3bf;--t3: #4a5e78;--t4: #263347;--r1: 6px;--r2: 10px;--r3: 14px;--shadow-sm: 0 1px 4px rgba(0,0,0,.3);--shadow: 0 4px 16px rgba(0,0,0,.4);--shadow-lg: 0 8px 32px rgba(0,0,0,.5)}html,body,#root{height:100vh;overflow:hidden}body{font-family:-apple-system,BlinkMacSystemFont,Inter,Segoe UI,Roboto,sans-serif;background:var(--c-panel);color:var(--t1);font-size:13px;line-height:1.5;-webkit-font-smoothing:antialiased}.layout{display:flex;height:100vh;width:100%}.sidebar{display:flex;flex-direction:row;flex-shrink:0;width:calc(var(--nav-w) + var(--panel-w));box-shadow:4px 0 24px #00000080;z-index:100}.map-area{flex:1;position:relative;min-width:0}.nav-bar{width:var(--nav-w);flex-shrink:0;background:var(--c-nav);display:flex;flex-direction:column;align-items:center;padding:14px 0;border-right:1px solid var(--bdr)}.nav-logo{width:34px;height:34px;background:var(--blue);border-radius:var(--r2);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:900;color:#fff;letter-spacing:-.3px;margin-bottom:18px;flex-shrink:0;box-shadow:0 0 0 1px #ffffff1f,0 4px 14px var(--blue-glow)}.nav-items{display:flex;flex-direction:column;gap:2px;flex:1;width:100%;padding:0 7px}.nav-item{position:relative;width:100%;height:58px;border-radius:var(--r1);background:none;border:none;cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;font-size:18px;color:var(--t3);transition:background .15s,color .15s}.nav-item-label{font-size:9px;font-weight:600;letter-spacing:.2px;line-height:1.25;text-transform:uppercase;color:inherit;width:100%;text-align:center;word-break:break-word;padding:0 6px}.nav-item:hover{background:#ffffff12;color:var(--t2)}.nav-item.active{background:var(--blue-dim);color:var(--blue)}.nav-item.active:before{content:"";position:absolute;left:-7px;top:50%;transform:translateY(-50%);width:3px;height:20px;background:var(--blue);border-radius:0 3px 3px 0}.content-panel{flex:1;background:var(--c-panel);display:flex;flex-direction:column;overflow:hidden;border-right:1px solid var(--bdr)}.panel-header{display:flex;align-items:center;justify-content:space-between;padding:15px 18px 13px;border-bottom:1px solid var(--bdr);flex-shrink:0}.panel-title{font-size:15px;font-weight:700;color:var(--t1);display:flex;align-items:center;gap:9px}.panel-title-icon{opacity:.8}.panel-content{flex:1;overflow-y:auto;padding:16px 18px}.panel-content::-webkit-scrollbar{width:4px}.panel-content::-webkit-scrollbar-thumb{background:var(--bdr-2);border-radius:2px}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border-radius:var(--r1);border:none;font-size:13px;font-weight:500;cursor:pointer;transition:all .14s;white-space:nowrap;font-family:inherit;line-height:1}.btn:disabled{opacity:.4;cursor:not-allowed}.btn-primary{background:var(--blue);color:#fff}.btn-primary:hover:not(:disabled){background:#2563eb;box-shadow:0 0 0 3px var(--blue-dim)}.btn-success{background:var(--green);color:#fff}.btn-success:hover:not(:disabled){background:#16a34a;box-shadow:0 0 0 3px var(--green-dim)}.btn-danger{background:var(--red);color:#fff}.btn-danger:hover:not(:disabled){background:#dc2626}.btn-ghost{background:transparent;color:var(--t2);border:1px solid var(--bdr-2)}.btn-ghost:hover:not(:disabled){background:var(--c-surface-2);color:var(--t1);border-color:var(--bdr-3)}.btn-sm{padding:5px 10px;font-size:12px}.btn-icon{padding:6px}.form-group{margin-bottom:12px}.form-label{display:block;font-size:11px;font-weight:600;color:var(--t2);margin-bottom:5px;text-transform:uppercase;letter-spacing:.5px}.form-input,.form-select,.form-textarea,input[type=text]:not([class]),input[type=number]:not([class]),input[type=search]:not([class]),select:not([class]){width:100%;padding:8px 11px;background:var(--c-surface);border:1px solid var(--bdr-2);border-radius:var(--r1);color:var(--t1);font-size:13px;font-family:inherit;transition:border-color .14s,box-shadow .14s;-webkit-appearance:none;-moz-appearance:none;appearance:none}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px var(--blue-dim)}.form-input::placeholder{color:var(--t3)}.form-select option{background:#1a2744;color:#fff}.form-textarea{resize:vertical;min-height:60px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}.form-actions{display:flex;gap:8px;margin-top:16px}.card{background:var(--c-surface);border:1px solid var(--bdr-2);border-radius:var(--r2);margin-bottom:12px;overflow:hidden}.card-header{padding:11px 14px;border-bottom:1px solid var(--bdr);display:flex;justify-content:space-between;align-items:center}.card-title{font-size:13px;font-weight:600;color:var(--t1)}.card-body{padding:14px}.item-list{display:flex;flex-direction:column;gap:6px}.item-card{background:var(--c-surface);border:1px solid var(--bdr);border-radius:var(--r2);padding:11px 13px;cursor:pointer;transition:background .14s,border-color .14s}.item-card:hover{background:var(--c-surface-2);border-color:var(--bdr-2)}.item-card.selected{background:var(--blue-dim);border-color:var(--blue)}.item-header{display:flex;justify-content:space-between;align-items:flex-start;gap:8px}.item-title{font-size:13px;font-weight:600;color:var(--t1)}.item-subtitle{font-size:11px;color:var(--t2);margin-top:2px}.item-meta{display:flex;gap:6px;align-items:center;flex-wrap:wrap;margin-top:6px}.badge{display:inline-flex;align-items:center;padding:2px 9px;border-radius:20px;font-size:10px;font-weight:700;letter-spacing:.3px;white-space:nowrap}.badge-pending{background:var(--orange-dim);color:#fbbf24;border:1px solid rgba(245,158,11,.2)}.badge-assigned{background:var(--blue-dim);color:#60a5fa;border:1px solid rgba(59,130,246,.2)}.badge-in_transit{background:var(--purple-dim);color:var(--purple);border:1px solid rgba(167,139,250,.2)}.badge-delivered{background:var(--green-dim);color:#4ade80;border:1px solid rgba(34,197,94,.2)}.badge-failed{background:var(--red-dim);color:#f87171;border:1px solid rgba(239,68,68,.2)}.badge-planned{background:var(--blue-dim);color:#60a5fa;border:1px solid rgba(59,130,246,.2)}.badge-active{background:var(--green-dim);color:#4ade80;border:1px solid rgba(34,197,94,.2)}.badge-completed{background:#47556933;color:var(--t2);border:1px solid rgba(71,85,105,.3)}.badge-cancelled{background:var(--red-dim);color:#f87171;border:1px solid rgba(239,68,68,.2)}.badge-car{background:var(--cyan-dim);color:var(--cyan);border:1px solid rgba(34,211,238,.2)}.badge-van{background:var(--purple-dim);color:var(--purple);border:1px solid rgba(167,139,250,.2)}.badge-truck{background:var(--orange-dim);color:#fbbf24;border:1px solid rgba(245,158,11,.2)}.badge-hgv{background:var(--red-dim);color:#f87171;border:1px solid rgba(239,68,68,.2)}.section-title{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--t3);margin-bottom:10px;display:flex;justify-content:space-between;align-items:center}.alert{padding:10px 14px;border-radius:var(--r1);font-size:12px;margin-bottom:12px;line-height:1.55}.alert-error{background:var(--red-dim);color:#fca5a5;border:1px solid rgba(239,68,68,.25)}.alert-success{background:var(--green-dim);color:#86efac;border:1px solid rgba(34,197,94,.25)}.alert-info{background:var(--blue-dim);color:#93c5fd;border:1px solid rgba(59,130,246,.25)}.alert-warning{background:var(--orange-dim);color:#fcd34d;border:1px solid rgba(245,158,11,.25)}.stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:14px}.stat-card{background:var(--c-surface);border:1px solid var(--bdr);border-radius:var(--r2);padding:14px 12px;text-align:center}.stat-value{font-size:28px;font-weight:800;color:var(--t1);line-height:1}.stat-label{font-size:10px;color:var(--t3);margin-top:5px;text-transform:uppercase;letter-spacing:.6px}.autocomplete-wrapper{position:relative}.autocomplete-list{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--c-surface-3);border:1px solid var(--bdr-2);border-radius:var(--r1);z-index:9999;max-height:210px;overflow-y:auto;box-shadow:var(--shadow-lg)}.autocomplete-item{padding:9px 13px;font-size:12px;color:var(--t2);cursor:pointer;border-bottom:1px solid var(--bdr);transition:background .1s,color .1s}.autocomplete-item:hover{background:var(--blue-dim);color:var(--t1)}.autocomplete-item:last-child{border-bottom:none}.spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.15);border-top-color:currentColor;border-radius:50%;animation:spin .55s linear infinite;flex-shrink:0}@keyframes spin{to{transform:rotate(360deg)}}.loading{display:flex;align-items:center;justify-content:center;gap:10px;padding:32px 16px;color:var(--t3);font-size:13px}.divider{height:1px;background:var(--bdr);margin:14px 0}.empty{text-align:center;padding:32px 16px;color:var(--t3);font-size:13px}.empty-icon{font-size:34px;margin-bottom:10px;opacity:.5}.stop-num{width:22px;height:22px;background:var(--blue);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:#fff;flex-shrink:0}.checkbox-label{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--t2);cursor:pointer}.checkbox-label input[type=checkbox]{width:15px;height:15px;cursor:pointer;accent-color:var(--blue)}.search-bar{margin-bottom:10px}.manager-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;gap:8px}.manager-header input,.manager-header .input{flex:1;padding:8px 11px;background:var(--c-surface);border:1px solid var(--bdr-2);border-radius:var(--r1);color:var(--t1);font-size:13px;font-family:inherit}.manager-header input:focus{outline:none;border-color:var(--blue)}.map-legend{position:absolute;bottom:30px;right:12px;z-index:1000;background:#06101eed;padding:11px 15px;border-radius:var(--r2);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--bdr-2);box-shadow:var(--shadow)}.legend-item{display:flex;align-items:center;gap:9px;font-size:11px;color:var(--t2);margin-bottom:5px}.legend-item:last-child{margin-bottom:0}.legend-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.tab-nav{display:flex;gap:3px;background:var(--c-surface);border:1px solid var(--bdr);border-radius:var(--r1);padding:3px;margin-bottom:16px}.tab-btn{flex:1;padding:7px 10px;border:none;border-radius:4px;background:transparent;color:var(--t3);font-size:12px;font-weight:600;cursor:pointer;transition:all .14s;display:flex;align-items:center;justify-content:center;gap:5px;font-family:inherit}.tab-btn.active{background:var(--blue);color:#fff;box-shadow:0 2px 8px var(--blue-glow)}.tab-btn:hover:not(.active){background:var(--c-surface-2);color:var(--t2)}.tab-count{background:#ffffff2e;border-radius:10px;padding:1px 6px;font-size:10px;font-weight:700}.tab-btn:not(.active) .tab-count{background:#ffffff14}.route-card{background:var(--c-surface);border:1px solid var(--bdr);border-radius:var(--r2);overflow:hidden;transition:border-color .14s,box-shadow .14s}.route-card:hover{border-color:var(--bdr-2)}.route-card.selected{border-color:var(--blue);box-shadow:0 0 0 1px var(--blue-dim),0 4px 20px #3b82f61f}.route-card-header{display:flex;align-items:flex-start;gap:10px;padding:13px 14px 9px;cursor:pointer}.route-card-header:hover{background:#ffffff05}.route-card-title{font-size:14px;font-weight:700;color:var(--t1);display:flex;align-items:center;gap:7px;margin-bottom:5px}.route-card-sub{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.route-warning-badge{font-size:10px;font-weight:700;color:#fbbf24;background:#f59e0b1f;border:1px solid rgba(245,158,11,.22);border-radius:10px;padding:1px 7px}.route-card-stats{display:flex;border-top:1px solid var(--bdr);border-bottom:1px solid var(--bdr)}.route-stat{flex:1;padding:8px 4px;text-align:center;border-right:1px solid var(--bdr)}.route-stat:last-child{border-right:none}.route-stat-label{display:block;font-size:9px;color:var(--t3);text-transform:uppercase;letter-spacing:.7px;margin-bottom:3px}.route-stat-value{display:block;font-size:12px;font-weight:700;color:var(--t2)}.route-expand-btn{width:100%;padding:7px 14px;background:none;border:none;border-bottom:1px solid var(--bdr);color:var(--t3);font-size:11px;cursor:pointer;text-align:left;transition:all .14s;font-family:inherit}.route-expand-btn:hover{color:var(--t2);background:#ffffff05}.route-stops-list{padding:6px 10px;display:flex;flex-direction:column;gap:1px;border-bottom:1px solid var(--bdr);max-height:260px;overflow-y:auto}.route-stops-list::-webkit-scrollbar{width:3px}.route-stops-list::-webkit-scrollbar-thumb{background:var(--bdr-2);border-radius:2px}.route-stop-item{display:flex;align-items:center;gap:8px;padding:6px 4px;border-radius:var(--r1);transition:background .1s}.route-stop-item:hover{background:#ffffff08}.route-card-actions{display:flex;gap:6px;padding:9px 12px;background:#0000001f}.route-editor{display:flex;flex-direction:column}.route-editor-back{display:inline-flex;align-items:center;gap:5px;background:none;border:none;color:var(--t3);cursor:pointer;font-size:12px;font-weight:500;padding:0 0 14px;transition:color .14s;font-family:inherit}.route-editor-back:hover{color:var(--t1)}.route-editor-title{font-size:17px;font-weight:700;color:var(--t1);display:flex;align-items:center;gap:9px;margin-bottom:18px}.editor-section{margin-bottom:16px}.editor-section-label{font-size:10px;font-weight:700;color:var(--t3);text-transform:uppercase;letter-spacing:.8px;margin-bottom:7px}.editor-section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.stop-list{display:flex;flex-direction:column;gap:3px;max-height:310px;overflow-y:auto;padding-right:2px}.stop-list::-webkit-scrollbar{width:3px}.stop-list::-webkit-scrollbar-thumb{background:var(--bdr-2);border-radius:2px}.stop-row{display:flex;align-items:center;gap:8px;padding:9px 10px;border-radius:var(--r1);background:var(--c-surface);border:1px solid var(--bdr);cursor:grab;transition:background .12s,border-color .12s,opacity .12s;-webkit-user-select:none;user-select:none}.stop-row:hover{background:var(--c-surface-2);border-color:var(--bdr-2)}.stop-row.dragging{opacity:.3;border-style:dashed}.stop-row.drag-over{border-color:var(--blue);background:var(--blue-dim)}.drag-handle{color:var(--t4);font-size:15px;cursor:grab;flex-shrink:0;line-height:1;transition:color .12s;-webkit-user-select:none;user-select:none}.drag-handle:hover{color:var(--t3)}.drag-handle:active{cursor:grabbing}.stop-order-btn{width:22px;height:22px;border:1px solid var(--bdr-2);border-radius:4px;background:var(--c-surface-2);color:var(--t3);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:9px;flex-shrink:0;padding:0;transition:all .12s;font-family:inherit}.stop-order-btn:hover:not(:disabled){background:var(--c-surface-3);color:var(--t1);border-color:var(--bdr-3)}.stop-order-btn:disabled{opacity:.18;cursor:default}.editor-actions{display:flex;gap:8px;margin-top:18px;padding-top:14px;border-top:1px solid var(--bdr)}.checklist{display:flex;flex-direction:column;gap:3px;overflow-y:auto}.checklist::-webkit-scrollbar{width:3px}.checklist::-webkit-scrollbar-thumb{background:var(--bdr-2);border-radius:2px}.checklist-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:var(--r1);border:1px solid var(--bdr);background:var(--c-surface);cursor:pointer;transition:background .12s,border-color .12s}.checklist-item:hover{background:var(--c-surface-2);border-color:var(--bdr-2)}.checklist-item.checked{background:var(--blue-dim);border-color:#3b82f64d}.checkmark{width:16px;height:16px;border:1.5px solid var(--bdr-2);border-radius:4px;flex-shrink:0;transition:all .12s;background:var(--c-surface-2)}.checkmark.checked{background:var(--blue);border-color:var(--blue);background-image:url("data:image/svg+xml,%3Csvg width='10' height='8' viewBox='0 0 10 8' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 4l3 3 5-6' stroke='white' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:center}.leaflet-container{height:100%;width:100%}.leaflet-popup-content-wrapper{border-radius:var(--r2)!important;box-shadow:var(--shadow-lg)!important}.leaflet-popup-tip-container{display:none}@keyframes route-dash{to{stroke-dashoffset:-20}}.route-animated-dash{stroke-dasharray:12 8;stroke-dashoffset:0;animation:route-dash 1.5s linear infinite}.login-bg{height:100vh;display:flex;align-items:center;justify-content:center;background:var(--c-nav)}.login-card{width:100%;max-width:380px;background:var(--c-panel);border:1px solid var(--bdr-2);border-radius:var(--r3);padding:36px 32px;box-shadow:var(--shadow-lg)}.login-logo{font-size:28px;font-weight:900;letter-spacing:-1px;color:var(--t1);text-align:center;margin-bottom:28px}
