:root{color:#17202a;background:#f6f7f9;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.4}*{box-sizing:border-box}body{margin:0}button,.button-link,.button-like{border:0;border-radius:8px;background:#126c62;color:#fff;cursor:pointer;display:inline-flex;justify-content:center;align-items:center;min-height:44px;padding:.75rem 1rem;text-decoration:none;font:inherit;font-weight:700}button:disabled{cursor:wait;opacity:.65}button.secondary,.button-like.secondary{background:#293241}.button-like input{display:none}button.ghost{background:transparent;color:#126c62;padding-left:0}button.danger{background:#b42318}input,select,textarea{border:1px solid #cfd7df;border-radius:8px;color:#17202a;font:inherit;min-height:44px;padding:.7rem .8rem;width:100%}textarea{resize:vertical}label{display:grid;gap:.35rem;font-weight:700}pre{background:#eef1f4;border-radius:8px;overflow:auto;padding:.75rem;white-space:pre-wrap}.app-shell{margin:0 auto;max-width:920px;min-height:100vh;padding:1rem}.home{display:grid;gap:1.25rem;min-height:100vh;align-content:center}.hero{display:grid;gap:.75rem}.hero h1{font-size:2.4rem;line-height:1.05;margin:0}.hero p{color:#4c5967;margin:0}.eyebrow,.meta{color:#657384;font-size:.88rem}.home-actions,.panel,.candidate-list,.inventory-list{display:grid;gap:.85rem}.panel{background:#fff;border:1px solid #dce2e8;border-radius:8px;margin:0 0 1rem;padding:1rem}.panel h2,.candidate-card h3,.inventory-card h3{margin:0}.preview{border-radius:8px;max-height:420px;object-fit:contain;width:100%}.scan-page{display:grid;gap:.85rem}.loading-overlay{align-items:center;background:#111820c7;display:flex;top:0;right:0;bottom:0;left:0;justify-content:center;padding:1rem;position:fixed;z-index:20}.loading-card{background:#fff;border-radius:8px;display:grid;gap:.6rem;justify-items:center;max-width:320px;padding:1.3rem;text-align:center;width:100%}.loading-card h2,.loading-card p{margin:0}.spinner{animation:spin .9s linear infinite;border:4px solid #cfd7df;border-top-color:#126c62;border-radius:999px;height:42px;width:42px}@keyframes spin{to{transform:rotate(360deg)}}.scan-camera-panel{gap:.75rem}.camera-stage{--guide-height: 70%;--guide-left: 10%;--guide-top: 15%;--guide-width: 80%;background:#111820;border-radius:8px;min-height:min(620px,78vh);overflow:hidden;position:relative}.camera-video{height:100%;top:0;right:0;bottom:0;left:0;object-fit:cover;position:absolute;width:100%}.camera-shade{background:linear-gradient(#00000094,#00000094) top / 100% var(--guide-top) no-repeat,linear-gradient(#00000094,#00000094) bottom / 100% calc(100% - var(--guide-top) - var(--guide-height)) no-repeat,linear-gradient(#00000094,#00000094) left / var(--guide-left) 100% no-repeat,linear-gradient(#00000094,#00000094) right / calc(100% - var(--guide-left) - var(--guide-width)) 100% no-repeat;top:0;right:0;bottom:0;left:0;pointer-events:none;position:absolute}.card-guide{border:3px solid #f04438;border-radius:8px;height:var(--guide-height);left:var(--guide-left);pointer-events:none;position:absolute;top:var(--guide-top);width:var(--guide-width)}.guide-zone{align-items:center;border:2px solid #f04438;color:#fff;display:flex;font-size:.72rem;font-weight:800;justify-content:center;line-height:1;min-height:22px;position:absolute;text-shadow:0 1px 2px #000;text-transform:uppercase}.scan-button{width:100%}.scan-status{background:#eef1f4;border:1px solid #dce2e8;border-radius:8px;color:#293241;font-weight:700;margin:0;padding:.7rem .8rem}.scan-status.good{background:#e8f4f2;border-color:#b9dcd7;color:#126c62}.scan-status.warn{background:#fff1f0;border-color:#ffc9c2;color:#9f1c13}.scan-manual{font-size:.92rem}.calibration-panel summary{cursor:pointer;font-weight:800}.ocr-lab-panel summary{cursor:pointer;font-weight:800}.guide-controls{display:grid;gap:.8rem}.zone-calibration{border-top:1px solid #dce2e8;padding-top:.75rem}.guide-output{align-items:center;display:grid;gap:.75rem}.guide-output code{background:#eef1f4;border-radius:8px;overflow-wrap:anywhere;padding:.7rem}.hint{color:#657384;font-size:.8rem;font-weight:500}.ocr-result h3{margin:.5rem 0 0}.variant-list{display:grid;gap:.35rem}.variant-list p{background:#eef1f4;border-radius:8px;margin:0;overflow-wrap:anywhere;padding:.55rem .65rem}.ocr-lab-preview{display:grid;gap:.8rem}.ocr-source,.ocr-snippet{display:grid;gap:.4rem;margin:0}.ocr-source-frame{aspect-ratio:900 / 1260;background:#111820;border-radius:8px;overflow:hidden;position:relative}.ocr-source-frame img{height:100%;object-fit:contain;width:100%}.ocr-source-zone{align-items:center;border:2px solid #f04438;color:#fff;display:flex;font-size:.72rem;font-weight:800;justify-content:center;line-height:1;min-height:22px;position:absolute;text-shadow:0 1px 2px #000;text-transform:uppercase}.ocr-snippet img{background:#111820;border-radius:8px;max-height:320px;object-fit:contain;width:100%}.ocr-source figcaption,.ocr-snippet figcaption{color:#657384;font-size:.86rem;font-weight:800}.debug-image-grid{display:grid;gap:.8rem}.debug-image{display:grid;gap:.4rem;margin:0}.debug-image img{background:#111820;border-radius:8px;max-height:520px;object-fit:contain;width:100%}.debug-image figcaption{color:#657384;font-size:.86rem;font-weight:800}.candidate-card,.inventory-card{background:#fff;border:1px solid #dce2e8;border-radius:8px;display:grid;grid-template-columns:92px 1fr;gap:.85rem;padding:.75rem}.candidate-card img,.inventory-card img,.image-fallback{aspect-ratio:.69;border-radius:6px;object-fit:cover;width:92px}.image-fallback{align-items:center;background:#e8edf2;color:#657384;display:flex;font-size:.82rem;justify-content:center;text-align:center}.candidate-body,.inventory-body{display:grid;gap:.75rem}.candidate-body p,.inventory-body p{margin:.18rem 0}.candidate-actions,.toolbar,.row-actions{align-items:center;display:flex;gap:.65rem;justify-content:space-between}.score{background:#e8f4f2;border-radius:999px;color:#126c62;font-weight:800;padding:.3rem .55rem}.selected-card{align-items:center;display:grid;grid-template-columns:88px 1fr;gap:.85rem}.selected-card img{border-radius:6px;width:88px}.check-row{align-items:center;display:flex;gap:.55rem}.check-row input{min-height:auto;width:auto}.filters,.edit-grid,.field-grid,.confirm-grid,.check-grid{display:grid;gap:.7rem}.check-grid{grid-template-columns:repeat(auto-fit,minmax(140px,1fr))}.field-grid{grid-template-columns:repeat(auto-fit,minmax(130px,1fr))}.field-pill{background:#eef7f5;border:1px solid #c9e3df;border-radius:8px;display:grid;gap:.1rem;padding:.55rem .65rem}.field-pill span{color:#657384;font-size:.78rem;text-transform:capitalize}.notes,.row-actions{grid-column:1 / -1}.error{background:#fff1f0;border:1px solid #ffc9c2;border-radius:8px;color:#9f1c13;padding:.75rem}.empty{color:#657384;padding:.75rem 0}@media (min-width: 680px){.app-shell{padding:2rem}.home-actions,.filters{grid-template-columns:repeat(3,1fr)}.edit-grid{grid-template-columns:.6fr 1fr 1fr auto}.confirm-grid{grid-template-columns:repeat(2,1fr)}.candidate-card,.inventory-card{grid-template-columns:120px 1fr}.candidate-card img,.inventory-card img,.image-fallback{width:120px}}
