*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--brand-primary:#e85a2b;--brand-primary-dark:#c84416;--brand-primary-light:#ffede3;--brand-secondary:#1e3a5f;--bg-page:#f5f6f8;--bg-card:#fff;--bg-subtle:#f9fafb;--border:#e5e7eb;--border-strong:#d1d5db;--text-primary:#111827;--text-secondary:#4b5563;--text-tertiary:#9ca3af;--text-inverse:#fff;--green:#10b981;--green-light:#d1fae5;--yellow:#f59e0b;--yellow-light:#fef3c7;--red:#ef4444;--red-light:#fee2e2;--gray-light:#e5e7eb;--blue:#3b82f6;--blue-light:#dbeafe;--line-green:#06c755;--shadow-sm:0 1px 2px #0000000d;--shadow:0 1px 3px #00000014, 0 1px 2px #0000000a;--r-sm:6px;--r:10px;--r-md:14px;--r-lg:20px;--c-primary:#e85a2b;--c-primary-d:#c84416;--c-primary-l:#ffede3;--c-primary-txt:#92400e;--c-bg:#f5f6f8;--c-surface:#fff;--c-surface-2:#f9fafb;--c-border:#e5e7eb;--c-border-s:#d1d5db;--c-text:#111827;--c-muted:#4b5563;--c-faint:#9ca3af;--c-success:#10b981;--c-success-l:#d1fae5;--c-warn:#f59e0b;--c-warn-l:#fef3c7;--c-danger:#ef4444;--c-danger-l:#fee2e2;--c-dark:#1e3a5f;--c-dark-2:#2d5a9e;--c-dark-border:#ffffff1f;--c-dark-muted:#ffffffb3;--font:"Noto Sans TC", "PingFang TC", "Microsoft JhengHei", -apple-system, BlinkMacSystemFont, sans-serif;--font-mono:"Courier New", monospace}html,body{font-family:var(--font);color:var(--text-primary);background:var(--bg-page);-webkit-font-smoothing:antialiased;font-size:14px;line-height:1.5}button{cursor:pointer;background:0 0;border:none;font-family:inherit}input,textarea,select{font-family:inherit}#root{width:100%;min-height:100dvh}.btn{border-radius:var(--r);cursor:pointer;font-size:14px;font-weight:600;font-family:var(--font);border:none;justify-content:center;align-items:center;gap:6px;padding:12px 20px;text-decoration:none;transition:all .15s;display:inline-flex}.btn:disabled{opacity:.45;cursor:not-allowed}.btn-primary{background:var(--brand-primary);color:#fff;font-size:15px}.btn-primary:hover:not(:disabled){background:var(--brand-primary-dark)}.btn-secondary{color:var(--brand-secondary);border:1.5px solid var(--brand-secondary);background:#fff;padding:10px 18px}.btn-secondary:hover:not(:disabled){background:var(--bg-subtle);border-color:var(--brand-primary);color:var(--brand-primary)}.btn-ghost{background:var(--bg-page);color:var(--text-secondary);padding:8px 14px;font-size:13px}.btn-ghost:hover:not(:disabled){color:var(--text-primary);background:#fff}.btn-line{background:var(--line-green);color:#fff;font-size:15px;font-weight:700}.btn-sm{padding:5px 12px;font-size:12px}.btn-lg{padding:14px 28px;font-size:15px}.btn-full{width:100%}.field{border:1.5px solid var(--border-strong);border-radius:var(--r);width:100%;font-size:14px;font-family:var(--font);color:var(--text-primary);background:#fff;padding:12px 14px;transition:border-color .15s}.field:focus{border-color:var(--brand-primary);outline:none}textarea.field{resize:none}select.field{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23999' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;padding-right:30px}.field-label{color:var(--text-secondary);margin-bottom:4px;font-size:12px;font-weight:600;display:block}.field-input{border:1.5px solid var(--border-strong);border-radius:var(--r);width:100%;font-size:14px;font-family:var(--font);color:var(--text-primary);background:#fff;padding:12px 14px;transition:border-color .15s}.field-input:focus{border-color:var(--brand-primary);outline:none}textarea.field-input{resize:none}.field-select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23999' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;padding-right:30px}.field-error{color:var(--red);font-size:11px}.tag{border-radius:999px;align-items:center;gap:4px;padding:3px 8px;font-size:11px;font-weight:600;display:inline-flex}.tag-green{background:var(--green-light);color:#047857}.tag-yellow{background:var(--yellow-light);color:#b45309}.tag-red{background:var(--red-light);color:#b91c1c}.tag-gray{background:var(--bg-page);color:var(--text-secondary)}.tag-blue{background:var(--blue-light);color:#1e40af}.tag-brand,.tag-orange{background:var(--brand-primary-light);color:var(--brand-primary-dark)}.status-draft,.status-assigned,.status-on_route,.status-arrived,.status-in_progress,.status-paid,.status-completed,.status-cancelled{border-radius:999px;align-items:center;padding:3px 8px;font-size:11px;font-weight:600;display:inline-flex}.status-draft{background:var(--bg-page);color:var(--text-secondary)}.status-assigned{background:var(--blue-light);color:#1e40af}.status-on_route{background:var(--yellow-light);color:#b45309}.status-arrived{background:var(--brand-primary-light);color:var(--brand-primary-dark)}.status-in_progress{color:#047857;background:#ecfdf5}.status-paid{background:var(--green-light);color:#047857}.status-completed{background:var(--gray-light);color:var(--text-secondary)}.status-cancelled{background:var(--red-light);color:#b91c1c}.card,.s-card{border-radius:var(--r-md);box-shadow:var(--shadow-sm);border:1px solid var(--border);background:#fff;margin-bottom:12px;padding:16px}.dot{border-radius:50%;width:8px;height:8px;display:inline-block}.dot-green{background:var(--green);box-shadow:0 0 0 3px var(--green-light)}.dot-yellow{background:var(--yellow);box-shadow:0 0 0 3px var(--yellow-light)}.dot-red{background:var(--red);box-shadow:0 0 0 3px var(--red-light)}.dot-gray{background:var(--text-tertiary);box-shadow:0 0 0 3px var(--gray-light)}.liff-header{border-bottom:1px solid var(--border);z-index:5;background:#fff;flex-shrink:0;align-items:center;gap:12px;padding:50px 16px 12px;display:flex}.liff-header .back{width:32px;height:32px;color:var(--text-secondary);cursor:pointer;border-radius:50%;place-items:center;display:grid}.liff-header .title{color:var(--text-primary);flex:1;font-size:16px;font-weight:600}.liff-header .close{background:var(--bg-page);width:28px;height:28px;color:var(--text-secondary);cursor:pointer;border-radius:50%;place-items:center;font-size:16px;display:grid}.screen-body{background:var(--bg-page);flex:1;padding-bottom:80px;overflow-y:auto}.s-section{padding:16px}.bottom-nav{border-top:1px solid var(--border);background:#fff;flex-shrink:0;justify-content:space-around;padding:8px 0 24px;display:flex}.bottom-nav button{color:var(--text-tertiary);cursor:pointer;font-size:10px;font-weight:600;font-family:var(--font);background:0 0;border:none;flex-direction:column;align-items:center;gap:2px;padding:4px 12px;display:flex}.bottom-nav button.active{color:var(--brand-primary)}.bottom-nav button svg{width:22px;height:22px}.line-login{background:linear-gradient(180deg, #fff 0%, var(--brand-primary-light) 100%);text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;padding:80px 32px 32px;display:flex}.line-login .big-logo{background:linear-gradient(135deg, var(--brand-primary) 0%, var(--brand-primary-dark) 100%);color:#fff;border-radius:28px;place-items:center;width:100px;height:100px;margin-bottom:24px;font-size:40px;font-weight:900;display:grid;box-shadow:0 10px 30px #e85a2b66}.line-login h1{color:var(--text-primary);margin-bottom:6px;font-size:24px}.line-login .subtitle{color:var(--text-secondary);margin-bottom:32px;font-size:14px}.line-login .form{flex-direction:column;gap:12px;width:100%;margin-bottom:16px;display:flex}.dashboard{zoom:var(--dash-zoom,1);background:#fff;grid-template-columns:240px 1fr;width:100%;height:100%;display:grid;overflow:hidden}.dashboard-sidebar{background:var(--brand-secondary);color:#fff;height:100%;padding:24px 16px;overflow-y:auto}.dashboard-sidebar .user-block{border-radius:var(--r);background:#ffffff0f;align-items:center;gap:10px;margin-bottom:24px;padding:12px;display:flex}.dashboard-sidebar .avatar{background:var(--brand-primary);color:#fff;border-radius:50%;flex-shrink:0;place-items:center;width:36px;height:36px;font-size:14px;font-weight:700;display:grid}.dashboard-sidebar .nav-section{color:#fff6;text-transform:uppercase;letter-spacing:1px;padding:12px 12px 6px;font-size:11px;font-weight:700}.dashboard-sidebar .nav-item{color:#ffffffb3;text-align:left;cursor:pointer;width:100%;font-size:15px;font-family:var(--font);background:0 0;border:none;border-radius:8px;align-items:center;gap:10px;margin-bottom:2px;padding:11px 12px;transition:all .15s;display:flex}.dashboard-sidebar .nav-item:hover{color:#fff;background:#ffffff14}.dashboard-sidebar .nav-item.active{background:var(--brand-primary);color:#fff;font-weight:600}.dashboard-sidebar .nav-item svg{width:18px;height:18px}.dashboard-sidebar .nav-item .badge{color:#fff;background:#ffffff26;border-radius:4px;margin-left:auto;padding:1px 6px;font-size:10px}.dashboard-main{flex-direction:column;height:100%;display:flex;overflow:hidden}.dashboard-topbar{border-bottom:1px solid var(--border);background:#fff;flex-shrink:0;align-items:center;gap:16px;padding:14px 24px;display:flex}.dashboard-topbar .breadcrumb{color:var(--text-secondary);align-items:center;gap:8px;font-size:13px;display:flex}.dashboard-topbar .search{background:var(--bg-page);width:280px;color:var(--text-tertiary);border-radius:8px;align-items:center;gap:8px;margin-left:auto;padding:6px 12px;font-size:13px;display:flex}.dashboard-topbar .icon-btn{background:var(--bg-page);width:36px;height:36px;color:var(--text-secondary);cursor:pointer;border-radius:50%;place-items:center;display:grid;position:relative}.dashboard-content{background:var(--bg-page);flex:1;padding:24px;overflow-y:auto}.dashboard-page-header{align-items:flex-end;margin-bottom:20px;display:flex}.dashboard-page-header h1{color:var(--text-primary);font-size:22px;font-weight:700}.dashboard-page-header .subtitle{color:var(--text-tertiary);margin-left:16px;font-size:13px}.dashboard-page-header .actions{gap:8px;margin-left:auto;display:flex}.kpi-grid{grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px;display:grid}.kpi-card{border-radius:var(--r-md);border:1px solid var(--border);background:#fff;padding:16px 20px}.kpi-card .label{color:var(--text-tertiary);align-items:center;gap:6px;font-size:12px;font-weight:500;display:flex}.kpi-card .value{color:var(--text-primary);margin-top:4px;font-size:28px;font-weight:700}.kpi-card .delta{align-items:center;gap:4px;margin-top:4px;font-size:12px;display:flex}.delta-up{color:var(--green)}.delta-down{color:var(--red)}.panel{border-radius:var(--r-md);border:1px solid var(--border);background:#fff;margin-bottom:16px;overflow:hidden}.panel-header{border-bottom:1px solid var(--border);align-items:center;gap:12px;padding:14px 18px;display:flex}.panel-title{color:var(--text-primary);flex:1;font-size:17px;font-weight:700}.panel-body{padding:18px}.panel-body-flush{padding:0}table{border-collapse:collapse;width:100%;font-size:15px}table th{background:var(--bg-subtle);color:var(--text-secondary);text-align:left;border-bottom:1px solid var(--border);padding:11px 16px;font-size:14px;font-weight:600}table td{border-bottom:1px solid var(--border);color:var(--text-primary);padding:13px 16px}table tr:last-child td{border-bottom:none}table tr:hover td{background:var(--bg-subtle)}.note-banner{background:linear-gradient(180deg, var(--brand-primary-light) 0%, white 100%);border-left:3px solid var(--brand-primary);color:var(--brand-primary-dark);border-radius:8px;margin-bottom:16px;padding:10px 14px;font-size:12px;font-weight:500}.note-banner strong{font-weight:700}.module-badge{background:var(--brand-secondary);color:#fff;letter-spacing:.5px;vertical-align:middle;border-radius:4px;margin-left:6px;padding:2px 6px;font-size:10px;font-weight:700;display:inline-block}.schedule-grid{border-radius:var(--r-md);border:1px solid var(--border);background:#fff;overflow:hidden}.schedule-row{border-bottom:1px solid var(--border);grid-template-columns:200px repeat(8,1fr);min-height:56px;display:grid}.schedule-row:last-child{border-bottom:none}.schedule-row.header{background:var(--bg-subtle);color:var(--text-secondary);min-height:36px;font-size:11px;font-weight:600}.schedule-row.header>div{text-align:center;place-items:center;padding:8px 4px;display:grid}.schedule-cell{border-left:1px solid var(--border);padding:6px;font-size:11px}.schedule-driver{background:var(--bg-subtle);border-right:2px solid var(--border);align-items:center;gap:8px;padding:12px 14px;font-size:13px;font-weight:600;display:flex}.schedule-block{background:var(--brand-primary);color:#fff;border-radius:4px;margin:2px 0;padding:4px 6px;font-size:10px;font-weight:600}.schedule-block.blue{background:var(--blue)}.schedule-block.green{background:var(--green)}.schedule-block.gray{background:var(--text-tertiary)}.light-strip{background:var(--bg-subtle);border-radius:var(--r);gap:16px;margin-bottom:16px;padding:16px;display:flex}.light-pill{border-radius:var(--r);border:1px solid var(--border);background:#fff;flex:1;align-items:center;gap:10px;padding:12px;display:flex}.light-pill .count{font-size:22px;font-weight:700}.light-pill .label{color:var(--text-tertiary);font-size:11px}.timeline{flex-direction:column;gap:8px;display:flex}.timeline-step{align-items:flex-start;gap:12px;display:flex}.timeline-step .marker{flex-direction:column;align-items:center;width:24px;display:flex}.timeline-step .dot-tl{background:var(--brand-primary);width:16px;height:16px;box-shadow:0 0 0 2px var(--brand-primary);border:3px solid #fff;border-radius:50%;flex-shrink:0}.timeline-step:not(.done) .dot-tl{box-shadow:0 0 0 2px var(--border-strong);background:#fff}.timeline-step .line-tl{background:var(--border);flex:1;width:2px;min-height:16px;margin:4px 0}.timeline-step .body{flex:1;padding-bottom:12px}.timeline-step .body .title{color:var(--text-primary);font-size:13px;font-weight:600}.timeline-step .body .time{color:var(--text-tertiary);font-size:11px}.timeline-step .dot{background:var(--brand-primary);width:16px;height:16px;box-shadow:0 0 0 2px var(--brand-primary);border:3px solid #fff;border-radius:50%}.timeline-step:not(.done) .dot{box-shadow:0 0 0 2px var(--border-strong);background:#fff}.timeline-step .line{background:var(--border);flex:1;width:2px;margin:4px 0}.timeline-step .title{font-size:13px;font-weight:600}.timeline-step .time{color:var(--text-tertiary);font-size:11px}.calendar{border-radius:var(--r-md);background:#fff;margin-bottom:16px;padding:16px}.calendar-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.calendar-grid{grid-template-columns:repeat(7,1fr);gap:4px;display:grid}.calendar-grid .day-header{color:var(--text-tertiary);text-align:center;padding:4px 0;font-size:11px;font-weight:600}.calendar-grid .day{aspect-ratio:1;color:var(--text-primary);cursor:pointer;border-radius:8px;place-items:center;font-size:13px;font-weight:500;transition:all .15s;display:grid}.calendar-grid .day.selected{background:var(--brand-primary);color:#fff;font-weight:700}.calendar-grid .day.disabled{color:var(--text-tertiary);cursor:not-allowed}.calendar-grid .day.weekend{color:var(--brand-primary)}.calendar-grid .day.weekend.selected{color:#fff}.calendar-grid .day:hover:not(.disabled):not(.selected){background:var(--bg-subtle)}.qr-scanner{color:#fff;background:linear-gradient(#000 0%,#1a1a1a 100%);flex-direction:column;flex:1;align-items:center;padding:20px;display:flex}.qr-frame{border-radius:16px;width:240px;height:240px;margin:40px auto;position:relative;overflow:hidden}.qr-corner{border-color:var(--brand-primary);z-index:2;border-style:solid;border-width:0;width:32px;height:32px;position:absolute}.qr-corner.tl{border-top-width:4px;border-left-width:4px;border-top-left-radius:16px;top:-2px;left:-2px}.qr-corner.tr{border-top-width:4px;border-right-width:4px;border-top-right-radius:16px;top:-2px;right:-2px}.qr-corner.bl{border-bottom-width:4px;border-left-width:4px;border-bottom-left-radius:16px;bottom:-2px;left:-2px}.qr-corner.br{border-bottom-width:4px;border-right-width:4px;border-bottom-right-radius:16px;bottom:-2px;right:-2px}.qr-scanline{background:linear-gradient(90deg, transparent, var(--brand-primary), transparent);z-index:2;height:2px;animation:2s ease-in-out infinite scan;position:absolute;top:50%;left:16px;right:16px}.qr-hint{color:#ffffffb3;text-align:center;margin-top:8px;font-size:14px}@keyframes scan{0%,to{opacity:.4;top:8%}50%{opacity:1;top:92%}}.otp-input{justify-content:center;gap:8px;margin:24px 0;display:flex}.otp-input input{border:1.5px solid var(--border-strong);border-radius:var(--r);text-align:center;width:44px;height:56px;font-size:22px;font-weight:700;font-family:var(--font);background:#fff}.otp-input input:focus{border-color:var(--brand-primary);outline:none}.bind-success{background:linear-gradient(180deg, var(--brand-primary-light) 0%, white 100%);flex-direction:column;flex:1;align-items:center;padding:40px 24px;display:flex;overflow-y:auto}.success-icon{background:var(--green);color:#fff;border-radius:50%;place-items:center;width:80px;height:80px;margin-bottom:16px;animation:.4s bounceIn;display:grid;box-shadow:0 10px 24px #10b9814d}@keyframes bounceIn{0%{transform:scale(0)}60%{transform:scale(1.1)}to{transform:scale(1)}}.bar-chart{align-items:flex-end;gap:8px;height:160px;padding:8px 0;display:flex}.bar{background:linear-gradient(180deg, var(--brand-primary), var(--brand-primary-dark));border-radius:6px 6px 0 0;flex:1;position:relative}.bar span{color:var(--text-tertiary);white-space:nowrap;font-size:10px;position:absolute;bottom:-22px;left:50%;transform:translate(-50%)}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:4px}.drv-tab-bar{border-top:1px solid var(--border);background:#fff;flex-shrink:0;display:none;box-shadow:0 -2px 8px #0000000f}.drv-tab-btn{cursor:pointer;color:var(--text-tertiary);padding:8px 4px;padding-bottom:max(10px, env(safe-area-inset-bottom,10px));font-size:10px;font-weight:600;font-family:var(--font);background:0 0;border:none;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:3px;transition:color .12s;display:flex}.drv-tab-btn.is-active{color:var(--brand-primary)}.drv-nav-links{align-items:center;gap:4px;display:flex}.drv-nav-burger{cursor:pointer;justify-content:center;align-items:center;padding:6px;display:none}.drv-menu-dropdown{border:1px solid var(--border);border-radius:var(--r);box-shadow:var(--shadow);z-index:50;background:#fff;min-width:160px;padding:6px;position:absolute;top:100%;right:0}.drv-menu-item{cursor:pointer;width:100%;font-size:13px;font-family:var(--font);color:var(--text-primary);background:0 0;border:none;border-radius:6px;align-items:center;gap:8px;padding:8px 12px;display:flex}.drv-menu-item:hover{background:var(--bg-subtle)}.drv-menu-divider{background:var(--border);height:1px;margin:4px 0}.kpi-strip-top{grid-template-columns:repeat(6,1fr);gap:12px;margin-bottom:16px;display:grid}.kpi-top-card{border-radius:var(--r-md);border:1px solid var(--border);background:#fff;flex-direction:column;gap:4px;padding:14px 16px;display:flex}.kpi-top-card .label{color:var(--text-tertiary);letter-spacing:.3px;text-transform:uppercase;font-size:11px;font-weight:600}.kpi-top-card .value{font-size:26px;font-weight:900;line-height:1.1}.kpi-top-card .sub{color:var(--text-secondary);font-size:11px}.kpi-top-card.accent-green{border-left:3px solid var(--green)}.kpi-top-card.accent-yellow{border-left:3px solid var(--yellow)}.kpi-top-card.accent-red{border-left:3px solid var(--red)}.kpi-top-card.accent-brand{border-left:3px solid var(--brand-primary)}.kpi-top-card.accent-blue{border-left:3px solid var(--blue)}.kpi-top-card.accent-secondary{border-left:3px solid var(--brand-secondary)}.vehicle-mini{border-radius:var(--r-md);border:1px solid var(--border);background:#fff;margin-bottom:16px;padding:14px 16px}.vehicle-mini-header{align-items:center;margin-bottom:10px;display:flex}.vehicle-mini-header h3{font-size:13px;font-weight:700}.vehicle-mini-grid{grid-template-columns:repeat(7,1fr);gap:8px;display:grid}.v-pill{background:var(--bg-subtle);border:1px solid var(--border);border-radius:8px;align-items:center;gap:6px;padding:6px 8px;font-size:11px;font-weight:600;display:flex}.v-pill.assigned{background:var(--brand-primary-light);border-color:var(--brand-primary);color:var(--brand-primary-dark)}.v-pill.idle{background:var(--bg-page);color:var(--text-tertiary)}.v-pill.maint{border-color:var(--yellow);color:#92400e;background:#fffbeb}.dispatch-grid{grid-template-columns:1.2fr 1fr;gap:16px;display:grid}.driver-pool,.order-queue{border-radius:var(--r-md);border:1px solid var(--border);background:#fff;overflow:hidden}.pool-header{border-bottom:1px solid var(--border);align-items:center;gap:10px;padding:14px 18px;display:flex}.pool-header h3{flex:1;font-size:14px;font-weight:700}.filter-chip{background:var(--bg-page);border:1px solid var(--border);cursor:pointer;border-radius:999px;align-items:center;gap:4px;padding:4px 10px;font-size:11px;font-weight:600;display:inline-flex}.filter-chip.active{background:var(--brand-secondary);color:#fff;border-color:var(--brand-secondary)}.pool-divider{text-transform:uppercase;letter-spacing:1px;background:var(--bg-subtle);color:var(--text-tertiary);align-items:center;gap:8px;padding:7px 18px;font-size:10px;font-weight:700;display:flex}.pool-divider .count-chip{color:var(--text-secondary);border:1px solid var(--border);background:#fff;border-radius:999px;padding:2px 8px;font-size:10px}.driver-card{border-bottom:1px solid var(--border);grid-template-columns:42px 1fr auto;align-items:center;gap:12px;padding:12px 18px;transition:background .15s;display:grid}.driver-card:hover{background:var(--bg-subtle)}.driver-card:last-child{border-bottom:none}.driver-card .avatar-d{background:var(--bg-page);width:40px;height:40px;color:var(--text-primary);border:1px solid var(--border);border-radius:50%;place-items:center;font-size:16px;font-weight:700;display:grid;position:relative}.driver-card .avatar-d .status-dot{border:2px solid #fff;border-radius:50%;width:13px;height:13px;position:absolute;bottom:-2px;right:-2px}.driver-card.status-green .avatar-d .status-dot{background:var(--green)}.driver-card.status-yellow .avatar-d .status-dot{background:var(--yellow)}.driver-card.status-red .avatar-d .status-dot{background:var(--red)}.driver-card.status-gray .avatar-d .status-dot{background:var(--text-tertiary)}.driver-card.status-green{background:linear-gradient(90deg,#10b9810a,#0000)}.driver-card.status-yellow{background:linear-gradient(90deg,#f59e0b0d,#0000)}.driver-card.status-red{opacity:.85;background:linear-gradient(90deg,#ef44440f,#0000)}.driver-card .info .name{font-size:14px;font-weight:700}.driver-card .info .meta{color:var(--text-tertiary);margin-top:2px;font-size:11px}.driver-card .actions{flex-direction:column;align-items:flex-end;gap:4px;display:flex}.driver-card .actions .load{color:var(--text-tertiary);font-size:11px}.btn-dispatch{background:var(--brand-primary);color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:8px;padding:6px 14px;font-size:12px;font-weight:600}.btn-dispatch:disabled{background:var(--bg-subtle);color:var(--text-tertiary);cursor:not-allowed}.driver-card.status-yellow .btn-dispatch{background:var(--yellow)}.order-card{border-bottom:1px solid var(--border);grid-template-columns:1fr auto;align-items:center;gap:10px;padding:12px 18px;display:grid}.order-card:last-child{border-bottom:none}.order-card:hover{background:var(--bg-subtle)}.order-card.is-special{border-left:3px solid var(--brand-primary)}.order-card .order-no{color:var(--brand-secondary);font-size:14px;font-weight:700}.order-card .order-time{color:var(--text-tertiary);font-size:11px;font-weight:600}.order-card .order-route{color:var(--text-primary);margin:2px 0;font-size:13px}.order-card .order-req{color:var(--text-tertiary);font-size:11px}.order-card .arrow{color:var(--text-tertiary);margin:0 4px}.dispatch-modal-overlay{z-index:1000;background:#11182780;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.dispatch-modal{border-radius:var(--r-md);background:#fff;flex-direction:column;width:520px;max-width:100%;max-height:88vh;display:flex;overflow:hidden;box-shadow:0 20px 50px #00000040}.dispatch-modal-header{border-bottom:1px solid var(--border);align-items:center;gap:10px;padding:16px 20px;display:flex}.dispatch-modal-header h2{flex:1;font-size:16px;font-weight:700}.dispatch-modal-close{background:var(--bg-page);width:28px;height:28px;color:var(--text-secondary);cursor:pointer;border:none;border-radius:50%;place-items:center;font-size:18px;line-height:1;display:grid}.dispatch-modal-body{flex:1;padding:18px 20px;overflow-y:auto}.dispatch-modal-footer{border-top:1px solid var(--border);justify-content:flex-end;gap:8px;padding:12px 20px;display:flex}.dispatch-b-wrap{border-radius:var(--r-md);border:1px solid var(--border);background:#fff;overflow-x:auto}.tl-grid{min-width:1100px}.tl-row{border-bottom:1px solid var(--border);grid-template-columns:200px repeat(14,1fr);min-height:68px;display:grid}.tl-row:last-child{border-bottom:none}.tl-row.head{background:var(--bg-subtle);color:var(--text-secondary);min-height:36px;font-size:11px;font-weight:600}.tl-row.head>div{text-align:center;border-left:1px solid var(--border);place-items:center;padding:8px 4px;display:grid}.tl-row.head>div:first-child{text-align:left;border-left:none;padding:8px 14px}.tl-driver-cell{background:var(--bg-subtle);border-right:2px solid var(--border);align-items:center;gap:10px;padding:8px 12px;display:flex}.tl-driver-cell.green{background:linear-gradient(90deg, #10b98112, var(--bg-subtle))}.tl-driver-cell.yellow{background:linear-gradient(90deg, #f59e0b14, var(--bg-subtle))}.tl-driver-cell.red{background:linear-gradient(90deg, #ef444414, var(--bg-subtle));opacity:.85}.tl-avatar{border:1px solid var(--border);background:#fff;border-radius:50%;flex-shrink:0;place-items:center;width:30px;height:30px;font-size:12px;font-weight:700;display:grid;position:relative}.tl-avatar .status-dot{border:2px solid var(--bg-subtle);border-radius:50%;width:10px;height:10px;position:absolute;bottom:-2px;right:-2px}.tl-driver-cell.green .status-dot{background:var(--green)}.tl-driver-cell.yellow .status-dot{background:var(--yellow)}.tl-driver-cell.red .status-dot{background:var(--red)}.tl-driver-cell.gray .status-dot{background:var(--text-tertiary)}.tl-d-name{font-size:12px;font-weight:700}.tl-d-meta{color:var(--text-tertiary);font-size:10px}.tl-slot{border-left:1px solid var(--border);padding:4px}.tl-slot.dropzone{background:repeating-linear-gradient(45deg,#0000,#0000 8px,#e85a2b0a 8px 16px)}.tl-block{background:var(--brand-primary);color:#fff;border-radius:5px;flex-direction:column;justify-content:center;height:calc(100% - 2px);padding:4px 7px;font-size:10px;font-weight:600;display:flex}.tl-block.special{background:linear-gradient(135deg, var(--brand-primary), #c84416)}.tl-block.blue{background:var(--blue)}.dispatch-b-right{border-radius:var(--r-md);border:1px solid var(--border);background:#fff;min-width:260px;overflow:hidden}.legend{background:var(--bg-subtle);border-radius:var(--r-md);flex-wrap:wrap;align-items:center;gap:14px;margin-bottom:12px;padding:10px 16px;font-size:12px;display:flex}.legend .item{align-items:center;gap:6px;display:flex}@keyframes spin{to{transform:rotate(360deg)}}@keyframes slideFromRight{0%{opacity:.85;transform:translate(100%)}to{opacity:1;transform:translate(0)}}@keyframes slideFromLeft{0%{opacity:.85;transform:translate(-100%)}to{opacity:1;transform:translate(0)}}.step-slide-forward{animation:.25s ease-in-out both slideFromRight}.step-slide-back{animation:.25s ease-in-out both slideFromLeft}@media (width<=639px){.drv-tab-bar{display:flex!important}.drv-nav-links{display:none!important}.drv-nav-burger{display:flex!important}.kpi-grid{grid-template-columns:repeat(2,1fr)}.dashboard{grid-template-columns:1fr}.dashboard-sidebar{display:none}}@media (width<=768px){.field,.field-input,input.field,textarea.field,select.field{font-size:16px!important}}.divider{background:var(--border);height:1px;margin:12px 0}.map-mock{background-color:#0000;background-image:linear-gradient(135deg,#e85a2b0d,#1e3a5f0d),radial-gradient(circle at 30% 40%,#e5edf5 0%,#0000 50%),radial-gradient(circle at 70% 60%,#e5edf5 0%,#0000 50%),linear-gradient(#f1f5f9 0%,#e2e8f0 100%);background-position:0 0,0 0,0 0,0 0;background-repeat:repeat,repeat,repeat,repeat;background-size:cover;background-attachment:scroll,scroll,scroll,scroll;background-origin:padding-box,padding-box,padding-box,padding-box;background-clip:border-box,border-box,border-box,border-box;height:320px;position:relative;overflow:hidden}.map-mock:before{content:"";opacity:.3;background-image:linear-gradient(#0000 49%,#cbd5e1 49% 51%,#0000 51%),linear-gradient(90deg,#0000 49%,#cbd5e1 49% 51%,#0000 51%);background-size:40px 40px;position:absolute;inset:0}.map-pin{place-items:center;width:32px;height:32px;display:grid;position:absolute}.map-pin .pin-dot{border:3px solid #fff;border-radius:50%;width:16px;height:16px;box-shadow:0 2px 6px #00000040}.map-pin.start .pin-dot{background:var(--blue)}.map-pin.end .pin-dot{background:var(--brand-primary)}.map-pin.driver .pin-dot{background:var(--green);animation:2s infinite pulse-pin}@keyframes pulse-pin{0%,to{box-shadow:0 0 #10b98166,0 2px 6px #00000040}50%{box-shadow:0 0 0 12px #10b98100,0 2px 6px #00000040}}.photo-grid{grid-template-columns:repeat(3,1fr);gap:8px;display:grid}.photo-tile{aspect-ratio:1;border-radius:var(--r);color:#fffc;background:linear-gradient(135deg,#d4d4d8,#a1a1aa);place-items:center;display:grid;position:relative;overflow:hidden}.photo-tile.add{background:var(--bg-page);border:2px dashed var(--border-strong);color:var(--text-tertiary)}.photo-tile:after{content:"";background:linear-gradient(#0000 60%,#0006);position:absolute;inset:0}.photo-tile span{color:#fff;z-index:1;font-size:10px;position:absolute;bottom:4px;left:6px}.photo-tile img{object-fit:cover;width:100%;height:100%}.check-item{border-radius:var(--r);border:1.5px solid var(--border);cursor:pointer;background:#fff;justify-content:space-between;align-items:center;margin-bottom:8px;padding:12px 16px;display:flex}.check-item.checked{border-color:var(--brand-primary);background:var(--brand-primary-light)}.check-item .check-box{border:2px solid var(--border-strong);border-radius:6px;flex-shrink:0;place-items:center;width:22px;height:22px;margin-right:12px;display:grid}.check-item.checked .check-box{background:var(--brand-primary);border-color:var(--brand-primary);color:#fff}.check-item .item-label{color:var(--text-primary);flex:1;font-size:14px}.check-item .item-price{color:var(--brand-secondary);font-size:14px;font-weight:700}.signature-pad{border:1px dashed var(--border-strong);border-radius:var(--r-md);height:160px;color:var(--text-tertiary);background:#fafafa;place-items:center;font-size:13px;display:grid;position:relative}.star-row{justify-content:center;gap:4px;margin:20px 0;display:flex}.star{color:#fcd34d;cursor:pointer;font-size:36px}.star.empty{color:var(--gray-light)}
