:root{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:#111827;background-color:#f7f7f9;line-height:1.5}*{box-sizing:border-box}body{margin:0;min-height:100vh;padding:env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left)}#root{min-height:100vh;display:flex;justify-content:center;background:radial-gradient(circle at 20% 20%,#f0f4ff,#f7f7f9 35%),radial-gradient(circle at 80% 10%,#f1f5f9,#f7f7f9 40%)}.login-shell{width:100%;min-height:100vh;display:flex;align-items:center;justify-content:center;padding:32px 20px}.login-card{width:min(420px,100%);background:#fff;border-radius:18px;border:1px solid #e5e7eb;padding:28px;box-shadow:0 18px 40px #0f172a14}.login-header{display:grid;gap:8px;margin-bottom:20px}.login-title{margin:0;font-size:24px;font-weight:700;color:#111827}.login-error{padding:10px 12px;border-radius:10px;background:#fee2e2;color:#991b1b;font-weight:600;font-size:14px}.shell{width:100%;padding:0;display:grid;grid-template-columns:360px 1fr;gap:0}.shell.mobile{grid-template-columns:1fr;padding:0}.panel{background:#fff;border:1px solid #e5e7eb;border-radius:0;box-shadow:none}.panel-header{padding:20px;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;align-items:center}.panel-body{padding:16px 20px 120px}.tag{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;background:#eef2ff;color:#4338ca;font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.4px}.list{display:flex;flex-direction:column;gap:8px}.list-item{border:1px solid #e5e7eb;border-radius:10px;padding:12px;background:#fff;cursor:pointer;transition:border-color .12s ease,box-shadow .12s ease}.list-item:hover,.list-item:focus-visible{outline:none;border-color:#6366f1;box-shadow:0 10px 24px #6366f11f}.list-item.active{border-color:#4338ca;box-shadow:0 12px 28px #4338ca2e}.row{display:flex;align-items:center;gap:12px;justify-content:space-between}.muted{color:#6b7280;font-size:14px}.strong{font-weight:700;color:#111827}.grid{display:grid;gap:8px}.grid.two{grid-template-columns:1fr 1fr}.input{width:100%;padding:10px 12px;border-radius:10px;border:1px solid #d1d5db;font-size:14px}.input:focus-visible{outline:2px solid #6366f1;border-color:#6366f1}.button{border:none;border-radius:12px;padding:12px 16px;background:linear-gradient(135deg,#4338ca,#6366f1);color:#fff;font-weight:700;cursor:pointer;transition:transform .12s ease,box-shadow .12s ease;font-size:15px}.button:active{transform:translateY(1px)}.button.secondary{background:#eef2ff;color:#4338ca}.button.danger{background:#dc2626;color:#fff}.button:disabled{opacity:.6;cursor:not-allowed}.line{display:grid;gap:2px;align-items:center;padding:6px 8px;border:1px solid #e5e7eb;border-radius:10px;background:#fff;cursor:pointer;text-align:left}.line.active{border-color:#4338ca;background:#f5f3ff}.line.warning{border-color:#f59e0b;background:#fff7ed}.line-title{font-size:14px;font-weight:700;color:#111827;width:100%}.line-meta{display:grid;gap:1px}.line-bottom{display:flex;align-items:center;justify-content:space-between;gap:12px}.qty-box{min-width:58px;text-align:center;padding:6px 8px;border-radius:10px;background:#eef2ff;color:#4338ca;font-weight:800;font-size:13px}.line .muted{font-size:12px}.line.warning .qty-box{background:#fef3c7;color:#b45309}.hint{display:inline-flex;gap:6px;align-items:center;padding:4px 10px;border-radius:8px;background:#f3f4f6;color:#4b5563;font-size:12px}.key{background:#111827;color:#fff;padding:2px 6px;border-radius:6px;font-weight:700;font-size:12px}.back-button{border:none;background:#eef2ff;color:#4338ca;border-radius:10px;padding:10px 12px;font-weight:700;cursor:pointer}.line-editor{margin-top:16px;padding:14px;border:1px solid #e5e7eb;border-radius:12px;background:#f9fafb;box-shadow:inset 0 1px #00000005}.qty-panel{display:flex;align-items:flex-end;flex-wrap:nowrap;gap:12px}.qty-input{max-width:120px}.qty-strip{display:grid;grid-template-columns:repeat(2,minmax(50px,1fr)) minmax(86px,1.2fr) repeat(2,minmax(50px,1fr));gap:6px;align-items:center}.qty-chip{border:1px solid #d1d5db;border-radius:10px;padding:8px 6px;background:#f9fafb;font-weight:700;font-size:14px;color:#111827;cursor:pointer}.qty-chip.primary{background:#eef2ff;border-color:#c7d2fe;color:#4338ca}.qty-pill{border:1px solid #d1d5db;border-radius:12px;padding:10px 14px;min-width:90px;background:#fff;font-size:18px;font-weight:800;color:#111827;text-align:center;cursor:pointer}.qty-pill:disabled{opacity:.6;cursor:not-allowed}.qty-input-row{display:flex;align-items:center;gap:8px}.lot-panel{border:1px solid #e5e7eb;border-radius:12px;padding:12px;background:#f9fafb;display:grid;gap:10px}.lot-row{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:8px 10px;border:1px solid #e5e7eb;border-radius:10px;background:#fff}.lot-actions{display:inline-flex;align-items:center;gap:8px}.lot-qty{min-width:36px;text-align:center;font-weight:700;color:#111827}.lot-form{display:grid;gap:8px}.lot-input{display:flex;align-items:center;gap:8px}.lot-input .input{flex:1}.lot-form-row{display:grid;grid-template-columns:1fr;gap:12px;align-items:stretch}.lot-qty-input{max-width:120px}.lot-input-wrap{display:grid;gap:8px;width:100%}.lot-preview{background:linear-gradient(135deg,#1e1b4b,#312e81);border-radius:12px;padding:14px 16px;text-align:center;min-height:52px;display:flex;align-items:center;justify-content:center}.lot-preview-value{font-family:JetBrains Mono,SF Mono,Consolas,monospace;font-size:24px;font-weight:700;color:#a5b4fc;letter-spacing:2px;word-break:break-all}.lot-input-xl{font-size:20px!important;padding:14px 16px!important;font-family:JetBrains Mono,SF Mono,Consolas,monospace;letter-spacing:1px}.lot-keyboard-btn,.lot-expand-btn{flex-shrink:0;width:48px;height:48px;border:1px solid #d1d5db;border-radius:12px;background:#f9fafb;color:#6b7280;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:all .15s ease}.lot-keyboard-btn:hover,.lot-expand-btn:hover{background:#eef2ff;border-color:#6366f1;color:#4338ca}.lot-keyboard-btn.active{background:linear-gradient(135deg,#4338ca,#6366f1);border-color:#4338ca;color:#fff}.lot-keyboard-btn:active,.lot-expand-btn:active{transform:scale(.95)}.lot-entry-modal{position:fixed;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,#1e1b4b,#312e81,#1e1b4b);z-index:50;display:flex;flex-direction:column;padding:env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left)}.lot-entry-header{padding:16px 20px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid rgba(255,255,255,.1)}.lot-entry-title{color:#e0e7ff;font-weight:700;font-size:16px}.lot-entry-close{background:#ffffff1a;border:none;border-radius:10px;padding:10px 16px;color:#e0e7ff;font-weight:700;cursor:pointer}.lot-entry-close:hover{background:#fff3}.lot-entry-body{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px;gap:24px}.lot-entry-display{background:#0000004d;border:2px solid rgba(165,180,252,.3);border-radius:16px;padding:24px 32px;min-width:280px;min-height:80px;display:flex;align-items:center;justify-content:center}.lot-entry-value{font-family:JetBrains Mono,SF Mono,Consolas,monospace;font-size:36px;font-weight:700;color:#a5b4fc;letter-spacing:4px;text-align:center;word-break:break-all}.lot-entry-value.empty{color:#a5b4fc66;font-size:20px;letter-spacing:1px}.lot-entry-input-row{display:flex;gap:12px;width:100%;max-width:400px}.lot-entry-input{flex:1;background:#fffffff2;border:2px solid #a5b4fc;border-radius:14px;padding:16px 20px;font-size:22px;font-family:JetBrains Mono,SF Mono,Consolas,monospace;letter-spacing:2px;text-align:center;color:#1e1b4b}.lot-entry-input:focus{outline:none;border-color:#818cf8;box-shadow:0 0 0 4px #818cf84d}.lot-entry-input::placeholder{color:#9ca3af;letter-spacing:0}.lot-entry-actions{display:flex;gap:12px;width:100%;max-width:400px}.lot-entry-btn{flex:1;padding:16px 20px;border-radius:14px;font-size:16px;font-weight:700;cursor:pointer;transition:all .15s ease}.lot-entry-btn.keyboard{background:#ffffff26;border:1px solid rgba(255,255,255,.2);color:#e0e7ff;display:flex;align-items:center;justify-content:center;gap:8px}.lot-entry-btn.keyboard:hover{background:#ffffff40}.lot-entry-btn.keyboard.active{background:#818cf8;border-color:#818cf8;color:#fff}.lot-entry-btn.clear{background:#ef444433;border:1px solid rgba(239,68,68,.3);color:#fca5a5}.lot-entry-btn.clear:hover{background:#ef44444d}.lot-entry-btn.confirm{background:linear-gradient(135deg,#10b981,#34d399);border:none;color:#fff;flex:2}.lot-entry-btn.confirm:hover{transform:translateY(-1px);box-shadow:0 8px 20px #10b9814d}.lot-entry-btn.confirm:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}.input-lg{padding:12px;font-size:16px}.button.ghost{background:#f3f4f6;color:#111827}.action-bar{position:sticky;bottom:0;display:grid;grid-template-columns:repeat(3,1fr);gap:10px;padding:12px;border-top:1px solid #e5e7eb;background:#ffffffe6;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.action-btn{padding:16px 14px;font-size:18px;border-radius:14px;border:1px solid #d1d5db;background:#f9fafb;font-weight:800;cursor:pointer}.action-btn.primary{background:#eef2ff;border-color:#c7d2fe;color:#4338ca}.action-btn.confirm{background:linear-gradient(135deg,#4338ca,#6366f1);color:#fff;border:none}.pad-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:10px;margin:12px 0}.status-bar{display:flex;gap:8px;align-items:center;justify-content:flex-end;padding:6px 10px;border-top:1px solid #e5e7eb;background:#f9fafb}.status-bar.global{position:fixed;bottom:calc(6px + env(safe-area-inset-bottom,0px));right:10px;left:auto;z-index:30;border:1px solid #e5e7eb;border-radius:999px;box-shadow:0 8px 24px #00000014;pointer-events:none}.toast{position:fixed;left:16px;right:16px;bottom:calc(18px + env(safe-area-inset-bottom,0px));z-index:35;padding:12px 14px;border-radius:14px;background:#191414eb;color:#f7e7d9;font-weight:600;text-align:center;box-shadow:0 16px 30px #0a0c1459;animation:toast-in .18s ease-out}@keyframes toast-in{0%{transform:translateY(6px);opacity:0}to{transform:translateY(0);opacity:1}}.summary-bar{margin-top:12px;padding:10px 12px;border:1px solid #e5e7eb;border-radius:12px;background:#f9fafb;display:flex;align-items:center;justify-content:space-between}.pda-action-bar{position:fixed;left:16px;right:16px;bottom:calc(12px + env(safe-area-inset-bottom,0px));display:flex;justify-content:center;z-index:15;pointer-events:none}.pda-action-wrap{pointer-events:auto;width:100%;max-width:560px;display:flex;gap:10px}.pda-action-btn{border:none;border-radius:18px;padding:14px 18px;color:#fff;font-weight:800;font-size:18px;display:inline-flex;align-items:center;justify-content:center;gap:10px;box-shadow:0 14px 28px #4338ca40;cursor:pointer}.pda-action-btn.add{flex:1 1 85%;border:none;background:linear-gradient(135deg,#4338ca,#6366f1)}.pda-action-btn.remove{flex:0 0 15%;background:linear-gradient(135deg,#dc2626,#f97316);box-shadow:0 14px 28px #ef444440}.pda-action-btn.remove .pda-action-icon{font-size:20px}.pda-action-icon{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:999px;background:#fff3;font-size:22px;line-height:1}.camera-box{border:1px dashed #cbd5e1;border-radius:12px;padding:12px;background:#f8fafc;display:grid;gap:8px}.status-pill{display:inline-flex;align-items:center;gap:6px;padding:5px 10px;border-radius:999px;background:#e5e7eb;color:#4b5563;font-weight:600;font-size:12px}.status-pill.active{background:#eef2ff;color:#4338ca}.dot{width:8px;height:8px;border-radius:50%;display:inline-block;background:#9ca3af}.dot.scan{background:#10b981}.dot.keyboard{background:#6366f1}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a47;display:flex;align-items:stretch;justify-content:stretch;padding:0;z-index:20}.modal-sheet{width:100%;max-height:100%;height:100%;background:#fff;border-radius:0;box-shadow:0 -4px 24px #00000029;display:flex;flex-direction:column}.modal-header{padding:16px;border-bottom:1px solid #e5e7eb;display:flex;align-items:center;justify-content:space-between}.modal-body{padding:16px;overflow-y:auto;flex:1}@media (max-width: 900px){.panel-header{flex-direction:column;align-items:flex-start;gap:8px}.row{flex-wrap:wrap}.line,.grid.two{grid-template-columns:1fr}.button,.input{width:100%}.qty-strip{grid-template-columns:repeat(2,minmax(44px,1fr)) minmax(80px,1.2fr) repeat(2,minmax(44px,1fr))}.lot-form{grid-template-columns:1fr}.modal-sheet{height:100vh;max-height:100vh}.status-bar.global{left:10px;right:10px;border-radius:12px;justify-content:center;pointer-events:none}.summary-bar{flex-direction:column;align-items:flex-start;gap:4px}}@keyframes slideUp{0%{transform:translate(-50%) translateY(20px);opacity:0}to{transform:translate(-50%) translateY(0);opacity:1}}
