:root{font-family:Segoe UI,system-ui,sans-serif;color:#0f172a;background:#f1f5f9;line-height:1.4}body{margin:0}.wrap{max-width:1200px;margin:0 auto;padding:2rem 1.25rem 3rem}.head h1{margin:0 0 .25rem;font-size:1.75rem}.sub{margin:0;color:#64748b;font-size:.95rem}.panel{margin-top:2rem;background:#fff;border-radius:10px;box-shadow:0 1px 3px #0f172a14;padding:1rem 1.25rem 1.5rem}.panel h2{margin:0 0 1rem;font-size:1.15rem}.table-wrap{overflow:auto}.table-wrap--scroll{max-height:290px;overflow-y:auto}table{width:100%;border-collapse:collapse;font-size:.9rem}th,td{text-align:left;padding:.5rem .6rem;border-bottom:1px solid #e2e8f0;vertical-align:middle}th{font-weight:600;color:#334155;white-space:nowrap}.mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:.85rem}.thumb a.thumb-link{display:inline-block;text-decoration:none;border-radius:6px;line-height:0}.thumb a.thumb-link:hover img{outline:2px solid #3b82f6;outline-offset:2px}.thumb img{display:block;width:72px;height:72px;object-fit:cover;border-radius:6px;background:#e2e8f0}.empty{color:#94a3b8;font-style:italic}.err{color:#b91c1c;margin-top:1rem}.hint{font-size:.75rem;color:#94a3b8}.sub.small{font-size:.8rem;margin:0 0 .75rem}.config-row{display:flex;gap:.75rem;align-items:center;margin-bottom:.75rem}.config-row select,.config-row button{height:2rem}.config-editor{width:100%;box-sizing:border-box;border:1px solid #cbd5e1;border-radius:8px;padding:.6rem;background:#f8fafc}.ref-photo-row{margin-bottom:.75rem}.ref-photo-row select{min-width:16rem;height:2rem}.wizard{max-width:56rem}.wizard-steps{display:flex;flex-wrap:wrap;gap:.35rem .5rem;margin:.75rem 0 1rem}.wizard-steps button{border-radius:999px;padding:.35rem .75rem;border:1px solid #cbd5e1;background:#fff;cursor:pointer;font-size:.85rem}.wizard-steps button.wizard-step--active{border-color:#2563eb;background:#eff6ff;font-weight:600}.wizard-nav{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1rem}.preview-block{margin-top:1rem;padding:.75rem 1rem;background:#f1f5f9;border-radius:8px;border:1px solid #e2e8f0;font-size:.9rem}.preview-block pre{margin:.5rem 0 0;white-space:pre-wrap;word-break:break-word;font-size:.8rem}.table-actions{white-space:nowrap}.table-actions a{margin-right:.5rem}.roi-toolbar{display:flex;flex-wrap:wrap;gap:.5rem .75rem;align-items:center;margin:.75rem 0 1rem}.roi-toolbar button{height:2rem}.roi-toolbar .btn-active{background:#3b82f6;color:#fff;border:1px solid #2563eb;border-radius:6px}.toolbar-hint{flex:1 1 12rem;margin:0}.roi-canvas{margin-bottom:1.25rem}.roi-stage{position:relative;display:inline-block;max-width:100%;border-radius:8px;overflow:hidden;background:#e2e8f0;box-shadow:inset 0 0 0 1px #cbd5e1}.roi-stage img,.roi-base-canvas{display:block;max-width:100%;height:auto;vertical-align:top}.camera-align-panel{margin:0 0 1rem;padding:.75rem 1rem;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px}.camera-align-panel h3{margin:0 0 .5rem;font-size:.95rem;font-weight:600}.camera-align-row{display:flex;flex-wrap:wrap;align-items:center;gap:.75rem 1rem;margin-bottom:.5rem}.camera-align-row:last-child{margin-bottom:0}.camera-align-slider{flex:1 1 12rem;min-width:8rem;max-width:24rem}.camera-deg-value{font-variant-numeric:tabular-nums;min-width:4.5rem;font-weight:600}.camera-align-actions{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}.roi-step-hint{margin:0 0 .75rem;font-size:.85rem;color:#475569}.wizard-ref-preview{margin:1rem 0 0}.wizard-ref-preview figcaption{margin-bottom:.35rem}.wizard-ref-preview-link{display:inline-block;max-width:100%;line-height:0;border-radius:8px;overflow:hidden;box-shadow:inset 0 0 0 1px #cbd5e1}.wizard-ref-preview-link:hover{box-shadow:inset 0 0 0 1px #2563eb}.wizard-ref-preview-link img{display:block;max-width:min(100%,40rem);max-height:min(50vh,28rem);width:auto;height:auto;object-fit:contain;vertical-align:top}.roi-stage--draw .roi-overlay{cursor:crosshair}.roi-overlay{position:absolute;left:0;top:0;width:100%;height:100%;cursor:default}.roi-box{position:absolute;box-sizing:border-box;border:2px solid rgb(59 130 246 / 95%);background:#3b82f61f;pointer-events:auto;cursor:grab;z-index:2}.roi-box:active{cursor:grabbing}.roi-box--selected{border-color:#d97706;background:#f59e0b2e;box-shadow:0 0 0 1px #d97706;z-index:3}.roi-box--align{border-color:#22c55ef2;background:#22c55e24}.roi-box--analog{border-color:#a855f7f2;background:#a855f724}.roi-box-label{position:absolute;left:2px;top:2px;font-size:.65rem;font-weight:700;color:#fff;background:#0f172abf;padding:.05rem .25rem;border-radius:3px;line-height:1.2;pointer-events:none}.roi-draft{position:absolute;border:2px dashed #2563eb;background:#2563eb33;pointer-events:none;z-index:1}.roi-handle-se{position:absolute;right:-5px;bottom:-5px;width:12px;height:12px;background:#d97706;border:1px solid #fff;border-radius:2px;cursor:nwse-resize;z-index:4}.roi-meta{margin-top:.5rem}.roi-hint{margin:.5rem 0 0}.ocr-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(11rem,1fr));gap:.75rem 1rem;margin-top:.5rem}.ocr-grid label{display:flex;flex-direction:column;gap:.25rem;font-size:.8rem;color:#475569}.ocr-grid label.check{flex-direction:row;align-items:center;gap:.4rem}.ocr-grid input[type=number],.ocr-grid input[type=text]{height:2rem;border:1px solid #cbd5e1;border-radius:6px;padding:0 .5rem;font-size:.85rem}.json-details{margin-top:1rem;border-top:1px solid #e2e8f0;padding-top:.75rem}.json-details summary{cursor:pointer;color:#475569;font-size:.9rem}.config-msg{margin-top:.75rem;color:#334155}.topic-cell{max-width:14rem;word-break:break-all;white-space:normal}.payload-cell{max-width:28rem;word-break:break-word;white-space:pre-wrap;font-size:.78rem}
