:root{--orange: #FF6B00;--orange-hover: #E55A00;--orange-light: #FFF3E8;--orange-subtle: #FFF8F3;--white: #ffffff;--bg: #F2F3F5;--text: #1C1C1E;--muted: #8E8E93;--border: #E5E5EA;--green: #27ae60;--green-bg: #f0faf4;--red: #c0392b;--red-bg: #fdecea;--shadow-sm: 0 1px 4px rgba(0,0,0,.08);--shadow: 0 4px 16px rgba(0,0,0,.1);--radius: 16px;--radius-sm: 10px}*{box-sizing:border-box;margin:0;padding:0}html,body{font-family:Inter,system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--text);min-height:100vh;-webkit-font-smoothing:antialiased}.hidden{display:none!important}.auth-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px 16px;background:linear-gradient(160deg,#ff6b00,#ff8c38 35%,#f2f3f5)}.auth-card{background:var(--white);border-radius:24px;padding:36px 28px;width:100%;max-width:380px;box-shadow:var(--shadow)}.auth-logo{text-align:center;margin-bottom:32px}.logo-icon{width:72px;height:72px;background:var(--orange);border-radius:20px;display:flex;align-items:center;justify-content:center;font-size:36px;margin:0 auto 14px}.auth-title{font-size:26px;font-weight:800;color:var(--text);margin-bottom:4px}.auth-subtitle{font-size:13px;color:var(--muted)}.auth-form{display:flex;flex-direction:column;gap:16px}.field{display:flex;flex-direction:column;gap:6px}.field label{font-size:13px;font-weight:600;color:var(--text)}.field input{padding:14px 16px;border-radius:var(--radius-sm);border:1.5px solid var(--border);background:var(--white);font-size:15px;color:var(--text);outline:none;transition:border-color .15s;font-family:inherit;width:100%}.field input:focus{border-color:var(--orange)}.password-wrapper{position:relative}.password-wrapper input{padding-right:48px}.toggle-pwd{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;font-size:16px;padding:4px;opacity:.5;line-height:1}.toggle-pwd:hover{opacity:.9}.auth-message{text-align:center;font-size:13px;color:var(--muted);padding:10px 14px;background:var(--orange-subtle);border-radius:var(--radius-sm);border:1px solid rgba(255,107,0,.12)}.auth-message.error{color:var(--red);background:var(--red-bg);border-color:#c0392b26}.btn-primary{background:var(--orange);color:#fff;border:none;border-radius:var(--radius-sm);padding:15px 20px;font-size:15px;font-weight:700;cursor:pointer;transition:background .15s,transform .1s;text-align:center;font-family:inherit;display:block}.btn-primary:hover{background:var(--orange-hover)}.btn-primary:active{transform:scale(.98)}.btn-primary.btn-sm{padding:10px 16px;font-size:13px;border-radius:8px;display:inline-block}.btn-wide{width:100%}.btn-secondary{background:var(--white);color:var(--text);border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:14px 18px;font-size:14px;font-weight:600;cursor:pointer;font-family:inherit;transition:border-color .15s}.btn-secondary:hover{border-color:var(--orange);color:var(--orange)}.btn-ghost{background:transparent;border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:9px 16px;font-size:14px;font-weight:600;color:var(--text);cursor:pointer;font-family:inherit;transition:border-color .15s}.btn-ghost:hover{border-color:var(--orange);color:var(--orange)}.btn-all-delivered{background:var(--green-bg);color:var(--green);border:1.5px solid var(--green);border-radius:var(--radius-sm);padding:8px 14px;font-size:13px;font-weight:700;cursor:pointer;font-family:inherit;white-space:nowrap;transition:background .15s}.btn-all-delivered:hover{background:#d4f5e3}.app-screen{min-height:100vh;background:var(--bg);display:flex;flex-direction:column}.app-header{background:var(--white);padding:14px 20px;display:flex;align-items:center;justify-content:space-between;box-shadow:var(--shadow-sm);position:sticky;top:0;z-index:100}.header-brand{display:flex;align-items:center;gap:12px}.header-logo{width:40px;height:40px;background:var(--orange);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:20px;flex:0 0 auto}.header-title{font-size:16px;font-weight:800;line-height:1.1}.header-sub{font-size:12px;color:var(--muted);margin-top:1px}.app-content{padding:20px 16px 48px;max-width:640px;margin:0 auto;width:100%}.upload-section{background:var(--white);border-radius:var(--radius);padding:20px;margin-bottom:16px;box-shadow:var(--shadow-sm)}.upload-btns{display:flex;gap:10px}.btn-upload{flex:1;padding:14px}.numbers-panel{margin-top:14px;padding:14px;background:var(--orange-subtle);border:1px solid rgba(255,107,0,.18);border-radius:var(--radius-sm)}.numbers-hint{font-size:13px;color:var(--muted);margin-bottom:10px;line-height:1.4}.numbers-row{display:flex;gap:8px}.numbers-input{flex:1;padding:10px 14px;border-radius:8px;border:1.5px solid var(--border);font-size:14px;color:var(--text);background:var(--white);font-family:inherit;outline:none}.numbers-input:focus{border-color:var(--orange)}.numbers-status{font-size:12px;color:var(--orange);margin-top:8px;font-weight:600;min-height:16px}.schedule-bar{display:flex;align-items:center;gap:10px;margin-top:12px;flex-wrap:wrap}.schedule-label{font-size:13px;color:var(--muted);font-weight:600}.date-nav{display:flex;align-items:center;gap:4px}.date-nav-btn{padding:6px 10px;font-size:18px;line-height:1;border-radius:8px}.date-picker-input{padding:7px 10px;border-radius:8px;border:1.5px solid var(--border);font-size:13px;color:var(--text);font-weight:600;font-family:inherit;background:var(--white);outline:none;cursor:pointer;transition:border-color .15s}.date-picker-input:focus{border-color:var(--orange)}.date-picker-input.is-today{border-color:var(--orange);color:var(--orange)}.dropzone{display:flex;align-items:center;gap:12px;padding:16px;border:2px dashed var(--border);border-radius:var(--radius-sm);cursor:pointer;margin-top:14px;transition:border-color .15s,background .15s}.dropzone:hover,.dropzone.dragover{border-color:var(--orange);background:var(--orange-subtle)}.dz-icon{font-size:22px;flex:0 0 auto}.dz-text{font-size:13px;color:var(--muted);line-height:1.4}.status-msg{font-size:13px;color:var(--muted);margin-top:10px;min-height:18px;line-height:1.4}.tab-bar{display:flex;gap:4px;background:var(--white);border-radius:var(--radius);padding:6px;margin-bottom:16px;box-shadow:var(--shadow-sm)}.tab-btn{flex:1;padding:10px;border:none;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;font-family:inherit;color:var(--muted);background:transparent;transition:background .15s,color .15s;display:flex;align-items:center;justify-content:center;gap:6px}.tab-btn.active{background:var(--orange);color:#fff}.tab-badge{background:#fff;color:var(--orange);border-radius:999px;font-size:11px;font-weight:700;padding:1px 6px;line-height:1.4}.tab-btn.active .tab-badge{background:#ffffff40;color:#fff}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.header-actions{display:flex;align-items:center;gap:8px}.route-count{font-size:13px;color:var(--orange);font-weight:600;background:var(--orange-light);padding:4px 10px;border-radius:999px}.route-list{display:flex;flex-direction:column;gap:10px;margin-bottom:16px}.route-card{background:var(--white);border-radius:var(--radius);border:1.5px solid transparent;box-shadow:var(--shadow-sm);overflow:hidden;cursor:pointer;transition:border-color .15s,box-shadow .15s,opacity .15s}.route-card.dragging{opacity:.35;box-shadow:none}.route-card.drag-over{border-color:var(--orange);box-shadow:0 0 0 3px #ff6b0026}.route-card.is-delivered{border-color:var(--green)}.card-main{display:flex;align-items:center;gap:12px;padding:14px 16px;cursor:pointer}.drag-handle-icon{display:grid;grid-template-columns:1fr 1fr;gap:3px;width:14px;color:#c7c7cc;cursor:grab;flex:0 0 auto;padding:2px 0;touch-action:none}.drag-handle-icon:active{cursor:grabbing}.dot{width:3px;height:3px;border-radius:50%;background:currentColor}.app-toast{position:fixed;bottom:80px;left:50%;transform:translate(-50%) translateY(12px);background:#191919eb;color:#fff;border-radius:20px;padding:10px 20px;font-size:14px;font-weight:500;opacity:0;transition:opacity .2s,transform .2s;pointer-events:none;z-index:10000;white-space:pre-line;max-width:88vw;text-align:center}.app-toast.visible{opacity:1;transform:translate(-50%) translateY(0)}.route-badge{width:32px;height:32px;border-radius:50%;background:var(--orange);color:#fff;font-size:13px;font-weight:700;display:flex;align-items:center;justify-content:center;flex:0 0 auto}.route-card.is-delivered .route-badge{background:var(--green)}.route-info{flex:1;min-width:0}.route-address{font-size:14px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.3}.route-ordnum{font-size:12px;color:var(--muted);margin-top:2px}.route-actions{display:flex;align-items:center;gap:8px;flex:0 0 auto}.delivered-btn{width:34px;height:34px;border-radius:50%;border:2px solid var(--border);background:var(--white);color:transparent;font-size:15px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;flex:0 0 auto;transition:all .15s;font-family:inherit;line-height:1}.delivered-btn:hover{border-color:var(--green);color:#27ae6080}.delivered-btn.is-delivered{background:var(--green);border-color:var(--green);color:#fff}.maps-btn{background:var(--orange);color:#fff;border:none;border-radius:8px;padding:8px 14px;font-size:12px;font-weight:700;cursor:pointer;white-space:nowrap;font-family:inherit;transition:background .15s}.maps-btn:hover{background:var(--orange-hover)}.card-details{padding:0 16px 14px;border-top:1px solid var(--border);margin-top:0}.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px 16px;margin-top:12px;font-size:13px;color:var(--muted)}.detail-grid strong{color:var(--text);display:block;font-weight:600;font-size:12px;margin-bottom:1px}.detail-grid span{font-size:13px;color:var(--text)}.cal-nav{display:flex;align-items:center;justify-content:space-between;background:var(--white);border-radius:var(--radius);padding:14px 16px;margin-bottom:12px;box-shadow:var(--shadow-sm)}.cal-nav-center{text-align:center;flex:1}.cal-nav-center>span{font-size:15px;font-weight:700;display:block;margin-bottom:2px}.cal-month-count{font-size:12px;color:var(--orange);font-weight:600}.cal-nav-btn{padding:8px 14px;font-size:20px;line-height:1}.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:3px;background:var(--white);border-radius:var(--radius);padding:14px 10px;box-shadow:var(--shadow-sm);margin-bottom:12px}.cal-header-cell{text-align:center;font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;padding:4px 0 8px;letter-spacing:.04em}.cal-cell{position:relative;text-align:center;padding:6px 2px;border-radius:8px;font-size:14px;font-weight:500;cursor:default;min-height:36px;display:flex;flex-direction:column;align-items:center;justify-content:center}.cal-cell.has-deliveries{cursor:pointer;font-weight:700;color:var(--orange)}.cal-cell.has-deliveries:hover{background:var(--orange-light)}.cal-cell.is-today{background:var(--orange-subtle);border:1.5px solid rgba(255,107,0,.4);border-radius:8px}.cal-cell.is-selected{background:var(--orange)!important;color:#fff!important}.cal-cell.is-selected .cal-dot{background:#fff}.cal-dot{width:5px;height:5px;border-radius:50%;background:var(--orange);margin-top:2px;flex-shrink:0}.cal-day-detail{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden;margin-bottom:12px}.cal-detail-header{padding:12px 16px;font-weight:700;font-size:14px;background:var(--orange-light);color:var(--orange);border-bottom:1px solid var(--border)}.history-item{background:var(--white);border-radius:0;padding:12px 16px;border-bottom:1px solid var(--border)}.history-item:last-child{border-bottom:none}.history-addr{font-size:14px;font-weight:600;margin-bottom:4px}.history-meta{font-size:12px;color:var(--muted)}.empty-state{text-align:center;padding:40px 20px;color:var(--muted);font-size:14px;background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow-sm)}@media (max-width: 420px){.card-main{padding:12px;gap:8px}.route-actions{flex-direction:column;align-items:flex-end;gap:6px}.detail-grid{grid-template-columns:1fr}}.admin-logo{font-size:22px}.admin-form{background:var(--white);border-radius:var(--radius);padding:20px;margin-bottom:16px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:14px}.admin-form-title{font-size:15px;font-weight:700;color:var(--text)}.admin-form-fields{display:grid;grid-template-columns:1fr 1fr;gap:12px}.admin-form-actions{display:flex;gap:10px;flex-wrap:wrap}.user-route-count{font-size:11px;color:var(--muted);font-weight:500;background:var(--bg);border-radius:999px;padding:2px 8px}.admin-role-badge{font-size:11px;font-weight:700;padding:2px 8px;border-radius:999px;display:inline-block}.admin-role-badge.role-admin{background:var(--red-bg);color:var(--red)}.admin-role-badge.role-driver{background:var(--orange-light);color:var(--orange)}.btn-danger{background:var(--red-bg);color:var(--red);border:1.5px solid var(--red);border-radius:8px;padding:8px 12px;font-size:12px;font-weight:700;cursor:pointer;font-family:inherit;white-space:nowrap;transition:background .15s}.btn-danger:hover{background:#f5c6c2}.btn-danger:disabled{opacity:.4;cursor:default}.btn-clear{background:var(--orange-light);color:var(--orange);border:1.5px solid var(--orange);border-radius:8px;padding:8px 12px;font-size:12px;font-weight:700;cursor:pointer;font-family:inherit;white-space:nowrap;transition:background .15s}.btn-clear:hover{background:#ffe4cc}.group-orders-section{border-top:1px solid var(--border)}.group-orders-toggle{display:flex;align-items:center;justify-content:space-between;width:100%;padding:10px 16px;background:none;border:none;cursor:pointer;font-size:13px;font-weight:600;color:var(--text-secondary);font-family:inherit}.group-orders-toggle:hover{background:var(--bg)}.toggle-caret{font-size:14px;color:var(--text-secondary)}.group-orders{display:flex;flex-direction:column;gap:0}.group-order-row{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 16px;border-bottom:1px solid var(--border)}.group-order-row:last-child{border-bottom:none}.group-order-num{font-size:13px;font-weight:600;color:var(--text);flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.group-invoice-list{display:flex;align-items:baseline;gap:6px;padding:10px 16px;border-top:1px solid var(--border)}.group-invoice-label{font-size:11px;font-weight:600;color:var(--text-secondary);white-space:nowrap;flex-shrink:0}.group-invoice-nums{font-size:13px;font-weight:600;color:var(--text)}.group-badge-count{font-size:11px;font-weight:700;background:var(--orange-light);color:var(--orange);border-radius:999px;padding:2px 8px;white-space:nowrap}.group-order-section{border-top:1px solid var(--border)}.group-order-section:first-child{border-top:none}.group-section-header{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 16px;background:var(--orange-subtle);font-size:13px;font-weight:600}.cal-cell.has-route{background:var(--orange-subtle)}.cal-cell.has-route.has-deliveries{background:var(--orange-light)}.cal-cell.is-selected.has-route{background:var(--orange)!important}@media (max-width: 480px){.app-header{padding:12px 14px;gap:8px}.header-logo{width:34px;height:34px;font-size:17px}.header-title{font-size:14px}.header-sub{font-size:11px}.upload-btns{gap:8px}.btn-upload{padding:12px 10px;font-size:14px}.section-header{flex-wrap:wrap;gap:8px}.header-actions{flex-wrap:wrap;gap:6px}.card-main{padding:10px 12px;gap:8px}.route-actions{flex-wrap:wrap;gap:6px;justify-content:flex-end}.delivered-btn{width:30px;height:30px;font-size:13px}.maps-btn{padding:7px 10px;font-size:11px}.drag-handle-icon{width:22px;gap:4px;padding:8px 4px}.dot{width:4px;height:4px}.detail-grid{grid-template-columns:1fr}.group-order-row{flex-wrap:wrap}.admin-form-fields{grid-template-columns:1fr}.admin-form-actions{gap:8px}.cal-grid{padding:10px 6px;gap:2px}.cal-cell{font-size:12px;min-height:32px;padding:4px 1px}.cal-header-cell{font-size:10px}.cal-nav-btn{padding:6px 10px;font-size:16px}.progress-panel{padding:10px 12px}.call-btn{min-width:34px;height:30px;padding:0 8px;font-size:13px}.call-btn .call-count{min-width:14px;height:14px;font-size:10px}}.progress-panel{background:var(--card-bg, #fff);border:1px solid var(--border, #e5e5ea);border-radius:12px;padding:12px 16px;margin:0 16px 12px;box-shadow:0 1px 2px #0000000a}.progress-track{height:8px;background:var(--border, #e5e5ea);border-radius:999px;overflow:hidden}.progress-fill{height:100%;width:0%;background:linear-gradient(90deg,var(--orange, #FF6B00),var(--green, #34C759));border-radius:999px;transition:width .35s ease}.progress-meta{display:flex;justify-content:space-between;align-items:center;margin-top:8px;font-size:12px;color:var(--text-secondary, #8e8e93);font-weight:600}.progress-percent{color:var(--orange, #FF6B00);font-size:13px}.call-btn{position:relative;display:inline-flex;align-items:center;justify-content:center;min-width:38px;height:34px;padding:0 10px;border-radius:8px;border:none;background:#34c759;color:#fff;font-size:15px;font-weight:700;text-decoration:none;cursor:pointer;font-family:inherit;transition:background .15s,transform .05s}.call-btn:hover{background:#2aa84a}.call-btn:active{transform:scale(.96)}.call-btn .call-count{display:inline-flex;align-items:center;justify-content:center;min-width:16px;height:16px;padding:0 4px;margin-left:4px;border-radius:999px;background:#ffffff47;color:#fff;font-size:11px;font-weight:700}.popup-menu{position:fixed;background:#fff;border:1px solid var(--border, #e5e5ea);border-radius:12px;box-shadow:0 10px 30px #0000002e;min-width:200px;max-width:300px;padding:4px;z-index:10000;animation:popupIn .12s ease-out}@keyframes popupIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.popup-menu-item{display:block;padding:12px 14px;color:var(--text, #1c1c1e);text-decoration:none;font-size:14px;font-weight:600;border-radius:8px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:background .12s}.popup-menu-item:hover,.popup-menu-item:active{background:#f2f2f7}
