@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";
:root{--font:"Inter", sans-serif;--brand-primary:#6366f1;--brand-secondary:#8b5cf6;--brand-accent:#06b6d4;--brand-gradient:linear-gradient(135deg, #6366f1 0%, #8b5cf6 100%);--bg-base:#0a0a0f;--bg-surface:#13131a;--bg-card:#1a1a26;--bg-elevated:#22223a;--bg-glass:#ffffff0a;--bg-glass-border:#ffffff14;--text-primary:#f1f1f5;--text-secondary:#9191a8;--text-muted:#5a5a72;--status-assigned:#f59e0b;--status-enroute:#06b6d4;--status-delivered:#10b981;--status-failed:#ef4444;--role-driver:#f59e0b;--role-dispatcher:#06b6d4;--role-ceo:#8b5cf6;--role-admin:#ef4444;--role-cs:#10b981;--radius-sm:6px;--radius-md:12px;--radius-lg:18px;--radius-xl:24px;--shadow-card:0 4px 24px #0006;--shadow-glow:0 0 24px #6366f126;--sidebar-width:240px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px}body{font-family:var(--font);background:var(--bg-base);color:var(--text-primary);-webkit-font-smoothing:antialiased;min-height:100vh}a{color:inherit;text-decoration:none}button{cursor:pointer;font-family:var(--font)}input,textarea,select{font-family:var(--font)}.app-shell{min-height:100vh;display:flex}.main-content{margin-left:var(--sidebar-width);flex:1;min-height:100vh;padding:28px;transition:margin-left .3s}@media (max-width:768px){.main-content{margin-left:0;padding:16px}.mobile-menu-btn{justify-content:center;align-items:center;display:flex!important}}.sidebar{width:var(--sidebar-width);background:var(--bg-surface);border-right:1px solid var(--bg-glass-border);z-index:100;flex-direction:column;transition:transform .3s;display:flex;position:fixed;top:0;bottom:0;left:0}.sidebar-logo{border-bottom:1px solid var(--bg-glass-border);padding:24px 20px 20px}.sidebar-logo .logo-text{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.08em;font-size:13px;font-weight:700}.sidebar-logo .app-name{background:var(--brand-gradient);-webkit-text-fill-color:transparent;-webkit-background-clip:text;margin-top:2px;font-size:18px;font-weight:800}.sidebar-nav{flex:1;padding:12px 10px;overflow-y:auto}.nav-section-label{text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);padding:12px 10px 6px;font-size:10px;font-weight:600}.nav-item{border-radius:var(--radius-sm);color:var(--text-secondary);align-items:center;gap:10px;margin-bottom:2px;padding:10px 12px;font-size:14px;font-weight:500;transition:all .15s;display:flex}.nav-item:hover{background:var(--bg-glass);color:var(--text-primary)}.nav-item.active{color:var(--brand-primary);border-left:2px solid var(--brand-primary);background:#6366f126}.nav-item .nav-icon{flex-shrink:0;width:18px;height:18px}.sidebar-footer{border-top:1px solid var(--bg-glass-border);padding:16px}.user-pill{background:var(--bg-glass);border-radius:var(--radius-sm);align-items:center;gap:10px;padding:10px;display:flex}.user-avatar{background:var(--brand-gradient);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:13px;font-weight:700;display:flex}.user-name{font-size:13px;font-weight:600}.user-role{color:var(--text-muted);text-transform:capitalize;font-size:11px}@media (max-width:768px){.sidebar{transform:translate(-100%);box-shadow:4px 0 32px #00000080}.sidebar.open{transform:translate(0)}}.card{background:var(--bg-card);border:1px solid var(--bg-glass-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);padding:24px}.card-sm{padding:16px}.card-title{align-items:center;gap:8px;margin-bottom:16px;font-size:16px;font-weight:700;display:flex}.stat-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:16px;margin-bottom:24px;display:grid}.stat-card{background:var(--bg-card);border:1px solid var(--bg-glass-border);border-radius:var(--radius-md);padding:20px;transition:transform .2s,box-shadow .2s;position:relative;overflow:hidden}.stat-card:hover{box-shadow:var(--shadow-glow);transform:translateY(-2px)}.stat-card:before{content:"";background:var(--brand-gradient);height:2px;position:absolute;top:0;left:0;right:0}.stat-value{font-size:28px;font-weight:800;line-height:1}.stat-label{color:var(--text-secondary);margin-top:6px;font-size:12px;font-weight:500}.stat-sub{color:var(--text-muted);margin-top:4px;font-size:11px}.btn{border-radius:var(--radius-sm);border:none;align-items:center;gap:8px;padding:10px 18px;font-size:14px;font-weight:600;transition:all .15s;display:inline-flex}.btn-primary{background:var(--brand-gradient);color:#fff}.btn-primary:hover{opacity:.9;transform:translateY(-1px)}.btn-ghost{background:var(--bg-glass);border:1px solid var(--bg-glass-border);color:var(--text-secondary)}.btn-ghost:hover{color:var(--text-primary);background:var(--bg-elevated)}.btn-danger{color:#ef4444;background:#ef444426;border:1px solid #ef444433}.btn-success{color:#10b981;background:#10b98126;border:1px solid #10b98133}.btn-lg{border-radius:var(--radius-md);padding:14px 28px;font-size:16px}.btn-full{justify-content:center;width:100%}.form-group{margin-bottom:18px}.form-label{color:var(--text-secondary);margin-bottom:6px;font-size:13px;font-weight:600;display:block}.form-input{background:var(--bg-surface);border:1px solid var(--bg-glass-border);border-radius:var(--radius-sm);width:100%;color:var(--text-primary);outline:none;padding:10px 14px;font-size:14px;transition:border-color .15s}.form-input:focus{border-color:var(--brand-primary)}.form-input::placeholder{color:var(--text-muted)}select.form-input option{background:var(--bg-card)}.table-wrap{overflow-x:auto}table{border-collapse:collapse;width:100%}th{text-align:left;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);border-bottom:1px solid var(--bg-glass-border);padding:10px 16px;font-size:11px;font-weight:600}td{vertical-align:middle;border-bottom:1px solid #ffffff0a;padding:14px 16px;font-size:14px}tr:last-child td{border-bottom:none}tr:hover td{background:var(--bg-glass)}.badge{border-radius:20px;align-items:center;gap:5px;padding:3px 10px;font-size:11px;font-weight:600;display:inline-flex}.badge-assigned{color:var(--status-assigned);background:#f59e0b26}.badge-enroute{color:var(--status-enroute);background:#06b6d426}.badge-delivered{color:var(--status-delivered);background:#10b98126}.badge-failed{color:var(--status-failed);background:#ef444426}.badge-admin{color:var(--role-admin);background:#ef444426}.badge-driver{color:var(--role-driver);background:#f59e0b26}.badge-dispatcher{color:var(--role-dispatcher);background:#06b6d426}.badge-ceo{color:var(--role-ceo);background:#8b5cf626}.badge-cs{color:var(--role-cs);background:#10b98126}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:24px;display:flex}.page-title{font-size:24px;font-weight:800}.page-subtitle{color:var(--text-secondary);margin-top:2px;font-size:14px}.driver-top-bar{background:var(--bg-surface);border-bottom:1px solid var(--bg-glass-border);z-index:100;justify-content:space-between;align-items:center;height:56px;padding:0 16px;display:flex;position:fixed;top:0;left:0;right:0}.driver-bottom-nav{background:var(--bg-surface);border-top:1px solid var(--bg-glass-border);z-index:100;padding-bottom:env(safe-area-inset-bottom);display:flex;position:fixed;bottom:0;left:0;right:0}.step-indicator{align-items:center;gap:8px;margin-bottom:28px;display:flex}.step-dot{background:var(--bg-elevated);width:28px;height:28px;color:var(--text-muted);border:2px solid var(--bg-glass-border);border-radius:50%;justify-content:center;align-items:center;font-size:12px;font-weight:700;transition:all .3s;display:flex}.step-dot.active{background:var(--brand-primary);color:#fff;border-color:var(--brand-primary)}.step-dot.done{background:var(--status-delivered);color:#fff;border-color:var(--status-delivered)}.step-line{background:var(--bg-glass-border);flex:1;height:2px}.step-line.done{background:var(--status-delivered)}.sig-wrap{border-radius:var(--radius-md);border:2px dashed var(--bg-glass-border);background:#fff;overflow:hidden}.sig-actions{gap:8px;margin-top:10px;display:flex}.toast{background:var(--bg-elevated);border:1px solid var(--bg-glass-border);border-radius:var(--radius-md);opacity:0;z-index:300;white-space:nowrap;padding:12px 20px;font-size:14px;font-weight:500;transition:all .3s;position:fixed;bottom:90px;left:50%;transform:translate(-50%)translateY(20px)}.toast.show{opacity:1;transform:translate(-50%)translateY(0)}.toast.success{border-color:var(--status-delivered);color:var(--status-delivered)}.toast.error{border-color:var(--status-failed);color:var(--status-failed)}.spinner{border:2px solid var(--bg-glass-border);border-top-color:var(--brand-primary);border-radius:50%;width:20px;height:20px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.3)}}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.map-container{border-radius:var(--radius-lg);border:1px solid var(--bg-glass-border);width:100%;height:480px;overflow:hidden}.grid-2{grid-template-columns:1fr 1fr;gap:16px;display:grid}.grid-3{grid-template-columns:repeat(3,1fr);gap:16px;display:grid}@media (max-width:1024px){.grid-3{grid-template-columns:1fr 1fr}}@media (max-width:640px){.grid-2,.grid-3{grid-template-columns:1fr}}.mt-4{margin-top:16px}.mt-6{margin-top:24px}.gap-4{gap:16px}.flex{display:flex}.items-center{align-items:center}.justify-between{justify-content:space-between}.text-muted{color:var(--text-secondary);font-size:13px}@media (max-width:640px){.btn{min-height:46px;font-size:15px}.btn-lg{min-height:54px;font-size:17px}.form-input{min-height:48px;padding:13px 14px;font-size:16px}.card{border-radius:var(--radius-md);padding:18px}.page-title{font-size:20px}}button,a{-webkit-tap-highlight-color:transparent}.sig-canvas{touch-action:none}.driver-sticky-header{z-index:20;background:var(--bg-base);margin-bottom:4px;padding-bottom:12px;position:sticky;top:0}.driver-card-enter{animation:.25s forwards slideUp}@keyframes borderPulse{0%,to{border-left-color:#ef444480}50%{border-left-color:#ef4444}}.card-overdue{animation:2s infinite borderPulse}
