:root{--bg: #0c1529;--surface: #132040;--surface-2: #1a2d52;--surface-hover: #213a63;--surface-raised: #182b4a;--sidebar-bg: #b91c1c;--sidebar-text: #f1f5f9;--sidebar-text-muted: #94a3b8;--border: #1e3a5f;--border-hover: #2d5a8e;--accent: #dc2626;--accent-hover: #ef4444;--accent-dim: rgba(220, 38, 38, .15);--text: #e2e8f0;--text-muted: #94a3b8;--text-subtle: #64748b;--red-500: #ef4444;--red-dim: rgba(239, 68, 68, .15);--amber-500: #f59e0b;--amber-dim: rgba(245, 158, 11, .15);--green-500: #22c55e;--green-dim: rgba( 34, 197, 94, .15);--blue-500: #3b82f6;--blue-dim: rgba( 59, 130, 246, .15);--purple-500: #8b5cf6;--purple-dim: rgba(139, 92, 246, .15);--lead-color: #7c3aed;--lead-bg: rgba(124, 58, 237, .15);--mover-color: #0891b2;--mover-bg: rgba( 8, 145, 178, .15);--driver-color: #ea580c;--driver-bg: rgba(234, 88, 12, .15);--sidebar-w: 240px;--sidebar-collapsed-w: 64px;--radius: 10px;--radius-sm: 6px;--radius-lg: 14px;--shadow: 0 4px 12px rgba(0,0,0,.4);--shadow-sm: 0 2px 6px rgba(0,0,0,.3)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Inter,Helvetica,Arial,sans-serif;font-size:14px;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:inherit;text-decoration:none}svg{display:block}button{cursor:pointer;font-family:inherit;font-size:14px;border:none;background:none;color:inherit}button:disabled{opacity:.5;cursor:not-allowed}input,textarea,select{font-family:inherit;font-size:14px;color:var(--text)}.app-shell{display:flex;height:100vh;overflow:hidden}.main-content{flex:1;overflow-y:auto;background:var(--bg);min-width:0}.main-content--kiosk{margin-left:0}.sidebar{width:var(--sidebar-w);min-width:var(--sidebar-w);background:var(--sidebar-bg);border-right:1px solid rgba(255,255,255,.08);display:flex;flex-direction:column;transition:width .22s ease,min-width .22s ease;overflow:hidden;z-index:10;color:var(--sidebar-text)}.sidebar--collapsed{width:var(--sidebar-collapsed-w);min-width:var(--sidebar-collapsed-w)}.sidebar-brand{display:flex;align-items:center;justify-content:space-between;padding:16px 14px;border-bottom:1px solid rgba(255,255,255,.1);min-height:60px;gap:8px}.sidebar-logo-text{font-size:18px;font-weight:800;letter-spacing:.1em;color:#fff;white-space:nowrap;overflow:hidden;flex:1}.sidebar-collapse-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:var(--radius-sm);border:1px solid rgba(255,255,255,.15);background:transparent;color:var(--sidebar-text-muted);transition:all .15s;flex-shrink:0}.sidebar-collapse-btn:hover{background:#ffffff1a;color:#fff;border-color:#ffffff40}.sidebar-nav{flex:1;padding:8px;display:flex;flex-direction:column;gap:2px;overflow-y:auto}.nav-item{display:flex;align-items:center;gap:12px;padding:10px;border-radius:var(--radius-sm);color:var(--sidebar-text-muted);transition:all .15s;white-space:nowrap;overflow:hidden;text-decoration:none}.nav-item:hover{background:#ffffff14;color:#fff}.nav-item--active{background:#fff3;color:#fff;font-weight:600}.nav-item--active:hover{background:#ffffff40;color:#fff}.nav-icon{display:flex;align-items:center;justify-content:center;width:20px;height:20px;flex-shrink:0;font-size:16px}.nav-icon svg{width:18px;height:18px}.nav-label{font-size:14px;font-weight:500}.sidebar-footer{padding:12px 14px;border-top:1px solid rgba(255,255,255,.1);min-height:44px;display:flex;align-items:center}.sidebar-version{font-size:11px;color:var(--sidebar-text-muted)}.sidebar-company-name{font-size:11px;font-weight:600;color:#fca5a5;text-transform:uppercase;letter-spacing:.07em;padding:0 16px 10px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-logout-btn{display:flex;align-items:center;gap:8px;padding:7px 10px;border-radius:var(--radius-sm);border:1px solid transparent;background:transparent;color:var(--sidebar-text-muted);font-size:13px;font-weight:500;width:100%;transition:all .15s;cursor:pointer}.sidebar-logout-btn:hover{background:#ef444426;border-color:#ef444440;color:#fca5a5}.page{padding:28px 32px;max-width:1440px;min-height:100%}.page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:28px;flex-wrap:wrap}.page-title{font-size:26px;font-weight:700;color:var(--text);line-height:1.2}.page-subtitle{font-size:14px;color:var(--text-muted);margin-top:4px}.page-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.date-nav{display:flex;align-items:center;gap:4px}.date-nav-btn{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-muted);font-size:18px;line-height:1;padding:5px 10px;cursor:pointer;transition:border-color .15s,color .15s;-webkit-user-select:none;user-select:none}.date-nav-btn:hover{border-color:var(--accent);color:var(--accent)}.date-input{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:7px 12px;color:var(--text);outline:none;cursor:pointer;font-size:14px;transition:border-color .15s}.date-input:focus{border-color:var(--accent)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 16px;border-radius:var(--radius-sm);border:1px solid transparent;font-size:14px;font-weight:500;line-height:1;transition:all .15s;white-space:nowrap;text-decoration:none;cursor:pointer}.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}.btn-primary:hover:not(:disabled){background:var(--accent-hover);border-color:var(--accent-hover);box-shadow:0 0 0 3px var(--accent-dim)}.btn-secondary{background:var(--surface-2);color:var(--text);border-color:var(--border)}.btn-secondary:hover:not(:disabled){background:var(--surface-hover);border-color:var(--border-hover)}.btn-ghost{background:transparent;color:var(--text-muted);border-color:transparent}.btn-ghost:hover:not(:disabled){background:var(--surface-hover);color:var(--text)}.btn-sm{padding:5px 10px;font-size:12px;border-radius:5px}.btn-danger{background:var(--red-dim);color:var(--red-500);border:1px solid rgba(239,68,68,.3)}.btn-danger:hover{background:#ef444433}.btn-success{background:#22c55e1a;color:var(--green-500);border:1px solid rgba(34,197,94,.3)}.btn-success:hover{background:#22c55e2e}.btn-link{background:none;border:none;color:var(--accent);cursor:pointer;font-size:inherit;text-decoration:underline;padding:0}.btn-link:hover{opacity:.8}.form-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.form-section{padding:24px 28px;border-bottom:1px solid var(--border)}.form-section:last-of-type{border-bottom:none}.form-section-title{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);margin-bottom:16px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}@media(max-width:640px){.form-row{grid-template-columns:1fr}}.form-group{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}.form-group:last-child{margin-bottom:0}.form-group--half{max-width:50%}.address-stack{display:flex;flex-direction:column;gap:0}.address-row{display:flex;align-items:flex-end;gap:8px;margin-bottom:10px}.address-row .form-input{flex:1;margin:0}.address-row-label{font-size:11px;font-weight:700;letter-spacing:.6px;text-transform:uppercase;color:var(--text-muted);margin-bottom:5px}.address-connector{display:flex;align-items:center;gap:10px;padding:2px 0 8px 10px;color:var(--border);font-size:16px;line-height:1;-webkit-user-select:none;user-select:none}.address-connector:before{content:"";display:block;width:2px;height:20px;background:var(--border);border-radius:1px}.stop-remove-btn{background:none;border:1px solid var(--border);border-radius:5px;color:var(--text-muted);cursor:pointer;font-size:15px;height:36px;width:36px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s;line-height:1;padding:0;margin-bottom:10px}.stop-remove-btn:hover{background:var(--red-dim);border-color:var(--red-500);color:#ef4444}.add-stop-btn{background:none;border:1.5px dashed var(--border);border-radius:6px;color:var(--text-muted);cursor:pointer;font-size:12px;font-weight:600;padding:5px 14px;display:inline-flex;align-items:center;gap:5px;margin-bottom:14px;transition:all .15s;letter-spacing:.3px}.add-stop-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}.input-prefix-wrap{position:relative;display:flex;align-items:center}.input-prefix{position:absolute;left:10px;font-size:14px;color:var(--text-muted);pointer-events:none}.input-with-prefix{padding-left:22px}.form-label{font-size:13px;font-weight:500;color:var(--text-muted)}.form-hint{font-size:11px;color:var(--text-subtle);font-weight:400;margin-left:4px}.required{color:var(--accent);margin-left:2px}.form-input{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:9px 12px;color:var(--text);outline:none;transition:border-color .15s,box-shadow .15s;width:100%}.form-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}.form-input::placeholder{color:var(--text-subtle)}.form-input option{background:var(--surface-2);color:var(--text)}.form-textarea{resize:vertical;min-height:80px}.form-range{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;height:6px;border-radius:3px;background:var(--border);outline:none;cursor:pointer;border:none;padding:0;margin-top:4px}.form-range::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:20px;height:20px;border-radius:50%;background:var(--thumb-color, var(--accent));cursor:pointer;border:3px solid var(--surface);box-shadow:var(--shadow-sm);transition:transform .1s}.form-range::-webkit-slider-thumb:hover{transform:scale(1.18)}.form-range::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:var(--thumb-color, var(--accent));cursor:pointer;border:3px solid var(--surface);box-shadow:var(--shadow-sm)}.range-labels{display:flex;justify-content:space-between;font-size:11px;color:var(--text-subtle);margin-top:4px}.priority-display{font-size:13px;font-weight:600}.form-actions{display:flex;justify-content:flex-end;gap:10px;padding:20px 28px;background:var(--surface);border-top:1px solid var(--border)}.multi-part-toggle{display:flex;align-items:center;gap:8px;font-weight:600;font-size:14px;cursor:pointer;color:var(--text)}.multi-part-toggle input[type=checkbox]{width:16px;height:16px;accent-color:var(--accent)}.sub-job-card{border:1px solid var(--border);border-radius:10px;padding:16px 18px;margin-bottom:12px;background:var(--surface-2);position:relative}.sub-job-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.sub-job-card-number{font-weight:700;font-size:13px;color:var(--accent)}.sub-job-remove-btn{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:20px;line-height:1;padding:2px 8px;border-radius:4px;transition:background .15s,color .15s}.sub-job-remove-btn:hover{background:#ef44441f;color:var(--red-500)}.add-sub-job-btn{width:100%;padding:14px;border:2px dashed var(--border);border-radius:10px;background:transparent;color:var(--text-muted);font-size:14px;font-weight:600;cursor:pointer;transition:all .15s}.add-sub-job-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}.job-group-badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:20px;font-size:10px;font-weight:600;background:#6366f11a;color:#6366f1;border:1px solid rgba(99,102,241,.2);max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.jobs-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:18px;align-items:start}.job-card{background:#1e3456;border:1px solid var(--accent);border-radius:var(--radius-lg);overflow:hidden;transition:box-shadow .15s;display:flex;flex-direction:column}.job-card:hover{border-color:#ef4444;box-shadow:0 0 8px #dc262640}.job-card--alert{border-color:#f59e0b73}.job-card--expanded{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent),var(--shadow)}.job-card-header{padding:16px 18px;border-bottom:1px solid var(--border)}.job-card-header:hover .job-expand-chevron{color:var(--accent)}.job-card-header-controls{position:absolute;top:10px;right:10px;display:flex;align-items:center;gap:2px}.job-expand-chevron{display:flex;align-items:center;justify-content:center;color:var(--text-muted);padding:4px;transition:transform .2s,color .15s}.job-expand-chevron--open{transform:rotate(180deg);color:var(--accent)}.job-card-detail-panel{padding:14px 18px;border-bottom:1px solid var(--border);background:var(--surface-2);display:flex;flex-direction:column;gap:14px}.job-detail-address-block{display:flex;flex-direction:column;gap:0;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden}.job-detail-address-row{display:flex;align-items:flex-start;gap:10px;padding:10px 12px}.job-detail-addr-icon{font-size:15px;line-height:1;flex-shrink:0;margin-top:2px}.job-detail-address-row>div{display:flex;flex-direction:column;gap:2px}.job-detail-addr-text{font-size:13px;color:var(--text);font-weight:500;line-height:1.4;word-break:break-word}.job-detail-addr-divider{height:1px;background:var(--border);margin:0}.job-detail-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:10px 12px}.job-detail-item{display:flex;flex-direction:column;gap:4px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:8px 10px}.job-detail-label{font-size:10px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}.job-detail-value{font-size:14px;color:var(--text);font-weight:600}.job-detail-notes{display:flex;flex-direction:column;gap:5px}.job-detail-notes-text{font-size:13px;color:var(--text-muted);line-height:1.55;margin:0;white-space:pre-wrap;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:8px 10px}.packing-summary{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px}.packing-summary-item{font-size:12px;color:var(--text-muted);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:3px 8px}.packing-summary-item strong{color:var(--text)}.job-card-title-row{display:flex;align-items:center;gap:8px;margin-bottom:8px;flex-wrap:wrap}.job-card-title{font-size:16px;font-weight:600;color:var(--text);margin-bottom:8px;line-height:1.35}.job-card-meta{display:flex;align-items:center;gap:14px;margin-bottom:8px;flex-wrap:wrap}.job-meta-item{display:flex;align-items:center;gap:5px;font-size:12px;color:var(--text-muted)}.job-meta-price{color:var(--accent);font-weight:600}.job-meta-truck{color:#7c3aed;font-weight:600}.job-detail-item--trucks{grid-column:1 / -1}.truck-assign-area{display:flex;flex-wrap:wrap;align-items:center;gap:6px;margin-top:4px}.truck-chip{display:inline-flex;align-items:center;gap:4px;background:#7c3aed1a;border:1px solid rgba(124,58,237,.25);color:#7c3aed;font-size:12px;font-weight:600;padding:3px 8px;border-radius:5px}.truck-chip-remove{background:none;border:none;color:#7c3aed;cursor:pointer;font-size:14px;line-height:1;padding:0 0 0 2px;opacity:.6;transition:opacity .15s}.truck-chip-remove:hover{opacity:1;color:#ef4444}.truck-select{font-size:12px!important;padding:4px 8px!important;height:28px!important;min-height:unset!important;border-radius:5px!important;max-width:100px}.truck-select--add{border-style:dashed!important;color:var(--text-muted)}.job-address{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-muted);margin-top:6px}.address-from,.address-to{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:130px}.job-menu-wrap{position:relative}.job-menu-btn{background:none;border:none;color:var(--text-muted);font-size:18px;line-height:1;cursor:pointer;padding:2px 6px;border-radius:4px;transition:background .15s,color .15s;letter-spacing:1px}.job-menu-btn:hover{background:var(--surface-hover);color:var(--text)}.job-menu-dropdown{position:absolute;top:calc(100% + 4px);right:0;background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:4px;min-width:140px;z-index:50;box-shadow:0 8px 24px #0000001f}.job-menu-item{display:block;width:100%;text-align:left;background:none;border:none;color:var(--text);font-size:13px;padding:8px 12px;border-radius:6px;cursor:pointer;transition:background .15s,color .15s}.job-menu-item:hover{background:var(--accent-dim);color:var(--accent)}.job-menu-item--danger:hover{background:#ef44441a;color:#ef4444}.job-floater-badge{display:inline-block;padding:2px 8px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;border-radius:999px;background:#a855f71f;color:#a855f7}.alert-banner{display:flex;align-items:center;gap:6px;padding:8px 18px;background:var(--amber-dim);color:var(--amber-500);font-size:12px;font-weight:500;border-bottom:1px solid rgba(245,158,11,.2)}.job-card-section{padding:14px 18px;border-bottom:1px solid var(--border);display:flex;flex-direction:column;gap:10px;flex:1}.job-card-section:last-child{border-bottom:none}.section-label{display:flex;align-items:center;justify-content:space-between;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-subtle)}.crew-count{font-size:11px;color:var(--text-muted);font-weight:500}.crew-list{display:flex;flex-direction:column;gap:6px}.empty-crew{font-size:12px;color:var(--text-subtle);font-style:italic}.crew-chip{display:flex;align-items:center;gap:8px}.avatar{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;flex-shrink:0;background:var(--surface-hover);color:var(--text)}.avatar.role--lead{background:var(--lead-bg);color:var(--lead-color)}.avatar.role--mover{background:var(--mover-bg);color:var(--mover-color)}.avatar.role--driver{background:var(--driver-bg);color:var(--driver-color)}.crew-chip-info{display:flex;flex-direction:column;gap:1px;min-width:0}.crew-chip-name{font-size:13px;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.crew-chip-role{font-size:11px;color:var(--text-muted);text-transform:capitalize}.crew-chip-role.role--lead{color:var(--lead-color)}.crew-chip-role.role--mover{color:var(--mover-color)}.crew-chip-role.role--driver{color:var(--driver-color)}.priority-badge{display:inline-flex;align-items:center;padding:3px 8px;border-radius:20px;font-size:11px;font-weight:600}.priority--high{background:var(--red-dim);color:var(--red-500)}.priority--med{background:var(--amber-dim);color:var(--amber-500)}.priority--low{background:var(--green-dim);color:var(--green-500)}.status-badge{display:inline-flex;align-items:center;padding:3px 8px;border-radius:20px;font-size:11px;font-weight:600;text-transform:capitalize}.status--pending{background:var(--amber-dim);color:var(--amber-500)}.status--scheduled{background:var(--blue-dim);color:var(--blue-500)}.status--in_progress{background:var(--purple-dim);color:var(--purple-500)}.status--completed{background:var(--green-dim);color:var(--green-500)}.status--cancelled{background:#64748b1f;color:#64748b}.role-badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:20px;font-size:11px;font-weight:600;text-transform:capitalize}.role-badge.role--lead{background:var(--lead-bg);color:var(--lead-color);border:1px solid rgba(124,58,237,.2)}.role-badge.role--mover{background:var(--mover-bg);color:var(--mover-color);border:1px solid rgba(8,145,178,.2)}.role-badge.role--driver{background:var(--driver-bg);color:var(--driver-color);border:1px solid rgba(234,88,12,.2)}.toast{position:fixed;bottom:24px;right:24px;padding:12px 20px;border-radius:var(--radius);font-size:14px;font-weight:500;z-index:1000;box-shadow:var(--shadow);animation:toast-in .2s ease}.toast--success{background:var(--green-dim);color:var(--green-500);border:1px solid rgba(34,197,94,.3)}.toast--error{background:var(--red-dim);color:var(--red-500);border:1px solid rgba(239,68,68,.3)}@keyframes toast-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.error-banner{background:var(--red-dim);border:1px solid rgba(239,68,68,.3);border-radius:var(--radius-sm);padding:12px 16px;color:var(--red-500);font-size:14px;margin-bottom:20px}.absent-banner{display:flex;align-items:center;flex-wrap:wrap;gap:8px;background:var(--red-dim);border:1px solid rgba(239,68,68,.3);border-radius:var(--radius-sm);padding:10px 14px;color:var(--red-500);font-size:13px;margin-bottom:20px}.absent-chip{background:#ef444426;border:1px solid rgba(239,68,68,.3);border-radius:20px;padding:2px 10px;font-size:12px;font-weight:500}.loading-state{text-align:center;padding:60px 20px;color:var(--text-muted);font-size:14px}.empty-state{text-align:center;padding:80px 20px;color:var(--text-muted);font-size:14px;display:flex;flex-direction:column;align-items:center}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:200;padding:20px;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);animation:fade-in .15s ease}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.modal-content,.modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;max-width:520px;max-height:88vh;display:flex;flex-direction:column;box-shadow:var(--shadow);animation:slide-up .18s ease}@keyframes slide-up{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;border-bottom:1px solid var(--border)}.modal-header h2,.modal-title{font-size:17px;font-weight:600;color:var(--text)}.modal-close{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:var(--radius-sm);border:1px solid transparent;background:transparent;color:var(--text-muted);font-size:14px;transition:all .15s}.modal-close:hover{background:var(--surface-hover);border-color:var(--border);color:var(--text)}.modal-body{padding:22px;overflow-y:auto;flex:1}.modal-footer{display:flex;justify-content:flex-end;gap:10px;padding:16px 22px;border-top:1px solid var(--border)}.calendar-layout{display:grid;grid-template-columns:1fr 420px;gap:20px;align-items:start}.calendar-layout:has(.cal-pending){grid-template-columns:1fr 340px 320px}@media(max-width:1200px){.calendar-layout:has(.cal-pending){grid-template-columns:1fr 300px}}@media(max-width:900px){.calendar-layout{grid-template-columns:1fr}}.cal-pending{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;position:sticky;top:20px;max-height:calc(100vh - 120px);overflow-y:auto}.cal-pending-header{padding:16px 18px;border-bottom:1px solid var(--border)}.cal-pending-title{font-size:15px;font-weight:600;color:var(--text);display:flex;align-items:center;gap:8px;margin-bottom:4px}.cal-pending-badge{background:var(--accent);color:#fff;font-size:11px;font-weight:700;padding:2px 8px;border-radius:10px}.cal-pending-hint{font-size:12px;color:var(--text-muted)}.cal-pending-list{padding:12px;display:flex;flex-direction:column;gap:12px}.calendar-wrap{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.cal-dow-row{display:grid;grid-template-columns:repeat(7,1fr);border-bottom:1px solid var(--border);background:var(--surface-2)}.cal-dow{padding:10px 0;text-align:center;font-size:11px;font-weight:600;color:var(--text-subtle);text-transform:uppercase;letter-spacing:.05em}.cal-grid{display:block}.cal-day{min-height:145px;display:flex;flex-direction:column;align-items:flex-start;justify-content:flex-start;padding:6px 5px 5px;border:none;background:transparent;color:var(--text);border-bottom:1px solid var(--border);border-right:1px solid var(--border);transition:background .1s;cursor:pointer;overflow:hidden}.cal-day:nth-child(7n){border-right:none}.cal-day:hover{background:var(--surface-hover)}.cal-day--other{color:var(--text-subtle)}.cal-day--today .cal-day-num{background:var(--accent);color:#fff;width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700}.cal-day--selected{background:var(--accent-dim)}.cal-day--selected .cal-day-num{color:var(--accent);font-weight:700}.cal-day-num{font-size:13px;font-weight:500;width:26px;height:26px;display:flex;align-items:center;justify-content:center;border-radius:50%;flex-shrink:0;margin-bottom:2px}.cal-strip{display:block;width:100%;font-size:10px;font-weight:600;color:#fff;padding:1px 5px;border-radius:3px;margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.5;text-align:left}.cal-strip--other{opacity:.45}.cal-strip-more{display:block;font-size:10px;color:var(--text-muted);padding:1px 4px;margin-top:2px;line-height:1.4}.cal-grid:not(.cal-grid--with-weeks) .cal-week-row{display:grid;grid-template-columns:repeat(7,1fr)}.cal-week-row .cal-day:last-child{border-right:none}.cal-tab-bar{display:flex;gap:4px;margin-bottom:16px;border-bottom:1px solid var(--border);padding-bottom:0}.cal-tab{padding:10px 20px;border:none;background:transparent;color:var(--text-muted);font-size:14px;font-weight:500;cursor:pointer;border-bottom:2px solid transparent;transition:all .15s;margin-bottom:-1px}.cal-tab:hover{color:var(--text)}.cal-tab--active{color:var(--accent);border-bottom-color:var(--accent);font-weight:600}.cal-detail{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;position:sticky;top:20px}.cal-detail-header{padding:16px 18px;border-bottom:1px solid var(--border)}.cal-detail-title{font-size:15px;font-weight:600;color:var(--text)}.cal-job-list{padding:12px;display:flex;flex-direction:column;gap:10px;max-height:650px;overflow-y:auto}.cal-job-item{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);padding:12px 14px;display:flex;flex-direction:column;gap:6px;transition:border-color .15s;cursor:pointer}.cal-job-item:hover{border-color:var(--border-hover)}.cal-job-title{font-size:14px;font-weight:600;color:var(--text)}.cal-job-meta{display:flex;gap:12px;font-size:12px;color:var(--text-muted);flex-wrap:wrap}.cal-job-price{color:var(--green-500);font-weight:600}.cal-job-alert{font-size:11px;color:var(--red-500);font-weight:600}.cal-job-chevron{font-size:10px;color:var(--text-muted)}.cal-job-header{display:flex;justify-content:space-between;align-items:center}.cal-job-detail{margin-top:10px;display:flex;flex-direction:column;gap:10px}.cal-detail-row{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:10px 14px;display:flex;flex-direction:column;gap:2px}.cal-detail-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.cal-detail-value{font-size:13px;font-weight:500;color:var(--text)}.cal-detail-price{color:var(--green-500);font-weight:700;font-size:15px}.cal-detail-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:12px 14px}.cal-detail-section-title{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:8px}.cal-detail-crew-row{display:flex;align-items:center;gap:8px;padding:4px 0}.cal-detail-crew-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.cal-detail-crew-name{font-size:13px;font-weight:500;color:var(--text)}.cal-detail-crew-role{font-size:11px;color:var(--text-muted);text-transform:capitalize;margin-left:auto}.cal-detail-backup-rank{font-size:11px;font-weight:700;color:var(--accent)}.cal-detail-notes{font-size:12px;color:var(--text-muted);line-height:1.5;white-space:pre-wrap}.crew-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}.crew-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:18px;display:flex;flex-direction:column;gap:12px;transition:border-color .15s,box-shadow .15s}.crew-card:hover{border-color:var(--border-hover);box-shadow:var(--shadow-sm)}.crew-card--inactive{opacity:.58}.crew-card-header{display:flex;align-items:center;gap:12px}.crew-avatar{width:46px;height:46px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700;flex-shrink:0}.crew-avatar.role--lead{background:var(--lead-bg);color:var(--lead-color)}.crew-avatar.role--mover{background:var(--mover-bg);color:var(--mover-color)}.crew-avatar.role--driver{background:var(--driver-bg);color:var(--driver-color)}.crew-card-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:5px}.crew-card-name{font-size:15px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.crew-skills{display:flex;flex-wrap:wrap;gap:5px}.skill-tag{background:var(--surface-2);border:1px solid var(--border);border-radius:20px;padding:2px 8px;font-size:11px;color:var(--text-muted)}.crew-availability{display:flex;gap:4px}.day-chip{width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;background:var(--surface-2);color:var(--text-subtle);border:1px solid var(--border);transition:all .1s}.day-chip--active{background:var(--green-dim);color:var(--green-500);border-color:#22c55e4d}.crew-contact{font-size:12px;color:var(--text-muted)}.crew-card-footer{display:flex;align-items:center;justify-content:space-between;padding-top:4px;border-top:1px solid var(--border)}.status-dot{font-size:11px;font-weight:600;text-transform:capitalize;display:flex;align-items:center;gap:5px}.status-dot:before{content:"";width:6px;height:6px;border-radius:50%;flex-shrink:0}.status-dot--active{color:var(--green-500)}.status-dot--active:before{background:var(--green-500)}.status-dot--inactive{color:var(--text-subtle)}.status-dot--inactive:before{background:var(--text-subtle)}.filter-tabs{display:flex;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:3px;gap:2px}.filter-tab{padding:5px 12px;border-radius:4px;border:none;background:transparent;color:var(--text-muted);font-size:13px;font-weight:500;transition:all .15s;text-transform:capitalize;cursor:pointer}.filter-tab:hover{color:var(--text)}.filter-tab--active{background:var(--surface);color:var(--text);box-shadow:var(--shadow-sm)}.day-picker{display:flex;gap:6px;flex-wrap:wrap}.day-btn{padding:5px 10px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface-2);color:var(--text-muted);font-size:12px;font-weight:500;transition:all .15s;cursor:pointer}.day-btn:hover{border-color:var(--border-hover);color:var(--text)}.day-btn--active{background:var(--green-dim);border-color:#22c55e59;color:var(--green-500)}.modal-tabs{display:flex;border-bottom:1px solid var(--border);padding:0 22px;background:var(--surface)}.modal-tab{padding:12px 16px;border:none;background:transparent;color:var(--text-muted);font-size:14px;font-weight:500;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:all .15s;white-space:nowrap}.modal-tab:hover{color:var(--text)}.modal-tab--active{color:var(--accent);border-bottom-color:var(--accent)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--border-hover)}.login-page{min-height:100vh;width:100%;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;padding:24px;background:#080f1a}.floating-bg{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0;overflow:hidden;background:radial-gradient(ellipse at 40% 50%,#0f2444,#080f1a 70%)}.floating-photo{position:absolute;left:-360px;aspect-ratio:4 / 3;background-size:cover;background-position:center;border-radius:10px;box-shadow:0 8px 32px #00000080;animation:float-across linear infinite}@keyframes float-across{0%{transform:translate(0) rotate(var(--r, 0deg))}to{transform:translate(calc(100vw + 360px)) rotate(var(--r, 0deg))}}.login-card{position:relative;z-index:2;background:#0f172ad9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:3px solid var(--accent);border-radius:var(--radius-lg);padding:40px;width:100%;max-width:400px;box-shadow:0 25px 50px #00000080;display:flex;flex-direction:column;align-items:center}.login-logo{display:flex;flex-direction:column;align-items:center;gap:12px;margin-bottom:6px}.login-logo-img{height:80px;width:auto;object-fit:contain}.login-brand{font-size:28px;font-weight:700;color:var(--accent);letter-spacing:-.5px}.login-subtitle{font-size:13px;color:var(--text-subtle);margin-bottom:32px;text-align:center}.login-form{width:100%;display:flex;flex-direction:column;gap:16px}.login-error{background:var(--red-dim);border:1px solid rgba(239,68,68,.3);border-radius:var(--radius-sm);padding:10px 14px;font-size:13px;color:var(--red-500);text-align:center}.login-btn{width:100%;padding:12px;font-size:15px;margin-top:4px}.login-footer-note{margin-top:24px;font-size:12px;color:var(--text-subtle);text-align:center}.loading-screen{min-height:100vh;width:100%;display:flex;align-items:center;justify-content:center;background:var(--bg)}@keyframes spin{to{transform:rotate(360deg)}}.loading-spinner{width:36px;height:36px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}.attendance-btns{display:flex;gap:4px;margin-left:auto;flex-shrink:0}.att-btn{width:26px;height:26px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface-2);font-size:12px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .12s;padding:0;line-height:1;color:var(--text-muted)}.att-btn:disabled{opacity:.4;cursor:not-allowed}.att-btn--present:hover{background:var(--green-dim);border-color:#22c55e66;color:var(--green-500)}.att-btn--late:hover{background:var(--amber-dim);border-color:#f59e0b66;color:var(--amber-500)}.att-btn--no_show:hover{background:var(--red-dim);border-color:#ef444466;color:var(--red-500)}.attendance-logged{display:flex;align-items:center;gap:4px;margin-left:auto;flex-shrink:0}.attendance-badge{font-size:11px;font-weight:600;padding:2px 8px;border-radius:20px;white-space:nowrap}.attendance--present{background:var(--green-dim);color:var(--green-500);border:1px solid rgba(34,197,94,.3)}.attendance--late{background:var(--amber-dim);color:var(--amber-500);border:1px solid rgba(245,158,11,.3)}.attendance--no_show{background:var(--red-dim);color:var(--red-500);border:1px solid rgba(239,68,68,.3)}.estimate-layout{display:grid;grid-template-columns:1fr 420px;gap:24px;align-items:start}@media(max-width:1100px){.estimate-layout{grid-template-columns:1fr}}.estimate-rate-notice{background:var(--surface);border:1px solid var(--border);border-left:3px solid var(--accent);border-radius:8px;padding:10px 14px;font-size:13px;color:var(--text-muted);margin-bottom:20px}.estimate-rate-notice strong{color:var(--text)}.estimate-mode-toggle{display:flex;gap:8px}.estimate-mode-btn{flex:1;padding:10px 16px;border-radius:8px;border:1px solid var(--border);background:var(--surface);color:var(--text-muted);font-size:14px;font-weight:500;cursor:pointer;transition:all .15s}.estimate-mode-btn:hover{border-color:var(--accent);color:var(--text)}.estimate-mode-btn--active{background:var(--accent);border-color:var(--accent);color:#fff}.crew-main-tabs{display:flex;gap:0;background:var(--surface);border:1px solid var(--border);border-radius:8px;overflow:hidden}.crew-main-tab{padding:8px 20px;font-size:14px;font-weight:600;background:transparent;border:none;color:var(--text-muted);cursor:pointer;transition:all .15s}.crew-main-tab:hover{color:var(--text);background:var(--surface-hover)}.crew-main-tab--active{background:var(--accent);color:#fff}.estimate-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:20px;margin-bottom:16px}.estimate-card--highlight{border-color:var(--accent)}.estimate-comparison{display:flex;flex-direction:column;gap:0}.estimate-comp-row{display:grid;grid-template-columns:50px 1fr auto;align-items:center;gap:12px;padding:10px 14px;border-radius:var(--radius-sm);cursor:pointer;transition:background .15s}.estimate-comp-row:hover{background:var(--surface-hover)}.estimate-comp-row--active{background:var(--accent-dim)}.estimate-comp-margin{font-size:14px;font-weight:700;color:var(--text-muted)}.estimate-comp-row--active .estimate-comp-margin{color:var(--accent)}.estimate-comp-charge{font-size:15px;font-weight:700;color:var(--text)}.estimate-comp-profit{font-size:14px;font-weight:600;color:var(--green-500);text-align:right}.estimate-margin-row{display:flex;align-items:center;flex-wrap:wrap;gap:8px}.estimate-margin-chip{padding:8px 18px;border-radius:20px;border:1px solid var(--border);background:var(--surface);color:var(--text-muted);font-size:14px;font-weight:500;cursor:pointer;transition:all .15s}.estimate-margin-chip:hover{border-color:var(--accent);color:var(--text)}.estimate-margin-chip--active{background:var(--accent);border-color:var(--accent);color:#fff}.estimate-margin-custom{display:flex;align-items:center}.estimate-margin-inline{display:flex;align-items:center;gap:2px}.estimate-margin-inline-input{width:58px;padding:4px 8px;border-radius:6px;border:1px solid var(--accent);background:var(--bg);color:var(--text);font-size:14px;font-weight:600;text-align:right;outline:none;-moz-appearance:textfield}.estimate-margin-inline-input::-webkit-inner-spin-button,.estimate-margin-inline-input::-webkit-outer-spin-button{opacity:1}.estimate-margin-inline-pct{font-size:14px;font-weight:600;color:var(--text)}.saved-estimates-container{margin-top:8px}.saved-estimates-table-wrap{overflow-x:auto}.saved-estimates-table{width:100%;border-collapse:collapse;font-size:13px}.saved-estimates-table th{text-align:left;padding:10px 12px;border-bottom:2px solid var(--border);color:var(--text-muted);font-weight:600;text-transform:uppercase;font-size:11px;letter-spacing:.5px;white-space:nowrap}.saved-estimates-table td{padding:12px;border-bottom:1px solid var(--border);white-space:nowrap}.saved-estimate-row{cursor:pointer;transition:background .15s}.saved-estimate-row:hover{background:var(--surface-hover)}.saved-estimate-row--active{background:color-mix(in srgb,var(--accent) 8%,var(--surface))}.saved-est-customer{font-weight:600;color:var(--text)}.saved-est-date,.saved-est-details{color:var(--text-muted)}.saved-est-charge{font-weight:700;color:var(--green-500)}.saved-est-mode{font-weight:400;color:var(--text-muted);font-size:12px;margin-left:2px}.saved-est-margin{font-weight:600;color:var(--accent)}.saved-est-saved{color:var(--text-muted);font-size:12px}.saved-est-actions{display:flex;gap:4px}.saved-est-delete{color:var(--red-500)!important}.saved-est-delete:hover{background:#dc26261a!important}.estimate-card-title{font-size:13px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin:0 0 16px}.estimate-breakdown{display:flex;flex-direction:column;gap:10px}.estimate-row{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.estimate-row-label{display:flex;flex-direction:column;font-size:14px;color:var(--text)}.estimate-row-value{font-size:14px;color:var(--text);font-weight:500;white-space:nowrap}.estimate-row-value--big{font-size:28px;font-weight:700;color:var(--accent);line-height:1}.estimate-divider{height:1px;background:var(--border);margin:4px 0}.estimate-profit{color:#22c55e;font-weight:700}.estimate-cta{width:100%;justify-content:center;padding:14px;font-size:15px}.bedroom-options{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}.bedroom-btn{padding:6px 16px;border-radius:8px;border:1px solid var(--border);background:var(--surface-2);color:var(--text-muted);font-size:13px;font-weight:500;cursor:pointer;transition:border-color .15s,color .15s,background .15s}.bedroom-btn:hover{border-color:var(--accent);color:var(--text)}.bedroom-btn--active{border-color:var(--accent);background:var(--accent-dim);color:var(--accent);font-weight:600}.form-optional{font-size:11px;font-weight:400;color:var(--text-subtle);margin-left:4px}.packing-toggle-row{display:flex;align-items:center;gap:14px;margin-top:14px;padding:12px 14px;border-radius:8px;background:var(--surface-2);border:1px solid var(--border)}.packing-toggle-label{display:flex;align-items:center;gap:10px;cursor:pointer;font-size:14px;font-weight:600;color:var(--text);-webkit-user-select:none;user-select:none}.packing-toggle-label input[type=checkbox]{width:16px;height:16px;accent-color:var(--accent);cursor:pointer;flex-shrink:0}.packing-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:10px;margin-top:12px}@media(max-width:900px){.packing-grid{grid-template-columns:repeat(3,1fr)}}@media(max-width:600px){.packing-grid{grid-template-columns:repeat(2,1fr)}}.packing-item{display:flex;flex-direction:column;gap:5px}.packing-item-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-subtle)}.packing-qty-input{text-align:center;font-size:15px;font-weight:600;padding:8px 6px!important}.history-filters{display:flex;align-items:flex-end;gap:14px;flex-wrap:wrap;margin-bottom:24px;padding:16px 20px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius)}.history-filters .form-group{margin-bottom:0;min-width:160px}.history-table{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.history-table-header{display:grid;grid-template-columns:2fr 1fr .8fr 1.4fr .7fr .7fr;padding:10px 18px;background:var(--surface-2);border-bottom:1px solid var(--border);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted)}.history-row{display:grid;grid-template-columns:2fr 1fr .8fr 1.4fr .7fr .7fr;padding:12px 18px;border-bottom:1px solid var(--border);align-items:center;cursor:pointer;transition:background .12s;font-size:13px;color:var(--text)}.history-row:last-child{border-bottom:none}.history-row:hover{background:var(--surface-hover)}.history-row-title{font-weight:600;color:var(--text)}.history-tabs{display:flex;gap:0;margin-bottom:24px;border-bottom:1px solid var(--border)}.history-tab{padding:9px 22px;font-size:14px;font-weight:500;color:var(--text-muted);border-bottom:2px solid transparent;margin-bottom:-1px;transition:color .15s,border-color .15s}.history-tab:hover{color:var(--text)}.history-tab--active{color:var(--accent);border-bottom-color:var(--accent)}.settings-body{display:flex;flex-direction:column;gap:20px;max-width:680px}.settings-card{background:var(--surface);border:2px solid var(--border);border-radius:var(--radius-lg);padding:24px;overflow:hidden;box-shadow:0 2px 8px #0000000a;transition:border-color .2s}.settings-card:hover{border-color:var(--border-hover)}.settings-card-header{display:flex;align-items:flex-start;gap:14px;padding:20px 22px;border-bottom:1px solid var(--border)}.settings-card-icon{font-size:24px;line-height:1;flex-shrink:0;margin-top:2px}.settings-grid{display:flex;flex-direction:column;gap:24px;max-width:720px}.settings-card-title{font-size:17px;font-weight:700;color:var(--text);margin:0 0 16px;padding-bottom:12px;border-bottom:2px solid var(--accent)}.settings-card-subtitle{font-size:13px;color:var(--text-muted);margin:-8px 0 16px;line-height:1.5}.settings-card-desc{font-size:13px;color:var(--text-muted);margin:0;line-height:1.5}.settings-card-body{padding:22px;display:flex;flex-direction:column;gap:20px}.settings-rate-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px}.settings-rate-item{display:flex;flex-direction:column;gap:6px}.settings-msg{font-size:13px;font-weight:500;padding:10px 14px;border-radius:var(--radius-sm)}.settings-msg--success{background:#22c55e1a;color:#22c55e}.settings-msg--error{background:#ef44441a;color:#ef4444}.settings-truck-add-row{display:flex;align-items:center;gap:10px}.settings-truck-list{display:flex;flex-direction:column;gap:6px;margin-top:14px}.settings-truck-item{display:flex;align-items:center;justify-content:space-between;background:var(--surface-2);border:1px solid var(--border);border-radius:8px;padding:10px 14px}.settings-truck-number{font-weight:600;font-size:14px}.settings-truck-delete{background:none;border:1px solid transparent;border-radius:5px;color:var(--text-muted);cursor:pointer;font-size:18px;line-height:1;width:30px;height:30px;display:flex;align-items:center;justify-content:center;transition:all .15s}.settings-truck-delete:hover{background:var(--red-dim);border-color:var(--red-500);color:#ef4444}.crew-chip--draggable{cursor:grab;-webkit-user-select:none;user-select:none}.crew-chip--dragging{opacity:.35}.crew-list--drag-over,.empty-crew.crew-list--drag-over{outline:2px dashed var(--accent);background:var(--accent-dim);border-radius:8px;padding:6px;transition:background .15s,outline .15s;min-height:48px}.job-card-section--actions{padding:10px 18px 14px}.job-action-btn{width:100%;justify-content:center}.departed-state{display:flex;align-items:center;justify-content:space-between;gap:10px}.departed-label{font-size:12px;color:var(--accent);font-weight:500}.departed-time-picker{max-width:120px}.departed-time-picker .qhp-display{padding:4px 8px;min-height:28px}.departed-time-picker .qhp-value{font-size:12px;color:var(--accent);font-weight:600}.job-loadhold-badge{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;padding:2px 8px;border-radius:10px;background:#f59e0b26;color:var(--amber-500);border:1px solid var(--amber-500)}.load-hold-info-bubble{background:#f59e0b1a;border:1px solid var(--amber-500);border-radius:var(--radius);padding:10px 16px;margin-bottom:16px;font-size:13px;color:var(--amber-500)}.load-hold-info-line{padding:2px 0}.load-hold-info-line+.load-hold-info-line{border-top:1px solid rgba(245,158,11,.2);margin-top:4px;padding-top:6px}.status--holding{background:#f59e0b26;color:var(--amber-500);border-color:var(--amber-500)}.return-section{margin-bottom:20px;padding-bottom:20px;border-bottom:1px solid var(--border)}.return-section:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.crew-hours-grid{display:flex;flex-direction:column;gap:8px}.crew-hours-row{display:flex;align-items:center;justify-content:space-between;gap:12px}.crew-hours-info{display:flex;align-items:center;gap:10px;flex:1;min-width:0}.crew-hours-avatar{width:32px;height:32px;border-radius:50%;background:var(--accent);color:#fff;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.crew-hours-name{font-size:13px;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.crew-hours-role{font-size:11px;color:var(--text-muted);text-transform:capitalize}.crew-hours-input{width:80px;flex-shrink:0;text-align:center}.return-section-header{font-size:13px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:12px}.return-times-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}@media(max-width:480px){.return-times-row{grid-template-columns:1fr}}.return-calc-hours{margin-top:8px;font-size:13px;color:var(--text-subtle)}.return-calc-hours strong{color:var(--accent)}.crew-hours-list{display:flex;flex-direction:column;gap:8px}.crew-hours-row{display:flex;align-items:center;justify-content:space-between;gap:12px;background:var(--surface-2);border:1px solid var(--border);border-radius:8px;padding:10px 14px}.crew-hours-info{display:flex;align-items:center;gap:8px;flex:1;min-width:0}.crew-hours-name{font-size:14px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.crew-hours-input-wrap{display:flex;align-items:center;gap:6px;flex-shrink:0}.crew-hours-input{width:72px;text-align:center;padding:6px 8px;font-size:14px}.crew-hours-unit{font-size:13px;color:var(--text-subtle);white-space:nowrap}.analytics-stats{display:flex;gap:1px;margin-bottom:24px;background:var(--border);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.analytics-stat{flex:1;padding:18px 20px;background:var(--surface);text-align:center}.analytics-stat-value{font-size:26px;font-weight:700;color:var(--text);line-height:1.2;margin-bottom:4px}.analytics-stat-label{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}.graphs-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}@media(max-width:960px){.graphs-grid{grid-template-columns:1fr}}.graph-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px 16px 12px}.graph-card--full{grid-column:1 / -1}.graph-card-title{font-size:13px;font-weight:600;color:var(--text);margin-bottom:14px}.export-btn{display:flex;align-items:center;gap:7px;padding:8px 16px;font-size:13px;white-space:nowrap;flex-shrink:0}.export-btn:disabled{opacity:.45;cursor:not-allowed}.export-spinner{display:inline-block;width:13px;height:13px;border:2px solid rgba(0,0,0,.15);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite;flex-shrink:0}.backup-chip{display:flex;align-items:flex-start;gap:8px;padding:6px 0}.backup-rank{font-size:11px;font-weight:700;color:var(--accent);min-width:22px;text-align:center;padding-top:6px}.backup-chip-inner{flex:1;min-width:0}.backup-source-job{display:block;font-size:11px;color:var(--text-subtle);margin-top:2px;padding-left:40px}.backup-source-priority{display:inline-block;margin-left:6px;font-size:10px;padding:1px 5px}.crew-check-list{display:flex;flex-direction:column;gap:4px}.crew-check-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:var(--radius-sm);transition:background .15s}.crew-check-item:hover{background:var(--surface-hover)}.crew-check-avatar{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff;flex-shrink:0}.crew-check-avatar.role--lead{background:var(--lead-color)}.crew-check-avatar.role--mover{background:var(--mover-color)}.crew-check-avatar.role--driver{background:var(--driver-color)}.crew-check-name{font-size:13px;font-weight:500;flex:1}.crew-check-role{font-size:11px;color:var(--text-muted);text-transform:capitalize}.crew-assign-tabs{display:flex;gap:4px;margin-bottom:4px;border-bottom:1px solid var(--border);padding-bottom:0}.crew-assign-tab{background:none;border:none;border-bottom:2px solid transparent;padding:6px 14px;font-size:13px;font-weight:500;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;gap:6px;margin-bottom:-1px;transition:color .15s}.crew-assign-tab:hover{color:var(--text-primary)}.crew-assign-tab--active{color:var(--accent);border-bottom-color:var(--accent)}.crew-assign-tab-count{background:var(--accent);color:#fff;border-radius:10px;font-size:10px;font-weight:700;padding:1px 6px}.crew-group-list{display:flex;flex-direction:column;gap:8px}.crew-group-card{border:1px solid var(--border);border-radius:8px;padding:10px 12px;cursor:pointer;transition:border-color .15s,background .15s}.crew-group-card:hover{border-color:var(--accent);background:var(--surface-hover)}.crew-group-card--selected{border-color:var(--accent);background:#dc262612}.crew-group-card--partial{border-color:var(--border-light, #334155)}.crew-group-job{display:flex;align-items:center;gap:8px;margin-bottom:8px}.crew-group-job-title{font-size:13px;font-weight:600;flex:1}.crew-group-members{display:flex;flex-direction:column;gap:4px}.crew-group-member{display:flex;align-items:center;gap:8px;padding:2px 0}.form-section-hint{font-size:12px;color:var(--text-subtle);margin:4px 0 10px;line-height:1.5}.modal--return{background:var(--surface);border-radius:var(--radius-lg);max-width:560px;width:90%;max-height:85vh;overflow-y:auto;box-shadow:var(--shadow)}.fab{position:fixed;bottom:28px;right:28px;width:56px;height:56px;border-radius:50%;background:var(--accent);color:#fff;font-size:28px;font-weight:300;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px #0000002e;transition:background .15s,transform .15s;z-index:50;text-decoration:none;line-height:1}.fab:hover{background:var(--accent-hover);transform:scale(1.08)}.attendance-logged{display:flex;align-items:center;gap:4px;margin-left:auto}.attendance-badge{font-size:11px;font-weight:600;padding:2px 8px;border-radius:10px}.attendance--present{background:var(--green-dim);color:var(--green-500)}.attendance--late{background:var(--amber-dim);color:var(--amber-500)}.attendance--no_show{background:var(--red-dim);color:var(--red-500)}.attendance-undo{font-size:14px;color:var(--text-subtle);padding:0 4px;cursor:pointer;background:none;border:none}.attendance-undo:hover{color:var(--red-500)}.attendance-btns{display:flex;gap:4px;margin-left:auto}.att-btn{width:26px;height:26px;border-radius:50%;font-size:12px;display:flex;align-items:center;justify-content:center;border:1px solid var(--border);background:var(--surface);cursor:pointer;transition:all .15s}.att-btn:hover{transform:scale(1.1)}.att-btn--present:hover{background:var(--green-dim);border-color:var(--green-500);color:var(--green-500)}.att-btn--late:hover{background:var(--amber-dim);border-color:var(--amber-500);color:var(--amber-500)}.att-btn--no_show:hover{background:var(--red-dim);border-color:var(--red-500);color:var(--red-500)}.crew-chip--draggable{cursor:grab}.crew-chip--draggable:active{cursor:grabbing}.crew-chip--dragging{opacity:.4}.truck-chip{display:inline-flex;align-items:center;gap:4px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:3px 8px;font-size:12px;font-weight:600}.truck-chip-remove{font-size:14px;color:var(--text-subtle);cursor:pointer;background:none;border:none;padding:0 2px}.truck-chip-remove:hover{color:var(--red-500)}.truck-assign-area{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.truck-select--add{padding:3px 6px;font-size:12px;min-width:60px}.pending-panel{position:fixed;right:0;top:0;bottom:0;width:50px;z-index:100;transition:width .25s ease;display:flex;flex-direction:column}.pending-panel--open{width:340px;background:var(--surface);border-left:2px solid var(--accent);box-shadow:-4px 0 20px #0000001a}.pending-panel-toggle{background:var(--accent);color:#fff;border:none;padding:10px 14px;cursor:pointer;font-size:13px;font-weight:600;display:flex;align-items:center;gap:8px;white-space:nowrap}.pending-panel:not(.pending-panel--open) .pending-panel-toggle{writing-mode:vertical-rl;text-orientation:mixed;padding:16px 12px;border-radius:var(--radius) 0 0 var(--radius);position:absolute;right:0;top:80px}.pending-badge{background:var(--surface);color:var(--accent);border-radius:50%;width:22px;height:22px;display:inline-flex;align-items:center;justify-content:center;font-size:12px;font-weight:700}.pending-panel-content{flex:1;overflow-y:auto;padding:16px}.pending-panel-title{font-size:15px;font-weight:700;color:var(--text);margin:0 0 4px}.pending-panel-hint{font-size:12px;color:var(--text-muted);margin:0 0 16px}.pending-card{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);padding:12px;margin-bottom:12px}.pending-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:4px;font-size:13px}.pending-fields{display:flex;flex-direction:column;gap:8px;margin-bottom:10px}.pending-field label{display:block;font-size:11px;font-weight:600;color:var(--text-muted);margin-bottom:3px;text-transform:uppercase;letter-spacing:.3px}.pending-field .form-input{padding:6px 8px;font-size:13px;height:auto}.pending-field-row{display:grid;grid-template-columns:1fr 1fr;gap:8px}.pending-card-actions{display:flex;gap:6px;justify-content:flex-end}.history-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:24px}@media(max-width:700px){.history-stats{grid-template-columns:repeat(2,1fr)}}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px 20px;text-align:center}.stat-card--clickable{cursor:pointer;transition:border-color .15s,background .15s}.stat-card--clickable:hover{border-color:var(--accent);background:#dc26260a}.stat-card--active{border-color:var(--accent);background:#dc26260f}.revenue-breakdown-wrap{position:relative}.revenue-breakdown-bubble{position:absolute;top:calc(100% + 10px);left:50%;transform:translate(-50%);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px 18px;min-width:220px;box-shadow:0 8px 24px #00000059;z-index:50}.revenue-breakdown-bubble:before{content:"";position:absolute;top:-6px;left:50%;transform:translate(-50%) rotate(45deg);width:10px;height:10px;background:var(--surface);border-left:1px solid var(--border);border-top:1px solid var(--border)}.revenue-breakdown-title{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin-bottom:10px}.revenue-breakdown-row{display:flex;justify-content:space-between;align-items:center;padding:5px 0;font-size:13px;border-bottom:1px solid rgba(255,255,255,.05)}.revenue-breakdown-row:last-child{border-bottom:none}.revenue-breakdown-type{color:var(--text);font-weight:500}.revenue-breakdown-amount{color:#34d399;font-weight:600;margin-left:16px}.stat-value{font-size:26px;font-weight:700;color:var(--text);line-height:1.2;margin-bottom:4px}.stat-label{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}.summary-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px 18px}.summary-card--flagged{border-color:#ef444466;background:color-mix(in srgb,var(--red-500) 8%,transparent)}.summary-card-name{font-size:13px;font-weight:600;color:var(--text);margin-bottom:2px}.summary-card-role{font-size:11px;color:var(--text-muted);text-transform:capitalize;margin-bottom:10px}.summary-stat{display:flex;justify-content:space-between;font-size:12px;color:var(--text-muted);margin-bottom:4px}.summary-stat-value{font-weight:600;color:var(--text)}.summary-flag{font-size:11px;font-weight:600;color:var(--red-500);margin-top:8px}.summary-card-stats{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text-muted)}.summary-toggle{display:flex;align-items:center;gap:8px;background:none;border:none;color:var(--text);font-size:14px;font-weight:600;cursor:pointer;padding:8px 0;margin-bottom:12px}.summary-toggle:hover{color:var(--accent)}.history-summary{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px;margin-bottom:28px}.history-job-list{display:flex;flex-direction:column;gap:0;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.history-job-row{padding:14px 18px;border-bottom:1px solid var(--border);cursor:pointer;transition:background .12s}.history-job-row:last-child{border-bottom:none}.history-job-row:hover,.history-job-row--expanded{background:var(--surface-hover)}.history-job-main{display:flex;flex-direction:column;gap:4px}.history-job-title{font-weight:600;font-size:14px;color:var(--text)}.history-job-meta{display:flex;flex-wrap:wrap;gap:10px;font-size:12px;color:var(--text-muted)}.history-job-detail{margin-top:12px;padding-top:12px;border-top:1px solid var(--border);font-size:13px;color:var(--text-muted)}.history-detail-grid{display:flex;flex-direction:column;gap:4px;margin-bottom:6px}.history-detail-crew{font-size:12px;color:var(--text-muted)}.history-detail-packing{font-size:12px;color:var(--text-muted);margin-top:6px}.history-packing-items{display:flex;flex-wrap:wrap;gap:6px;margin-top:4px}.history-packing-chip{background:#fb923c1a;color:#fb923c;border:1px solid rgba(251,146,60,.25);border-radius:4px;padding:2px 8px;font-size:11px;font-weight:500}.graph-toggles{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:20px}.graph-toggle-item{display:flex;align-items:center;gap:5px;font-size:13px;color:var(--text-muted);cursor:pointer}.graph-toggle-item input[type=checkbox]{accent-color:var(--accent)}.graph-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}@media(max-width:960px){.graph-grid{grid-template-columns:1fr}}.graph-no-data{height:200px;display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:13px;font-style:italic}.history-empty{padding:48px;text-align:center;color:var(--text-muted);font-size:14px}.history-empty-icon{font-size:48px;margin-bottom:12px}.history-empty h3{font-size:16px;margin-bottom:6px;color:var(--text)}.history-empty p{font-size:13px}.truck-analytics-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px;margin-bottom:24px}.truck-analytics-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px}.truck-analytics-card-header{display:flex;align-items:center;gap:8px;margin-bottom:14px}.truck-analytics-icon{font-size:20px}.truck-analytics-number{font-size:16px;font-weight:700;color:var(--text)}.truck-analytics-stats{display:flex;flex-direction:column;gap:8px}.truck-analytics-stat{display:flex;justify-content:space-between;align-items:baseline}.truck-analytics-stat-val{font-size:18px;font-weight:700;color:var(--accent)}.truck-analytics-stat-lbl{font-size:12px;color:var(--text-muted);font-weight:500}.import-dropzone{border:2px dashed var(--border);border-radius:8px;padding:32px 16px;text-align:center;cursor:pointer;transition:border-color .2s,background .2s}.import-dropzone:hover,.import-dropzone--active{border-color:#f97316;background:#f973160a}.import-error-list{padding-left:18px;margin:0}.ch-nav{display:flex;align-items:center;gap:12px;margin-bottom:20px;flex-wrap:wrap}.ch-nav-btn{background:none;border:1px solid var(--border);border-radius:6px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:18px;color:var(--text-muted)}.ch-nav-btn:hover{background:var(--surface-hover)}.ch-nav-label{text-align:center;min-width:200px}.ch-nav-period{font-weight:600;font-size:15px;color:var(--text)}.ch-nav-subtext{font-size:12px;color:var(--text-muted);margin-top:2px}.ch-summary{display:flex;gap:16px;margin-bottom:20px;flex-wrap:wrap}.ch-summary-stat{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:16px 20px;min-width:140px;flex:1}.ch-summary-val{font-size:22px;font-weight:700;color:var(--text)}.ch-summary-lbl{font-size:12px;color:var(--text-muted);margin-top:2px}.ch-table-wrap{overflow-x:auto;border:1px solid var(--border);border-radius:8px;background:var(--surface)}.ch-table{width:100%;border-collapse:collapse;font-size:14px}.ch-table th{text-align:left;padding:10px 12px;font-weight:600;font-size:12px;text-transform:uppercase;color:var(--text-muted);border-bottom:2px solid var(--border);background:var(--surface-2)}.ch-table td{padding:10px 12px;border-bottom:1px solid var(--surface-hover)}.ch-row{transition:background .15s}.ch-row:hover{background:var(--surface-hover)}.ch-row--open{background:var(--surface-2)}.ch-cell-name{font-weight:600}.ch-chevron-icon{display:inline-block;transition:transform .2s;font-size:12px;color:var(--text-subtle)}.ch-chevron-icon--open{transform:rotate(180deg)}.ch-detail-row td{padding:0 12px 12px;background:var(--surface-2)}.ch-detail-grid{font-size:13px;padding:8px 0}.ch-detail-header,.ch-detail-item{display:grid;grid-template-columns:1fr 100px 80px;gap:8px;padding:4px 0}.ch-detail-header{font-weight:600;color:var(--text-muted);font-size:11px;text-transform:uppercase;border-bottom:1px solid var(--border);padding-bottom:6px;margin-bottom:4px}.ch-detail-item{color:var(--text)}.ch-totals-row{background:var(--surface-2);border-top:2px solid var(--border)}.ch-totals-row td{padding:12px}@media(max-width:768px){.page{padding:20px 16px}.page-title{font-size:22px}.jobs-grid,.crew-grid,.form-row{grid-template-columns:1fr}}.crew-request-scroll{display:flex;gap:10px;overflow-x:auto;padding-bottom:6px;scrollbar-width:thin;scrollbar-color:var(--border) transparent}.crew-request-scroll::-webkit-scrollbar{height:4px}.crew-request-scroll::-webkit-scrollbar-track{background:transparent}.crew-request-scroll::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}.crew-request-chip{display:flex;flex-direction:column;align-items:center;gap:4px;min-width:88px;padding:12px 10px;border-radius:12px;border:1.5px solid var(--border);background:var(--surface-2);cursor:pointer;transition:border-color .15s,background .15s,transform .1s;position:relative;flex-shrink:0}.crew-request-chip:hover{border-color:var(--border-hover);transform:translateY(-2px)}.crew-request-chip--selected{transform:translateY(-2px)}.crew-request-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.crew-request-name{font-size:12px;font-weight:600;color:var(--text);text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:76px}.crew-request-role{font-size:10px;font-weight:500;color:var(--text-subtle);text-transform:uppercase;letter-spacing:.05em}.crew-request-check{position:absolute;top:6px;right:8px;font-size:11px;font-weight:700;color:var(--accent)}.crew-request-summary{margin-top:10px;font-size:12px;color:var(--accent);font-weight:500}.settings-card-header{display:flex;align-items:flex-start;gap:14px;margin-bottom:20px}.settings-card-icon{font-size:28px;flex-shrink:0}.settings-card-desc{font-size:13px;color:var(--text-muted);margin-top:4px;line-height:1.5}.settings-card-body{padding-top:0}.passcode-status-badge{font-size:12px;font-weight:600;padding:4px 12px;border-radius:20px;white-space:nowrap;margin-left:auto;flex-shrink:0}.passcode-status--on{background:var(--green-dim);color:var(--green-500)}.passcode-status--off{background:var(--red-dim);color:var(--red-500)}.settings-pin-section{display:flex;gap:32px;flex-wrap:wrap;margin-bottom:12px}.settings-pin-col{display:flex;flex-direction:column;gap:10px}.settings-pin-col--current{padding-right:32px;border-right:1px solid var(--border)}.settings-pin-hint{font-size:11px;color:var(--text-muted);font-style:italic}.settings-label{font-size:12px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}.settings-actions{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.pin-input{width:120px;text-align:center;font-size:20px;letter-spacing:6px;padding:10px}.packing-price-grid{display:flex;flex-direction:column;gap:0;margin-bottom:16px}.packing-price-header{display:grid;grid-template-columns:1fr 120px 120px;gap:12px;padding:10px 14px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);border-bottom:2px solid var(--border);background:var(--surface-2);border-radius:var(--radius-sm) var(--radius-sm) 0 0}.packing-price-row{display:grid;grid-template-columns:1fr 120px 120px;gap:12px;align-items:center;padding:10px 14px;border-bottom:1px solid var(--surface-hover);transition:background .15s}.packing-price-row:hover{background:var(--surface-hover)}.packing-price-row:last-child{border-bottom:none}.packing-price-label{font-size:14px;font-weight:500;color:var(--text)}.packing-price-input{padding:6px 10px!important;font-size:13px!important;text-align:center}.pin-gate{display:flex;align-items:center;justify-content:center;min-height:calc(100vh - 60px);padding:40px}.pin-gate-card{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:40px;text-align:center;max-width:360px;width:100%;box-shadow:var(--shadow)}.pin-gate-icon{font-size:48px;margin-bottom:16px}.pin-gate-title{font-size:22px;font-weight:700;color:var(--text);margin-bottom:8px}.pin-gate-subtitle{font-size:14px;color:var(--text-muted);margin-bottom:24px}.pin-gate-input{text-align:center;font-size:24px;letter-spacing:8px;padding:14px;margin-bottom:12px}.pin-gate-error{color:var(--red-500);font-size:13px;margin-bottom:12px}.pin-gate-btn{width:100%;padding:12px;font-size:16px;font-weight:600}.jd-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000a6;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:9000;display:flex;align-items:center;justify-content:center;padding:16px}.jd-modal{background:var(--surface);border:1px solid var(--border);border-radius:14px;width:100%;max-width:660px;max-height:88vh;overflow-y:auto;box-shadow:0 24px 64px #0009;display:flex;flex-direction:column}.jd-header{display:flex;align-items:flex-start;justify-content:space-between;padding:20px 24px 16px;border-bottom:1px solid var(--border);gap:12px;flex-shrink:0}.jd-title{font-size:17px;font-weight:600;color:var(--text);line-height:1.3}.jd-subtitle{font-size:12px;color:var(--text-muted);margin-top:3px}.jd-close{background:#ffffff0f;border:1px solid var(--border);color:var(--text-muted);border-radius:50%;width:30px;height:30px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:13px;flex-shrink:0;transition:background .15s,color .15s}.jd-close:hover{background:#ffffff1f;color:var(--text)}.jd-body{padding:16px 24px 24px;display:flex;flex-direction:column;gap:20px;overflow-y:auto}.jd-section{display:flex;flex-direction:column;gap:10px}.jd-section-title{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);border-bottom:1px solid var(--border);padding-bottom:6px}.jd-hours-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;text-align:center}.jd-hours-cell{background:#ffffff08;border:1px solid var(--border);border-radius:8px;padding:12px 8px;display:flex;flex-direction:column;align-items:center;gap:5px}.jd-hours-val{font-size:22px;font-weight:700;line-height:1}.jd-hours-lbl{font-size:10px;color:var(--text-muted);white-space:nowrap}.jd-variance-big{font-size:17px!important;padding:4px 10px!important;font-weight:700}.jd-finance-table{display:flex;flex-direction:column;gap:2px}.jd-finance-row{display:flex;align-items:center;justify-content:space-between;padding:7px 10px;border-radius:6px;font-size:13px;color:var(--text)}.jd-finance-row:hover{background:#ffffff08}.jd-finance-row--sub{font-size:12px;color:var(--text-muted);padding-left:20px}.jd-finance-row--total{font-size:14px;font-weight:600}.jd-finance-note{font-size:11px;color:var(--text-muted);font-weight:400}.jd-finance-divider{height:1px;background:var(--border);margin:4px 10px}.jd-logistics-grid{display:flex;flex-wrap:wrap;gap:12px}.jd-logistics-item{min-width:120px}.jd-logistics-item--wide{flex:1 1 100%}.jd-logistics-lbl{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin-bottom:3px}.jd-logistics-val{font-size:13px;color:var(--text-muted);line-height:1.4}.jd-crew-list{display:flex;flex-wrap:wrap;gap:8px}.jd-crew-chip{display:flex;align-items:center;gap:6px;background:#ffffff0d;border:1px solid var(--border);border-radius:20px;padding:5px 12px 5px 6px;font-size:12px}.jd-crew-name{color:var(--text);font-weight:500}.jd-crew-rate{font-size:11px;color:var(--text-muted);margin-left:2px}.storage-summary{display:flex;gap:16px;margin-bottom:24px}.storage-stat{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:16px 24px;display:flex;flex-direction:column;align-items:center;min-width:160px}.storage-stat-value{font-size:24px;font-weight:700;color:var(--text)}.storage-stat-label{font-size:12px;color:var(--text-muted);text-transform:uppercase;margin-top:4px}.warehouse-wrapper{display:flex;gap:20px;align-items:flex-start}.warehouse-blueprint{display:flex;flex-direction:column;gap:0;flex:1}.blueprint-row{display:flex;gap:8px}.blueprint-col{display:flex;flex-direction:column;gap:8px}.blueprint-hallway-v{display:flex;align-items:center;justify-content:center;width:40px;min-width:40px;background:var(--surface);border:1px dashed var(--border);border-radius:4px;writing-mode:vertical-rl;text-orientation:mixed}.blueprint-hallway-h{display:flex;align-items:center;justify-content:center;height:32px;background:var(--surface);border:1px dashed var(--border);border-radius:4px;margin:8px 0}.warehouse-block{display:flex;align-items:center;justify-content:center;padding:16px 12px;background:var(--surface);border:1px dashed var(--border);border-radius:8px;flex:1}.warehouse-label{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:1px}.storage-room{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:16px;min-width:200px;flex:none}.storage-room-header{font-size:14px;font-weight:700;color:var(--text);margin-bottom:12px;padding-bottom:8px;border-bottom:2px solid var(--accent)}.storage-grid{display:grid;gap:4px}.storage-cell{aspect-ratio:1;border-radius:6px;display:flex;align-items:center;justify-content:center;cursor:default;transition:all .15s;border:2px solid transparent;min-height:48px}.storage-cell--empty{background:#2ecc711a;border-color:#2ecc714d}.storage-cell--occupied{cursor:pointer;opacity:.9}.storage-cell--occupied:hover{opacity:1;transform:scale(1.05)}.storage-cell-label{font-size:10px;font-weight:700;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.5);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:90%;text-align:center}.storage-room-stats{font-size:11px;color:var(--text-muted);margin-top:8px;text-align:center}.storage-room--small .storage-room{transform:scale(.75);transform-origin:top left}.storage-room--small .storage-grid{gap:3px}.storage-room--small .storage-cell{min-height:36px}.crates-sidebar{width:220px;min-width:220px;background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:16px;max-height:80vh;overflow-y:auto}.crates-sidebar-header{font-size:14px;font-weight:700;color:var(--text);margin-bottom:12px;padding-bottom:8px;border-bottom:2px solid var(--accent)}.crates-cell-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}.crate-cell{width:100%;aspect-ratio:1;border-radius:6px;display:flex;align-items:center;justify-content:center;border:2px solid rgba(46,204,113,.3);background:#2ecc711a;cursor:default;transition:all .15s}.crate-cell--occupied{cursor:pointer;opacity:.9}.crate-cell--occupied:hover{opacity:1;transform:scale(1.08)}.crate-cell-number{font-size:12px;font-weight:700;color:var(--text-muted)}.crate-cell--occupied .crate-cell-number{color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.5)}.storage-crates{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:16px;min-width:200px;flex:1}.storage-crate-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}.storage-crate{aspect-ratio:1;border-radius:8px;display:flex;flex-direction:column;align-items:center;justify-content:center;border:2px solid transparent;transition:all .15s;min-height:52px;cursor:default}.storage-crate--empty{background:#2ecc711a;border-color:#2ecc714d}.storage-crate--occupied{cursor:pointer;opacity:.9}.storage-crate--occupied:hover{opacity:1;transform:scale(1.05)}.storage-crate-number{font-size:14px;font-weight:700;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.4)}.storage-crate--empty .storage-crate-number{color:var(--text-muted)}.storage-crate-name{font-size:9px;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.5);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:90%}.storage-legend{display:flex;gap:16px;margin-top:20px;align-items:center}.storage-legend-item{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-muted)}.storage-legend-swatch{width:16px;height:16px;border-radius:4px;border:1px solid var(--border)}.storage-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.storage-detail-item{display:flex;flex-direction:column;gap:2px}.storage-detail-label{font-size:11px;color:var(--text-muted);text-transform:uppercase}.storage-detail-value{font-size:14px;color:var(--text);font-weight:600}.storage-assign-grid{display:grid;gap:4px}.storage-assign-cell{aspect-ratio:1;border-radius:6px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s;border:2px solid var(--border);min-height:48px;background:var(--surface)}.storage-assign-cell:hover{border-color:var(--accent)}.storage-assign-cell--selected{background:var(--accent);border-color:var(--accent);color:#fff}.storage-assign-cell--occupied{cursor:not-allowed;opacity:.5}.storage-assign-cell--occupied:hover{border-color:var(--border)}.storage-customers-list{display:flex;flex-direction:column;gap:12px}.storage-customer-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:16px;transition:all .15s}.storage-customer-card--overdue{border-color:var(--accent)}.storage-customer-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px;padding-bottom:10px;border-bottom:1px solid var(--border)}.storage-customer-name{font-size:16px;font-weight:700;color:var(--text)}.storage-customer-location{font-size:12px;color:var(--text-muted);margin-top:2px}.storage-customer-rate{font-size:18px;font-weight:700;color:var(--green-500)}.storage-customer-details{display:grid;grid-template-columns:1fr 1fr;gap:8px 16px;margin-bottom:12px}.storage-customer-detail{display:flex;flex-direction:column;gap:1px}.storage-customer-detail-label{font-size:11px;color:var(--text-muted);text-transform:uppercase}.storage-customer-detail span:last-child{font-size:13px;color:var(--text)}.storage-customer-actions{display:flex;gap:8px;justify-content:flex-end}.clock-card-grid{display:flex;flex-direction:column;gap:6px}.clock-card{display:flex;align-items:center;justify-content:space-between;background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:12px 16px;transition:all .15s}.clock-card--in{border-color:var(--green-500);border-left-width:4px}.clock-card-left{display:flex;align-items:center;gap:12px}.clock-card-indicator{width:10px;height:10px;border-radius:50%;background:var(--border);flex-shrink:0}.clock-card-indicator--in{background:var(--green-500);box-shadow:0 0 6px #2ecc7180;animation:clock-pulse 2s infinite}@keyframes clock-pulse{0%,to{opacity:1}50%{opacity:.5}}.clock-card-name{font-size:15px;font-weight:600;color:var(--text)}.clock-card-meta{font-size:12px;color:var(--text-muted);margin-top:1px}.clock-pin-input-wrap{display:flex;justify-content:center}.clock-pin-input{width:160px;text-align:center;font-size:32px;font-weight:700;letter-spacing:12px;padding:12px 16px;background:var(--bg);border:2px solid var(--border);border-radius:12px;color:var(--text);outline:none;transition:border-color .15s}.clock-pin-input:focus{border-color:var(--accent)}.clock-success-modal{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:48px 56px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:12px;box-shadow:0 20px 60px #00000080;animation:clockSuccessPop .25s ease}@keyframes clockSuccessPop{0%{transform:scale(.88);opacity:0}to{transform:scale(1);opacity:1}}.clock-success-logo{width:100px;height:auto;margin-bottom:8px}.clock-success-name{font-size:28px;font-weight:700;color:var(--text)}.clock-success-time{font-size:18px;color:var(--text-muted)}.clock-success-msg{font-size:22px;font-weight:600;color:var(--accent);margin-top:8px}.crew-portal-shell{min-height:100vh;display:flex;flex-direction:column;background:var(--bg)}.crew-portal-header{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;background:var(--surface);border-bottom:1px solid var(--border)}.crew-portal-header-left{flex:1}.crew-portal-header-center{flex:1;text-align:center}.crew-portal-header-right{flex:1;display:flex;justify-content:flex-end}.crew-portal-logo{height:36px;width:auto}.crew-portal-title{font-size:16px;font-weight:700;color:var(--text)}.crew-portal-user{display:flex;align-items:center;gap:12px}.crew-portal-name{font-size:14px;color:var(--text-muted)}.crew-portal-logout{background:none;border:1px solid var(--border);color:var(--text-muted);padding:6px 12px;border-radius:var(--radius-sm);font-size:13px;cursor:pointer}.crew-portal-logout:hover{border-color:var(--accent);color:var(--accent)}.crew-portal-main{flex:1;padding:20px;max-width:680px;margin:0 auto;width:100%}.crew-login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg);padding:24px}.crew-login-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:40px;width:100%;max-width:400px;display:flex;flex-direction:column;align-items:center}.crew-login-logo{margin-bottom:16px}.crew-login-logo-img{height:60px;width:auto}.crew-login-heading{font-size:22px;font-weight:700;color:var(--text);margin:0 0 6px}.crew-login-sub{font-size:13px;color:var(--text-muted);margin:0 0 24px;text-align:center}.crew-dashboard{padding:4px 0}.crew-dashboard-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.crew-dashboard-title{font-size:22px;font-weight:700;color:var(--text);margin:0 0 4px}.crew-dashboard-date{font-size:13px;color:var(--text-muted);margin:0}.crew-job-count{text-align:center;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:12px 20px}.crew-job-count-num{display:block;font-size:28px;font-weight:800;color:var(--accent);line-height:1}.crew-job-count-label{font-size:12px;color:var(--text-muted)}.crew-loading{text-align:center;color:var(--text-muted);padding:40px}.crew-empty{text-align:center;color:var(--text-muted);padding:60px 20px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius)}.crew-job-list{display:flex;flex-direction:column;gap:12px}.crew-job-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px;cursor:pointer;transition:border-color .15s}.crew-job-card:hover{border-color:var(--accent)}.crew-job-card-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px}.crew-job-info{flex:1}.crew-job-time{font-size:12px;color:var(--accent);font-weight:600;text-transform:uppercase;letter-spacing:.05em}.crew-job-title{font-size:16px;font-weight:700;color:var(--text);margin:4px 0 2px}.crew-job-customer{font-size:13px;color:var(--text-muted);margin:0}.crew-job-status-badge{font-size:12px;font-weight:600;padding:4px 10px;border-radius:20px;border:1px solid;white-space:nowrap;margin-left:12px}.crew-job-addresses{display:flex;flex-direction:column;gap:6px;margin-bottom:12px}.crew-job-address-row{display:flex;align-items:flex-start;gap:8px}.crew-address-icon{font-size:14px;flex-shrink:0}.crew-address-text{font-size:13px;color:var(--text-muted)}.crew-job-card-footer{display:flex;justify-content:space-between;align-items:center}.crew-job-tap{font-size:12px;color:var(--text-subtle)}.crew-job-signed{font-size:12px;color:#10b981;font-weight:600}.crew-card-depart-btn{width:100%;margin-top:10px;padding:10px;font-size:14px;font-weight:700}.crew-card-end-btn{width:100%;margin-top:10px;padding:10px;font-size:14px;font-weight:700;background:var(--accent);color:#fff;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:background .15s}.crew-card-end-btn:hover{background:var(--accent-hover)}.crew-job-crew-list{margin-top:8px;padding-top:8px;border-top:1px solid var(--border)}.crew-job-crew-chips{display:flex;flex-wrap:wrap;gap:6px;margin-top:4px}.crew-job-crew-chip{font-size:12px;padding:3px 10px;border-radius:12px;background:var(--surface-2);border:1px solid var(--border);color:var(--text)}.crew-job-crew-chip--lead{border-color:var(--purple-500);color:var(--purple-500)}.crew-job-crew-chip--driver{border-color:var(--amber-500);color:var(--amber-500)}.crew-job-crew-chip--mover{border-color:var(--blue-500);color:var(--blue-500)}.crew-job-detail{padding:4px 0}.crew-back-btn{background:none;border:none;color:var(--accent);font-size:14px;cursor:pointer;padding:0 0 16px;display:block}.crew-detail-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px;margin-bottom:16px}.crew-detail-title{font-size:20px;font-weight:700;color:var(--text);margin:0 0 4px}.crew-detail-customer{font-size:15px;color:var(--text-muted);margin:0 0 2px}.crew-detail-phone{font-size:14px;color:var(--accent);margin:0 0 16px}.crew-detail-section{display:flex;flex-direction:column;gap:10px;margin-top:16px;border-top:1px solid var(--border);padding-top:16px}.crew-detail-row{display:flex;gap:12px}.crew-detail-label{font-size:13px;color:var(--text-muted);min-width:80px;flex-shrink:0}.crew-detail-value{font-size:13px;color:var(--text)}.crew-release-title{font-size:16px;font-weight:700;color:var(--text);margin:0 0 12px}.crew-release-desc{font-size:14px;color:var(--text-muted);margin:0 0 16px;line-height:1.6}.crew-release-btn{width:100%}.crew-release-signed{text-align:center;padding:8px 0}.crew-release-signed-icon{font-size:32px;margin-bottom:8px}.crew-release-signed-text{font-size:15px;color:var(--text);margin:0 0 4px}.crew-release-signed-date{font-size:13px;color:var(--text-muted);margin:0 0 12px}.crew-release-sig-preview{max-width:100%;border:1px solid var(--border);border-radius:var(--radius-sm);background:#1e293b}.crew-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;z-index:100;display:flex;align-items:center;justify-content:center;padding:16px}.crew-modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;width:100%;max-width:560px;max-height:90vh;overflow-y:auto}.crew-modal-title{font-size:18px;font-weight:700;color:var(--text);margin:0 0 8px}.crew-modal-desc{font-size:13px;color:var(--text-muted);margin:0 0 20px;line-height:1.6}.crew-sig-pad-wrap{position:relative;margin-bottom:8px}.crew-sig-canvas{width:100%;height:160px;background:#fff;border:1px solid var(--border);border-radius:var(--radius-sm);display:block;touch-action:none}.crew-sig-clear{position:absolute;top:8px;right:8px;background:var(--bg);border:1px solid var(--border);color:var(--text-muted);font-size:12px;padding:4px 10px;border-radius:var(--radius-sm);cursor:pointer}.crew-modal-actions{display:flex;gap:12px;margin-top:20px;justify-content:flex-end}.crew-tabs{display:flex;gap:4px;margin-bottom:20px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:4px}.crew-tab{flex:1;background:none;border:none;color:var(--text-muted);font-size:14px;font-weight:600;padding:10px 12px;border-radius:calc(var(--radius) - 2px);cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .15s}.crew-tab:hover{color:var(--text)}.crew-tab--active{background:var(--accent);color:#fff}.crew-tab-count{background:#fff3;font-size:12px;padding:1px 7px;border-radius:10px}.crew-tab:not(.crew-tab--active) .crew-tab-count{background:var(--border);color:var(--text-muted)}.crew-tab-count--alert{background:#f59e0b!important;color:#000!important}.claim-crew-list{display:flex;flex-direction:column;gap:4px;max-height:300px;overflow-y:auto}.claim-crew-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--radius-sm);border:1px solid var(--border);cursor:pointer}.claim-crew-item:has(input:checked){border-color:var(--accent);background:#dc26260f}.claim-crew-name{flex:1;font-size:14px;font-weight:500;color:var(--text)}.claim-crew-role{font-size:12px;color:var(--text-muted);text-transform:capitalize}.crew-floater-card{border-color:#f59e0b4d}.crew-floater-badge{background:#f59e0b26;color:#f59e0b;border:1px solid rgba(245,158,11,.3);border-radius:6px;padding:3px 10px;font-size:12px;font-weight:600;white-space:nowrap}.crew-floater-notes{font-size:12px;color:var(--text-muted);margin:6px 0 0;padding:0 4px}.crew-claim-btn{width:100%;margin-top:12px}.crew-help-btn{width:100%;margin-top:-8px;margin-bottom:16px;background:#3b82f61f;color:#60a5fa;border:1px solid rgba(59,130,246,.25);border-top:none;border-radius:0 0 var(--radius) var(--radius);padding:14px;font-size:13px;cursor:pointer;transition:background .15s}.crew-help-btn:hover{background:#3b82f633}.history-release{margin-top:12px;padding-top:12px;border-top:1px solid var(--border)}.history-release-label{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:8px}.history-release-signed{display:flex;align-items:flex-start;gap:10px}.history-release-check{font-size:20px;flex-shrink:0}.history-release-name{font-size:13px;color:var(--text);margin-bottom:2px}.history-release-date{font-size:12px;color:var(--text-muted);margin-bottom:8px}.history-release-sig{display:block;max-width:280px;border:1px solid var(--border);border-radius:var(--radius-sm);background:#1e293b}.history-release-unsigned{font-size:13px;color:#f59e0b}.history-release-download{display:inline-block;margin-top:8px;text-decoration:none}.crew-today-section{margin-bottom:20px}.crew-today-label{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin:0 0 10px}.crew-today-list{display:flex;flex-wrap:wrap;gap:10px}.crew-today-chip{display:flex;align-items:center;gap:10px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:8px 14px 8px 8px}.crew-today-avatar{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:#fff;flex-shrink:0}.crew-today-avatar--lead{background:var(--accent)}.crew-today-avatar--mover{background:#3b82f6}.crew-today-avatar--driver{background:#10b981}.crew-today-info{display:flex;flex-direction:column}.crew-today-name{font-size:14px;font-weight:600;color:var(--text);line-height:1.2}.crew-today-role{font-size:11px;color:var(--text-muted);text-transform:capitalize}.crew-job-billing{border-top:1px solid var(--border);margin-top:10px;padding-top:10px;display:flex;flex-direction:column;gap:8px;margin-bottom:10px}.crew-job-rate{display:flex;align-items:center;gap:10px}.crew-billing-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);min-width:110px}.crew-billing-value{font-size:16px;font-weight:800;color:var(--accent)}.crew-job-packing{display:flex;align-items:flex-start;gap:10px}.crew-packing-list{display:flex;flex-wrap:wrap;gap:6px}.crew-packing-item{font-size:12px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);padding:2px 8px;color:var(--text)}.crew-modal--end{max-width:560px}.crew-modal--end .return-section{margin-bottom:20px}.crew-modal--end .return-section-header{font-size:13px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:12px}.crew-modal--end .return-times-row{display:flex;gap:12px}.crew-modal--end .return-times-row .form-group{flex:1}.crew-modal--end .return-calc-hours{font-size:13px;color:var(--text-muted);margin:8px 0 0}.crew-modal--end .packing-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin-top:12px}.crew-modal--end .packing-item{display:flex;flex-direction:column;gap:4px}.crew-modal--end .packing-item-label{font-size:12px;color:var(--text-muted)}.crew-modal--end .packing-qty-input{padding:6px 10px;font-size:14px}.crew-modal--end .packing-toggle-label{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:var(--text)}.release-form-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:var(--bg);overflow-y:auto;-webkit-overflow-scrolling:touch}.release-form-container{max-width:720px;margin:0 auto;padding:20px 16px 40px}.release-form-header{text-align:center;margin-bottom:20px;padding-bottom:16px;border-bottom:2px solid var(--border)}.release-form-close{position:absolute;left:16px;top:20px;background:none;border:none;color:var(--accent);font-size:15px;font-weight:600;cursor:pointer;padding:4px 8px}.release-form-title{font-size:20px;font-weight:800;color:var(--text);letter-spacing:.05em;margin:0 0 8px}.release-form-meta{display:flex;justify-content:center;gap:24px;font-size:13px;color:var(--text-muted)}.release-form-intro{margin-bottom:20px}.release-form-intro p{font-size:13px;color:var(--text-muted);line-height:1.6;margin:0 0 8px}.release-form-instruction{font-style:italic;font-weight:600;color:var(--text)!important}.release-form-name-section{margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid var(--border)}.release-form-items{display:flex;flex-direction:column;gap:2px}.release-form-item{display:flex;align-items:flex-start;gap:12px;padding:12px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface);transition:all .15s ease;cursor:pointer}.release-form-item:active{background:var(--surface-hover)}.release-form-item--initialed{border-color:var(--green-500);background:#22c55e0f}.release-form-initial-btn{flex-shrink:0;width:40px;height:40px;min-width:40px;border-radius:8px 8px 0 0;border:2px dashed var(--border);border-bottom:2px solid var(--text-muted);background:var(--surface-2);color:var(--text-muted);font-size:14px;font-weight:700;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s ease;margin-top:2px}.release-form-initial-btn--active{border:2px solid var(--green-500);border-bottom:2px solid var(--green-500);background:#22c55e26;color:var(--green-500);font-size:15px}.release-form-item-content{font-size:12px;color:var(--text-muted);line-height:1.5;flex:1}.release-form-item-content strong{color:var(--text);font-size:13px}.release-form-item-dash{margin:0 4px;color:var(--text-subtle)}.release-form-other{margin-top:16px;padding-top:16px;border-top:1px solid var(--border)}.release-form-statement{margin:16px 0;padding:12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm)}.release-form-statement p{font-size:13px;color:var(--text);line-height:1.6;margin:0;font-weight:500}.release-form-sig-section{margin-top:20px;padding-top:16px;border-top:2px solid var(--border)}.release-form-sig-row,.release-form-sig-block{margin-bottom:16px}.release-form-sig-line{font-size:14px;color:var(--text);padding:8px 0;border-bottom:1px solid var(--border);min-height:32px}.release-form-existing-sig{margin-bottom:12px;text-align:center}.release-form-existing-sig .crew-release-sig-preview{max-width:280px;margin-bottom:4px}.release-form-signed-info{font-size:12px;color:var(--green-500);margin:0}.crew-release-status-row{margin-bottom:12px}.crew-release-signed-badge{font-size:13px;color:var(--green-500);margin-bottom:4px}.crew-release-initial-count{font-size:12px;color:var(--text-muted)}.release-form-actions{display:flex;gap:12px;margin-top:20px;padding-top:16px;border-top:1px solid var(--border);position:sticky;bottom:0;background:var(--bg);padding-bottom:16px}.release-form-actions .btn{flex:1}.release-form-mandatory{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--accent);padding:6px 12px 0;margin-top:8px}.release-form-item--mandatory{border-color:var(--accent)!important;background:#dc26260f!important}.initials-popup-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1100;background:#000000b3;display:flex;align-items:center;justify-content:center;padding:20px}.initials-popup{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;max-width:340px;width:100%}.initials-popup-title{font-size:18px;font-weight:700;color:var(--text);margin:0 0 8px}.initials-popup-desc{font-size:13px;color:var(--text-muted);margin:0 0 16px;line-height:1.5}.initials-pad-wrap{position:relative;margin-bottom:8px}.initials-canvas{width:100%;height:100px;background:#fff;border:1px solid var(--border);border-radius:var(--radius-sm);display:block;touch-action:none}.release-form-initial-img{width:100%;height:100%;object-fit:contain;border-radius:4px}.bill-drive-note{font-size:12px;color:var(--amber-500);font-style:italic;margin:6px 0 0}.packing-item-price{font-size:11px;color:var(--text-subtle);font-weight:400;margin-left:4px}.bill-total-section{margin-top:16px;padding:12px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm)}.bill-total-row{display:flex;justify-content:space-between;align-items:center;padding:6px 0;font-size:13px;color:var(--text-muted)}.bill-total-row--grand{border-top:1px solid var(--border);margin-top:6px;padding-top:10px;font-size:20px;font-weight:800;color:var(--text)}.qhp{position:relative;width:100%}.qhp-display{display:flex;align-items:center;justify-content:space-between;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:8px 10px;cursor:pointer;transition:border-color .15s;min-height:38px}.qhp-display:hover{border-color:var(--border-hover)}.qhp-value{font-size:14px;color:var(--text);font-weight:500}.qhp-arrows{display:flex;flex-direction:column;gap:0;margin-left:8px}.qhp-arrow{background:none;border:none;color:var(--text-muted);font-size:8px;line-height:1;padding:2px 4px;cursor:pointer;border-radius:3px;transition:background .1s,color .1s}.qhp-arrow:hover{background:var(--surface-hover);color:var(--text)}.qhp-list{position:absolute;top:100%;left:0;right:0;z-index:200;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);margin-top:4px;max-height:220px;overflow-y:auto;box-shadow:var(--shadow)}.qhp-option{padding:8px 12px;font-size:13px;color:var(--text);cursor:pointer;transition:background .1s}.qhp-option:hover{background:var(--surface-hover)}.qhp-option--active{background:var(--accent-dim);color:var(--accent-hover);font-weight:600}
