:root,[data-theme=light]{--bg: #F5F5F5;--surface: #FFFFFF;--surface-hover: #EBEBEB;--accent: #0E7A3A;--accent-hover: #095E2C;--error: #C81818;--warning: #B45309;--text: #111111;--text-secondary: #4B5563;--border: #D1D5DB;--shadow: rgba(0,0,0,.12);--numpad-bg: #E8E8E8;--numpad-active: #DADADA}[data-theme=dark]{--bg: #0F1117;--surface: #1A1D27;--surface-hover: #252830;--accent: #22C55E;--accent-hover: #16A34A;--error: #EF4444;--warning: #F59E0B;--text: #F1F5F9;--text-secondary: #94A3B8;--border: #2D3140;--shadow: rgba(0,0,0,.3);--numpad-bg: #1A1D27;--numpad-active: #252830}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;overflow:hidden}body{font-family:system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;-webkit-tap-highlight-color:transparent;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;-webkit-user-select:none;user-select:none}.page{display:flex;flex-direction:column;height:100%;overflow:hidden}.header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0}.header-left{flex:1;min-width:0}.header-warehouse{font-size:18px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.header-user{font-size:13px;color:var(--text-secondary)}.header-center{flex:1;min-width:0;text-align:center}.header-order{font-size:18px;font-weight:700}.header-client{font-size:13px;color:var(--text-secondary)}.btn{display:inline-flex;align-items:center;justify-content:center;min-height:48px;min-width:48px;padding:10px 20px;border:none;border-radius:10px;font-size:16px;font-weight:600;cursor:pointer;transition:background .15s;touch-action:manipulation}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-hover)}.btn-accent{background:var(--accent);color:#fff}.btn-accent:hover{background:var(--accent-hover)}.btn-secondary{background:var(--surface);color:var(--text);border:1px solid var(--border)}.btn-icon{background:transparent;color:var(--text);font-size:22px;padding:8px;min-width:44px;min-height:44px}.btn-full{width:100%}.task-list{flex:1;overflow-y:auto;padding:12px;gap:12px;display:flex;flex-direction:column;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}.task-card{background:var(--surface);border-radius:12px;padding:14px 16px;border:1px solid var(--border);box-shadow:0 1px 3px var(--shadow)}.task-urgent{border-color:var(--error);border-width:2px}.task-card-header{display:flex;gap:8px;align-items:center;margin-bottom:4px}.urgent-label{font-size:12px;font-weight:700;color:var(--error);text-transform:uppercase}.task-card-order{font-size:18px;font-weight:700;margin-bottom:2px}.task-card-client{font-size:14px;color:var(--text-secondary);margin-bottom:4px}.task-card-meta{font-size:13px;color:var(--text-secondary);margin-bottom:10px}.task-card-progress-text{font-size:13px;color:var(--text-secondary);margin:6px 0 10px}.task-card-actions{display:flex;gap:8px}.status-badge{font-size:11px;font-weight:700;text-transform:uppercase;padding:3px 8px;border-radius:6px}.badge-new{background:#1d4ed8;color:#fff}.badge-progress{background:var(--accent);color:#fff}.badge-done{background:#6b7280;color:#fff}.badge-partial{background:var(--warning);color:#fff}.progress-bar{background:var(--border);border-radius:4px;overflow:hidden;width:100%}.progress-bar-fill{height:100%;background:var(--accent);border-radius:4px;transition:width .3s}.assembly-page{display:flex;flex-direction:column;height:100%}.assembly-header{gap:8px}.assembly-progress{display:flex;align-items:center;gap:10px;padding:8px 16px;background:var(--surface);flex-shrink:0}.progress-text{font-size:13px;font-weight:600;white-space:nowrap;color:var(--text-secondary)}.assembly-lines{flex:1;overflow-y:auto;padding:8px 12px;display:flex;flex-direction:column;gap:8px;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}.assembly-footer{padding:10px 16px;background:var(--surface);border-top:1px solid var(--border);flex-shrink:0;display:flex;flex-direction:column;gap:8px}.scan-hint{text-align:center;font-size:13px;color:var(--text-secondary)}.line-item{background:var(--surface);border-radius:10px;padding:12px 14px;border:2px solid var(--border);box-shadow:0 1px 3px var(--shadow);cursor:pointer;transition:border-color .2s}.line-item:active{background:var(--surface-hover)}.line-complete{opacity:.5;border-color:var(--border);cursor:default}.line-highlighted{border-color:var(--accent)!important;box-shadow:0 0 12px #22c55e4d}.line-item-header{display:flex;align-items:center;gap:6px;margin-bottom:2px}.line-check{font-size:14px}.line-item-name{font-size:15px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.line-item-sku{font-size:12px;color:var(--text-secondary);margin-bottom:6px;font-family:monospace}.line-item-quantity{font-size:22px;font-weight:700;font-family:SF Mono,Cascadia Mono,monospace;text-align:right;margin-bottom:6px}.qty-fact{color:var(--accent)}.qty-sep{color:var(--text-secondary)}.qty-plan{color:var(--text)}.qty-unit{font-size:14px;color:var(--text-secondary);font-family:system-ui}.login-page{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:20px;background:var(--bg)}.login-logo{margin-bottom:12px}.login-logo-img{height:64px;width:auto;object-fit:contain}.login-title{font-size:22px;font-weight:700;margin-bottom:28px;text-align:center}.pin-display{display:flex;gap:14px;margin-bottom:12px}.pin-dot{width:18px;height:18px;border-radius:50%;border:2px solid var(--text-secondary);transition:all .15s}.pin-dot-filled{background:var(--accent);border-color:var(--accent)}.pin-error .pin-dot{border-color:var(--error)}.pin-error .pin-dot-filled{background:var(--error)}.login-error{color:var(--error);font-size:14px;font-weight:600;margin-bottom:8px;min-height:20px}.shake{animation:shake .4s ease-in-out}@keyframes shake{0%,to{transform:translate(0)}20%{transform:translate(-10px)}40%{transform:translate(10px)}60%{transform:translate(-6px)}80%{transform:translate(6px)}}.numpad{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;max-width:280px;width:100%}.login-numpad{margin-bottom:24px}.numpad-btn{min-height:56px;min-width:56px;font-size:24px;font-weight:600;border:none;border-radius:12px;background:var(--numpad-bg);color:var(--text);cursor:pointer;transition:background .1s;touch-action:manipulation}.numpad-btn:active{background:var(--numpad-active)}.login-divider{font-size:13px;color:var(--text-secondary);text-align:center}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;padding:16px}.modal{background:var(--surface);border-radius:16px;padding:20px;width:100%;max-width:340px}.modal-title{font-size:17px;font-weight:700;margin-bottom:6px}.modal-progress{font-size:14px;color:var(--text-secondary);margin-bottom:16px}.modal-input-display{font-size:36px;font-weight:700;text-align:center;padding:10px;background:var(--bg);border-radius:10px;margin-bottom:12px;min-height:60px;font-family:monospace}.modal .numpad{margin-bottom:16px}.modal .numpad-btn{min-height:48px;font-size:20px}.modal-actions{display:flex;gap:10px}.modal-actions .btn{flex:1}.toast{position:fixed;bottom:100px;left:50%;transform:translate(-50%);background:var(--surface);color:var(--text);padding:12px 24px;border-radius:10px;font-size:15px;font-weight:600;box-shadow:0 4px 20px var(--shadow);z-index:2000;pointer-events:auto;border:1px solid var(--border);white-space:nowrap}.complete-page{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:30px 20px;text-align:center;min-height:100vh}.complete-icon{font-size:64px;margin-bottom:16px}.complete-title{font-size:24px;font-weight:700;margin-bottom:20px}.complete-info{font-size:16px;color:var(--text-secondary);margin-bottom:24px;line-height:1.6}.shortages{text-align:left;width:100%;max-width:340px;margin-bottom:24px}.shortage-title{font-size:16px;font-weight:700;margin-bottom:8px}.shortage-item{font-size:15px;padding:6px 0;border-bottom:1px solid var(--border);color:var(--warning)}.complete-actions{display:flex;flex-direction:column;gap:10px;width:100%;max-width:340px}.dashboard-page{min-height:100vh;padding:20px;max-width:960px;margin:0 auto;background:var(--bg);color:var(--text)}.dashboard-header h1{font-size:24px;margin-bottom:20px}.dashboard-section{margin-bottom:30px}.dashboard-section h2{font-size:18px;margin-bottom:12px;color:var(--text-secondary)}.dashboard-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:16px}.dashboard-card{background:var(--surface);border-radius:12px;padding:16px;border:1px solid var(--border);box-shadow:0 1px 3px var(--shadow)}.dashboard-card-title{font-size:17px;font-weight:700;margin-bottom:12px}.dashboard-stat-row{display:flex;justify-content:space-between;padding:4px 0;font-size:15px}.stat-label{color:var(--text-secondary)}.stat-value{font-weight:700;font-size:18px}.stat-new{color:#1d4ed8}.stat-progress,.stat-done{color:var(--accent)}.dashboard-table{width:100%;border-collapse:collapse;background:var(--surface);border-radius:12px;overflow:hidden;border:1px solid var(--border)}.dashboard-table th,.dashboard-table td{padding:12px 16px;text-align:left;border-bottom:1px solid var(--border)}.dashboard-table th{font-size:13px;color:var(--text-secondary);font-weight:600}.dashboard-table td{font-size:15px}.dashboard-error{background:var(--error);color:#fff;padding:12px;border-radius:8px;text-align:center;margin-bottom:20px}.loading{display:flex;align-items:center;justify-content:center;height:100%;font-size:16px;color:var(--text-secondary)}.empty-state{text-align:center;padding:40px 20px;color:var(--text-secondary);font-size:16px}.offline-banner{background:var(--error);color:#fff;text-align:center;padding:8px;font-size:14px;font-weight:600;position:fixed;top:0;left:0;right:0;z-index:10000}.error-boundary{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;gap:20px;padding:20px}.landscape-block{display:none}@media(orientation:landscape)and (max-width:800px){.landscape-block{display:flex;position:fixed;top:0;right:0;bottom:0;left:0;z-index:99999;background:#fff;color:#333;flex-direction:column;align-items:center;justify-content:center;gap:16px;font-size:18px;font-weight:600;text-align:center;padding:20px}}
