:root{color-scheme:light;--bg:#f6f7f9;--panel:#ffffff;--panel-soft:#f1f5f9;--line:#d8dee8;--text:#172033;--muted:#647085;--brand:#1167b1;--brand-dark:#0d4f87;--good:#0f8a5f;--warn:#b7791f;--bad:#b42318}*{box-sizing:border-box}body,html{margin:0;min-height:100%;background:var(--bg);color:var(--text);font-family:Arial,Helvetica,sans-serif}button,input{font:inherit}a{color:inherit}.shell{min-height:100vh}.topbar{border-bottom:1px solid var(--line);background:var(--panel)}.topbar-inner{justify-content:space-between;gap:24px;max-width:1180px;margin:0 auto;padding:16px 24px}.brand,.topbar-inner{display:flex;align-items:center}.brand{gap:12px;min-width:0}.brand-mark{display:grid;width:36px;height:36px;place-items:center;border-radius:6px;background:var(--brand);color:#fff;font-weight:700}.brand-title{margin:0;font-size:17px;line-height:1.2}.nav{display:flex;gap:10px;white-space:nowrap}.nav a,.secondary-link{border:1px solid var(--line);border-radius:6px;padding:9px 12px;background:#fff;color:var(--text);font-size:14px;text-decoration:none}.main{max-width:960px;margin:0 auto;padding:24px}.grid{display:grid;grid-template-columns:minmax(0,1fr);grid-gap:20px;gap:20px}.section{margin-bottom:20px}.panel{border:1px solid var(--line);border-radius:8px;background:var(--panel)}.panel-header{display:flex;align-items:center;justify-content:space-between;gap:12px;border-bottom:1px solid var(--line);padding:16px 18px}.panel-title{margin:0;font-size:16px}.panel-body{padding:18px}.muted{color:var(--muted)}.field-table{width:100%;border-collapse:collapse;font-size:14px}.field-table td,.field-table th{border-bottom:1px solid var(--line);padding:12px 10px;text-align:left;vertical-align:top}.field-table th{color:var(--muted);font-weight:600}.field-table tr:last-child td{border-bottom:0}.badge{display:inline-flex;align-items:center;min-height:24px;border:1px solid var(--line);border-radius:999px;padding:2px 9px;background:var(--panel-soft);color:var(--text);font-size:12px}.stack{display:grid;grid-gap:14px;gap:14px}.form-row{display:grid;grid-gap:6px;gap:6px}.label{font-size:13px;font-weight:600}.input{width:100%;min-height:42px;border:1px solid var(--line);border-radius:6px;padding:9px 11px;background:#fff;color:var(--text)}.file-input{padding:8px}.button{display:inline-flex;align-items:center;justify-content:center;min-height:42px;border:0;border-radius:6px;padding:10px 14px;background:var(--brand);color:#fff;cursor:pointer;font-weight:700}.button:disabled{cursor:not-allowed;opacity:.6}.icon-button,.secondary-button{border:1px solid var(--line);background:var(--panel);color:var(--text)}.icon-button{min-height:34px;border-radius:6px;padding:7px 10px;cursor:pointer}.text-button{font-size:13px;font-weight:700}.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap}.capture-toolbar{display:flex;align-items:center;flex-wrap:wrap;gap:10px}.camera-box{display:grid;grid-gap:12px;gap:12px;border:1px solid var(--line);border-radius:8px;padding:12px;background:var(--panel-soft)}.camera-preview{width:100%;max-height:420px;border-radius:6px;background:#111827;object-fit:contain}.image-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));grid-gap:12px;gap:12px}.image-card{display:grid;grid-gap:10px;gap:10px;border:1px solid var(--line);border-radius:8px;padding:10px;background:var(--panel)}.image-preview-button{display:block;width:100%;padding:0;border:0;border-radius:6px;background:transparent;cursor:zoom-in}.image-preview-button img{width:100%;aspect-ratio:4/3;border-radius:6px;background:var(--panel-soft);object-fit:contain}.image-viewer{position:relative;max-width:min(96vw,1180px);max-height:92vh}.image-viewer img{display:block;max-width:100%;max-height:92vh;border-radius:8px;background:#111827;object-fit:contain}.image-viewer-close{position:absolute;top:10px;right:10px;width:36px;height:36px;border:1px solid rgba(255,255,255,.42);border-radius:999px;background:rgba(15,23,42,.74);color:#ffffff;cursor:pointer}.image-viewer-close:before{content:"X";font-size:16px;font-weight:800;line-height:1}.image-meta{display:grid;grid-gap:4px;gap:4px;color:var(--muted);font-size:12px;overflow-wrap:anywhere}.image-actions{display:flex;gap:8px}.modal-backdrop{position:fixed;inset:0;z-index:20;display:grid;place-items:center;padding:20px;background:rgba(15,23,42,.58)}.crop-modal{width:min(920px,100%);max-height:calc(100vh - 40px);overflow:auto;border:1px solid var(--line);border-radius:8px;background:var(--panel);box-shadow:0 24px 80px rgba(15,23,42,.24)}.crop-body{display:grid;grid-gap:16px;gap:16px;padding:16px}.crop-stage{position:relative;width:100%;aspect-ratio:4/3;max-height:62vh;overflow:hidden;border-radius:8px;background:#111827;touch-action:none}.crop-resize-frame{position:absolute;top:50%;left:50%;z-index:2;border:2px solid #ffffff;box-shadow:0 0 0 1px rgba(15,23,42,.25);pointer-events:none;transform:translate(-50%,-50%)}.crop-resize-handle{position:absolute;border:0;border-radius:999px;background:#ffffff;box-shadow:0 1px 6px rgba(15,23,42,.35);pointer-events:auto;touch-action:none}.crop-resize-handle-bottom,.crop-resize-handle-top{left:50%;width:72px;height:14px;cursor:ns-resize;transform:translateX(-50%)}.crop-resize-handle-top{top:-8px}.crop-resize-handle-bottom{bottom:-8px}.crop-resize-handle-left,.crop-resize-handle-right{top:50%;width:14px;height:72px;cursor:ew-resize;transform:translateY(-50%)}.crop-resize-handle-left{left:-8px}.crop-resize-handle-right{right:-8px}.crop-slider{display:grid;grid-gap:6px;gap:6px;color:var(--muted);font-size:13px;font-weight:700}.job-card{display:grid;grid-gap:14px;gap:14px;border:1px solid var(--line);border-radius:8px;padding:16px;background:var(--panel)}.job-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.job-file-name{color:var(--text);font-size:15px;font-weight:700;overflow-wrap:anywhere}.job-id{margin-top:4px;color:var(--muted);font-size:12px;overflow-wrap:anywhere}.job-status{display:inline-flex;align-items:center;min-height:28px;border:1px solid var(--line);border-radius:999px;padding:4px 10px;background:var(--panel-soft);color:var(--text);font-size:12px;font-weight:800;white-space:nowrap}.job-status-completed{border-color:#b7e4d3;background:#ecfdf5;color:var(--good)}.job-status-failed{border-color:#f1a29a;background:#fff1f0;color:var(--bad)}.job-status-processing,.job-status-queued{border-color:#bfdbfe;background:#eff6ff;color:var(--brand-dark)}.job-meta-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));grid-gap:10px;gap:10px}.job-meta-grid>div{display:grid;grid-gap:4px;gap:4px;border:1px solid var(--line);border-radius:8px;padding:10px;background:var(--panel-soft);min-width:0}.job-meta-grid span{color:var(--muted);font-size:11px;font-weight:700;text-transform:uppercase}.job-meta-grid strong{color:var(--text);font-size:13px;font-weight:700;overflow-wrap:anywhere}.job-error{display:grid;grid-gap:4px;gap:4px;border:1px solid #f1a29a;border-radius:8px;padding:12px;background:#fff1f0;color:var(--bad)}.job-error strong{font-size:13px}.job-error span{font-size:14px;overflow-wrap:anywhere}.result-table-wrap{overflow:hidden;border:1px solid var(--line);border-radius:8px}.result-table{width:100%;border-collapse:collapse;background:#fff;font-size:14px}.result-table td,.result-table th{border-bottom:1px solid var(--line);padding:12px;text-align:left;vertical-align:top}.result-table tr:last-child td,.result-table tr:last-child th{border-bottom:0}.result-table th{width:220px;background:var(--panel-soft);color:var(--muted);font-weight:700}.result-table td{color:var(--text);overflow-wrap:anywhere}.empty-result{border:1px dashed var(--line);border-radius:8px;padding:14px;color:var(--muted);text-align:center}.crop-slider input{width:100%}.crop-actions{display:flex;justify-content:flex-end;gap:10px}.status{display:flex;align-items:center;justify-content:space-between;gap:12px;border:1px solid var(--line);border-radius:8px;padding:12px;background:var(--panel-soft)}.ocr-results{padding-top:14px}.status strong{font-size:14px}.status-value{color:var(--brand-dark);font-weight:700}.error{border:1px solid #f1a29a;border-radius:8px;padding:12px;background:#fff1f0;color:var(--bad);font-size:14px}.result{max-height:420px;overflow:auto;border:1px solid var(--line);border-radius:8px;padding:14px;background:#0f172a;color:#dbeafe;font-size:13px;line-height:1.55}@media (max-width:920px){.topbar-inner{align-items:flex-start;flex-direction:column}.nav{flex-wrap:wrap}.grid{grid-template-columns:1fr}.crop-actions{justify-content:stretch}.crop-actions .button{flex:1 1}.job-card-header{flex-direction:column}.job-meta-grid{grid-template-columns:1fr}.result-table th{width:140px}}