:root{--bg: oklch(.985 .003 240);--surface: #ffffff;--surface-2: oklch(.975 .004 240);--border: oklch(.92 .006 240);--border-strong: oklch(.86 .008 240);--ink: oklch(.22 .01 250);--ink-2: oklch(.42 .01 250);--ink-3: oklch(.58 .01 250);--ink-4: oklch(.72 .008 240);--accent: oklch(.52 .14 250);--accent-2: oklch(.45 .15 250);--accent-tint: oklch(.96 .02 250);--success: oklch(.58 .13 155);--success-tint: oklch(.96 .04 155);--warn: oklch(.72 .14 75);--warn-tint: oklch(.97 .04 75);--danger: oklch(.58 .18 25);--danger-tint: oklch(.97 .04 25);--radius: 8px;--radius-sm: 6px;--radius-lg: 12px;--shadow-1: 0 1px 2px rgba(20, 30, 55, .04);--shadow-2: 0 4px 14px rgba(20, 30, 55, .06), 0 1px 2px rgba(20, 30, 55, .04);--shadow-pop: 0 14px 40px rgba(20, 30, 55, .14), 0 2px 6px rgba(20, 30, 55, .06);--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono: "JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, monospace}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:var(--font-sans);font-size:14px;color:var(--ink);background:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-feature-settings:"cv11","ss01"}button{font-family:inherit;cursor:pointer;border:0;background:none;color:inherit}input,select,textarea{font-family:inherit;font-size:inherit;color:inherit}a{color:inherit;text-decoration:none}code,.mono{font-family:var(--font-mono);font-size:12.5px}.app{display:grid;grid-template-columns:232px 1fr;min-height:100vh}.sidebar{border-right:1px solid var(--border);background:var(--surface);padding:20px 14px;display:flex;flex-direction:column;gap:2px;position:sticky;top:0;height:100vh}.brand{display:flex;align-items:center;gap:10px;padding:6px 8px 20px;border-bottom:1px solid var(--border);margin-bottom:14px}.brand-mark{width:26px;height:26px;border-radius:6px;background:var(--ink);position:relative;display:grid;place-items:center}.brand-mark:before{content:"";width:12px;height:12px;border-radius:3px;border:2px solid var(--bg);transform:rotate(45deg)}.brand-name{font-weight:600;letter-spacing:-.01em;font-size:14px}.brand-sub{font-size:11px;color:var(--ink-3);letter-spacing:.04em;text-transform:uppercase;margin-top:1px}.nav-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:var(--radius-sm);color:var(--ink-2);font-size:13.5px;font-weight:500;width:100%;text-align:left;transition:background .12s,color .12s}.nav-item:hover{background:var(--surface-2);color:var(--ink)}.nav-item.active{background:var(--accent-tint);color:var(--accent-2)}.nav-item .ic{width:16px;height:16px;flex-shrink:0}.nav-item .count{margin-left:auto;font-size:11.5px;color:var(--ink-3);font-variant-numeric:tabular-nums}.sidebar-footer{margin-top:auto;padding-top:14px;border-top:1px solid var(--border)}.user-card{display:flex;align-items:center;gap:10px;padding:6px 4px}.avatar{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,#a5bad1,#6a87b7);color:#fff;display:grid;place-items:center;font-size:11px;font-weight:600;flex-shrink:0}.user-meta{min-width:0;flex:1}.user-name{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role{font-size:11px;color:var(--ink-3);text-transform:capitalize}.icon-btn{width:28px;height:28px;display:grid;place-items:center;border-radius:var(--radius-sm);color:var(--ink-3)}.icon-btn:hover{background:var(--surface-2);color:var(--ink)}.main{display:flex;flex-direction:column;min-width:0}.topbar{height:56px;border-bottom:1px solid var(--border);background:color-mix(in oklch,var(--bg) 75%,white);-webkit-backdrop-filter:saturate(1.2) blur(8px);backdrop-filter:saturate(1.2) blur(8px);display:flex;align-items:center;padding:0 28px;gap:16px;position:sticky;top:0;z-index:10}.crumbs{font-size:13px;color:var(--ink-3);display:flex;align-items:center;gap:6px;font-weight:500}.crumbs .sep{opacity:.6}.crumbs .cur{color:var(--ink)}.topbar-right{margin-left:auto;display:flex;align-items:center;gap:8px}.page{padding:28px 32px 64px;max-width:1400px;width:100%}.page-header{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;margin-bottom:24px}.page-title{font-size:24px;font-weight:600;letter-spacing:-.015em;margin:0 0 4px}.page-sub{color:var(--ink-3);font-size:13.5px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:7px 12px;border-radius:var(--radius-sm);font-size:13px;font-weight:500;border:1px solid var(--border-strong);background:var(--surface);color:var(--ink);transition:all .12s;white-space:nowrap}.btn:hover{border-color:var(--ink-3)}.btn:disabled{opacity:.45;cursor:not-allowed}.btn-primary{background:var(--ink);color:#fff;border-color:var(--ink)}.btn-primary:hover{background:#232a30;border-color:#232a30}.btn-accent{background:var(--accent);color:#fff;border-color:var(--accent)}.btn-accent:hover{background:var(--accent-2);border-color:var(--accent-2)}.btn-ghost{border-color:transparent;background:transparent;color:var(--ink-2)}.btn-ghost:hover{background:var(--surface-2);color:var(--ink)}.btn-sm{padding:5px 9px;font-size:12.5px}.btn-icon{width:30px;height:30px;padding:0}.field{display:flex;flex-direction:column;gap:6px}.label{font-size:12px;font-weight:500;color:var(--ink-2);letter-spacing:.01em}.input,.select{padding:8px 12px;border-radius:var(--radius-sm);border:1px solid var(--border-strong);background:var(--surface);font-size:13.5px;transition:border-color .12s,box-shadow .12s;outline:none;width:100%;color:var(--ink)}.input:focus,.select:focus{border-color:var(--accent);box-shadow:0 0 0 3px color-mix(in oklch,var(--accent) 18%,transparent)}.select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23667' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:32px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.card-pad{padding:20px 22px}.card-title{font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-3);margin:0 0 14px}.status{display:inline-flex;align-items:center;gap:6px;font-size:12.5px;font-weight:500}.status .dot{width:7px;height:7px;border-radius:50%;background:var(--ink-4)}.status.st-processing .dot{background:var(--accent);box-shadow:0 0 0 3px color-mix(in oklch,var(--accent) 22%,transparent);animation:pulse 1.8s ease-in-out infinite}.status.st-complete .dot{background:var(--success)}.status.st-error .dot{background:var(--danger)}.status.st-queued .dot{background:var(--warn)}.status.st-idle .dot{background:var(--ink-4)}@keyframes pulse{0%,to{box-shadow:0 0 0 3px color-mix(in oklch,var(--accent) 22%,transparent)}50%{box-shadow:0 0 0 5px color-mix(in oklch,var(--accent) 10%,transparent)}}.table{width:100%;border-collapse:collapse}.table thead th{text-align:left;font-size:11.5px;font-weight:600;color:var(--ink-3);text-transform:uppercase;letter-spacing:.04em;padding:10px 14px;border-bottom:1px solid var(--border);background:var(--surface-2)}.table tbody td{padding:12px 14px;border-bottom:1px solid var(--border);font-size:13.5px;vertical-align:middle}.table tbody tr{transition:background .08s}.table tbody tr:hover{background:var(--surface-2);cursor:pointer}.table tbody tr:last-child td{border-bottom:0}.filters{display:grid;grid-template-columns:1fr 1fr 1fr 1fr auto;gap:10px;align-items:end;padding:14px 16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:16px}.filters .field{gap:4px}.empty{padding:52px 20px;text-align:center;color:var(--ink-3)}.chip{display:inline-flex;align-items:center;gap:6px;padding:3px 8px;border-radius:999px;background:var(--surface-2);border:1px solid var(--border);font-size:11.5px;color:var(--ink-2);font-weight:500}.chip-accent{background:var(--accent-tint);border-color:color-mix(in oklch,var(--accent) 20%,transparent);color:var(--accent-2)}.chip-success{background:var(--success-tint);border-color:color-mix(in oklch,var(--success) 20%,transparent);color:#005d33;color:oklch(.42 .12 155)}.chip-danger{background:var(--danger-tint);border-color:color-mix(in oklch,var(--danger) 25%,transparent);color:#932b2a}.pagination{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-top:1px solid var(--border);color:var(--ink-3);font-size:12.5px}.pagination .controls{display:flex;gap:6px}.pipeline{display:flex;align-items:stretch;gap:0;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.pipeline-step{flex:1;padding:14px 16px;position:relative;border-right:1px solid var(--border);display:flex;flex-direction:column;gap:4px;min-width:0}.pipeline-step:last-child{border-right:0}.pipeline-step .step-num{font-family:var(--font-mono);font-size:11px;color:var(--ink-4);letter-spacing:.05em}.pipeline-step .step-name{font-size:13px;font-weight:500;color:var(--ink-2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pipeline-step .step-files{font-size:11.5px;color:var(--ink-3);font-variant-numeric:tabular-nums}.pipeline-step.done{background:color-mix(in oklch,var(--success-tint) 60%,white)}.pipeline-step.done .step-name{color:#00502b;color:oklch(.38 .12 155)}.pipeline-step.active{background:var(--accent-tint)}.pipeline-step.active .step-name{color:var(--accent-2);font-weight:600}.pipeline-step.active:after{content:"";position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--accent);animation:scan 1.6s ease-in-out infinite}@keyframes scan{0%,to{opacity:.4}50%{opacity:1}}.pipeline-step.error{background:var(--danger-tint)}.pipeline-step.error .step-name{color:#932b2a}.pipeline-step.pending .step-name{color:var(--ink-4)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#14192861;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:grid;place-items:center;z-index:100;animation:fade .15s ease-out}.modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-pop);width:100%;max-width:480px;overflow:hidden;animation:pop .18s ease-out}.modal.lg{max-width:640px}.modal-head{padding:18px 22px 12px;display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.modal-title{font-size:16px;font-weight:600;margin:0;letter-spacing:-.01em}.modal-sub{font-size:13px;color:var(--ink-3);margin-top:3px}.modal-body{padding:6px 22px 20px}.modal-foot{padding:14px 22px;display:flex;gap:8px;justify-content:flex-end;background:var(--surface-2);border-top:1px solid var(--border)}@keyframes fade{0%{opacity:0}to{opacity:1}}@keyframes pop{0%{opacity:0;transform:translateY(6px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.file-group{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);overflow:hidden;margin-bottom:10px}.file-group-head{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--surface);cursor:pointer;-webkit-user-select:none;user-select:none}.file-group-head:hover{background:var(--surface-2)}.file-group-head .caret{width:14px;height:14px;transition:transform .15s;color:var(--ink-3)}.file-group.open .file-group-head .caret{transform:rotate(90deg)}.file-group-head .name{font-size:13.5px;font-weight:600;color:var(--ink)}.file-group-head .meta{font-size:12px;color:var(--ink-3);font-variant-numeric:tabular-nums}.file-list{border-top:1px solid var(--border);background:var(--surface-2)}.file-row{display:grid;grid-template-columns:1fr 120px 90px 60px 80px;gap:10px;align-items:center;padding:10px 16px;border-bottom:1px solid var(--border);font-size:13px}.file-row:last-child{border-bottom:0}.file-row:hover{background:color-mix(in oklch,var(--surface-2) 50%,white)}.file-name{display:flex;align-items:center;gap:10px;min-width:0}.file-name .fn-icon{width:28px;height:28px;background:var(--surface);border:1px solid var(--border);border-radius:6px;display:grid;place-items:center;color:var(--ink-3);flex-shrink:0}.file-name .fn-txt{min-width:0;overflow:hidden;white-space:nowrap;text-overflow:ellipsis;font-family:var(--font-mono);font-size:12.5px}.file-meta{color:var(--ink-3);font-size:12px}.file-actions{display:flex;gap:4px;justify-content:flex-end}.meta-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);overflow:hidden}.meta-cell{padding:14px 16px;border-right:1px solid var(--border);border-bottom:1px solid var(--border)}.meta-cell:nth-child(4n){border-right:0}.meta-cell:nth-last-child(-n+4){border-bottom:0}.meta-label{font-size:11px;text-transform:uppercase;color:var(--ink-3);letter-spacing:.05em;font-weight:500;margin-bottom:4px}.meta-value{font-size:13.5px;color:var(--ink)}.login-shell{min-height:100vh;display:grid;grid-template-columns:1fr 1fr;background:var(--surface)}.login-shell.login-shell-single{grid-template-columns:1fr;background:var(--bg)}.login-art{background:radial-gradient(ellipse at 30% 20%,oklch(.96 .04 240) 0%,transparent 55%),radial-gradient(ellipse at 80% 90%,oklch(.95 .04 260) 0%,transparent 55%),var(--bg);border-right:1px solid var(--border);display:flex;flex-direction:column;justify-content:space-between;padding:40px;position:relative;overflow:hidden}.login-art .grid{position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(to right,oklch(.88 .008 240 / .5) 1px,transparent 1px),linear-gradient(to bottom,oklch(.88 .008 240 / .5) 1px,transparent 1px);background-size:40px 40px;-webkit-mask-image:radial-gradient(ellipse at center,black 40%,transparent 75%);mask-image:radial-gradient(ellipse at center,black 40%,transparent 75%)}.login-form-wrap{display:grid;place-items:center;padding:40px}.login-form{width:100%;max-width:360px}.dropzone{border:1.5px dashed var(--border-strong);border-radius:var(--radius);padding:32px 24px;text-align:center;background:var(--surface-2);transition:border-color .15s,background .15s;cursor:pointer}.dropzone:hover,.dropzone.drag{border-color:var(--accent);background:var(--accent-tint)}.dropzone .dz-icon{width:40px;height:40px;display:grid;place-items:center;background:var(--surface);border:1px solid var(--border);border-radius:10px;margin:0 auto 12px;color:var(--ink-3)}.tabs{display:flex;gap:2px;border-bottom:1px solid var(--border);margin-bottom:20px}.tab{padding:10px 14px;font-size:13px;font-weight:500;color:var(--ink-3);border-bottom:2px solid transparent;margin-bottom:-1px;transition:color .12s}.tab:hover{color:var(--ink-2)}.tab.active{color:var(--ink);border-bottom-color:var(--ink)}.row{display:flex;align-items:center;gap:8px}.row-between{display:flex;align-items:center;justify-content:space-between;gap:12px}.stack{display:flex;flex-direction:column;gap:12px}.grow{flex:1}.muted{color:var(--ink-3)}.bold{font-weight:600}.tabnum{font-variant-numeric:tabular-nums}.divider{height:1px;background:var(--border);margin:20px 0;border:0}.tweaks-panel{position:fixed;bottom:18px;right:18px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-pop);padding:14px 16px;z-index:60;width:240px;font-size:12.5px}.tweaks-panel h4{margin:0 0 10px;font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-3)}.tweak-row{display:flex;justify-content:space-between;align-items:center;padding:6px 0}.swatch-row{display:flex;gap:6px}.swatch{width:22px;height:22px;border-radius:50%;border:2px solid var(--border);cursor:pointer}.swatch.active{border-color:var(--ink)}.chart-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px;min-width:0}.chart-bar{transition:opacity .12s}.chart-col:hover .chart-bar{opacity:.8}.chart-tip{position:absolute;left:50%;top:-4px;transform:translate(-50%,-100%);padding:4px 8px;background:var(--ink);color:#fff;font-size:11px;border-radius:var(--radius-sm);white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .1s;box-shadow:var(--shadow-2);z-index:1}.chart-tip:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:4px solid transparent;border-top-color:var(--ink)}.chart-col:hover .chart-tip{opacity:1}.toast-stack{position:fixed;bottom:20px;left:50%;transform:translate(-50%);display:flex;flex-direction:column;gap:8px;z-index:120}.toast{background:var(--ink);color:#fff;padding:10px 14px;border-radius:var(--radius-sm);font-size:13px;box-shadow:var(--shadow-2);display:flex;align-items:center;gap:10px;animation:toast-in .2s ease-out}.toast.success{background:#003219;background:oklch(.28 .08 155)}.toast.error{background:#7c1117}@keyframes toast-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
