:root{--primary: #84cc16;--primary-light: #d9f99d;--primary-dark: #65a30d;--primary-hover: #a3e635;--primary-bg: #f7fee7;--bg-main: #f1f5f9;--bg-card: #ffffff;--bg-hover: #f8fafc;--bg-input: #f8fafc;--text-main: #0f172a;--text-secondary: #475569;--text-muted: #94a3b8;--border-color: #e2e8f0;--border-light: #f1f5f9;--success: #22c55e;--success-bg: #f0fdf4;--warning: #f59e0b;--warning-bg: #fffbeb;--error: #ef4444;--error-bg: #fef2f2;--info: #3b82f6;--info-bg: #eff6ff;--shadow-sm: 0 1px 2px rgba(0,0,0,.05);--shadow-md: 0 4px 12px rgba(0,0,0,.08);--shadow-lg: 0 8px 24px rgba(0,0,0,.1);--radius-sm: 10px;--radius-md: 14px;--radius-lg: 18px;--radius-full: 9999px;--font: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono: "SF Mono", "Fira Code", monospace;color-scheme:light}[data-theme=dark]{--primary: #a3e635;--primary-light: #4d7c0f;--primary-dark: #84cc16;--primary-hover: #bef264;--primary-bg: rgba(163, 230, 53, .1);--bg-main: #0f172a;--bg-card: #1e293b;--bg-hover: #334155;--bg-input: #1e293b;--text-main: #f1f5f9;--text-secondary: #94a3b8;--text-muted: #64748b;--border-color: #334155;--border-light: #1e293b;--success-bg: rgba(34, 197, 94, .12);--warning-bg: rgba(245, 158, 11, .12);--error-bg: rgba(239, 68, 68, .12);--info-bg: rgba(59, 130, 246, .12);--shadow-sm: 0 1px 2px rgba(0,0,0,.2);--shadow-md: 0 4px 12px rgba(0,0,0,.3);--shadow-lg: 0 8px 24px rgba(0,0,0,.4);color-scheme:dark}*{margin:0;padding:0;box-sizing:border-box}html,body,#root{height:100%;width:100%}body{font-family:var(--font);background:var(--bg-main);color:var(--text-main);-webkit-font-smoothing:antialiased;-webkit-tap-highlight-color:transparent;overscroll-behavior:none}.spin{animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.mono{font-family:var(--font-mono);letter-spacing:-.3px}.driver-app{max-width:480px;margin:0 auto;min-height:100vh;display:flex;flex-direction:column}.app-loader{display:flex;align-items:center;justify-content:center;height:100vh;color:var(--text-muted)}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:linear-gradient(135deg,var(--bg-main) 0%,var(--bg-card) 100%)}.login-card{width:100%;max-width:380px;background:var(--bg-card);border-radius:var(--radius-lg);padding:32px 24px;box-shadow:var(--shadow-lg);border:1px solid var(--border-color)}.login-logo{text-align:center;margin-bottom:28px}.login-icon{width:64px;height:64px;margin:0 auto 14px;display:flex;align-items:center;justify-content:center;background:var(--primary-bg);color:var(--primary-dark);border-radius:var(--radius-md)}.login-logo h1{font-size:20px;font-weight:800}.login-logo p{font-size:13px;color:var(--text-muted);margin-top:4px}.login-error{display:flex;align-items:center;gap:8px;padding:10px 14px;background:var(--error-bg);color:var(--error);border-radius:var(--radius-sm);font-size:13px;margin-bottom:16px}.form-field{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}.form-field label{font-size:12px;font-weight:600;color:var(--text-secondary)}.form-field input,textarea{padding:12px 14px;border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:16px;font-family:var(--font);background:var(--bg-input);color:var(--text-main);outline:none;width:100%;transition:border .15s}.form-field input:focus,textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px #84cc161f}.pw-wrap{position:relative}.pw-wrap input{padding-right:44px}.pw-toggle{position:absolute;right:4px;top:50%;transform:translateY(-50%);background:transparent;border:none;color:var(--text-muted);padding:8px;cursor:pointer}.btn-primary{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 24px;background:var(--primary);color:#0f172a;border:none;border-radius:var(--radius-sm);font-size:15px;font-weight:700;font-family:var(--font);cursor:pointer;transition:all .15s;-webkit-tap-highlight-color:transparent}.btn-primary:hover{background:var(--primary-hover)}.btn-primary:active{transform:scale(.97)}.btn-primary:disabled{opacity:.5;pointer-events:none}.btn-secondary{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 24px;background:var(--bg-card);color:var(--text-secondary);border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:15px;font-weight:600;font-family:var(--font);cursor:pointer;transition:all .15s}.btn-secondary:hover{border-color:var(--primary)}.btn-full{width:100%}.btn-danger{background:var(--error);color:#fff;border-color:var(--error)}.btn-danger:hover{background:#dc2626}.icon-btn{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);border:1px solid var(--border-color);background:var(--bg-card);color:var(--text-secondary);cursor:pointer;transition:all .15s}.icon-btn:hover{border-color:var(--primary);color:var(--primary)}.icon-btn:active{transform:scale(.93)}.icon-btn-danger:hover{border-color:var(--error);color:var(--error)}.pill{padding:6px 14px;border-radius:var(--radius-full);border:1px solid var(--border-color);background:var(--bg-card);color:var(--text-secondary);font-size:12px;font-weight:600;cursor:pointer;transition:all .15s;font-family:var(--font)}.pill:hover{border-color:var(--primary)}.pill.active{background:var(--primary);color:#0f172a;border-color:var(--primary)}.driver-header{display:flex;align-items:center;justify-content:space-between;padding:16px 16px 12px;background:var(--bg-card);border-bottom:1px solid var(--border-color)}.driver-header-left{display:flex;align-items:center;gap:12px}.driver-avatar{width:42px;height:42px;border-radius:var(--radius-sm);background:var(--primary);color:#0f172a;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:18px}.driver-header h2{font-size:16px;font-weight:700}.driver-date{display:flex;align-items:center;gap:4px;font-size:11px;color:var(--text-muted);margin-top:2px}.driver-header-actions{display:flex;gap:6px}.route-stats{display:flex;gap:8px;padding:12px 16px}.route-stat{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;padding:10px 8px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-sm)}.route-stat svg{color:var(--text-muted)}.route-stat-val{font-size:20px;font-weight:800}.stat-success{color:var(--success)}.stat-error{color:var(--error)}.stat-info{color:var(--info)}.route-stat-label{font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted)}.route-region{display:flex;align-items:center;justify-content:center;gap:6px;padding:6px 12px;margin:0 16px;background:var(--info-bg);color:var(--info);border-radius:var(--radius-sm);font-size:12px;font-weight:600}.stops-list{padding:12px 16px 100px;display:flex;flex-direction:column;gap:8px;flex:1;overflow-y:auto}.stop-card{display:flex;align-items:flex-start;gap:12px;padding:14px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;transition:all .15s;text-align:left;width:100%;font-family:var(--font)}.stop-card:active{transform:scale(.98)}.stop-card.active{border-left:3px solid var(--primary)}.stop-card.done{opacity:.5;border-left:3px solid var(--success);cursor:default}.stop-card.failed{opacity:.5;border-left:3px solid var(--error);cursor:default}.stop-num{width:36px;height:36px;border-radius:var(--radius-sm);background:var(--primary-bg);color:var(--primary-dark);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:15px;flex-shrink:0}.stop-card.done .stop-num{background:var(--success-bg);color:var(--success)}.stop-card.failed .stop-num{background:var(--error-bg);color:var(--error)}.stop-info{flex:1;min-width:0}.stop-order-num{font-family:var(--font-mono);font-size:13px;font-weight:700;color:var(--primary-dark)}.stop-tenant,.stop-address,.stop-property{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-secondary);margin-top:3px}.stop-tenant svg,.stop-address svg{color:var(--text-muted);flex-shrink:0}.stop-property{font-size:11px;color:var(--text-muted)}.stop-meta{display:flex;flex-wrap:wrap;gap:4px;margin-top:6px}.stop-tag{display:inline-flex;align-items:center;gap:3px;padding:2px 7px;background:var(--bg-hover);border-radius:4px;font-size:10px;font-weight:600;color:var(--text-muted)}.stop-tag-pro{background:var(--info-bg);color:var(--info)}.stop-tag-warn{background:var(--warning-bg);color:var(--warning)}.stop-chevron{color:var(--text-muted);margin-top:8px;flex-shrink:0}.stop-card.done .stop-chevron,.stop-card.failed .stop-chevron{display:none}.empty-card{display:flex;flex-direction:column;align-items:center;text-align:center;padding:56px 24px;margin:16px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md)}.empty-card svg{color:var(--text-muted);opacity:.3;margin-bottom:16px}.empty-card h3{font-size:17px;margin-bottom:6px}.empty-card p{font-size:13px;color:var(--text-muted)}.delivery-view{display:flex;flex-direction:column;min-height:100vh}.delivery-header{display:flex;align-items:center;gap:12px;padding:14px 16px;background:var(--bg-card);border-bottom:1px solid var(--border-color)}.back-btn{display:flex;align-items:center;gap:2px;background:transparent;border:none;color:var(--primary-dark);font-size:14px;font-weight:600;cursor:pointer;font-family:var(--font);padding:6px 4px}.delivery-header-title{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:600}.delivery-stop-badge{padding:3px 10px;background:var(--primary-bg);color:var(--primary-dark);border-radius:6px;font-size:11px;font-weight:700}.delivery-section{padding:14px 16px;border-bottom:1px solid var(--border-light)}.section-label{display:flex;align-items:center;gap:6px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);margin-bottom:10px}.delivery-contact{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.contact-info h3{display:flex;align-items:center;gap:8px;font-size:16px}.contact-address,.contact-property{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-secondary);margin-top:4px}.contact-property{color:var(--text-muted);font-size:11px}.contact-actions{display:flex;gap:6px;flex-shrink:0}.contact-btn{display:flex;flex-direction:column;align-items:center;gap:3px;padding:10px 14px;border-radius:var(--radius-sm);text-decoration:none;font-size:10px;font-weight:700;transition:all .15s}.contact-btn:active{transform:scale(.93)}.contact-btn.call{background:var(--success-bg);color:var(--success)}.contact-btn.sms{background:var(--info-bg);color:var(--info)}.contact-status-row{display:flex;gap:16px}.toggle-check{display:flex;align-items:center;gap:8px;font-size:13px;cursor:pointer}.toggle-check input[type=checkbox]{width:20px;height:20px;accent-color:var(--primary)}.delivery-instructions{font-size:13px;color:var(--text-secondary);line-height:1.5;padding:10px 12px;background:var(--warning-bg);border-radius:var(--radius-sm);border-left:3px solid var(--warning)}.service-flags{display:flex;flex-direction:column;gap:8px}.service-flag{display:flex;gap:12px;padding:12px;border-radius:var(--radius-sm)}.service-flag.pro{background:var(--info-bg);color:var(--info)}.service-flag.remove{background:var(--warning-bg);color:var(--warning)}.service-flag svg{flex-shrink:0;margin-top:2px}.service-flag strong{display:block;font-size:13px}.service-flag span{display:block;font-size:11px;opacity:.8;margin-top:2px}.delivery-items{display:flex;flex-direction:column;gap:6px}.d-item{display:flex;align-items:center;gap:10px;padding:8px;background:var(--bg-hover);border-radius:var(--radius-sm)}.d-item-img{width:40px;height:40px;border-radius:6px;background:var(--bg-main);display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0}.d-item-img img{width:100%;height:100%;object-fit:cover}.d-item-img svg{color:var(--text-muted)}.d-item-name{font-size:13px;font-weight:600;display:block}.d-item-qty{font-size:11px;color:var(--text-muted)}.photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(90px,1fr));gap:8px}.photo-thumb{position:relative;aspect-ratio:1;border-radius:var(--radius-sm);overflow:hidden}.photo-thumb img{width:100%;height:100%;object-fit:cover}.photo-remove{position:absolute;top:4px;right:4px;width:22px;height:22px;border-radius:50%;background:#0009;color:#fff;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer}.photo-add{aspect-ratio:1;border:2px dashed var(--border-color);border-radius:var(--radius-sm);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;background:transparent;color:var(--text-muted);font-size:10px;font-weight:600;font-family:var(--font);cursor:pointer;transition:all .15s}.photo-add:hover{border-color:var(--primary);color:var(--primary)}.delivery-actions{padding:16px;display:flex;flex-direction:column;gap:8px;background:var(--bg-card);border-top:1px solid var(--border-color);margin-top:auto}.btn-delivered{font-size:16px;padding:16px}.btn-failed{font-size:14px;color:var(--error);border-color:var(--error)}.btn-failed:hover{background:var(--error-bg)}.modal-overlay{position:fixed;inset:0;background:#00000080;z-index:200;display:flex;align-items:flex-end;justify-content:center;animation:fadeIn .2s}[data-theme=dark] .modal-overlay{background:#000000b3}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.fail-modal{width:100%;max-width:480px;background:var(--bg-card);border-radius:var(--radius-lg) var(--radius-lg) 0 0;padding:24px;animation:slideUp .25s ease}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.fail-modal h3{display:flex;align-items:center;gap:8px;font-size:16px;margin-bottom:16px;color:var(--error)}.fail-reasons{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin-bottom:16px}.fail-reason{padding:12px;border:1px solid var(--border-color);border-radius:var(--radius-sm);background:var(--bg-card);color:var(--text-main);font-size:13px;font-weight:500;font-family:var(--font);cursor:pointer;transition:all .15s;text-align:center}.fail-reason:hover{border-color:var(--error)}.fail-reason.active{background:var(--error-bg);border-color:var(--error);color:var(--error);font-weight:700}.fail-actions{display:flex;gap:12px;margin-top:16px}.fail-actions .btn-secondary{flex:1}.fail-actions .btn-danger{flex:2}.delivery-success{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;min-height:100vh;padding:24px}.delivery-success svg{color:var(--success);margin-bottom:16px}.delivery-success h2{font-size:24px;margin-bottom:8px}.delivery-success p{color:var(--text-muted);margin-bottom:24px}.history-view{display:flex;flex-direction:column;min-height:100vh}.history-period{display:flex;gap:6px;padding:12px 16px}.history-stats{display:flex;gap:8px;padding:0 16px 12px}.h-stat{flex:1;display:flex;flex-direction:column;align-items:center;padding:10px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-sm)}.h-stat-val{font-size:22px;font-weight:800}.h-stat-label{font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted)}.history-list{padding:0 16px 80px;display:flex;flex-direction:column;gap:6px;overflow-y:auto}.history-card{display:flex;gap:12px;padding:12px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-sm)}.history-card.delivered{border-left:3px solid var(--success)}.history-card.failed{border-left:3px solid var(--error)}.history-icon{flex-shrink:0;margin-top:2px}.history-card.delivered .history-icon{color:var(--success)}.history-card.failed .history-icon{color:var(--error)}.history-info{flex:1;min-width:0}.history-order{font-family:var(--font-mono);font-size:12px;font-weight:700;color:var(--primary-dark)}.history-detail{display:flex;align-items:center;gap:4px;font-size:11px;color:var(--text-secondary);margin-top:2px}.history-detail svg{color:var(--text-muted);flex-shrink:0}.history-notes{font-size:11px;color:var(--text-muted);margin-top:4px;font-style:italic}.history-meta{display:flex;flex-direction:column;align-items:flex-end;gap:4px;flex-shrink:0}.history-date{font-size:10px;color:var(--text-muted)}.history-region{font-size:9px;font-weight:600;padding:2px 6px;background:var(--info-bg);color:var(--info);border-radius:4px}@supports (padding-bottom: env(safe-area-inset-bottom)){.delivery-actions{padding-bottom:calc(16px + env(safe-area-inset-bottom))}.stops-list{padding-bottom:calc(100px + env(safe-area-inset-bottom))}}
