@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&family=JetBrains+Mono:wght@400;500;600&display=swap";:root{--bg:#f8fafc;--surface:#fff;--surface-2:#f1f5f9;--surface-3:#e2e8f0;--border:#e2e8f0;--border-strong:#cbd5e1;--text:#0f172a;--text-muted:#64748b;--accent:#4f46e5;--accent-hover:#4338ca;--accent-soft:#e0e7ff;--accent-soft-2:#f5f7ff;--green:#10b981;--green-soft:#d1fae5;--yellow:#f59e0b;--yellow-soft:#fef3c7;--red:#ef4444;--red-soft:#fee2e2;--radius:12px;--radius-sm:8px;--radius-md:10px;--radius-lg:16px;--shadow-sm:0 1px 2px 0 #0000000d;--shadow:0 4px 6px -1px #0000000d, 0 2px 4px -2px #0000000d;--shadow-md:0 10px 15px -3px #0000000f, 0 4px 6px -4px #0000000f;--shadow-lg:0 20px 25px -5px #00000014, 0 8px 10px -6px #00000014;--shadow-premium:0 12px 30px -10px #4f46e526;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:24px;--space-6:32px;color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}*{box-sizing:border-box}html,body,#root{background-color:var(--bg);height:100%;margin:0}button{cursor:pointer;font-family:inherit}button:disabled{cursor:not-allowed;opacity:.5}.app{flex-direction:column;height:100vh;display:flex;overflow:hidden}.header{padding:0 var(--space-5);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);z-index:10;background:#fffc;flex-shrink:0;justify-content:space-between;align-items:center;height:64px;display:flex}.header h1{letter-spacing:-.02em;color:var(--text);margin:0;font-size:16px;font-weight:700}.header .brand{align-items:center;gap:var(--space-3);display:flex}.header .logo{border-radius:var(--radius-sm);object-fit:cover;width:32.5px;height:32.5px;box-shadow:var(--shadow-sm);border:1px solid var(--border)}.header .meta{color:var(--text-muted);background:var(--surface-2);border-radius:var(--radius-sm);border:1px solid var(--border);text-overflow:ellipsis;white-space:nowrap;max-width:220px;padding:6px 12px;font-size:13px;font-weight:500;overflow:hidden}.engine-picker{align-items:center;gap:var(--space-2);display:inline-flex}.engine-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;font-size:10px;font-weight:700}.engine-select{color:var(--text);background:var(--surface);border:1px solid var(--border-strong);border-radius:var(--radius-sm);cursor:pointer;appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'><path d='M1 1l4 4 4-4' stroke='%2364748b' stroke-width='1.8' fill='none' stroke-linecap='round' stroke-linejoin='round'/></svg>");background-position:right 12px center;background-repeat:no-repeat;padding:6px 32px 6px 12px;font-family:inherit;font-size:13px;font-weight:600;transition:all .15s}.engine-select:hover{border-color:var(--text-muted);background-color:var(--bg)}.engine-select:focus{border-color:var(--accent);outline:none;box-shadow:0 0 0 3px #4f46e526}.workspace{flex:1;min-height:0;display:flex}.panel-left{border-right:1px solid var(--border);background:#f1f5f9;flex-direction:column;flex:1.4;min-width:0;display:flex;position:relative}.panel-right{background:var(--surface);z-index:5;flex-direction:column;flex:1;min-width:380px;max-width:480px;display:flex;box-shadow:-4px 0 16px #00000005}.btn{border:1px solid var(--border-strong);background:var(--surface);color:var(--text);border-radius:var(--radius-sm);justify-content:center;align-items:center;gap:8px;padding:8px 16px;font-size:13px;font-weight:600;transition:all .15s cubic-bezier(.4,0,.2,1);display:inline-flex}.btn:hover:not(:disabled){background:var(--surface-2);border-color:var(--text-muted)}.btn-primary{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 2px 4px #4f46e51a}.btn-primary:hover:not(:disabled){background:var(--accent-hover);border-color:var(--accent-hover);box-shadow:0 4px 8px #4f46e533}.btn-ghost{color:var(--text-muted);background:0 0;border-color:#0000}.btn-ghost:hover:not(:disabled){background:var(--surface-2);color:var(--text)}.btn-danger{background:var(--red);border-color:var(--red);color:#fff}.btn-danger:hover:not(:disabled){background:#dc2626;border-color:#dc2626}.btn-sm{padding:6px 12px;font-size:12px}.btn-icon-only{border-radius:var(--radius-sm);justify-content:center;align-items:center;width:32px;height:32px;padding:0;display:inline-flex}.upload-wrap{padding:var(--space-6);background:var(--bg);flex:1;place-items:center;display:grid}.dropzone{background:var(--surface);border:2px dashed var(--border-strong);border-radius:var(--radius-lg);width:min(520px,100%);padding:56px var(--space-6);text-align:center;box-shadow:var(--shadow);flex-direction:column;align-items:center;transition:all .2s cubic-bezier(.4,0,.2,1);display:flex}.dropzone:hover{border-color:var(--accent);box-shadow:var(--shadow-md)}.dropzone.drag{border-color:var(--accent);background:var(--accent-soft-2);transform:scale(1.02)}.dropzone-icon-wrap{background:var(--accent-soft-2);width:64px;height:64px;color:var(--accent);margin-bottom:var(--space-4);border-radius:50%;place-items:center;transition:transform .2s;display:grid}.dropzone:hover .dropzone-icon-wrap{transform:translateY(-4px)}.dropzone h2{margin:0 0 var(--space-2);letter-spacing:-.02em;font-size:20px;font-weight:700}.dropzone p{color:var(--text-muted);margin:0 0 var(--space-5);max-width:320px;font-size:14px;line-height:1.5}.dropzone .hint{margin-top:var(--space-4);color:var(--text-muted);font-size:12px;font-weight:500}.progress-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);width:min(400px,95%);padding:var(--space-5);box-shadow:var(--shadow-md);text-align:center}.progress-card .fname{margin-bottom:var(--space-2);color:var(--text);text-overflow:ellipsis;white-space:nowrap;font-size:14px;font-weight:600;overflow:hidden}.progress-card .stage{color:var(--text-muted);margin-bottom:var(--space-4);justify-content:center;align-items:center;gap:8px;font-size:13px;font-weight:500;display:flex}.bar{background:var(--surface-2);border-radius:99px;height:6px;overflow:hidden}.bar>i{background:var(--accent);border-radius:99px;height:100%;transition:width .3s;display:block}.spinner{border:2px solid var(--border-strong);border-top-color:var(--accent);border-radius:50%;width:16px;height:16px;animation:.6s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.preview{background:#f1f5f9;flex-direction:column;flex:1;min-height:0;display:flex}.preview-bar{justify-content:space-between;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-5);background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0;height:56px;display:flex}.preview-name{color:var(--text);text-overflow:ellipsis;white-space:nowrap;max-width:45%;font-size:13px;font-weight:600;overflow:hidden}.preview-actions{align-items:center;gap:var(--space-2);display:flex}.preview-stage{padding:var(--space-5);flex:1;place-items:center;display:grid;position:relative;overflow:auto}.preview-img-wrap{max-width:100%;box-shadow:var(--shadow-lg);border-radius:var(--radius-sm);background:#fff;display:inline-block;position:relative;overflow:hidden}.preview-stage img{max-width:100%;max-height:70vh;transition:transform .2s;display:block}.preview-overlay{color:var(--text);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#ffffffd9;flex-direction:column;justify-content:center;align-items:center;gap:12px;font-size:14px;font-weight:600;display:flex;position:absolute;inset:0}.preview-hint{text-align:center;color:var(--text-muted);padding:var(--space-3) var(--space-5);background:var(--surface);border-top:1px solid var(--border);font-size:12.5px;font-weight:500}.panel-placeholder{text-align:center;padding:var(--space-6);justify-content:center;align-items:center;gap:var(--space-3);background:var(--surface);flex-direction:column;flex:1;display:flex}.panel-placeholder-icon{color:var(--text-muted);opacity:.4;margin-bottom:var(--space-2)}.panel-placeholder p{color:var(--text);margin:0;font-size:15px;font-weight:600}.panel-placeholder .sub{color:var(--text-muted);max-width:290px;font-size:13px;font-weight:400;line-height:1.5}.viewer-toolbar{align-items:center;gap:var(--space-2);padding:0 var(--space-4);border-bottom:1px solid var(--border);background:var(--surface);z-index:10;flex-shrink:0;height:56px;display:flex}.viewer-toolbar .spacer{flex:1}.viewer-toolbar .tool-sep{background:var(--border);width:1px;height:20px;margin:0 var(--space-1)}.viewer-toolbar .pageinfo{color:var(--text-muted);text-align:center;min-width:96px;font-size:13px;font-weight:600}.mode-toggle-group{background:var(--surface-2);border:1px solid var(--border-strong);border-radius:var(--radius-lg);gap:2px;padding:3px;display:inline-flex}.mode-toggle-btn{align-items:center;gap:var(--space-2);border-radius:var(--radius-lg);color:var(--text-muted);background:0 0;border:none;padding:6px 14px;font-size:12.5px;font-weight:600;transition:all .2s cubic-bezier(.4,0,.2,1);display:flex}.mode-toggle-btn:hover{color:var(--text)}.mode-toggle-btn.active{background:var(--surface);color:var(--accent);box-shadow:var(--shadow-sm)}.zoom-group{border:1px solid var(--border-strong);border-radius:var(--radius-sm);background:var(--surface);display:inline-flex;overflow:hidden}.zoom-group .btn-zoom{width:32px;height:32px;color:var(--text-muted);background:0 0;border:none;justify-content:center;align-items:center;transition:all .1s;display:flex}.zoom-group .btn-zoom:hover{background:var(--surface-2);color:var(--text)}.zoom-group .btn-zoom+.btn-zoom{border-left:1px solid var(--border)}.viewer-canvas{background:#e2e8f0;position:relative;overflow:hidden;flex:1!important;width:100%!important;height:100%!important}.viewer-content{justify-content:center;align-items:center;width:100%;height:100%;display:flex}.page-stage{box-shadow:var(--shadow-lg);background:#fff;border-radius:4px;transition:box-shadow .2s;position:relative;overflow:visible}.page-stage.panning{cursor:grab}.page-stage.panning:active{cursor:grabbing}.page-stage.panning img{pointer-events:none}.page-stage.snipping{cursor:crosshair}.page-stage img{object-fit:fill;-webkit-user-select:none;user-select:none;-webkit-user-drag:none;width:100%;height:100%;display:block}.bbox-svg{z-index:15;width:100%;height:100%;position:absolute;inset:0}.bbox{fill:#4f46e508;stroke:#4f46e5bf;stroke-width:2.2px;cursor:pointer;transition:all .15s}.bbox:hover{fill:#4f46e51f;stroke:#4f46e5f2}.bbox.low{stroke:#f59e0b;stroke-width:2.2px;fill:#f59e0b0f}.bbox.low:hover{fill:#f59e0b26;stroke:#d97706}.bbox.sel{fill:#4f46e526;stroke:var(--accent);stroke-width:3px;filter:drop-shadow(0 0 4px #4f46e559)}.bbox.snip{fill:#4f46e514;stroke:var(--accent);stroke-width:2px;stroke-dasharray:5 3}.bbox.snip.drawing{fill:#4f46e50a;stroke:var(--accent);stroke-width:1.5px;stroke-dasharray:4 4}.snip-card{z-index:40;background:var(--surface);border:1px solid var(--accent);border-radius:var(--radius);min-width:220px;max-width:300px;box-shadow:var(--shadow-lg), 0 0 0 1px #4f46e51a;padding:var(--space-3);pointer-events:auto;animation:.2s cubic-bezier(.175,.885,.32,1.275) card-pop;position:absolute;transform:translate(-50%,calc(-100% - 12px))}@keyframes card-pop{0%{opacity:0;transform:translate(-50%,calc(-100% - 4px))scale(.95)}to{opacity:1;transform:translate(-50%,calc(-100% - 12px))scale(1)}}.snip-row{color:var(--text-muted);align-items:center;gap:8px;font-size:13px;display:flex}.snip-head{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:8px;margin-bottom:8px;padding-bottom:6px;display:flex}.snip-label{color:var(--accent);text-transform:uppercase;letter-spacing:.05em;font-size:10px;font-weight:700}.snip-label.err{color:var(--red)}.snip-x{cursor:pointer;color:var(--text-muted);background:0 0;border:none;border-radius:50%;align-items:center;padding:2px;transition:all .1s;display:flex}.snip-x:hover{background:var(--surface-2);color:var(--text)}.snip-value{margin:var(--space-2) 0;word-break:break-word;color:var(--text);font-size:14px;font-weight:600;line-height:1.4}.snip-actions{gap:8px;margin-top:8px;display:flex}.panel-head{padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--border);background:var(--surface);flex-shrink:0;justify-content:space-between;align-items:center;height:56px;display:flex}.seg{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:2px;display:inline-flex}.seg-btn{color:var(--text-muted);background:0 0;border:none;border-radius:6px;padding:6px 14px;font-size:12.5px;font-weight:600;transition:all .15s}.seg-btn:hover:not(.on){color:var(--text);background:#00000005}.seg-btn.on{background:var(--surface);color:var(--text);box-shadow:var(--shadow-sm)}.panel-head .count{color:var(--text-muted);font-size:12.5px;font-weight:600}.json-wrap{background:#0f172a;flex:1;position:relative;overflow:auto}.json-copy{z-index:10;color:#f8fafc;background:#ffffff1a;border:1px solid #ffffff26;position:absolute;top:16px;right:16px}.json-copy:hover:not(:disabled){background:#ffffff2e;border-color:#ffffff4d}.json-view{color:#38bdf8;white-space:pre-wrap;word-break:break-word;margin:0;padding:24px;font-family:JetBrains Mono,ui-monospace,monospace;font-size:12.5px;line-height:1.6}.field-list{padding:var(--space-4) var(--space-4) var(--space-6);background:var(--bg);gap:var(--space-3);flex-direction:column;flex:1;display:flex;overflow-y:auto}.field{border:1px solid var(--border);border-radius:var(--radius);padding:var(--space-4);background:var(--surface);box-shadow:var(--shadow-sm);transition:all .2s cubic-bezier(.4,0,.2,1)}.field:hover{border-color:var(--border-strong);box-shadow:var(--shadow);transform:translateY(-1px)}.field.sel{border-color:var(--accent);box-shadow:var(--shadow-premium), 0 0 0 1px var(--accent)}.field.hovered{box-shadow:var(--shadow-md), 0 0 0 1px #818cf8;background-color:#f0f2ff;border-color:#818cf8;transform:translateY(-2px)}.field.invalid.warn{border-color:var(--yellow)}.field.invalid.error{border-color:var(--red)}.field-issues{margin:var(--space-2) 0 0;padding:var(--space-2) var(--space-3);border-radius:var(--radius-sm);flex-direction:column;gap:2px;font-size:11px;line-height:1.4;list-style:none;display:flex}.field-issues.warn{background:var(--yellow-soft);color:#92400e}.field-issues.error{background:var(--red-soft);color:#991b1b}.count-warn{color:var(--red);font-weight:700}.field-top{margin-bottom:var(--space-2);justify-content:space-between;align-items:center;display:flex}.field-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;font-size:11px;font-weight:700}.field input,.field textarea{border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text);background:var(--surface-2);padding:10px 12px;font-family:inherit;font-size:14px;font-weight:500;transition:border-color .15s,background .15s,box-shadow .15s}.field textarea{resize:none;white-space:pre-wrap;word-break:break-word;line-height:1.45;display:block;overflow:hidden}.field input:focus,.field textarea:focus{border-color:var(--accent);background:#fff;outline:none;box-shadow:0 0 0 3px #4f46e51a}.badge{white-space:nowrap;border-radius:99px;align-items:center;gap:4px;padding:3px 10px;font-size:11px;font-weight:700;display:inline-flex}.badge.green{background:var(--green-soft);color:#065f46}.badge.yellow{background:var(--yellow-soft);color:#92400e}.badge.red{background:var(--red-soft);color:#991b1b}.badge.status{background:var(--surface-3);color:var(--text-muted);text-transform:capitalize}.badge.status.edited{background:var(--accent-soft);color:var(--accent)}.badge.status.validated{background:var(--green-soft);color:#065f46}.field-actions{align-items:center;gap:var(--space-2);margin-top:var(--space-3);display:flex}.field-meta{align-items:center;gap:6px;display:flex}.proposal{margin-top:var(--space-4);border:1px solid var(--accent);background:var(--accent-soft-2);border-radius:var(--radius-md);padding:var(--space-4);animation:.2s ease-out slide-down;box-shadow:inset 0 2px 4px #4f46e508}@keyframes slide-down{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.proposal .plabel{color:var(--accent);text-transform:uppercase;letter-spacing:.05em;align-items:center;gap:4px;font-size:10px;font-weight:700;display:flex}.proposal .pv{margin:var(--space-2) 0 var(--space-3);color:var(--text);background:var(--surface);border-radius:var(--radius-sm);border:1px dashed var(--accent);padding:8px 12px;font-size:14.5px;font-weight:600}.error-banner{margin:var(--space-4);padding:var(--space-3) var(--space-4);background:var(--red-soft);color:#991b1b;border-radius:var(--radius-sm);border:1px solid #fee2e2;font-size:13px;font-weight:500}.empty{color:var(--text-muted);flex:1;justify-content:center;align-items:center;font-size:13.5px;font-weight:500;display:flex}.kn{font-family:inherit}.toast{align-items:center;gap:var(--space-3);color:#fff;border-radius:var(--radius);box-shadow:var(--shadow-lg), 0 0 0 1px #ffffff1a;z-index:100;background:#0f172a;max-width:500px;padding:12px 20px;font-size:13px;font-weight:600;animation:.2s cubic-bezier(.175,.885,.32,1.275) toast-in;display:flex;position:fixed;bottom:32px;left:50%;transform:translate(-50%)}.toast-x{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:50%;align-items:center;padding:2px;font-size:18px;line-height:1;transition:all .1s;display:flex}.toast-x:hover{color:#fff;background:#ffffff1a}@keyframes toast-in{0%{opacity:0;transform:translate(-50%,12px)}to{opacity:1;transform:translate(-50%)}}.bbox-tooltip{pointer-events:none}.tooltip-bg{fill:#4f46e5;stroke:#fff;stroke-width:1px;filter:drop-shadow(0 2px 4px #00000026)}.tooltip-bg.low{fill:#f59e0b}.tooltip-text{fill:#fff;dominant-baseline:central;font-family:inherit;font-size:10px;font-weight:700}.review-tracker{padding:12px var(--space-4);background:var(--surface);border-bottom:1px solid var(--border);flex-direction:column;gap:8px;display:flex}.review-tracker.success{background:var(--green-soft);border-bottom:1px solid var(--green);color:#065f46;padding:10px var(--space-4);flex-direction:row;align-items:center;gap:8px}.tracker-success-icon{color:var(--green);flex-shrink:0}.tracker-success-text{font-size:12px;font-weight:600}.tracker-label-row{justify-content:space-between;align-items:center;display:flex}.tracker-title{color:var(--text);font-size:12px;font-weight:600}.tracker-value{color:var(--accent);font-size:11px;font-weight:700}.tracker-bar-bg{background:var(--surface-2);border-radius:99px;height:6px;position:relative;overflow:hidden}.tracker-bar-fill{background:linear-gradient(90deg, var(--accent) 0%, #818cf8 100%);border-radius:99px;height:100%;transition:width .3s cubic-bezier(.4,0,.2,1)}.crop-preview-container{border-top:1px solid var(--border);margin-top:10px;padding-top:10px}.crop-preview-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px;font-size:10px;font-weight:700}.crop-preview-wrapper{border:1px solid var(--border-strong);background:var(--surface-2);border-radius:6px;width:100%;max-height:120px;position:relative;overflow:hidden}.crop-preview-wrapper img{pointer-events:none}.theme-toggle{color:var(--text-muted);border-radius:var(--radius-sm);background:0 0;border:none;justify-content:center;align-items:center;padding:6px;transition:all .15s;display:flex}.theme-toggle:hover{color:var(--text);background:var(--surface-2)}html.dark{--bg:#090d16;--surface:#131a26;--surface-2:#1e293b;--surface-3:#334155;--border:#1e293b;--border-strong:#334155;--text:#f8fafc;--text-muted:#94a3b8;--accent:#6366f1;--accent-hover:#4f46e5;--accent-soft:#6366f126;--accent-soft-2:#6366f114;--green:#10b981;--green-soft:#10b98126;--yellow:#f59e0b;--yellow-soft:#f59e0b26;--red:#ef4444;--red-soft:#ef444426}html.dark .panel-left{background:#0b111e}html.dark .viewer-canvas{background:#070b12}html.dark .page-stage{background:#131a26;box-shadow:0 10px 25px -5px #00000080}html.dark .header{background:#131a26cc}html.dark .preview{background:#0b111e}html.dark .preview-img-wrap{background:#131a26;box-shadow:0 10px 25px -5px #00000080}html.dark .preview-overlay{background:#131a26d9}html.dark .field.hovered{background-color:#6366f114}html.dark .field input:focus,html.dark .field textarea:focus{background:#131a26}html.dark .badge.green{color:#34d399}html.dark .badge.yellow{color:#fbbf24}html.dark .badge.red{color:#f87171}html.dark .field-issues.warn{color:#fbbf24}html.dark .field-issues.error{color:#f87171}html.dark .badge.status.validated{color:#34d399}
