:root{color:#111827;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;--ink:#111827;--muted:#64748b;--line:#d7dee8;--panel:#fff;--soft:#f6f8fb;--accent:#0f766e;--blue:#1d4ed8;--orange:#ea580c;--danger:#b91c1c;--shadow:0 14px 40px #0f172a14;background:#edf2f7;font-family:Inter,PingFang SC,Microsoft YaHei,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}body{min-width:320px;margin:0;overflow-x:hidden}button,input,select,textarea{font:inherit}button{-webkit-tap-highlight-color:transparent}.app-shell{background:linear-gradient(#0f172a 0 168px,#0000 168px),#edf2f7;width:min(100%,760px);min-height:100vh;margin:0 auto;padding:18px 14px 92px;overflow-x:hidden}.topbar{color:#fff;justify-content:space-between;align-items:center;padding:8px 2px 14px;display:flex}.eyebrow{color:inherit;opacity:.72;margin:0 0 5px;font-size:12px;font-weight:700}.topbar h1,.page-head h2,.scan-card h2,.confirm-row h3{letter-spacing:0;margin:0}.topbar h1{font-size:26px;line-height:1.18}.icon-button{color:#fff;background:#ffffff1a;border:1px solid #fff3;border-radius:8px;place-items:center;width:42px;height:42px;display:grid}.page-stack{gap:12px;display:grid}.status-strip{grid-template-columns:repeat(4,1fr);gap:8px;display:grid}.step{color:#ffffff9e;text-align:center;background:#ffffff17;border-radius:8px;min-width:0;padding:10px 6px}.step span{background:#ffffff1f;border-radius:50%;place-items:center;width:20px;height:20px;margin-right:4px;font-size:12px;display:inline-grid}.step b{font-size:13px}.step.active{color:#fff;background:#2dd4bf38}.step.active span{background:#14b8a6}.capture-layout,.confirm-panel,.tools-panel,.page-card{z-index:1;background:var(--panel);min-width:0;box-shadow:var(--shadow);border:1px solid #d7dee8f2;border-radius:8px;position:relative}.capture-layout{gap:10px;padding:10px;display:grid}.scan-card,.result-card{min-width:0}.scan-card-head{justify-content:space-between;gap:12px;margin-bottom:8px;display:flex}.badge{height:25px;color:var(--badge);background:color-mix(in srgb, var(--badge), white 88%);border-radius:999px;align-items:center;padding:0 8px;font-size:12px;font-weight:800;display:inline-flex}.badge.neutral{color:#64748b;background:#f1f5f9}.scan-card h2{margin-top:5px;font-size:18px}.score{color:#075985;text-align:center;background:#e0f2fe;border-radius:8px;align-self:start;min-width:50px;padding:7px 8px;font-size:13px;font-weight:900}.image-frame{z-index:0;background:#0b1020;border-radius:8px;width:100%;height:clamp(150px,34vh,230px);position:relative;overflow:hidden}.image-frame img,.camera-view{width:100%;height:100%;display:block}.image-frame img{object-fit:contain;background:#111827}.camera-view{object-fit:cover}.empty-camera{color:#94a3b8;background:linear-gradient(135deg,#94a3b81f,#14b8a61f),#111827;align-content:center;place-items:center;gap:8px;width:100%;height:100%;font-weight:900;display:grid}.scan-line{background:#2dd4bf;height:2px;position:absolute;top:52%;left:8%;right:8%;box-shadow:0 0 18px #2dd4bfb8}.quick-actions{grid-template-columns:repeat(3,1fr);gap:8px;margin-top:8px;display:grid}.quick-actions button,.button-label,.batch-commit-button,.raw-input button,.primary-button,.commit-button,.print-button,.label-placeholder button{cursor:pointer;border:0;border-radius:8px;justify-content:center;align-items:center;gap:7px;min-height:40px;font-weight:800;display:inline-flex}.quick-actions button,.button-label{color:#0f172a;background:#eef2f7}.quick-actions .primary-action{color:#fff;background:#0f766e}.button-label input{display:none}.inline-error{color:#fef2f2;background:#b91c1c;border-radius:8px;margin:8px 0 0;padding:8px 10px;font-size:13px}.scan-flow{margin-top:8px}.scan-flow-steps{grid-template-columns:repeat(5,minmax(0,1fr));gap:4px;display:grid}.scan-flow-step{color:#64748b;text-align:center;background:#f8fafc;border:1px solid #dbe4ef;border-radius:8px;min-width:0;padding:7px 4px 6px;position:relative}.scan-flow-step span{color:#334155;background:#e2e8f0;border-radius:999px;place-items:center;width:18px;height:18px;margin-bottom:3px;font-size:10px;font-weight:900;display:inline-grid}.scan-flow-step b,.scan-flow-step small{text-overflow:ellipsis;white-space:nowrap;display:block;overflow:hidden}.scan-flow-step b{color:#334155;font-size:12px;font-weight:900}.scan-flow-step small{margin-top:2px;font-size:9px;font-weight:700}.scan-flow-step.done{background:#ecfdf5;border-color:#99f6e4}.scan-flow-step.done span,.scan-flow-step.active span{color:#fff;background:#0f766e}.scan-flow-step.active{color:#0f766e;background:#ccfbf1;border-color:#0f766e;box-shadow:0 0 0 1px #0f766e2e}.scan-flow-step.active b{color:#0f766e}.scan-status{color:#0f766e;background:#ecfeff;border:1px solid #bae6fd;border-radius:8px;margin:8px 0 0;padding:8px 10px;font-size:13px;font-weight:900;line-height:1.45}.card-title{color:#334155;align-items:center;gap:7px;margin-bottom:10px;font-weight:900;display:flex}.field-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:6px;display:grid}.field-section-title{color:#0f766e;grid-column:1/-1;align-items:center;min-height:22px;margin-top:2px;font-size:12px;font-weight:900;display:flex}.field-item{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;min-height:48px;padding:7px 8px}.field-item span,.label-grid span,.std-top span,.label-bottom span{color:var(--muted);margin-bottom:3px;font-size:11px;font-weight:800;display:block}.field-item b{overflow-wrap:anywhere;min-width:0;font-size:13px;display:block}.field-item input,.field-item select,.field-item textarea,.inline-code-input{width:100%;min-width:0;color:var(--ink);font:inherit;background:0 0;border:0;outline:none;font-size:13px;font-weight:900;line-height:1.25}.field-item select{appearance:none;padding:0}.field-item textarea{resize:vertical;min-height:42px;padding:0;display:block}.editable-field.wide textarea{font-weight:800}.field-item input::placeholder,.field-item textarea::placeholder{color:#94a3b8;font-weight:700}.param-strip{flex-wrap:wrap;align-items:center;gap:6px;min-height:0;padding:7px;display:flex}.param-strip>span{color:#334155;background:#e2e8f0;border-radius:999px;align-items:center;gap:4px;max-width:100%;margin:0;padding:4px 7px;font-size:11px;font-weight:900;display:inline-flex}.param-strip em{color:#64748b;font-style:normal}.param-strip b{text-overflow:ellipsis;white-space:nowrap;max-width:220px;font-size:11px;overflow:hidden}.field-item input:focus,.field-item select:focus,.field-item textarea:focus,.inline-code-input:focus{box-shadow:inset 0 -2px #14b8a6}.inline-code-input{height:28px;padding:0}.field-item.wide{grid-column:1/-1}.field-item.ok{background:#ecfdf5;border-color:#14b8a661}.field-item.miss{background:#fef2f2;border-color:#b91c1c47}.empty-result{color:#64748b;text-align:center;background:#f8fafc;border:1px dashed #cbd5e1;border-radius:8px;place-items:center;gap:6px;min-height:138px;padding:16px;display:grid}.empty-result b{color:#334155}.empty-result span{max-width:260px;font-size:12px;line-height:1.5}.section-mini-head{color:#334155;justify-content:space-between;align-items:center;padding:12px 12px 0;font-size:14px;font-weight:900;display:flex}.sample-note{color:#64748b;margin:0 11px 8px;font-size:12px;line-height:1.45}.section-mini-head b,.count-pill{color:#0f766e;background:#ccfbf1;border-radius:999px;padding:4px 8px;font-size:12px}.sample-rail{z-index:2;scrollbar-width:none;grid-template-columns:none;grid-auto-columns:118px;grid-auto-flow:column;gap:10px;width:100%;max-width:100%;padding:8px 12px 10px;display:grid;position:relative;overflow-x:auto}.sample-rail::-webkit-scrollbar{display:none}.sample-tile{z-index:3;text-align:left;background:#fff;border:1px solid #d7dee8;border-radius:8px;min-width:118px;padding:6px;position:relative}.sample-tile.selected{border-color:#14b8a6;box-shadow:0 0 0 2px #14b8a629}.sample-tile img{aspect-ratio:1.55;object-fit:cover;background:#e5e7eb;border-radius:6px;width:100%}.sample-tile i{color:#fff;background:#0f172ac7;border-radius:999px;padding:2px 6px;font-size:11px;font-style:normal;font-weight:900;position:absolute;top:12px;left:12px}.sample-tile span,.sample-tile b{text-overflow:ellipsis;white-space:nowrap;margin-top:5px;font-size:12px;display:block;overflow:hidden}.confirm-panel,.tools-panel,.page-card{padding:10px}.confirm-row{grid-template-columns:1.15fr .85fr;gap:10px;display:grid}.confirm-row>div{background:#f8fafc;border-radius:8px;min-width:0;padding:10px}.confirm-row h3{overflow-wrap:anywhere;font-size:16px}.confirm-row span{color:var(--muted);margin-top:5px;font-size:12px;display:block}.warning{color:#991b1b;background:#fee2e2;border-radius:8px;align-items:center;gap:7px;margin-top:10px;padding:9px;font-weight:800;display:flex}.confirm-actions{margin-top:10px}.confirm-actions .primary-button{width:100%;margin:0}.commit-button{color:#fff;background:linear-gradient(135deg,#0f766e,#1d4ed8);width:100%;margin-top:10px}.commit-button:disabled{cursor:not-allowed;opacity:.46}.tools-panel{gap:8px;padding-bottom:82px;display:grid}.tools-panel details{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px}.tools-panel summary{color:#334155;cursor:pointer;align-items:center;gap:8px;padding:11px;font-weight:900;list-style:none;display:flex}.tools-panel summary::-webkit-details-marker{display:none}.batch-upload-row{color:#64748b;grid-template-columns:minmax(0,1fr) auto auto;align-items:center;gap:10px;padding:0 11px 11px;font-size:12px;font-weight:800;display:grid}.batch-upload-row .button-label,.batch-commit-button{color:#fff;background:#334155;min-width:0}.batch-commit-button{white-space:nowrap;background:#0f766e;padding:0 12px}.batch-commit-button:disabled{cursor:not-allowed;opacity:.48}.batch-result-list{gap:7px;max-height:280px;padding:0 11px 11px;display:grid;overflow:auto}.batch-result-row{background:#fff;border:1px solid #e2e8f0;border-radius:8px;gap:3px;min-width:0;padding:9px;display:grid}.batch-result-row.ok{background:#f0fdfa;border-color:#99f6e4}.batch-result-row.committed{background:#eff6ff;border-color:#93c5fd}.batch-result-row.needsMapping{background:#fffbeb;border-color:#fde68a}.batch-result-row.failed{background:#fff7f7;border-color:#fecaca}.batch-result-row b,.batch-result-row small{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.batch-result-row span{color:#64748b;font-size:12px;font-weight:800}.batch-result-row small{color:#334155}.manual-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:9px;padding:0 11px 11px;display:grid}.manual-grid label{color:#475569;gap:5px;font-size:12px;font-weight:900;display:grid}.manual-grid input,.manual-grid select{min-width:0;height:42px;color:var(--ink);background:#fff;border:1px solid #cbd5e1;border-radius:8px;padding:0 9px;font-weight:700}.primary-button{color:#0f172a;background:#dbeafe;width:calc(100% - 22px);margin:0 11px 11px}.primary-button:disabled{cursor:not-allowed;opacity:.48}.template-actions{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;padding:0 11px 11px;display:grid}.template-actions .primary-button{width:100%;margin:0}.save-template-button{color:#fff;background:#0f766e}.raw-input{padding:0 11px 11px}.raw-input textarea{resize:vertical;background:#fff;border:1px solid #cbd5e1;border-radius:8px;width:100%;min-height:72px;padding:10px}.raw-input button{color:#fff;background:var(--blue);width:100%;margin-top:8px}.filter-panel{gap:8px;margin-bottom:10px;display:grid}.search-box{color:#64748b;background:#fff;border:1px solid #cbd5e1;border-radius:8px;align-items:center;gap:8px;min-height:42px;padding:0 10px;display:flex}.search-box input,.filter-panel select{width:100%;min-width:0;height:42px;color:var(--ink);background:0 0;border:0;outline:none;font-weight:800}.filter-panel select{background:#fff;border:1px solid #cbd5e1;border-radius:8px;padding:0 10px}.print-list-head,.preview-title{color:#334155;justify-content:space-between;align-items:center;gap:8px;margin:10px 0 8px;font-size:13px;font-weight:900;display:flex}.print-list-head button{color:#0f766e;background:#ccfbf1;border:0;border-radius:8px;min-height:32px;padding:0 10px;font-weight:900}.print-list-head button:disabled{cursor:not-allowed;opacity:.45}.preview-title b{color:#075985;background:#e0f2fe;border-radius:999px;padding:3px 8px}.print-record-list{gap:8px;display:grid}.print-record-row{color:#334155;text-align:left;background:#fff;border:1px solid #e2e8f0;border-radius:8px;grid-template-columns:24px 1fr 22px;align-items:center;gap:8px;min-height:70px;padding:9px;display:grid}.print-record-row.selected{background:#ecfdf5;border-color:#14b8a694}.print-record-row b,.print-record-row small,.print-record-row em{text-overflow:ellipsis;white-space:nowrap;min-width:0;display:block;overflow:hidden}.print-record-row b{color:#0f766e;font-size:14px}.print-record-row small{color:#334155;margin-top:3px;font-size:12px;font-weight:900}.print-record-row em{color:var(--muted);margin-top:3px;font-size:11px;font-style:normal}.check-dot{color:#fff;background:#fff;border:1px solid #cbd5e1;border-radius:50%;place-items:center;width:22px;height:22px;display:grid}.print-record-row.selected .check-dot{background:#0f766e;border-color:#0f766e}.page-head{justify-content:space-between;align-items:center;gap:12px;margin-bottom:10px;display:flex}.page-head .eyebrow{color:#475569}.page-head h2{font-size:20px}.tap-note{color:#334155;background:#f1f5f9;border-radius:8px;padding:10px;font-size:13px;line-height:1.58}.tap-note.compact{margin-bottom:10px}.record-list{gap:8px;display:grid}.record-row,.empty-state{text-align:left;background:#fff;border:1px solid #e2e8f0;border-radius:8px;grid-template-columns:112px 1fr;align-items:center;gap:4px 8px;min-height:54px;padding:9px;display:grid}.record-row span{color:#0f766e;font-weight:900}.record-row b{overflow-wrap:anywhere;min-width:0}.record-row small{color:var(--muted);grid-column:2}.empty-state{color:var(--muted);font-weight:800;display:flex}.print-button{color:#fff;background:var(--orange);min-width:88px}.print-button:disabled{cursor:not-allowed;opacity:.42}.print-area{background:#f1f5f9;border-radius:8px;padding:8px;overflow-x:auto}.batch-print-area{gap:10px;display:grid}.std-label{color:#111827;background:#fff;border:1px solid #cbd5e1;border-radius:6px;width:356px;min-height:238px;margin:0 auto;padding:12px 14px}.std-top{justify-content:space-between;align-items:start;margin-bottom:4px;display:flex}.std-top b{font-size:17px}.std-top strong{font-size:13px}.barcode-svg{width:176px;height:54px;margin-bottom:4px;display:block}.label-grid{grid-template-columns:38px 1fr 40px 78px;gap:2px 5px;font-size:12px;line-height:1.25;display:grid}.label-grid span{margin:0}.label-grid b{overflow-wrap:anywhere;min-width:0}.desc-cell{grid-column:span 3;font-size:10px}.label-bottom{justify-content:space-between;align-items:end;margin-top:6px;display:flex}.label-bottom strong{font-size:17px;display:block}.label-bottom small{color:#64748b;font-size:10px}.label-bottom img{width:78px;height:78px}.label-placeholder{min-height:220px;color:var(--muted);background:#f8fafc;border:1px dashed #cbd5e1;border-radius:8px;place-items:center;gap:8px;font-weight:800;display:grid}.label-placeholder button{color:#fff;background:var(--blue);padding:0 18px}.supplier-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin-bottom:12px;display:grid}.supplier-card{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;min-width:0;padding:10px}.supplier-card span{font-size:13px;font-weight:900;display:block}.supplier-card b{overflow-wrap:anywhere;margin-top:4px;font-size:14px;display:block}.supplier-card small{color:var(--muted);margin-top:4px;line-height:1.4;display:block}.mapping-list,.custom-template-list{gap:8px;display:grid}.custom-template-card{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;grid-template-columns:76px minmax(0,1fr) 48px 48px;align-items:center;gap:8px;padding:8px;display:grid}.custom-template-card img,.template-image-placeholder{background:#111827;border-radius:6px;width:76px;height:54px}.custom-template-card img{object-fit:cover}.template-image-placeholder{color:#94a3b8;place-items:center;display:grid}.custom-template-card div{min-width:0}.custom-template-card b,.custom-template-card span,.custom-template-card small{text-overflow:ellipsis;white-space:nowrap;min-width:0;display:block;overflow:hidden}.custom-template-card b{color:var(--ink);font-size:13px}.custom-template-card span,.custom-template-card small{color:var(--muted);font-size:11px}.custom-template-card button{color:#0f766e;background:#ccfbf1;border:0;border-radius:8px;min-height:34px;font-weight:900}.custom-template-card .ghost-danger{color:#991b1b;background:#fee2e2}.mapping-row{background:#f8fafc;border-radius:8px;grid-template-columns:78px 1fr 16px 1fr;align-items:center;gap:6px;padding:9px;font-size:12px;display:grid}.mapping-row span{color:#475569;font-weight:800}.mapping-row b,.mapping-row strong{overflow-wrap:anywhere;min-width:0}.mapping-row strong{color:#0f766e}.bottom-nav{z-index:15;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#fffffff0;border:1px solid #cbd5e1db;border-radius:8px;grid-template-columns:repeat(4,1fr);gap:6px;width:min(100% - 24px,720px);padding:7px;display:grid;position:fixed;bottom:12px;left:50%;transform:translate(-50%);box-shadow:0 16px 40px #0f172a2e}.bottom-nav button{color:#64748b;background:0 0;border:0;border-radius:8px;place-items:center;gap:3px;min-height:50px;font-size:12px;font-weight:900;display:grid;position:relative}.bottom-nav button.active{color:#0f766e;background:#ccfbf1}.bottom-nav i{color:#fff;background:#ef4444;border-radius:999px;place-items:center;min-width:17px;height:17px;padding:0 4px;font-size:10px;font-style:normal;display:grid;position:absolute;top:4px;right:12px}.toast{z-index:20;color:#fff;background:#0f172af0;border-radius:8px;align-items:center;gap:7px;min-width:150px;padding:11px 14px;font-weight:800;display:flex;position:fixed;bottom:82px;left:50%;transform:translate(-50%);box-shadow:0 12px 30px #0f172a33}@media (width<=380px){.app-shell{padding-inline:10px}.status-strip{gap:5px}.step{padding-inline:3px}.step span{display:none}.field-grid,.manual-grid,.confirm-row,.supplier-grid,.mapping-row{grid-template-columns:1fr}.mapping-row svg{display:none}.batch-upload-row{grid-template-columns:1fr;justify-items:stretch}.batch-upload-row>span{text-align:center}.std-label{width:326px;padding-inline:10px}.label-grid{grid-template-columns:34px 1fr 36px 68px;font-size:11px}}@media print{body{background:#fff}body *{visibility:hidden}.print-area,.print-area *{visibility:visible}.print-area{background:#fff;padding:0;display:block;position:fixed;inset:0;overflow:visible}.batch-print-area{display:block}.std-label{box-shadow:none;margin:8mm auto}}
