:root{--bg:#f7f9fc;--card:#ffffff;--panel:#e6ebf3;--muted:#5b6472;--text:#0f172a;--accent:#2563eb;--success:#1b9e4b;--warn:#ff9800;--danger:#e53935;--pickup:#e07a17;--delivery:#0d63b5;--bar-bg: rgba(255,255,255,.9);--chip-bg:#eef2f7;--chip-border:#d6dde8;--font-scale: 1;--radius:12px;--space:12px;--safe-top: env(safe-area-inset-top);--safe-bottom: env(safe-area-inset-bottom)}.theme-dark{--bg:#0b0c0f;--card:#121418;--panel:#2a2f3a;--muted:#8a93a3;--text:#e9eef7;--accent:#2b8aef;--success:#25a244;--warn:#ff9800;--danger:#e53935;--pickup:#ffb74d;--delivery:#64b5f6;--bar-bg: rgba(10,12,16,.8);--chip-bg:#1a1d24;--chip-border:#2a2f3a}:root[data-theme=light]{--bg:#f7f9fc;--card:#ffffff;--panel:#e6ebf3;--muted:#5b6472;--text:#0f172a;--accent:#2563eb;--success:#1b9e4b;--warn:#ff9800;--danger:#e53935;--pickup:#e07a17;--delivery:#0d63b5;--bar-bg: rgba(255,255,255,.9);--chip-bg:#eef2f7;--chip-border:#d6dde8}:root[data-theme=dark]{--bg:#0b0c0f;--card:#121418;--panel:#2a2f3a;--muted:#8a93a3;--text:#e9eef7;--accent:#2b8aef;--success:#25a244;--warn:#ff9800;--danger:#e53935;--pickup:#ffb74d;--delivery:#64b5f6;--bar-bg: rgba(10,12,16,.8);--chip-bg:#1a1d24;--chip-border:#2a2f3a}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;background:var(--bg);color:var(--text)}body :root{--surface: #ffffff;--danger: #b00020}body .btn{display:inline-flex;align-items:center;justify-content:center;padding:10px 14px;border:1px solid rgba(0,0,0,.1);background:#f5f5f5;border-radius:10px}body .btn.compact{padding:6px 10px;font-size:calc(14px * var(--font-scale))}body .card{border:1px solid #e5e7eb;border-radius:12px;padding:12px;background:#fff}body .card-title{font-weight:700;margin-bottom:4px}body .small{font-size:calc(12px * var(--font-scale))}.app-shell{padding:calc(var(--space) + var(--safe-top)) var(--space) calc(64px + var(--safe-bottom));max-width:720px;margin:0 auto}h1,h2,h3{margin:0 0 8px}.banner{display:flex;align-items:center;gap:8px;padding:10px 12px;border-radius:999px;width:100%}.banner.pickup{color:var(--pickup)}.banner.delivery{color:var(--delivery)}.banner.none{color:var(--muted)}.banner.pickup{background:#fff7e9;border:1px solid #ffdfb3}.banner.delivery{background:#e9f4ff;border:1px solid #b9dcff}.banner.none{background:#f3f5f9;border:1px dashed #d6dde8}.theme-dark .banner.pickup{background:#ffb74d26;border:1px solid rgba(255,183,77,.3)}.theme-dark .banner.delivery{background:#64b5f626;border:1px solid rgba(100,181,246,.3)}.theme-dark .banner.none{background:#1a1d24;border:1px dashed var(--panel)}.chips{display:flex;gap:6px;margin-top:8px;flex-wrap:wrap}.chip{font-size:12px;padding:4px 8px;border-radius:999px;background:var(--chip-bg);color:var(--muted);border:1px solid var(--chip-border)}.chip.live{color:#1db954;border-color:#1db95433;background:#1db95414}.chip.off{color:#ff5252;border-color:#ff525233;background:#ff525214}.section{margin-top:16px}.card{background:var(--card);border:1px solid var(--panel);border-radius:var(--radius);padding:12px}.card+.card{margin-top:10px}.card-title{display:flex;align-items:center;gap:8px;font-weight:600}.small{font-size:12px;color:var(--muted)}.accordion{border:1px solid var(--panel);border-radius:var(--radius);overflow:hidden}.accordion-header{display:flex;justify-content:space-between;align-items:center;padding:12px;background:color-mix(in oklch,var(--card) 90%,var(--text));cursor:pointer}.accordion-body{padding:12px;background:color-mix(in oklch,var(--card) 96%,var(--text))}.type-badge{display:inline-flex;align-items:center;gap:6px;padding:2px 8px;border-radius:999px;font-weight:700;font-size:12px;border:1px solid transparent}.type-badge .emoji{filter:saturate(.9);opacity:.95}.type-badge.pickup{color:var(--pickup);border-color:color-mix(in srgb,var(--pickup) 45%,transparent);background:color-mix(in oklch,var(--card) 92%,var(--pickup))}.type-badge.delivery{color:var(--delivery);border-color:color-mix(in srgb,var(--delivery) 45%,transparent);background:color-mix(in oklch,var(--card) 92%,var(--delivery))}.type-badge.both{color:color-mix(in srgb,var(--pickup) 50%,var(--delivery) 50%);border-color:color-mix(in srgb,var(--pickup) 30%,var(--delivery) 30%);background:color-mix(in oklch,var(--card) 90%,color-mix(in srgb,var(--pickup) 50%,var(--delivery) 50%))}.theme-dark .type-badge.pickup{background:color-mix(in srgb,var(--pickup) 18%,transparent);border-color:color-mix(in srgb,var(--pickup) 35%,transparent)}.theme-dark .type-badge.delivery{background:color-mix(in srgb,var(--delivery) 18%,transparent);border-color:color-mix(in srgb,var(--delivery) 35%,transparent)}.theme-dark .type-badge.both{background:color-mix(in srgb,var(--pickup) 9%,var(--delivery) 9%,transparent);border-color:color-mix(in srgb,var(--pickup) 25%,var(--delivery) 25%,transparent)}.bottom-bar{position:fixed;left:0;right:0;bottom:0;padding:8px calc(12px + env(safe-area-inset-right)) calc(8px + var(--safe-bottom)) calc(12px + env(safe-area-inset-left));background:var(--bar-bg);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-top:1px solid var(--panel);z-index:100}.actions{display:flex;gap:8px}.btn{flex:1;min-height:44px;border-radius:10px;border:none;font-weight:600;color:#fff;cursor:pointer}.btn.primary{background:var(--accent)}.btn.secondary{background:#374151}.btn.warn{background:var(--warn)}.btn.danger{background:var(--danger)}.btn.locked{background:#3b4250;color:#c0c6d4;position:relative}.theme-dark .btn.locked{background:#2a2f3a;color:#9aa3b5}.btn.locked:after{content:"";position:absolute;inset:0;border:1px dashed #9aa3b544;border-radius:10px;pointer-events:none}.btn.locked:hover{cursor:not-allowed}.btn.compact{flex:0 0 auto;min-width:120px;padding:8px 12px;color:var(--text)}.input,textarea.input{width:100%;padding:10px;border-radius:10px;border:1px solid #2a2f3a;background:#0f1218;color:var(--text)}.label{display:block;margin:6px 0 6px 2px;font-size:13px;color:var(--muted)}.toast{position:fixed;left:50%;transform:translate(-50%);bottom:calc(72px + var(--safe-bottom));background:var(--card);color:var(--text);border:1px solid var(--panel);border-radius:999px;padding:10px 14px;z-index:200;box-shadow:0 6px 24px #00000040}@media (min-width: 768px){.app-shell{padding-bottom:24px}.bottom-bar{position:sticky;inset:auto auto 0}}.btn{color:var(--text);background:#fff;border:1px solid #d6dde8;font-weight:600}.btn.primary{background:var(--accent);color:#fff}.btn.secondary{background:#374151;color:#fff}.btn.ghost{background:#fff;color:var(--accent);border:1px solid var(--accent);font-weight:600}.btn.ghost:hover,.btn.ghost:focus{background:color-mix(in srgb,var(--accent) 8%,#ffffff)}.theme-dark .btn{background:#2a2f3a;border:1px solid #3a4350;color:var(--text)}.theme-dark .btn.ghost{background:transparent;color:var(--accent);border:1px solid var(--accent)}.theme-dark .btn.ghost:hover,.theme-dark .btn.ghost:focus{background:color-mix(in srgb,var(--accent) 20%,transparent)}.btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.btn.block{width:100%}.btn.subtle-warn{background:transparent;color:var(--warn);border:1px solid color-mix(in srgb,var(--warn) 20%,transparent);min-height:40px;border-radius:10px;font-size:calc(13px * var(--font-scale));font-weight:600;opacity:.8;transition:background .2s ease,border-color .2s ease,opacity .2s ease,transform .05s ease}.btn.subtle-warn:hover,.btn.subtle-warn:focus{background:color-mix(in srgb,var(--warn) 10%,transparent);border-color:color-mix(in srgb,var(--warn) 35%,transparent);opacity:1}.btn.subtle-warn:active{transform:translateY(1px)}.btn.subtle-warn:before{content:"⚠";display:inline-block;margin-right:6px;font-size:1em;line-height:1;opacity:.9}.theme-dark .btn.subtle-warn{background:transparent;border-color:color-mix(in srgb,var(--warn) 28%,transparent)}.theme-dark .btn.subtle-warn:hover,.theme-dark .btn.subtle-warn:focus{background:color-mix(in srgb,var(--warn) 18%,transparent);border-color:color-mix(in srgb,var(--warn) 40%,transparent)}.task-address-primary{font-weight:700;font-size:calc(19px * var(--font-scale));line-height:1.35;color:var(--text)}.task-address-primary.compact{font-size:calc(17px * var(--font-scale));font-weight:600}.task-address-secondary{font-size:calc(16px * var(--font-scale));line-height:1.35;color:var(--text);opacity:.9}.task-customer-secondary{font-size:calc(14px * var(--font-scale));color:var(--muted);opacity:.85}:root{--bg:#F7F9FC;--surface:#FFFFFF;--surface-alt:#F1F5FA;--border:#E2E8F0;--border-strong:#CBD5E1;--accent:#0A66FF;--accent-rgb:10 102 255;--accent-hover:#004FCC;--accent-soft:#E5F0FF;--warn:#F4B400;--success:#27AE60;--text:#1E2933;--text-dim:#5A6B7D;--radius-xs:4px;--radius-sm:6px;--radius:10px;--radius-lg:16px;--shadow-sm:0 1px 2px rgba(0 0 0 / .04), 0 0 0 1px var(--border);--shadow:0 4px 12px -2px rgba(0 0 0 / .08), 0 2px 4px -1px rgba(0 0 0 / .06);--shadow-focus:0 0 0 2px #fff, 0 0 0 4px rgba(var(--accent-rgb)/.55);--font-sans:system-ui,"Inter","Segoe UI",Roboto,Arial,sans-serif;--transition-fast: .18s cubic-bezier(.4,0,.2,1);--transition-med: .28s cubic-bezier(.4,0,.2,1)}@media (prefers-color-scheme: dark){:root{--bg:#12141A;--surface:#1E232B;--surface-alt:#262C35;--border:#2F3742;--border-strong:#3A4552;--text:#EEF3F9;--text-dim:#94A2B5;--shadow-sm:0 1px 2px rgba(0 0 0 / .6),0 0 0 1px #2F3742;--shadow:0 4px 14px -2px rgba(0 0 0 / .65),0 2px 6px -1px rgba(0 0 0 / .5);--shadow-focus:0 0 0 2px #1E232B,0 0 0 4px rgba(var(--accent-rgb)/.55)}}:root[data-theme=light]{--bg:#F7F9FC;--surface:#FFFFFF;--surface-alt:#F1F5FA;--border:#E2E8F0;--border-strong:#CBD5E1;--accent:#0A66FF;--accent-rgb:10 102 255;--accent-hover:#004FCC;--accent-soft:#E5F0FF;--warn:#F4B400;--success:#27AE60;--text:#1E2933;--text-dim:#5A6B7D;--radius-xs:4px;--radius-sm:6px;--radius:10px;--radius-lg:16px;--shadow-sm:0 1px 2px rgba(0 0 0 / .04), 0 0 0 1px var(--border);--shadow:0 4px 12px -2px rgba(0 0 0 / .08), 0 2px 4px -1px rgba(0 0 0 / .06);--shadow-focus:0 0 0 2px #fff, 0 0 0 4px rgba(var(--accent-rgb)/.55)}:root[data-theme=dark]{--bg:#12141A;--surface:#1E232B;--surface-alt:#262C35;--border:#2F3742;--border-strong:#3A4552;--accent:#0A66FF;--accent-rgb:10 102 255;--accent-hover:#004FCC;--accent-soft:#0f172a33;--warn:#F4B400;--success:#27AE60;--text:#EEF3F9;--text-dim:#94A2B5;--radius-xs:4px;--radius-sm:6px;--radius:10px;--radius-lg:16px;--shadow-sm:0 1px 2px rgba(0 0 0 / .6),0 0 0 1px #2F3742;--shadow:0 4px 14px -2px rgba(0 0 0 / .65),0 2px 6px -1px rgba(0 0 0 / .5);--shadow-focus:0 0 0 2px #1E232B,0 0 0 4px rgba(var(--accent-rgb)/.55)}.dashboard-root{background:var(--bg);color:var(--text);font-family:var(--font-sans);min-height:100vh;display:flex;flex-direction:column}.dashboard-nav{background:var(--surface);border-bottom:1px solid var(--border);padding:14px clamp(16px,3vw,32px) 10px;position:sticky;top:0;z-index:40}.dashboard-nav-head{display:flex;align-items:center;gap:12px;margin-bottom:12px}.dashboard-title{font-size:22px;font-weight:600;margin:0;letter-spacing:.3px}.dashboard-tabs{display:flex;list-style:none;padding:0;margin:0;gap:8px;flex-wrap:wrap}.dashboard-tab-btn{--_bg:transparent;--_color:var(--accent);background:var(--_bg);color:var(--_color);border:1px solid var(--accent);border-radius:var(--radius-sm);padding:7px 14px;font-size:14px;cursor:pointer;position:relative;display:inline-flex;align-items:center;gap:6px;transition:var(--transition-fast);font-weight:500}.dashboard-tab-btn:hover{background:var(--accent-soft)}.dashboard-tab-btn.is-active{background:var(--accent);color:#fff;box-shadow:0 2px 4px -1px rgba(var(--accent-rgb)/.5)}.dashboard-tab-btn:focus-visible{outline:none;box-shadow:var(--shadow-focus)}.dashboard-archive-btn{margin-left:auto;font-size:12px;padding:6px 12px;background:#6c757d;color:#fff;border:none;border-radius:var(--radius-xs);cursor:pointer;display:inline-flex;align-items:center;gap:4px}.dashboard-archive-btn.is-active{background:var(--accent)}.dashboard-archive-btn:focus-visible{outline:none;box-shadow:var(--shadow-focus)}.overview-wrapper{flex:1;overflow:auto}.overview-inner{max-width:1320px;margin:0 auto;padding:24px clamp(16px,3vw,40px) 48px}.overview-inner h2{font-size:24px;margin:0 0 8px;letter-spacing:.25px}.overview-inner p{margin:0 0 16px;color:var(--text-dim)}.notice-banner{margin:14px 0 6px;padding:10px 14px;background:#fff3cd;border:1px solid #ffeeba;border-radius:var(--radius-sm);color:#856404;font-size:14px}.notice-banner:focus{outline:2px solid #856404}.module-grid{display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-top:28px}.dashboard-card{position:relative;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px 18px 70px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;min-height:220px;transition:box-shadow var(--transition-fast),transform var(--transition-fast),background var(--transition-med)}.dashboard-card:before{content:"";position:absolute;inset:0;border-radius:inherit;background:linear-gradient(140deg,rgba(var(--accent-rgb)/.08),transparent 55%);opacity:0;transition:opacity var(--transition-med);pointer-events:none}.dashboard-card:hover{transform:translateY(-2px);box-shadow:var(--shadow)}.dashboard-card:hover:before{opacity:1}.dashboard-card:focus-visible{outline:none;box-shadow:var(--shadow-focus)}.card-head{display:flex;align-items:center;gap:12px;margin-bottom:12px}.card-icon{width:46px;height:46px;display:flex;align-items:center;justify-content:center;font-size:22px;background:var(--accent-soft);border-radius:14px}.card-title{font-size:18px;font-weight:600;letter-spacing:.3px;margin:0}.card-desc{font-size:14px;line-height:1.45;color:var(--text-dim);display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:3;line-clamp:3;overflow:hidden;margin:0 0 18px}.card-action{margin-top:auto;align-self:flex-start;background:var(--accent);color:#fff;border:none;font-size:14px;font-weight:500;padding:10px 16px;border-radius:var(--radius-sm);cursor:pointer;line-height:1.1;letter-spacing:.25px;display:inline-flex;gap:6px;align-items:center;transition:background var(--transition-fast)}.card-action:hover{background:var(--accent-hover)}.card-action:focus-visible{outline:none;box-shadow:0 0 0 3px rgba(var(--accent-rgb)/.4)}@media (max-width:600px){.dashboard-card{min-height:200px;padding:18px 16px 64px}.card-title{font-size:16px}.overview-inner{padding:20px 18px 40px}.dashboard-title{font-size:20px}}@media (prefers-reduced-motion: reduce){.dashboard-card,.dashboard-tab-btn{transition:none!important}}.addressbook-wrap{padding:24px;display:flex;justify-content:center}.addressbook-card{width:100%;max-width:1100px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow)}.addressbook-loading{min-height:240px;display:flex;flex-direction:column;gap:12px}.skeleton-title,.skeleton-row,.skeleton-list{background:linear-gradient(90deg,#f3f4f6,#eef2f7,#f3f4f6);border-radius:6px}.skeleton-title{height:18px;width:30%}.skeleton-row{height:12px;width:50%}.skeleton-list{height:120px;width:100%}.addressbook-header{display:flex;gap:16px;align-items:center;justify-content:space-between;margin-bottom:12px}.addressbook-title{margin:0;font-size:20px;color:var(--text);font-weight:700}.addressbook-sub{margin:4px 0 0;color:var(--text-dim);font-size:14px}.addressbook-controls{display:flex;gap:10px;align-items:center}.address-search{padding:8px 10px;border:1px solid var(--border-strong);border-radius:8px;min-width:220px;background:var(--surface);color:var(--text)}.address-sort{padding:8px 10px;border:1px solid var(--border-strong);border-radius:8px;background:var(--surface)}.btn-primary{padding:10px 14px;background:var(--accent);color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:600}.btn-primary:hover{background:var(--accent-hover)}.address-add-btn{white-space:nowrap}.addressbook-main{margin-top:10px}.address-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}@media (max-width:900px){.address-grid{grid-template-columns:1fr}}.address-card{border:1px solid var(--border);border-radius:8px;padding:12px;background:var(--surface);transition:box-shadow .12s ease,transform .06s ease}.address-card:hover{box-shadow:var(--shadow);transform:translateY(-2px)}.address-card-body{display:flex;justify-content:space-between;gap:12px;align-items:flex-start}.address-card-main{flex:1;min-width:0}.address-name{margin:0;font-size:16px;font-weight:700;color:var(--text)}.address-line{margin:6px 0 0;color:var(--text-dim);font-size:14px}.address-phone,.address-notes{margin-top:6px;color:var(--text-dim);font-size:13px}.address-actions{display:flex;gap:8px;align-items:center;margin-left:12px}.btn-ghost{padding:8px 10px;border-radius:8px;border:1px solid rgba(14,165,233,.12);background:#eef6ff;color:var(--accent);cursor:pointer;font-weight:600}.btn-danger{padding:8px 10px;border-radius:8px;border:1px solid #fee2e2;background:#fff1f2;color:#b91c1c;cursor:pointer;font-weight:600}.address-empty{padding:36px;text-align:center;color:var(--text-dim)}.address-search:focus,.address-sort:focus,.btn-primary:focus,.btn-ghost:focus,.btn-danger:focus{outline:3px solid rgba(var(--accent-rgb),.18);outline-offset:2px}.archive-container{padding:20px;display:flex;justify-content:center}.archive-card{width:100%;max-width:1200px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;box-shadow:var(--shadow-sm)}.archive-header{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px}.archive-title{margin:0;font-size:20px;color:var(--text)}.archive-controls{display:flex;gap:10px;align-items:center}.archive-search{padding:8px 10px;border:1px solid var(--border-strong);border-radius:6px;min-width:260px;font-size:14px}.archive-bulk-btn{padding:8px 14px;background:#6c757d;color:#fff;border:none;border-radius:6px;cursor:pointer}.archive-bulk-btn:disabled{opacity:.6;cursor:not-allowed}.archive-error{color:#b91c1c;margin-bottom:10px}.archive-summary{margin:12px 0 18px;padding:10px;background:var(--surface-alt);border-radius:6px;display:flex;gap:20px;flex-wrap:wrap;color:var(--text-dim)}.archive-table-wrap{overflow-x:auto}.archive-table{width:100%;border-collapse:collapse;font-size:13px}.archive-table thead th{background:var(--surface-alt);padding:10px 8px;text-align:left;border-bottom:1px solid var(--border);color:var(--text-dim)}.archive-table tbody td{padding:10px 8px;border-bottom:1px solid #f1f5f9;vertical-align:middle;color:var(--text)}.archive-table tbody tr:nth-child(odd){background:transparent}.archive-table tbody tr:hover{background:#fbfdff}.badge{display:inline-block;padding:4px 8px;border-radius:999px;font-size:12px;font-weight:600;text-transform:capitalize;color:#fff}.badge.delivery{background:#10b981}.badge.pickup{background:#2563eb}.badge.both{background:#7c3aed}.badge.na{background:#6b7280}.archive-unarchive-btn{padding:6px 10px;background:transparent;border:1px solid var(--border);border-radius:6px;cursor:pointer}.archive-unarchive-btn:disabled{opacity:.6;cursor:not-allowed}.archive-pagination{margin-top:20px;text-align:center;display:flex;justify-content:center;gap:12px;align-items:center}.archive-paginate-btn{padding:6px 10px;border:1px solid var(--border);border-radius:6px;background:transparent;cursor:pointer}.archive-paginate-info{margin:0 6px;color:var(--text-dim)}.archive-empty{text-align:center;padding:40px;color:var(--text-dim)}.archive-noaccess{padding:20px;text-align:center;color:var(--warn)}@media (max-width:800px){.archive-card{padding:14px}.archive-controls{flex-direction:column;align-items:flex-end}.archive-search{width:100%;min-width:auto}}.archive-controls{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:12px;align-items:start;padding:12px;background:#fff;border-radius:8px;box-shadow:0 1px 2px #0000000a;border:1px solid #e9ecef;box-sizing:border-box;width:100%;max-width:100%}.archive-filters{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px;row-gap:12px;align-items:start;grid-auto-rows:minmax(40px,auto);min-width:0}.filter-group{display:flex;flex-direction:column;gap:6px;min-width:0;align-self:start}.filter-label{font-size:12px;font-weight:600;color:#333}.filter-label{margin-bottom:2px}.filter-input,.filter-select,.archive-search,.archive-driver,.filter-input[type=date]{padding:8px 10px;height:36px;border:1px solid #dfe3e8;border-radius:6px;font-size:14px;background:#fff;box-sizing:border-box;width:100%}.filter-group.quick-range-row{grid-column:1 / -1;display:flex;gap:6px;align-items:center;margin-top:8px;align-self:center}.archive-actions{display:flex;flex-direction:column;gap:10px;align-items:flex-start;justify-self:end;min-width:0;padding-top:20px}.archive-actions .actions-top{display:flex;gap:8px;align-items:center;margin:0}.btn,.archive-bulk-btn{height:36px;line-height:20px;min-width:72px;padding:0 12px;box-sizing:border-box;display:inline-flex;align-items:center;justify-content:center;border-radius:6px;border:1px solid #dfe3e8;font-size:14px;cursor:pointer;background:#fff;color:#111}.btn:hover{background:#f8f9fb}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:#0d6efd;color:#fff;border-color:#0d6efd}.btn-primary:hover{background:#0b5ed7;border-color:#0b5ed7}.btn-secondary{background:#fff;color:#111;border-color:#e6e9ee}.btn-secondary:hover{background:#f8f9fb}.btn-sm{padding:6px 8px;font-size:13px;height:34px;min-width:48px}.quick-range-btn{padding:6px 8px;border-radius:6px;border:1px solid #e6e9ee;background:#f6f8fa}.quick-range-btn.active{background:#0d6efd;color:#fff;border-color:#0d6efd}.archive-bulk-btn{padding:8px 12px;background:#6c757d;color:#fff;border:none;border-radius:8px;cursor:pointer;min-width:140px}.archive-bulk-btn:disabled{opacity:.7;cursor:not-allowed}.filter-badge{background:#0d6efd;color:#fff;padding:4px 8px;border-radius:999px;font-weight:700;font-size:12px;display:inline-block}@media (max-width: 700px){.archive-controls{grid-template-columns:1fr}.archive-filters{grid-template-columns:repeat(2,minmax(140px,1fr))}.archive-actions{align-items:stretch;justify-self:stretch}.archive-actions .actions-top{justify-content:flex-end;width:100%}.archive-bulk-btn{min-width:auto;width:100%}}.archive-loading-overlay{position:relative}.archive-loading-overlay:after{content:"";position:absolute;inset:0;background:#fff9;display:none}.archive-loading-overlay.loading:after{display:block}.archive-controls .filter-group input[type=date],.archive-controls .filter-group input[type=text]{min-width:120px}@media (max-width: 540px){.archive-filters{grid-template-columns:1fr}}.archive-card{background:transparent;overflow:hidden}.filter-input:focus,.filter-select:focus,.archive-search:focus,.archive-driver:focus{outline:3px solid rgba(13,110,253,.12);outline-offset:1px}.archive-controls .btn.btn-primary{background:#0d6efd;border-color:#0d6efd;color:#fff}.archive-controls .quick-range-btn{padding:6px 8px;height:34px;min-width:48px;border-radius:6px;border:1px solid #e6e9ee;background:#f6f8fa;color:#111}.archive-controls .quick-range-btn.active{background:#0d6efd;border-color:#0d6efd;color:#fff}@media (min-width: 1100px){.archive-filters{grid-template-columns:repeat(4,minmax(200px,1fr));grid-auto-rows:auto;grid-template-areas:"search type   status  driver" "from   to     ranges  driver"}.filter-group.search{grid-area:search}.filter-group.type{grid-area:type}.filter-group.status{grid-area:status}.filter-group.from{grid-area:from}.filter-group.to{grid-area:to}.filter-group.driver{grid-area:driver}.filter-group.quick-range-row{grid-area:ranges;margin-top:0}}@media (max-width: 1099.98px){.archive-filters{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));grid-template-areas:none}.filter-group.quick-range-row{grid-column:1 / -1}}.filter-group.search{min-width:220px}.filter-group.search .archive-search{max-width:360px;width:100%;box-sizing:border-box}.filter-group.from,.filter-group.to{min-width:160px}.quick-ranges{display:flex;gap:6px;align-items:center;flex-wrap:wrap}@media (max-width: 700px){.archive-controls{grid-template-columns:1fr}.archive-filters{grid-template-columns:repeat(2,minmax(140px,1fr))}.filter-group.quick-range-row{grid-column:1 / -1;margin-top:6px}.archive-actions{align-items:stretch;justify-self:stretch;padding-top:8px}.archive-actions .actions-top{justify-content:flex-end;width:100%}.archive-bulk-btn{min-width:auto;width:100%}}.driver-reorder-panel{position:fixed;top:var(--driver-panel-top, 0px);right:0;bottom:0;width:380px;background:#fff;border-left:1px solid #e5e7eb;display:flex;flex-direction:column;z-index:2000;box-shadow:-2px 0 6px #0000000a;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}.driver-reorder-header{padding:10px 12px;border-bottom:1px solid #eee;display:flex;align-items:center;justify-content:space-between}.driver-reorder-error{color:#b91c1c;padding:6px 10px;font-size:12px}.driver-reorder-body{flex:0 0 auto;padding:8px 10px;display:flex;flex-direction:column;gap:12px}.driver-group{border:1px solid #e5e7eb;border-radius:8px;overflow:hidden;background:#fff}.driver-group-header{padding:6px 8px;display:flex;align-items:center;justify-content:space-between;cursor:pointer}.driver-group-header.is-drop-target{outline:2px dashed #2563eb;outline-offset:-2px;position:relative}.driver-group-header.is-drop-target:after{content:"Drop to move";font-size:10px;font-weight:500;color:#1d4ed8;margin-left:8px}.driver-deliveries{list-style:none;margin:0;padding:0}.driver-deliveries li{padding:6px 8px;font-size:12px;border-top:1px solid #f1f5f9;display:flex;align-items:center;gap:6px;cursor:move}.driver-reorder-footer{padding:8px;border-top:1px solid #eee;font-size:11px;color:#555;display:flex;justify-content:space-between;flex-shrink:0}.driver-reorder-body{padding-bottom:env(safe-area-inset-bottom,12px)}.live-map-container{min-height:calc(100vh - 140px);height:100%;display:flex;flex-direction:column;position:relative}.live-map-main{flex:1 1 auto;position:relative;min-height:0;display:block}.live-map-canvas{position:absolute;inset:0;width:100%;height:100%;background:#e5e3df}.drivers-sidebar{position:absolute;top:0;left:0;width:320px;height:100%;background:#fffffff2;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-right:1px solid rgba(0,0,0,.1);padding:12px;overflow-y:auto;z-index:1000;box-shadow:2px 0 8px #0000001a}.history-sidebar{position:absolute;top:0;right:0;width:360px;height:100%;background:#fffffff2;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-left:1px solid rgba(0,0,0,.1);padding:12px;overflow-y:auto;z-index:1000;box-shadow:-2px 0 8px #0000001a}.driver-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}.driver-item{width:100%;display:flex;align-items:center;gap:10px;padding:10px;border:1px solid #e6eef8;border-radius:8px;background:#fff;cursor:pointer}.driver-item:hover{box-shadow:0 1px 4px #0000000f}.driver-item.selected{background:#f1f7ff;box-shadow:0 2px 8px #0e41960f}.driver-avatar{width:40px;height:40px;border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:13px;flex-shrink:0}.driver-meta{min-width:0;overflow:hidden}.driver-name{font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.driver-sub{font-size:12px;color:#666;display:flex;gap:10px;margin-top:4px}.driver-controls{margin-left:auto;display:flex;align-items:center;gap:8px}.driver-swatch{width:28px;height:28px;border-radius:6px;border:1px solid #ddd}.color-input{width:34px;height:28px;padding:0;border:none;background:transparent;cursor:pointer}.color-input::-webkit-color-swatch-wrapper{padding:0}.color-input::-webkit-color-swatch{border:none}.btn-reset{padding:6px 8px;border-radius:6px;border:1px solid #eee;background:#fff;cursor:pointer}.visually-hidden-input{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);border:0}.driver-item:focus{outline:3px solid rgba(21,156,228,.15);outline-offset:2px}.driver-item:focus .driver-avatar{box-shadow:0 0 0 3px #159ce414}
