:root{--bg:#0e1015;--bg-elev:#161922;--bg-elev-2:#1d2230;--border:#262c3a;--text:#e6e8ee;--text-muted:#8d94a8;--accent:#6c8cff;--accent-hover:#8aa3ff;--success:#4ade80;--warning:#facc15;--error:#f87171;--radius:10px;--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;font-family:-apple-system,BlinkMacSystemFont,Inter,Segoe UI,Roboto,sans-serif}*{box-sizing:border-box}html,body,#root{height:100%}body{background:var(--bg);color:var(--text);margin:0;font-size:14px;line-height:1.5}.app{flex-direction:column;min-height:100vh;display:flex}.header{z-index:10;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);background:#0e1015d9;justify-content:space-between;align-items:center;padding:14px 24px;display:flex;position:sticky;top:0}.brand{letter-spacing:.2px;align-items:center;gap:10px;font-weight:600;display:flex}.brand-mark{color:var(--accent);font-size:20px;line-height:1}.brand-text{font-size:15px}.brand-sub{color:var(--text-muted);letter-spacing:.04em;margin-left:4px;font-size:11px;font-weight:400}@media (width<=760px){.brand-sub{display:none}}.header-controls{align-items:center;gap:12px;display:flex}.provider-select{background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius);align-items:center;gap:8px;padding:6px 10px;display:flex}.provider-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;font-size:12px}.provider-select select{color:var(--text);cursor:pointer;background:0 0;border:none;outline:none;min-width:220px;font-family:inherit;font-size:13px}.provider-select select:disabled{color:var(--text-muted);cursor:not-allowed}.main{flex-direction:column;flex:1;gap:16px;width:100%;max-width:1100px;margin:0 auto;padding:24px;display:flex}.toolbar{background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius);flex-wrap:wrap;align-items:center;gap:10px;padding:12px;display:flex}.toolbar-spacer{flex:1}button{background:var(--bg-elev-2);color:var(--text);border:1px solid var(--border);cursor:pointer;border-radius:8px;padding:8px 14px;font-family:inherit;font-size:13px;transition:background .12s,border-color .12s,transform 80ms}button:hover:not(:disabled){background:#242a3a;border-color:#313a4f}button:active:not(:disabled){transform:translateY(1px)}button:disabled{opacity:.45;cursor:not-allowed}button.primary{background:var(--accent);color:#0b0f1a;border-color:#0000;font-weight:600}button.primary:hover:not(:disabled){background:var(--accent-hover)}.counts{flex-wrap:wrap;gap:6px;display:flex}.count{background:var(--bg-elev-2);border:1px solid var(--border);color:var(--text-muted);border-radius:999px;padding:4px 8px;font-size:12px}.count.pending{color:var(--accent);border-color:#6c8cff66}.count.success{color:var(--success);border-color:#4ade8059}.count.error{color:var(--error);border-color:#f8717166}.banner{border-radius:var(--radius);border:1px solid var(--border);background:var(--bg-elev);padding:10px 14px;font-size:13px}.banner.warning{background:#facc1512;border-color:#facc1559}.empty{text-align:center;color:var(--text-muted);border:1px dashed var(--border);border-radius:var(--radius);padding:56px 24px}.empty p{margin:4px 0}.muted{color:var(--text-muted)}.results{flex-direction:column;gap:12px;margin:0;padding:0;list-style:none;display:flex}.row{background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius);grid-template-columns:132px 240px 1fr;gap:16px;padding:14px;transition:border-color .15s;display:grid}.row-processing{border-color:#6c8cff66}.row-queued{opacity:.7}.row-passed{border-color:#4ade8066}.row-failed{border-color:#facc1580}.row-error{border-color:#f8717173}.row-approved{background:#4ade800a;border-color:#4ade8066}.status-approved{color:var(--success)}.thumb{background:#0a0c12;border-radius:8px;justify-content:center;align-items:center;width:132px;height:132px;display:flex;overflow:hidden}.thumb img{object-fit:contain;max-width:100%;max-height:100%}.meta{flex-direction:column;gap:6px;min-width:0;display:flex}.filename{white-space:nowrap;text-overflow:ellipsis;font-weight:600;overflow:hidden}.sub{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.badge{background:var(--bg-elev-2);border:1px solid var(--border);color:var(--text-muted);border-radius:999px;padding:2px 8px;font-size:11px;display:inline-block}.status{font-variant-numeric:tabular-nums;align-items:center;gap:8px;margin-top:4px;font-size:13px;display:flex}.status-pending,.status-processing,.status-queued{color:var(--accent)}.status-success,.status-passed{color:var(--success)}.status-failed{color:var(--warning)}.status-error{color:var(--error)}.spinner{border:2px solid #6c8cff40;border-top-color:var(--accent);border-radius:50%;width:12px;height:12px;animation:.8s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.progress{background:linear-gradient(90deg, transparent 0%, var(--accent) 50%, transparent 100%);background-size:200% 100%;border-radius:2px;height:3px;margin-top:6px;animation:1.4s linear infinite shimmer}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.text{min-width:0}.text-output{border:1px solid var(--border);white-space:pre-wrap;word-break:break-word;background:#0a0c12;border-radius:8px;max-height:280px;margin:0;padding:10px 12px;font-family:SF Mono,ui-monospace,Cascadia Code,Consolas,monospace;font-size:12.5px;line-height:1.5;overflow:auto}.error-output{color:var(--error);background:#f8717114;border:1px solid #f871714d;border-radius:8px;padding:10px 12px;font-family:SF Mono,ui-monospace,monospace;font-size:12.5px}@media (width<=760px){.row{grid-template-columns:96px 1fr}.row .text{grid-column:1/-1}.thumb{width:96px;height:96px}}.phase-indicator{background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius);align-items:center;gap:6px;padding:4px;display:flex}.phase-step{color:var(--text-muted);white-space:nowrap;border-radius:6px;padding:4px 10px;font-size:12px}.phase-step.active{background:var(--accent);color:#0b0f1a;font-weight:600}.phase-step.done{color:var(--success)}.banner.error{background:#f8717112;border-color:#f8717166}.banner ul{margin:6px 0 0;padding-left:18px}.banner code{background:#ffffff0d;border-radius:4px;padding:1px 5px;font-size:12px}button.link,.count.link{cursor:pointer;background:0 0;border:1px solid}.source-list{padding:0 2px;font-size:12px}.rows-list{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:10px;margin:0;padding:0;list-style:none;display:grid}.row-card{background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius);grid-template-columns:64px 1fr auto;align-items:center;gap:10px;padding:10px;display:grid}.row-card.paired{border-color:#4ade804d}.row-card.unpaired{border-color:#facc1559}.row-card.conflict,.row-card.class-unrecognized{border-color:#f8717180}.row-thumb{background:#0a0c12;border-radius:6px;justify-content:center;align-items:center;width:64px;height:64px;display:flex;overflow:hidden}.row-thumb img{object-fit:contain;max-width:100%;max-height:100%}.thumb-empty{width:100%;height:100%;color:var(--text-muted);justify-content:center;align-items:center;font-size:24px;display:flex}.row-info{flex-direction:column;gap:2px;min-width:0;display:flex}.row-brand{white-space:nowrap;text-overflow:ellipsis;font-weight:600;overflow:hidden}.row-meta{white-space:nowrap;text-overflow:ellipsis;font-size:12px;overflow:hidden}.row-status{font-size:12px}.row-remove{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:4px 8px;font-size:16px}.row-remove:hover{color:var(--error);background:#f8717114}.modal-backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;background:#0009;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.modal{background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;width:100%;max-width:900px;max-height:calc(100vh - 48px);display:flex;overflow:hidden}.modal-header,.modal-footer{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:14px 18px;display:flex}.modal-footer{border-bottom:none;border-top:1px solid var(--border)}.modal-header h2{margin:0;font-size:16px}.modal-header button{color:var(--text-muted);cursor:pointer;background:0 0;border:none;font-size:18px}.modal-body{flex-direction:column;gap:18px;padding:18px;display:flex;overflow-y:auto}.conflict-group{border:1px solid var(--border);background:var(--bg);border-radius:8px;padding:12px}.conflict-group h3{margin:0 0 10px;font-size:14px;font-weight:500}.conflict-group h3 code{background:#ffffff0d;border-radius:4px;padding:1px 6px;font-size:13px}.conflict-images{flex-wrap:wrap;gap:10px;margin-bottom:12px;display:flex}.conflict-image{flex-direction:column;align-items:center;gap:4px;margin:0;display:flex}.conflict-image img{object-fit:contain;border:1px solid var(--border);background:#0a0c12;border-radius:6px;width:120px;height:120px}.conflict-image figcaption{font-size:11px}.conflict-table{border-collapse:collapse;width:100%;font-size:13px}.conflict-table th,.conflict-table td{text-align:left;border-bottom:1px solid var(--border);padding:6px 8px}.conflict-table th{color:var(--text-muted);text-transform:uppercase;font-size:11px;font-weight:500}.conflict-table select{background:var(--bg-elev-2);color:var(--text);border:1px solid var(--border);border-radius:6px;padding:4px 8px;font-family:inherit;font-size:13px}.class-warning{flex-wrap:wrap;align-items:center;gap:8px;margin-top:6px;font-size:12.5px;display:flex}.approval-draft{border:1px solid var(--border);background:var(--bg);border-radius:8px;margin-top:8px;padding:10px}.approval-draft textarea{background:var(--bg-elev-2);width:100%;color:var(--text);border:1px solid var(--border);resize:vertical;box-sizing:border-box;border-radius:6px;margin-top:4px;padding:6px 8px;font-family:inherit;font-size:13px}.approval-label{text-transform:uppercase;letter-spacing:.06em;font-size:11px}.approval-actions{gap:8px;margin-top:8px;display:flex}.approval-actions button{padding:4px 12px;font-size:12px}.approval-applied{margin-top:6px;font-size:12.5px}.reasons{color:var(--warning);margin:6px 0 0;padding-left:18px;font-size:12.5px}.row-actions{gap:8px;margin-top:8px;display:flex}.row-actions button{padding:4px 10px;font-size:12px}.clickable-image{cursor:zoom-in;transition:opacity .12s}.clickable-image:hover{opacity:.85}.spotlight{z-index:200;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);cursor:zoom-out;background:#000000d9;flex-direction:column;justify-content:center;align-items:center;padding:32px;display:flex;position:fixed;inset:0}.spotlight img{object-fit:contain;border-radius:6px;max-width:min(95vw,1400px);max-height:88vh;box-shadow:0 10px 40px #00000080}.spotlight-caption{color:var(--text);text-align:center;margin-top:14px;font-size:13px;font-weight:500}.spotlight-close{color:var(--text);cursor:pointer;background:#00000080;border:1px solid #fff3;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;font-size:16px;display:flex;position:absolute;top:18px;right:22px}.spotlight-close:hover{background:#000000b3}.passed-collapsible{background:var(--bg-elev);border-radius:var(--radius);border:1px solid #4ade804d;padding:4px 0}.passed-collapsible>summary{cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:10px;padding:10px 14px;font-weight:600;list-style:none;display:flex}.passed-collapsible>summary::-webkit-details-marker{display:none}.passed-collapsible>summary:before{content:"▸";color:var(--text-muted);width:12px;transition:transform .15s;display:inline-block}.passed-collapsible[open]>summary:before{transform:rotate(90deg)}.passed-check{font-size:16px}.passed-hint{margin-left:auto;font-size:12px;font-weight:400}.passed-list{margin:0;padding:4px 12px 12px}.bottom-bar{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-top:1px solid var(--border);background:#0e1015f2;flex-direction:column;gap:6px;padding:10px 24px 12px;display:flex;position:sticky;bottom:0}.bottom-bar-text{color:var(--text-muted);font-variant-numeric:tabular-nums;font-size:12px}.bottom-bar-track{background:var(--bg-elev-2);border-radius:2px;height:4px;overflow:hidden}.bottom-bar-fill{background:var(--accent);height:100%;transition:width .25s}.setup{flex-direction:column;gap:16px;display:flex;position:relative}.setup.drag-active{outline:2px dashed var(--accent);outline-offset:-10px;border-radius:var(--radius)}.setup.drag-active:after{content:"Drop files to add";color:var(--accent);pointer-events:none;border-radius:var(--radius);z-index:5;background:#6c8cff14;justify-content:center;align-items:center;font-size:18px;font-weight:600;display:flex;position:absolute;inset:0}.howto{background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;gap:18px;width:100%;max-width:720px;margin:0 auto;padding:28px 32px;display:flex}.howto-title{margin:0;font-size:18px;font-weight:700}.howto-steps{flex-direction:column;gap:10px;margin:0;padding-left:22px;font-size:14px;line-height:1.55;display:flex}.howto-steps strong{color:var(--text)}.example-table{border-collapse:collapse;border:1px solid var(--border);background:#0a0c12;border-radius:8px;width:100%;font-size:13px;overflow:hidden}.example-table th,.example-table td{text-align:left;border-bottom:1px solid var(--border);padding:8px 12px}.example-table tbody tr:last-child td{border-bottom:none}.example-table th{background:var(--bg-elev-2);color:var(--text);letter-spacing:.02em;font-family:SF Mono,ui-monospace,monospace;font-size:12.5px;font-weight:600}
