:root{--bg-primary: #0F1923;--bg-secondary: #15222E;--bg-card: #1A2A3A;--bg-hover: #1F3042;--bg-input: #0D1520;--border: #1E3045;--border-light: #2A3F56;--text-primary: #EAECEF;--text-secondary: #8899AA;--text-muted: #5C7288;--brand: #2196F3;--brand-light: #42A5F5;--brand-dark: #1565C0;--brand-bg: rgba(33,150,243,.12);--brand-shadow: rgba(33,150,243,.3);--success: #00C853;--success-bg: rgba(0,200,83,.12);--warning: #FF9800;--warning-bg: rgba(255,152,0,.12);--danger: #FF5252;--danger-bg: rgba(255,82,82,.12);--danger-shadow: rgba(255,82,82,.3);--info: #00BCD4;--info-bg: rgba(0,188,212,.12);--chart-green-light: #69F0AE;--status-accepted: #CE93D8;--status-accepted-bg: rgba(156,39,176,.12);--status-arrived: #4DB6AC;--status-arrived-bg: rgba(0,150,136,.12);--status-in-service: #F06292;--status-in-service-bg: rgba(233,30,99,.12);--sidebar-w: 240px;--header-h: 64px;--radius: 10px;--radius-sm: 6px;--radius-lg: 14px;--shadow: 0 2px 12px rgba(0,0,0,.3);--shadow-heavy: 0 20px 60px rgba(0,0,0,.5);--transition: .2s cubic-bezier(.4,0,.2,1)}html.light{--bg-primary: #F0F2F5;--bg-secondary: #FFFFFF;--bg-card: #FFFFFF;--bg-hover: #F5F7FA;--bg-input: #F5F7FA;--border: #E4E7ED;--border-light: #DCDFE6;--text-primary: #303133;--text-secondary: #606266;--text-muted: #909399;--brand: #409EFF;--brand-light: #66B1FF;--brand-dark: #337ECC;--brand-bg: rgba(64,158,255,.1);--brand-shadow: rgba(64,158,255,.2);--success: #67C23A;--success-bg: rgba(103,194,58,.1);--warning: #E6A23C;--warning-bg: rgba(230,162,60,.1);--danger: #F56C6C;--danger-bg: rgba(245,108,108,.1);--danger-shadow: rgba(245,108,108,.2);--info: #909399;--info-bg: rgba(144,147,153,.1);--chart-green-light: #95D475;--status-accepted: #7B1FA2;--status-accepted-bg: rgba(156,39,176,.08);--status-arrived: #00897B;--status-arrived-bg: rgba(0,150,136,.08);--status-in-service: #C2185B;--status-in-service-bg: rgba(233,30,99,.08);--shadow: 0 2px 12px rgba(0,0,0,.08);--shadow-heavy: 0 20px 60px rgba(0,0,0,.1)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Microsoft YaHei,sans-serif;background:var(--bg-primary);color:var(--text-primary);min-height:100vh;overflow-x:hidden}#app{display:flex;min-height:100vh}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--border-light)}html.light .modal-overlay{background:#0006}html.light .sidebar{background:#fff}html.light .sidebar-logo{border-bottom-color:#e4e7ed}html.light .nav-item{color:#606266}html.light .nav-item:hover{background:#f5f7fa;color:#303133}html.light .nav-section-title{color:#909399}html.light .sidebar-footer{border-top-color:#e4e7ed}html.light .sidebar-user-name,html.light .sidebar-logo-text{color:#303133}.sidebar{width:var(--sidebar-w);height:100vh;position:fixed;left:0;top:0;background:var(--bg-secondary);border-right:1px solid var(--border);display:flex;flex-direction:column;z-index:100;overflow-y:auto}.sidebar-logo{padding:20px 24px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:12px}.sidebar-logo-icon{width:36px;height:36px;border-radius:8px;background:linear-gradient(135deg,var(--brand),var(--brand-dark));display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700;color:#fff;flex-shrink:0}.sidebar-logo-text{font-size:18px;font-weight:700;letter-spacing:-.3px}.sidebar-logo-sub{font-size:11px;color:var(--text-muted);margin-top:1px}.sidebar-nav{flex:1;padding:12px}.nav-section{margin-bottom:8px}.nav-section-title{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:1px;padding:8px 12px 6px}.nav-item{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:var(--radius-sm);cursor:pointer;color:var(--text-secondary);font-size:14px;transition:all var(--transition);margin-bottom:2px;position:relative;font-weight:500;text-decoration:none}.nav-item:hover{background:var(--bg-hover);color:var(--text-primary)}.nav-item.active{background:var(--brand-bg);color:var(--brand)}.nav-item.active:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:20px;background:var(--brand);border-radius:0 3px 3px 0}.nav-item svg{flex-shrink:0;opacity:.75}.nav-item.active svg{opacity:1}.nav-item .badge{background:var(--danger);color:#fff;font-size:11px;padding:2px 7px;border-radius:10px;margin-left:auto;font-weight:600}.sidebar-footer{padding:16px;border-top:1px solid var(--border)}.sidebar-user{display:flex;align-items:center;gap:10px;padding:8px;border-radius:var(--radius-sm);cursor:pointer}.sidebar-user:hover{background:var(--bg-hover)}.sidebar-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--brand),var(--brand-dark));display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;color:#fff;flex-shrink:0}.sidebar-user-info{flex:1;min-width:0}.sidebar-user-name{font-size:13px;font-weight:600}.sidebar-user-role{font-size:11px;color:var(--text-muted)}.main-content{flex:1;margin-left:var(--sidebar-w);min-height:100vh}.header{height:var(--header-h);background:var(--bg-secondary);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 28px;position:sticky;top:0;z-index:50}.header-breadcrumb{font-size:13px;color:var(--text-muted);display:flex;align-items:center;gap:8px}.header-breadcrumb span{color:var(--text-primary);font-weight:500}.header-actions{display:flex;align-items:center;gap:16px}.header-date{font-size:13px;color:var(--text-muted)}.header-notify{position:relative;cursor:pointer;padding:6px;border-radius:var(--radius-sm)}.header-notify:hover{background:var(--bg-hover)}.header-notify .dot{position:absolute;top:4px;right:4px;width:8px;height:8px;background:var(--danger);border-radius:50%}.header-notify .badge-count{position:absolute;top:-2px;right:-4px;background:var(--danger);color:#fff;font-size:10px;font-weight:700;min-width:18px;height:18px;padding:0 5px;border-radius:10px;display:flex;align-items:center;justify-content:center;line-height:1}.header-logout{display:flex;align-items:center;gap:5px;cursor:pointer;padding:6px 10px;border-radius:var(--radius-sm);color:var(--text-muted);font-size:13px;transition:all var(--transition)}.header-logout:hover{background:var(--bg-hover);color:var(--danger)}.header-logout svg{flex-shrink:0}.header-logout-text{white-space:nowrap}.header-theme-tgl{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--radius-sm);cursor:pointer;color:var(--text-muted);transition:all var(--transition)}.header-theme-tgl:hover{background:var(--bg-hover);color:var(--brand)}.content{padding:24px 28px}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-bottom:24px}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px 22px}.stat-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.stat-card-label{font-size:13px;color:var(--text-muted);font-weight:500}.stat-card-icon{width:42px;height:42px;border-radius:var(--radius);display:flex;align-items:center;justify-content:center}.stat-card-icon.blue{background:var(--brand-bg);color:var(--brand)}.stat-card-icon.green{background:var(--success-bg);color:var(--success)}.stat-card-icon.orange{background:var(--warning-bg);color:var(--warning)}.stat-card-icon.cyan{background:var(--info-bg);color:var(--info)}.stat-card-value{font-size:32px;font-weight:700;letter-spacing:-1px;margin-bottom:6px}.stat-card-change{font-size:12px;display:flex;align-items:center;gap:4px}.stat-card-change.up{color:var(--success)}.stat-card-change.down{color:var(--danger)}.panel{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;margin-bottom:24px}.panel-header{padding:16px 22px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.panel-title{font-size:15px;font-weight:600}.panel-actions{display:flex;gap:8px}.panel-body{padding:0}.chart-area{padding:22px;height:300px;display:flex;align-items:center;justify-content:center}.chart-bars{display:flex;align-items:flex-end;gap:12px;height:200px;padding:0 10px;width:100%}.chart-bar-group{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px}.chart-bar{width:100%;max-width:48px;border-radius:6px 6px 0 0;transition:all var(--transition);cursor:pointer;position:relative}.chart-bar.blue{background:linear-gradient(to top,var(--brand),var(--brand-light))}.chart-bar.green{background:linear-gradient(to top,var(--success),var(--chart-green-light))}.chart-bar:hover{filter:brightness(1.2);transform:scaleY(1.05);transform-origin:bottom}.chart-bar-label{font-size:11px;color:var(--text-muted)}.chart-bar-value{font-size:11px;color:var(--text-secondary);font-weight:600}table{width:100%;border-collapse:collapse}thead th{font-size:12px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;padding:12px 16px;text-align:left;border-bottom:1px solid var(--border);background:var(--bg-secondary);white-space:nowrap}tbody td{padding:14px 16px;font-size:13px;border-bottom:1px solid var(--border);color:var(--text-secondary)}tbody tr:hover{background:var(--bg-hover)}tbody tr:last-child td{border-bottom:none}.badge-status{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:12px;font-size:12px;font-weight:500;white-space:nowrap}.badge-status:before{content:"";width:6px;height:6px;border-radius:50%}.badge-status.pending_dispatch{background:var(--warning-bg);color:var(--warning)}.badge-status.pending_dispatch:before{background:var(--warning)}.badge-status.accepted{background:var(--status-accepted-bg);color:var(--status-accepted)}.badge-status.accepted:before{background:var(--status-accepted)}.badge-status.arrived{background:var(--status-arrived-bg);color:var(--status-arrived)}.badge-status.arrived:before{background:var(--status-arrived)}.badge-status.in_service{background:var(--status-in-service-bg);color:var(--status-in-service)}.badge-status.in_service:before{background:var(--status-in-service)}.badge-status.completed{background:var(--success-bg);color:var(--success)}.badge-status.completed:before{background:var(--success)}.badge-status.cancelled{background:var(--danger-bg);color:var(--danger)}.badge-status.cancelled:before{background:var(--danger)}.badge-status.online{background:var(--success-bg);color:var(--success)}.badge-status.online:before{background:var(--success)}.badge-status.offline{background:var(--danger-bg);color:var(--danger)}.badge-status.offline:before{background:var(--danger)}.badge-status.busy{background:var(--status-in-service-bg);color:var(--status-in-service)}.badge-status.busy:before{background:var(--status-in-service)}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:var(--radius-sm);font-size:13px;font-weight:500;border:none;cursor:pointer;transition:all var(--transition);white-space:nowrap}.btn:active{transform:scale(.97)}.btn-primary{background:var(--brand);color:#fff}.btn-primary:hover{background:var(--brand-light);box-shadow:0 4px 12px var(--brand-shadow)}.btn-outline{background:transparent;border:1px solid var(--border-light);color:var(--text-secondary)}.btn-outline:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--text-muted)}.btn-sm{padding:5px 10px;font-size:12px}.btn-xs{padding:3px 8px;font-size:11px}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{box-shadow:0 4px 12px var(--danger-shadow)}.btn-success{background:var(--success);color:#fff}.form-group{margin-bottom:16px}.form-label{display:block;font-size:12px;font-weight:600;color:var(--text-muted);margin-bottom:6px;text-transform:uppercase;letter-spacing:.5px}.form-input,.form-select{width:100%;padding:10px 14px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:13px;transition:all var(--transition);font-family:inherit}.form-input:focus,.form-select:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-bg)}.form-select{cursor:pointer}.form-textarea{min-height:80px;resize:vertical}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.tabs{display:flex;gap:0;border-bottom:1px solid var(--border);padding:0 22px;background:var(--bg-secondary);overflow-x:auto}.tab{padding:12px 18px;font-size:13px;font-weight:500;color:var(--text-muted);cursor:pointer;border-bottom:2px solid transparent;transition:all var(--transition);white-space:nowrap}.tab:hover{color:var(--text-secondary)}.tab.active{color:var(--brand);border-bottom-color:var(--brand)}.filter-bar{display:flex;align-items:center;gap:10px;padding:14px 22px;flex-wrap:wrap}.filter-bar .form-select,.filter-bar .form-input{width:auto;min-width:140px}.search-box{display:flex;align-items:center;gap:8px;padding:8px 14px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);width:280px}.search-box input{flex:1;background:transparent;border:none;outline:none;color:var(--text-primary);font-size:13px}.search-box svg{flex-shrink:0;color:var(--text-muted)}.pagination{display:flex;align-items:center;justify-content:flex-end;gap:6px;padding:14px 22px;border-top:1px solid var(--border)}.pagination button{width:32px;height:32px;border-radius:var(--radius-sm);border:1px solid var(--border);background:transparent;color:var(--text-secondary);cursor:pointer;font-size:12px;transition:all var(--transition)}.pagination button:hover{background:var(--bg-hover);color:var(--text-primary)}.pagination button.active{background:var(--brand);color:#fff;border-color:var(--brand)}.pagination .ellipsis{color:var(--text-muted);padding:0 4px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;z-index:200;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);width:90%;max-width:640px;max-height:85vh;overflow-y:auto;box-shadow:var(--shadow-heavy);animation:fadeIn .2s ease}.modal-box{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);width:90%;max-width:420px;box-shadow:var(--shadow-heavy);animation:fadeIn .2s ease}.modal-sm{max-width:380px}.modal-header{padding:18px 24px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;background:var(--bg-card);z-index:1}.modal-title{font-size:16px;font-weight:600;padding:24px 24px 0}.modal-close{width:32px;height:32px;border-radius:50%;border:none;background:transparent;color:var(--text-muted);cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;transition:all var(--transition)}.modal-close:hover{background:var(--bg-hover);color:var(--text-primary)}.modal-body{padding:16px 24px 24px;font-size:14px;color:var(--text-secondary)}.modal-footer{padding:16px 24px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:10px}.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;padding:22px}.detail-item{margin-bottom:4px}.detail-label{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}.detail-value{font-size:14px;color:var(--text-primary);font-weight:500}.timeline{position:relative;padding:10px 0 10px 28px}.timeline:before{content:"";position:absolute;left:20px;top:0;bottom:0;width:2px;background:var(--border)}.timeline-item{position:relative;padding:6px 0 18px 20px}.timeline-item:last-child{padding-bottom:0}.timeline-dot{position:absolute;left:-24px;top:8px;width:10px;height:10px;border-radius:50%;background:var(--border);border:2px solid var(--bg-card);z-index:1}.timeline-item.active .timeline-dot{background:var(--brand);box-shadow:0 0 0 4px var(--brand-bg)}.timeline-item.completed .timeline-dot{background:var(--success);box-shadow:0 0 0 4px var(--success-bg)}.timeline-content{font-size:13px}.timeline-time{font-size:11px;color:var(--text-muted);margin-top:2px}.ent-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px;padding:22px}.ent-card{background:var(--bg-hover);border:1px solid var(--border);border-radius:var(--radius);padding:18px;cursor:pointer;transition:all var(--transition)}.ent-card:hover{border-color:var(--brand);box-shadow:var(--shadow)}.ent-card-header{display:flex;align-items:center;gap:12px;margin-bottom:12px}.ent-card-avatar{width:44px;height:44px;border-radius:var(--radius);display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700;color:#fff;flex-shrink:0}.ent-card-name{font-size:15px;font-weight:600}.ent-card-contact{font-size:12px;color:var(--text-muted)}.ent-card-stats{display:flex;gap:24px;margin-top:12px;padding-top:12px;border-top:1px solid var(--border)}.ent-card-stat{text-align:center}.ent-card-stat-val{font-size:18px;font-weight:700}.ent-card-stat-label{font-size:11px;color:var(--text-muted)}.empty-state{text-align:center;padding:60px 20px}.empty-state-text{font-size:14px;color:var(--text-muted);margin-bottom:4px}.empty-state-sub{font-size:12px;color:var(--text-muted);opacity:.7}.toast{position:fixed;top:24px;right:24px;z-index:300;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:14px 20px;box-shadow:var(--shadow);display:flex;align-items:center;gap:10px;font-size:13px;transform:translate(120%);transition:transform .3s ease;max-width:380px}.toast.show{transform:translate(0)}.toast.success{border-left:3px solid var(--success)}.toast.error{border-left:3px solid var(--danger)}.login-page{flex:1;min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-primary)}.login-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:40px;width:100%;max-width:400px}.login-logo{text-align:center;margin-bottom:16px}.login-logo svg{width:48px;height:48px}.login-title{font-size:24px;font-weight:700;text-align:center;margin-bottom:8px}.login-sub{font-size:13px;color:var(--text-muted);text-align:center;margin-bottom:32px}.login-error{color:var(--danger);font-size:12px;margin-bottom:12px;text-align:center}.login-btn{width:100%;padding:12px;font-size:14px;justify-content:center}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fadeIn .25s ease}.status-dist{display:flex;flex-direction:column;gap:14px;padding:22px}.status-dist-row{display:flex;align-items:center;justify-content:space-between}.status-dist-label{font-size:13px;color:var(--text-secondary);display:flex;align-items:center;gap:8px}.status-dist-dot{width:10px;height:10px;border-radius:3px}.status-dist-val{font-weight:700}
