.react-flow{direction:ltr}.react-flow__container{position:absolute;width:100%;height:100%;top:0;left:0}.react-flow__pane{z-index:1;cursor:-webkit-grab;cursor:grab}.react-flow__pane.selection{cursor:pointer}.react-flow__pane.dragging{cursor:-webkit-grabbing;cursor:grabbing}.react-flow__viewport{transform-origin:0 0;z-index:2;pointer-events:none}.react-flow__renderer{z-index:4}.react-flow__selection{z-index:6}.react-flow__nodesselection-rect:focus,.react-flow__nodesselection-rect:focus-visible{outline:none}.react-flow .react-flow__edges{pointer-events:none;overflow:visible}.react-flow__edge-path,.react-flow__connection-path{stroke:#b1b1b7;stroke-width:1;fill:none}.react-flow__edge{pointer-events:visibleStroke;cursor:pointer}.react-flow__edge.animated path{stroke-dasharray:5;-webkit-animation:dashdraw .5s linear infinite;animation:dashdraw .5s linear infinite}.react-flow__edge.animated path.react-flow__edge-interaction{stroke-dasharray:none;-webkit-animation:none;animation:none}.react-flow__edge.inactive{pointer-events:none}.react-flow__edge.selected,.react-flow__edge:focus,.react-flow__edge:focus-visible{outline:none}.react-flow__edge.selected .react-flow__edge-path,.react-flow__edge:focus .react-flow__edge-path,.react-flow__edge:focus-visible .react-flow__edge-path{stroke:#555}.react-flow__edge-textwrapper{pointer-events:all}.react-flow__edge-textbg{fill:#fff}.react-flow__edge .react-flow__edge-text{pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-flow__connection{pointer-events:none}.react-flow__connection .animated{stroke-dasharray:5;-webkit-animation:dashdraw .5s linear infinite;animation:dashdraw .5s linear infinite}.react-flow__connectionline{z-index:1001}.react-flow__nodes{pointer-events:none;transform-origin:0 0}.react-flow__node{position:absolute;-webkit-user-select:none;-moz-user-select:none;user-select:none;pointer-events:all;transform-origin:0 0;box-sizing:border-box;cursor:-webkit-grab;cursor:grab}.react-flow__node.dragging{cursor:-webkit-grabbing;cursor:grabbing}.react-flow__nodesselection{z-index:3;transform-origin:left top;pointer-events:none}.react-flow__nodesselection-rect{position:absolute;pointer-events:all;cursor:-webkit-grab;cursor:grab}.react-flow__handle{position:absolute;pointer-events:none;min-width:5px;min-height:5px;width:6px;height:6px;background:#1a192b;border:1px solid white;border-radius:100%}.react-flow__handle.connectionindicator{pointer-events:all;cursor:crosshair}.react-flow__handle-bottom{top:auto;left:50%;bottom:-4px;transform:translate(-50%)}.react-flow__handle-top{left:50%;top:-4px;transform:translate(-50%)}.react-flow__handle-left{top:50%;left:-4px;transform:translateY(-50%)}.react-flow__handle-right{right:-4px;top:50%;transform:translateY(-50%)}.react-flow__edgeupdater{cursor:move;pointer-events:all}.react-flow__panel{position:absolute;z-index:5;margin:15px}.react-flow__panel.top{top:0}.react-flow__panel.bottom{bottom:0}.react-flow__panel.left{left:0}.react-flow__panel.right{right:0}.react-flow__panel.center{left:50%;transform:translate(-50%)}.react-flow__attribution{font-size:10px;background:#ffffff80;padding:2px 3px;margin:0}.react-flow__attribution a{text-decoration:none;color:#999}@-webkit-keyframes dashdraw{0%{stroke-dashoffset:10}}@keyframes dashdraw{0%{stroke-dashoffset:10}}.react-flow__edgelabel-renderer{position:absolute;width:100%;height:100%;pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-flow__edge.updating .react-flow__edge-path{stroke:#777}.react-flow__edge-text{font-size:10px}.react-flow__node.selectable:focus,.react-flow__node.selectable:focus-visible{outline:none}.react-flow__node-default,.react-flow__node-input,.react-flow__node-output,.react-flow__node-group{padding:10px;border-radius:3px;width:150px;font-size:12px;color:#222;text-align:center;border-width:1px;border-style:solid;border-color:#1a192b;background-color:#fff}.react-flow__node-default.selectable:hover,.react-flow__node-input.selectable:hover,.react-flow__node-output.selectable:hover,.react-flow__node-group.selectable:hover{box-shadow:0 1px 4px 1px #00000014}.react-flow__node-default.selectable.selected,.react-flow__node-default.selectable:focus,.react-flow__node-default.selectable:focus-visible,.react-flow__node-input.selectable.selected,.react-flow__node-input.selectable:focus,.react-flow__node-input.selectable:focus-visible,.react-flow__node-output.selectable.selected,.react-flow__node-output.selectable:focus,.react-flow__node-output.selectable:focus-visible,.react-flow__node-group.selectable.selected,.react-flow__node-group.selectable:focus,.react-flow__node-group.selectable:focus-visible{box-shadow:0 0 0 .5px #1a192b}.react-flow__node-group{background-color:#f0f0f040}.react-flow__nodesselection-rect,.react-flow__selection{background:#0059dc14;border:1px dotted rgba(0,89,220,.8)}.react-flow__nodesselection-rect:focus,.react-flow__nodesselection-rect:focus-visible,.react-flow__selection:focus,.react-flow__selection:focus-visible{outline:none}.react-flow__controls{box-shadow:0 0 2px 1px #00000014}.react-flow__controls-button{border:none;background:#fefefe;border-bottom:1px solid #eee;box-sizing:content-box;display:flex;justify-content:center;align-items:center;width:16px;height:16px;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;padding:5px}.react-flow__controls-button:hover{background:#f4f4f4}.react-flow__controls-button svg{width:100%;max-width:12px;max-height:12px}.react-flow__controls-button:disabled{pointer-events:none}.react-flow__controls-button:disabled svg{fill-opacity:.4}.react-flow__minimap{background-color:#fff}.react-flow__minimap svg{display:block}.react-flow__resize-control{position:absolute}.react-flow__resize-control.left,.react-flow__resize-control.right{cursor:ew-resize}.react-flow__resize-control.top,.react-flow__resize-control.bottom{cursor:ns-resize}.react-flow__resize-control.top.left,.react-flow__resize-control.bottom.right{cursor:nwse-resize}.react-flow__resize-control.bottom.left,.react-flow__resize-control.top.right{cursor:nesw-resize}.react-flow__resize-control.handle{width:4px;height:4px;border:1px solid #fff;border-radius:1px;background-color:#3367d9;transform:translate(-50%,-50%)}.react-flow__resize-control.handle.left{left:0;top:50%}.react-flow__resize-control.handle.right{left:100%;top:50%}.react-flow__resize-control.handle.top{left:50%;top:0}.react-flow__resize-control.handle.bottom{left:50%;top:100%}.react-flow__resize-control.handle.top.left,.react-flow__resize-control.handle.bottom.left{left:0}.react-flow__resize-control.handle.top.right,.react-flow__resize-control.handle.bottom.right{left:100%}.react-flow__resize-control.line{border-color:#3367d9;border-width:0;border-style:solid}.react-flow__resize-control.line.left,.react-flow__resize-control.line.right{width:1px;transform:translate(-50%);top:0;height:100%}.react-flow__resize-control.line.left{left:0;border-left-width:1px}.react-flow__resize-control.line.right{left:100%;border-right-width:1px}.react-flow__resize-control.line.top,.react-flow__resize-control.line.bottom{height:1px;transform:translateY(-50%);left:0;width:100%}.react-flow__resize-control.line.top{top:0;border-top-width:1px}.react-flow__resize-control.line.bottom{border-bottom-width:1px;top:100%}:root{--bg: #f5f7fa;--panel: #ffffff;--panel-2: #f1f4f8;--panel-3: #e6ebf2;--text: #1a2233;--muted: #6b7589;--accent: #2563eb;--accent-soft: #eaf2ff;--accent-2: #16a34a;--accent-2-soft: #e8f7ee;--accent-3: #7c3aed;--accent-3-soft: #f1ecfd;--warn: #b45309;--warn-soft: #fef3e0;--err: #dc2626;--err-soft: #fdecec;--on-accent: #ffffff;--border: #dde3ec;--border-strong: #c5ccd8;--radius: 10px;--shadow-sm: 0 1px 2px rgba(15, 23, 42, .04);--shadow: 0 1px 3px rgba(15, 23, 42, .06), 0 4px 16px rgba(15, 23, 42, .05);--shadow-lg: 0 4px 24px rgba(15, 23, 42, .1), 0 8px 32px rgba(15, 23, 42, .06)}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{background:var(--bg);color:var(--text);font-family:Inter,ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;font-size:14px;-webkit-font-smoothing:antialiased}code,pre{font-family:ui-monospace,JetBrains Mono,Fira Code,Menlo,monospace;font-size:12.5px}button{background:var(--panel);color:var(--text);border:1px solid var(--border);border-radius:8px;padding:7px 12px;cursor:pointer;font-size:13px;transition:background .15s,border-color .15s,box-shadow .15s;box-shadow:var(--shadow-sm)}button:hover:not(:disabled){background:var(--panel-2);border-color:var(--border-strong)}button:disabled{opacity:.5;cursor:not-allowed;box-shadow:none}button.primary{background:var(--accent);border-color:var(--accent);color:var(--on-accent);font-weight:600}button.primary:hover:not(:disabled){filter:brightness(1.05);box-shadow:0 2px 6px #2563eb40}button.ghost{background:transparent;border:1px dashed var(--border);color:var(--muted)}button.ghost:hover{color:var(--text);border-color:var(--border-strong)}button.x{padding:2px 8px;font-size:12px}input,select,textarea{background:var(--panel);color:var(--text);border:1px solid var(--border);border-radius:8px;padding:7px 10px;font-size:13px;width:100%;font-family:inherit}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent)}textarea{resize:vertical;min-height:46px}.app{height:100vh;display:flex;flex-direction:column}.topbar{display:flex;align-items:center;justify-content:space-between;padding:10px 18px;border-bottom:1px solid var(--border);background:var(--panel);box-shadow:var(--shadow-sm)}.brand{display:flex;align-items:baseline;gap:10px}.brand .logo{width:14px;height:14px;border-radius:3px;background:linear-gradient(135deg,var(--accent),var(--accent-2));display:inline-block}.brand strong{font-size:16px;letter-spacing:.2px}.brand .tag{color:var(--muted);font-size:12px}.topbar-right{display:flex;gap:8px;align-items:center}.pill{background:var(--panel-2);border:1px solid var(--border);border-radius:999px;padding:3px 10px;font-size:12px;color:var(--muted);display:inline-flex;align-items:center;gap:6px}.pill.ok{color:var(--accent-2);border-color:#b9e3c5}.pill.warn{color:var(--warn);border-color:#f4d7a3}.landing{flex:1;padding:40px;display:grid;grid-template-columns:minmax(320px,440px) 1fr;gap:32px;overflow:auto}.landing-left{display:flex;flex-direction:column;gap:16px}.landing-app{background:radial-gradient(circle at 20% 0%,rgba(37,99,235,.1),transparent 55%),radial-gradient(circle at 90% 30%,rgba(124,58,237,.1),transparent 60%),radial-gradient(circle at 50% 100%,rgba(236,72,153,.06),transparent 60%),linear-gradient(180deg,#f7f9fc,#eef2f7);min-height:100vh;overflow:auto}.landing-min{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;padding:40px 24px}.landing-min-inner{position:relative;z-index:1;width:100%;max-width:680px;display:flex;flex-direction:column;align-items:center;gap:18px}.landing-min-divider{display:flex;align-items:center;gap:12px;width:100%;margin:6px 0 -2px;color:var(--muted);font-size:11px;letter-spacing:.4px;text-transform:uppercase}.landing-min-divider:before,.landing-min-divider:after{content:"";flex:1;height:1px;background:linear-gradient(90deg,transparent,rgba(15,23,42,.1),transparent)}.landing-min-inner>.sample-picker{width:100%}.landing-decor{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;pointer-events:none;opacity:.6;z-index:0}.landing-min-brand{display:flex;align-items:center;gap:14px;margin-bottom:4px}.landing-logo{display:inline-flex;border-radius:12px;overflow:hidden;box-shadow:0 8px 20px #2563eb38,0 2px 4px #0f172a0f}.landing-min-text{display:flex;flex-direction:column}.landing-min-text strong{font-size:24px;letter-spacing:.2px;background:linear-gradient(135deg,#2563eb,#7c3aed);-webkit-background-clip:text;background-clip:text;color:transparent;line-height:1.1}.landing-min-text span{font-size:12px;color:var(--muted);letter-spacing:.4px;text-transform:uppercase;margin-top:2px}.landing-min-badge{display:inline-flex;align-items:center;gap:8px;padding:6px 14px;border-radius:999px;background:#ffffffb3;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid rgba(37,99,235,.18);color:var(--accent);font-size:12px;font-weight:600;letter-spacing:.35px;text-transform:uppercase;box-shadow:0 2px 8px #2563eb14}.landing-min-foot{margin:0;font-size:12px;color:var(--muted);display:inline-flex;align-items:center;gap:6px}.landing-min-foot i{color:var(--accent);opacity:.8}.landing-min-credit{margin:-10px 0 0;font-size:11.5px;color:var(--muted);letter-spacing:.2px}.landing-min-credit a{color:var(--accent);text-decoration:none;display:inline-flex;align-items:center;gap:5px;font-weight:500;padding:2px 6px;border-radius:6px;transition:background .15s,color .15s}.landing-min-credit a:hover{background:#2563eb14;color:#1d4ed8}.landing-min-credit a i{font-size:12px}.upload-hero{width:100%;max-width:520px;background:#ffffffc7;border:1px solid rgba(15,23,42,.08);border-radius:18px;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);box-shadow:0 18px 50px #0f172a1a,0 6px 18px #2563eb0f;padding:18px;display:flex;flex-direction:column;gap:14px}.upload-hero-head{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.upload-tabs{display:inline-flex;background:#f1f4f8d9;border:1px solid rgba(15,23,42,.07);border-radius:999px;padding:3px;gap:2px}.upload-tab{border:none;background:transparent;padding:6px 14px;border-radius:999px;font-size:12px;font-weight:500;color:var(--muted);cursor:pointer;display:inline-flex;align-items:center;gap:6px;transition:background .18s,color .18s,box-shadow .18s;box-shadow:none}.upload-tab:hover:not(.active){color:var(--text);background:transparent}.upload-tab.active{background:#fff;color:var(--accent);box-shadow:0 1px 3px #0f172a1a}.upload-fs .field.inline.tiny{margin:0;flex-direction:row;align-items:center;gap:6px}.upload-fs .field.inline.tiny>span{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.3px}.fs-input{display:inline-flex;align-items:center;border:1px solid var(--border);border-radius:8px;background:var(--panel);padding:0 8px 0 0;transition:border-color .15s,box-shadow .15s}.fs-input:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px #2563eb1f}.fs-input input{border:none;width:70px;text-align:right;background:transparent;font-variant-numeric:tabular-nums;padding-right:4px}.fs-input input:focus{box-shadow:none}.fs-input .suffix{font-size:11px;color:var(--muted)}.hero-dropzone{position:relative;border-radius:14px;border:1.5px dashed rgba(37,99,235,.3);background:linear-gradient(180deg,#fff6,#f1f4f899);padding:36px 24px 28px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:10px;cursor:pointer;transition:border-color .18s,background .18s,transform .18s;overflow:hidden}.hero-dropzone:hover{border-color:var(--accent);background:linear-gradient(180deg,#eaf2ff99,#eaf2ffd9);transform:translateY(-1px)}.hero-dropzone.dragging{border-color:var(--accent);border-style:solid;background:linear-gradient(180deg,#eaf2ffd9,#eaf2fff2);box-shadow:0 0 0 4px #2563eb1a}.hero-dropzone.zip{border-color:#7c3aed4d}.hero-dropzone.zip:hover{border-color:var(--accent-3);background:linear-gradient(180deg,#f1ecfd99,#f1ecfde6)}.hero-dropzone.busy{cursor:progress}.hero-drop-glow{position:absolute;width:220px;height:220px;border-radius:50%;filter:blur(60px);background:radial-gradient(circle,rgba(37,99,235,.18),transparent 70%);top:-40px;left:50%;transform:translate(-50%);pointer-events:none}.hero-dropzone.zip .hero-drop-glow{background:radial-gradient(circle,rgba(124,58,237,.22),transparent 70%)}.hero-drop-icon{width:56px;height:56px;border-radius:16px;background:linear-gradient(135deg,#2563eb,#7c3aed);color:#fff;display:inline-flex;align-items:center;justify-content:center;font-size:22px;box-shadow:0 10px 30px #2563eb4d;margin-bottom:6px}.hero-dropzone.zip .hero-drop-icon{background:linear-gradient(135deg,#7c3aed,#ec4899);box-shadow:0 10px 30px #7c3aed47}.hero-drop-title{font-size:16px;color:var(--text)}.hero-drop-sub{font-size:13px;color:var(--muted);max-width:360px;line-height:1.5}.hero-drop-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-top:4px}.hero-drop-btn{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border-radius:999px;background:linear-gradient(135deg,#2563eb,#7c3aed);color:#fff;font-size:13px;font-weight:600;box-shadow:0 6px 16px #2563eb33}.hero-dropzone.zip .hero-drop-btn{background:linear-gradient(135deg,#7c3aed,#ec4899);box-shadow:0 6px 16px #7c3aed38}.hero-drop-formats{font-size:11px;color:var(--muted);letter-spacing:.5px}.hero-drop-busy{display:flex;flex-direction:column;align-items:center;gap:8px;padding:20px 0}.hero-spinner{width:36px;height:36px;border:3px solid rgba(37,99,235,.2);border-top-color:var(--accent);border-radius:50%;animation:hero-spin .8s linear infinite}@keyframes hero-spin{to{transform:rotate(360deg)}}.upload-hero-foot{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;padding:2px 6px}.upload-hero-foot .checkbox{font-size:12px;color:var(--muted)}.upload-hero-foot .hint i{margin-right:4px}@media (max-width: 560px){.landing-min{padding:24px 14px}.landing-min-brand{flex-direction:column;text-align:center;gap:8px}}.sample-picker .sample-controls{margin-bottom:12px;display:flex;align-items:center;gap:12px}.sample-picker:not(.compact) .sample-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:12px}.sample-picker:not(.compact) .sample-card{--card-accent: #2563eb;display:flex;flex-direction:column;gap:8px;padding:12px 12px 10px;background:#ffffffd9;border:1px solid rgba(15,23,42,.06);border-radius:14px;cursor:pointer;text-align:left;position:relative;overflow:hidden;color:var(--card-accent);transition:transform .18s,box-shadow .18s,border-color .18s;box-shadow:0 1px 3px #0f172a0a}.sample-picker:not(.compact) .sample-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,color-mix(in srgb,var(--card-accent) 10%,transparent),transparent 70%);opacity:0;transition:opacity .18s;pointer-events:none}.sample-picker:not(.compact) .sample-card:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 12px 28px #0f172a1a;border-color:color-mix(in srgb,var(--card-accent) 40%,transparent)}.sample-picker:not(.compact) .sample-card:hover:not(:disabled):before{opacity:1}.sample-picker:not(.compact) .sample-card.loading{cursor:progress}.sample-card-head{display:flex;align-items:center;gap:10px}.sample-icon{width:32px;height:32px;border-radius:9px;background:color-mix(in srgb,var(--card-accent) 14%,transparent);color:var(--card-accent);display:inline-flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}.sample-meta{display:flex;flex-direction:column;min-width:0;flex:1}.sample-picker:not(.compact) .sample-card .sample-kind{font-family:ui-monospace,monospace;font-size:11px;font-weight:700;letter-spacing:.7px;color:var(--card-accent)}.sample-picker:not(.compact) .sample-card .sample-label{font-size:12px;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sample-picker:not(.compact) .sample-card .sample-fs{font-size:11px;color:var(--muted)}.sample-spark{width:100%;height:30px;color:var(--card-accent);opacity:.75;filter:drop-shadow(0 1px 0 rgba(255,255,255,.4))}.sample-card-foot{display:flex;align-items:center;justify-content:space-between;margin-top:2px}.sample-cta{display:inline-flex;align-items:center;gap:4px;font-size:12px;font-weight:600;color:var(--card-accent)}.sample-picker .sample-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(110px,1fr));gap:8px;margin-top:6px}.sample-card{display:flex;flex-direction:column;align-items:flex-start;gap:2px;padding:10px 12px;background:var(--panel);border:1px solid var(--border);border-radius:10px;cursor:pointer;text-align:left;transition:border-color .15s,background .15s,box-shadow .15s;box-shadow:var(--shadow-sm)}.sample-card:hover:not(:disabled){border-color:var(--accent);background:var(--accent-soft);box-shadow:var(--shadow)}.sample-card .sample-kind{font-family:ui-monospace,monospace;font-size:11px;font-weight:700;letter-spacing:.5px;color:var(--accent)}.sample-card .sample-label{font-size:12px;color:var(--text)}.sample-card .sample-fs{font-size:10px;color:var(--muted)}.workspace{flex:1;display:grid;grid-template-columns:320px 1fr;gap:12px;padding:12px;overflow:hidden;min-height:0}.side-left{overflow:auto;display:flex;flex-direction:column;gap:12px}.main{display:flex;flex-direction:column;gap:12px;min-width:0;overflow:hidden}.navbar{display:flex;background:var(--panel);border-bottom:1px solid var(--border);padding:0 14px}.nav-tabs{display:flex;gap:2px}.nav-tab{background:transparent;border:1px solid transparent;border-bottom:2px solid transparent;border-radius:0;padding:10px 16px;color:var(--muted);font-size:13px;font-weight:500;display:inline-flex;align-items:center;gap:8px}.nav-tab:hover:not(.active){color:var(--text);background:transparent;border-color:transparent}.nav-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.nav-icon{display:inline-grid;place-items:center;width:18px;height:18px;border-radius:4px;background:var(--panel-2);color:var(--accent);font-family:ui-monospace,monospace;font-size:12px}.nav-tab.active .nav-icon{background:var(--accent);color:var(--on-accent)}.nav-badge{background:var(--panel-2);color:var(--muted);border-radius:999px;padding:1px 7px;font-size:10px;font-weight:700}.nav-tab.active .nav-badge{background:var(--accent);color:var(--on-accent)}.view-host{flex:1;min-height:0;overflow:hidden;display:flex}.view{flex:1;min-height:0;display:grid;grid-template-columns:340px 1fr;gap:12px;padding:12px;overflow:hidden}.view>aside,.view>section.proc-main,.view>section.features-main,.view>section.labels-main,.view>section.dataset-main{overflow:auto;min-height:0}.view>aside{display:flex;flex-direction:column;gap:12px;background:transparent;border:none;padding:0}.view>aside section{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);padding:12px;box-shadow:var(--shadow-sm)}.view>section{display:flex;flex-direction:column;gap:10px;background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);padding:12px;box-shadow:var(--shadow-sm)}.proc-plots{display:flex;flex-direction:column;gap:10px}.proc-plot-block{background:var(--panel-2);border:1px solid var(--border);border-radius:8px;padding:8px;display:flex;flex-direction:column;gap:4px}.proc-plot-head{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--muted);padding:0 4px 4px}.proc-plot-head strong{color:var(--text);font-size:12px;text-transform:uppercase;letter-spacing:.4px}.proc-plot-head .spacer{flex:1}.proc-lineage{background:var(--panel-2);border:1px solid var(--border);border-radius:8px;padding:8px 12px;display:flex;align-items:center;gap:8px;overflow-x:auto}.proc-lineage code{color:var(--accent);white-space:nowrap}.mini-plot{display:flex;flex-direction:column;background:var(--panel);border:1px solid var(--border);border-radius:8px;overflow:hidden}.mini-plot-head{display:flex;align-items:center;gap:8px;padding:6px 10px;border-bottom:1px solid var(--border);background:var(--panel-2);font-size:12px}.mini-plot-head .spacer{flex:1}.mini-plot-title{font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.4px}.mini-plot-body{flex:1;min-height:0}.cat-menu{position:relative;display:inline-block}.cat-dropdown{position:fixed;z-index:1000;min-width:360px;max-width:min(520px,calc(100vw - 16px));max-height:60vh;overflow:auto;background:var(--panel);border:1px solid var(--border);border-radius:8px;box-shadow:var(--shadow);padding:8px;display:flex;flex-direction:column;gap:8px}.cat-group{display:flex;flex-direction:column;gap:4px}.cat-title{font-size:11px;font-weight:700;color:var(--accent);text-transform:uppercase;letter-spacing:.5px;padding:4px 6px 2px;border-bottom:1px dashed var(--border)}.cat-items{display:flex;flex-wrap:wrap;gap:4px;padding:2px 4px 4px}.cat-item{background:var(--panel-2);border:1px solid var(--border);color:var(--text);padding:4px 9px;border-radius:6px;font-size:12px}.cat-item:hover{border-color:var(--accent);color:var(--accent)}.cat-tag{font-size:10px;color:var(--muted);background:var(--panel);border:1px solid var(--border);border-radius:999px;padding:0 7px}.editing-banner{display:flex;align-items:center;gap:8px;margin-top:8px;padding:6px 8px;background:var(--warn-soft);border:1px solid #f4d7a3;border-radius:6px;font-size:12px}.editing-banner .spacer{flex:1}.editing-banner strong{color:var(--warn)}.apply-row{margin-top:10px;gap:6px}.apply-row .grow,.row .grow{flex:1}.pipeline-actions{margin-top:6px;gap:6px;flex-wrap:wrap}.ghost-btn{display:inline-block;padding:7px 12px;border-radius:8px;border:1px dashed var(--border);color:var(--muted);cursor:pointer;font-size:13px;background:transparent}.ghost-btn:hover{color:var(--text);border-color:var(--border-strong)}.chain-history .form-head{gap:6px}.chain-history .form-head h3{margin:0}.history-list{list-style:none;margin:6px 0 0;padding:0;display:flex;flex-direction:column;gap:4px}.history-item{display:flex;align-items:center;gap:8px;background:var(--panel-2);border:1px solid var(--border);border-radius:6px;padding:5px 8px;font-size:12px}.history-item .params-inline{color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:180px}.history-item .step-num{background:var(--panel);color:var(--muted);border:1px solid var(--border)}.history-item strong{color:var(--accent)}.reapply-pop{position:fixed;z-index:1000;width:min(360px,calc(100vw - 16px));background:var(--panel);border:1px solid var(--border);border-radius:10px;box-shadow:var(--shadow);padding:12px;display:flex;flex-direction:column;gap:8px}.reapply-head{display:flex;align-items:center;gap:8px}.reapply-head strong{font-size:13px}.reapply-chain{display:flex;flex-wrap:wrap;gap:4px;padding:6px 8px;background:var(--panel-2);border:1px solid var(--border);border-radius:6px;max-height:90px;overflow:auto}.combine-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:6px;margin-bottom:6px}.combine-grid .field{margin:0}.features-side,.labels-side,.dataset-side{display:flex;flex-direction:column;gap:12px}.features-main,.labels-main,.dataset-main{display:flex;flex-direction:column;gap:10px}.kind-switch{display:flex;gap:2px;margin-bottom:8px}.kind-switch.sub{margin:4px 0 8px}.kind-switch .mode{flex:1;padding:6px 10px;font-size:12px;border-radius:6px;background:transparent;border:1px solid var(--border);color:var(--muted)}.kind-switch .mode.active{background:var(--accent);color:var(--on-accent);border-color:var(--accent);font-weight:600}.signal-picker .v-name{font-weight:500}@media (max-width: 1100px){.view{grid-template-columns:1fr;grid-auto-rows:min-content;overflow:auto}.view>aside,.view>section{overflow:visible}.nav-label{display:none}}section{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);padding:14px;box-shadow:var(--shadow-sm)}section h3{margin:0 0 10px;font-size:13px;letter-spacing:.3px;text-transform:uppercase;color:var(--muted)}.panel-head{display:flex;align-items:center;gap:12px;margin-bottom:10px;flex-wrap:wrap}.panel-head h3{margin:0}.hint{color:var(--muted)}.hint.small{font-size:12px}.empty{color:var(--muted);text-align:center;padding:20px}.row{display:flex;gap:8px;align-items:center}.field{display:flex;flex-direction:column;gap:4px;margin-bottom:10px}.field span{font-size:12px;color:var(--muted)}.dropzone{border:2px dashed var(--border);border-radius:var(--radius);padding:28px 16px;text-align:center;cursor:pointer;transition:border-color .15s,background .15s;display:flex;flex-direction:column;align-items:center;gap:6px}.dropzone:hover,.dropzone.dragging{border-color:var(--accent);background:var(--accent-soft)}.dropzone .hint{font-size:12px}.upload-panel.compact .dropzone{padding:16px 12px}.step-adders{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px}.step-list{list-style:none;padding:0;margin:0 0 10px;display:flex;flex-direction:column;gap:6px}.step{background:var(--panel-2);border:1px solid var(--border);border-radius:8px;padding:8px 10px}.step.block{cursor:pointer;transition:border-color .15s,background .15s,box-shadow .15s}.step.block:hover{border-color:var(--border-strong);background:var(--panel)}.step.block.selected{border-color:var(--accent);background:var(--accent-soft);box-shadow:0 0 0 1px var(--accent) inset,var(--shadow-sm)}.step.block.selected .step-num{background:var(--accent);color:var(--on-accent)}.step-head{display:flex;align-items:center;gap:8px;font-size:12px}.step-num{background:var(--accent);color:var(--on-accent);border-radius:999px;width:18px;height:18px;display:grid;place-items:center;font-size:10px;font-weight:700}.step .spacer{flex:1}.params{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-top:8px}.params label{display:flex;flex-direction:column;gap:2px;font-size:11px;color:var(--muted)}.view.split-view{grid-template-columns:1fr 1fr}.view.split-view>.canvas-half,.view.split-view>.plots-half{display:flex;flex-direction:column;gap:10px;background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);padding:12px;box-shadow:var(--shadow-sm);overflow:auto;min-height:0}.view.split-view>.canvas-half{padding:0;background:transparent;border:none;box-shadow:none}.canvas-host{flex:1;display:flex;flex-direction:column;gap:10px}.canvas-host>.processing-canvas{flex:1;min-height:320px}.processing-canvas{position:relative;width:100%;background:var(--panel-2);border:1px solid var(--border);border-radius:10px;overflow:hidden;margin-bottom:10px}.processing-canvas .react-flow__attribution{display:none}.processing-canvas .react-flow__controls{box-shadow:var(--shadow-sm);border-radius:6px;overflow:hidden}.processing-canvas .react-flow__controls-button{background:var(--panel);border:none;border-bottom:1px solid var(--border);color:var(--muted);width:24px;height:24px}.processing-canvas .react-flow__controls-button:hover{background:var(--accent-soft);color:var(--accent)}.processing-canvas .react-flow__controls-button svg{fill:currentColor}.canvas-home-btn{position:absolute;top:12px;right:12px;z-index:6;display:inline-flex;align-items:center;gap:6px;padding:6px 12px;background:var(--panel);border:1px solid var(--border);border-radius:999px;color:var(--accent);font-size:12px;font-weight:600;cursor:pointer;box-shadow:var(--shadow);transition:background .12s ease,color .12s ease,border-color .12s ease,transform .12s ease}.canvas-home-btn:hover{background:var(--accent);color:var(--on-accent);border-color:var(--accent);transform:translateY(-1px)}.canvas-home-btn:active{transform:translateY(0)}.canvas-home-btn i{font-size:12px}.canvas-empty{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;pointer-events:none;z-index:5}.canvas-empty-inner{background:var(--panel);border:1px dashed var(--border-strong);border-radius:10px;padding:14px 18px;text-align:center;max-width:320px;box-shadow:var(--shadow-sm)}.canvas-empty-inner strong{display:block;margin-bottom:4px;font-size:13px;color:var(--text)}.canvas-empty-inner p{margin:0}.canvas-block{background:var(--panel);border:1px solid var(--border);border-radius:10px;box-shadow:var(--shadow-sm);padding:8px 10px;font-size:12px;cursor:grab;-webkit-user-select:none;user-select:none;will-change:transform,box-shadow,border-color;transition:border-color .12s ease,box-shadow .12s ease,background .12s ease,transform .18s cubic-bezier(.22,1,.36,1)}.canvas-block:hover{border-color:var(--border-strong);box-shadow:var(--shadow);transform:translateY(-1px)}.canvas-block:active{cursor:grabbing;transform:translateY(0)}.canvas-block.selected{border-color:var(--accent);box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 18%,transparent),0 6px 18px #2563eb29;transform:translateY(-1px)}.canvas-block.canvas-block-combine.selected{border-color:var(--accent-3);box-shadow:0 0 0 3px color-mix(in srgb,var(--accent-3) 18%,transparent),0 6px 18px #7c3aed29}.canvas-block.canvas-block-source.active{border-color:var(--accent-2);box-shadow:0 0 0 3px color-mix(in srgb,var(--accent-2) 18%,transparent),0 4px 14px #16a34a24}.react-flow__node.dragging .canvas-block,.react-flow__node.dragging .canvas-block:hover{transform:none;transition:none}.canvas-block-head{display:flex;align-items:center;gap:6px;margin-bottom:4px}.canvas-block-num{background:var(--accent);color:var(--on-accent);border-radius:999px;width:18px;height:18px;display:grid;place-items:center;font-size:10px;font-weight:700;flex-shrink:0}.canvas-block-name{font-family:ui-monospace,monospace;font-size:12px;color:var(--text);flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.canvas-block-remove{background:transparent;border:none;color:var(--muted);font-size:14px;line-height:1;padding:2px 5px;border-radius:4px;cursor:pointer;box-shadow:none}.canvas-block-remove:hover{background:var(--err-soft);color:var(--err)}.canvas-block-meta{display:flex;align-items:center;gap:6px;font-size:10px;color:var(--muted)}.canvas-block-meta .cat-tag{font-size:10px;padding:0 6px}.canvas-block-step{margin-left:auto;font-family:ui-monospace,monospace}.canvas-block-handle{width:10px!important;height:10px!important;background:var(--accent)!important;border:2px solid var(--panel)!important;transition:transform .12s ease,background .12s ease}.canvas-block-handle:hover{transform:scale(1.4);background:var(--accent)!important}.canvas-block-handle.in{background:var(--accent-3)!important}.canvas-block-source .canvas-block-handle.out{background:var(--accent-2)!important}.react-flow__node{transition:filter .12s ease}.react-flow__edge-path{transition:stroke .15s ease}.react-flow__edge:hover .react-flow__edge-path{stroke-width:2.5px}.react-flow__edge.selected .react-flow__edge-path{stroke:var(--accent)!important;stroke-width:2.5px}.react-flow__edgeupdater{r:8}.cat-item[draggable=true]{cursor:grab}.cat-item[draggable=true]:active{cursor:grabbing}.canvas-block-source{border-color:#b9e3c5;background:var(--accent-2-soft)}.canvas-block-source.active{border-color:var(--accent-2);box-shadow:0 0 0 2px #16a34a2e,var(--shadow)}.canvas-block-source .canvas-block-name{color:#15803d}.canvas-block-dot{width:8px;height:8px;border-radius:999px;background:var(--accent-2);flex-shrink:0}.canvas-block-dot.derived{background:var(--accent-3)}.canvas-block-combine{border-color:#d6c8f3;background:var(--accent-3-soft)}.canvas-block-combine.selected{border-color:var(--accent-3);box-shadow:0 0 0 2px #7c3aed2e,var(--shadow)}.canvas-block-combine .canvas-block-name{color:#6d28d9}.canvas-block-symbol{font-family:ui-monospace,monospace;font-size:14px;color:var(--accent-3);flex-shrink:0}.canvas-block-inputs{display:flex;flex-direction:column;gap:2px;padding:4px 0;font-size:11px}.canvas-input-row{display:flex;align-items:center;gap:6px}.canvas-input-row.missing .canvas-input-name{color:var(--muted);font-style:italic}.canvas-input-label{font-family:ui-monospace,monospace;font-weight:700;color:var(--accent-3);width:14px}.canvas-input-name{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.canvas-block-status{font-size:12px;padding:1px 6px;border-radius:999px;background:var(--panel-2);flex-shrink:0;line-height:1}.canvas-block-status.busy{color:var(--warn);background:var(--warn-soft)}.canvas-block-status.ok{color:var(--accent-2);background:var(--accent-2-soft)}.canvas-block-status.error{color:var(--err);background:var(--err-soft)}.canvas-block-status.idle{color:var(--muted)}.canvas-block-combine.computed{border-color:var(--accent-3)}.canvas-menu{position:absolute;z-index:50;min-width:170px;max-width:240px;max-height:280px;background:var(--panel);border:1px solid var(--border);border-radius:6px;box-shadow:var(--shadow-lg);display:flex;flex-direction:column;overflow:hidden}.canvas-menu-tabs{display:flex;border-bottom:1px solid var(--border);background:var(--panel-2)}.canvas-menu-tab{flex:1;background:transparent;border:none;border-bottom:2px solid transparent;border-radius:0;padding:4px 8px;font-size:11px;color:var(--muted);cursor:pointer;box-shadow:none}.canvas-menu-tab.active{color:var(--accent);border-bottom-color:var(--accent);background:var(--panel)}.canvas-menu-body{overflow:auto;padding:4px}.canvas-menu-group{display:flex;flex-direction:column;gap:1px;margin-bottom:4px}.canvas-menu-cat{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;color:var(--accent);padding:3px 5px 1px;border-bottom:1px dashed var(--border);margin-bottom:1px}.canvas-menu-item{background:transparent;border:1px solid transparent;border-radius:3px;padding:3px 7px;text-align:left;font-family:ui-monospace,monospace;font-size:11px;color:var(--text);cursor:pointer;box-shadow:none;line-height:1.4}.canvas-menu-item:hover{background:var(--accent-soft);color:var(--accent)}.canvas-hint{position:absolute;bottom:12px;left:12px;background:var(--panel);border:1px dashed var(--border-strong);border-radius:8px;padding:6px 10px;font-size:11px;color:var(--muted);pointer-events:none;box-shadow:var(--shadow-sm);max-width:320px}.canvas-hint strong{color:var(--text)}.ai-pill{background:linear-gradient(135deg,var(--accent-3) 0%,var(--accent) 100%);color:var(--on-accent);border:none;border-radius:999px;padding:4px 12px;font-size:12px;font-weight:600;letter-spacing:.2px;cursor:pointer;box-shadow:0 1px 3px #7c3aed40;transition:transform .12s ease,box-shadow .12s ease,filter .12s ease}.ai-pill:hover:not(:disabled){transform:translateY(-1px);filter:brightness(1.05);box-shadow:0 3px 8px #7c3aed4d}.ai-pill:disabled{opacity:.5;cursor:not-allowed;box-shadow:none}.ai-modal{width:min(560px,95vw)}.ai-modal .modal-body{display:flex;flex-direction:column;gap:10px}.ai-modal textarea{font-family:inherit;font-size:13px;line-height:1.4}.ai-rationale{background:var(--accent-3-soft);border:1px solid #d6c8f3;border-radius:6px;padding:8px 10px;margin:0;color:var(--text)}.ai-chain-result{display:flex;flex-direction:column;gap:8px;margin-top:4px}.ai-step-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:6px}.ai-step{display:flex;gap:8px;background:var(--panel-2);border:1px solid var(--border);border-radius:8px;padding:8px 10px}.ai-step .step-num{flex-shrink:0;margin-top:1px}.ai-step-body{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}.ai-step-body .mono{font-size:13px;color:var(--accent)}.ai-step-params{font-family:ui-monospace,monospace;font-size:11px;color:var(--muted);word-break:break-word}.ai-step-body p{margin:2px 0 0}.ai-step.kind-combine{background:var(--accent-3-soft);border-color:#d6c8f3}.ai-step-head{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.ai-op-kind{font-size:10px;text-transform:uppercase;letter-spacing:.4px;font-weight:700;padding:1px 6px;border-radius:999px;background:var(--accent-soft);color:var(--accent)}.ai-op-kind.combine{background:var(--accent-3-soft);color:var(--accent-3)}.ai-step-id{font-family:ui-monospace,monospace;font-size:10px;color:var(--muted);margin-left:auto}.ai-step-inputs{font-family:ui-monospace,monospace;font-size:11px;color:var(--muted)}.ai-step-inputs code{background:var(--panel);padding:0 4px;border-radius:3px;font-size:10px}.ai-history-tag{display:inline-block;padding:1px 7px;border-radius:999px;background:var(--accent-3-soft);color:var(--accent-3);font-size:10px;font-weight:600;margin:0 4px}.labels-view{grid-template-columns:340px 1fr}.labels-side,.labels-main{display:flex;flex-direction:column;gap:12px;overflow:auto}.dataset-overview .dataset-name{margin:0 0 8px;word-break:break-all}.stat-grid.compact{grid-template-columns:repeat(2,1fr);gap:6px}.stat.compact{padding:6px 8px}.stat.compact .stat-value{font-size:16px}.stat.compact .stat-label{font-size:10px}.recording-tree .tree{list-style:none;margin:6px 0 0;padding:0;display:flex;flex-direction:column;gap:4px;max-height:360px;overflow:auto}.tree-rec{display:flex;flex-direction:column;background:var(--panel-2);border:1px solid var(--border);border-radius:6px;padding:4px 6px}.tree-rec-head{display:flex;align-items:center;gap:6px;background:transparent;border:none;padding:2px 0;cursor:pointer;text-align:left;box-shadow:none;width:100%}.tree-rec-head .caret{width:12px;font-size:10px;color:var(--muted)}.tree-rec-head .rec-name{flex:1;font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tree-rec-head .rec-meta{font-size:10px;color:var(--muted);font-family:ui-monospace,monospace}.tree-sigs{list-style:none;margin:4px 0 2px 14px;padding:0;display:flex;flex-direction:column;gap:2px}.tree-sig{display:flex;align-items:center;gap:6px;background:transparent;border:1px solid transparent;border-radius:4px;padding:3px 6px;width:100%;text-align:left;cursor:pointer;font-size:12px;box-shadow:none}.tree-sig:hover{background:var(--panel);border-color:var(--border)}.tree-sig.active{background:var(--accent-soft);border-color:var(--accent);color:var(--accent)}.tree-sig.derived .sig-name{color:var(--accent-3)}.tree-sig .sig-name{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tree-sig .sig-badges{display:flex;gap:3px}.badge-mini{font-size:9px;font-weight:700;letter-spacing:.3px;padding:1px 5px;border-radius:999px;background:var(--panel-2);color:var(--muted);text-transform:uppercase}.badge-mini.proc{background:var(--accent-2-soft);color:var(--accent-2)}.badge-mini.lbl{background:var(--warn-soft);color:var(--warn)}.export-panel .download-btn{display:inline-block;text-decoration:none;padding:6px 12px;border-radius:8px;font-size:13px}.active-signal{display:flex;flex-direction:column;gap:6px}.active-signal .form-head .mono{font-size:14px}.label-editor .kind-switch{margin-top:8px}.label-editor .kind-switch.sub{margin-top:2px}.label-add-row{display:grid;grid-template-columns:1fr 1fr auto;gap:6px;margin-top:8px}.label-list-section .label-list{list-style:none;margin:4px 0 0;padding:0;display:flex;flex-direction:column;gap:4px}.label-row{display:flex;align-items:center;gap:8px;background:var(--panel-2);border:1px solid var(--border);border-radius:6px;padding:6px 8px;font-size:12px}.label-dot{width:8px;height:8px;border-radius:999px;flex-shrink:0}.label-row .pill{font-size:10px;padding:1px 7px}.label-row .pill.numeric{background:var(--accent-soft);color:var(--accent);border-color:var(--accent-soft)}.label-row .pill.categorical{background:var(--accent-3-soft);color:var(--accent-3);border-color:var(--accent-3-soft)}.label-value{color:var(--text)}.upload-divider{margin:14px 0 8px;border:none;border-top:1px dashed var(--border)}.upload-subhead{margin:0 0 4px;font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.4px}.dropzone.zip{margin-top:6px;padding:16px 12px;border-color:var(--accent-3)}.dropzone.zip:hover,.dropzone.zip.dragging{background:var(--accent-3-soft)}.zip-batch-note{margin-top:6px;padding:6px 8px;background:var(--accent-3-soft);border-left:3px solid var(--accent-3);border-radius:4px;color:var(--text)}.rec-sig-picker{display:flex;align-items:flex-end;gap:10px;padding:8px 10px;background:var(--panel);border:1px solid var(--border);border-radius:8px;box-shadow:var(--shadow-sm)}.rec-sig-picker .rs-field{display:flex;flex-direction:column;gap:3px;flex:1;min-width:0;margin:0}.rec-sig-picker .rs-field>span{font-size:10px;letter-spacing:.4px;text-transform:uppercase;color:var(--muted)}.rec-sig-picker select{font-size:13px;font-family:ui-monospace,monospace}.rec-sig-picker .rs-count{font-size:10px;color:var(--muted);font-family:ui-monospace,monospace;align-self:flex-end;margin-top:-16px;margin-bottom:6px}.rec-sig-picker .rs-nav{display:flex;gap:4px;align-self:stretch;align-items:flex-end}.rec-sig-picker .rs-nav button{padding:4px 8px}.step-params-panel{background:var(--panel);border:1px solid var(--border);border-radius:8px;padding:10px 12px;margin-bottom:10px;box-shadow:var(--shadow-sm)}.step-params-head{display:flex;align-items:center;gap:8px;margin-bottom:6px;padding-bottom:6px;border-bottom:1px solid var(--border)}.step-params-label{font-size:11px;text-transform:uppercase;letter-spacing:.4px;color:var(--muted);font-weight:600}.step-params-head .mono{font-family:ui-monospace,monospace;font-size:13px;color:var(--accent)}.plot-panel{flex:1;display:flex;flex-direction:column;min-height:320px}.plot-wrap{flex:1;min-height:280px}.channel-toggles{display:flex;gap:6px;flex-wrap:wrap}.chip{background:var(--panel-2);border:1px solid var(--border);color:var(--muted);border-radius:999px;padding:3px 10px;cursor:pointer;font-size:12px}.chip.on{background:var(--accent);color:var(--on-accent);border-color:var(--accent);font-weight:600}.window-controls{margin-left:auto;display:flex;gap:8px;align-items:center}.feature-form{display:grid;grid-template-columns:1fr 2fr auto;gap:8px;margin-bottom:12px}.feature-form textarea{grid-column:2 / 3}.features{width:100%;border-collapse:collapse;font-size:13px}.features th,.features td{text-align:left;padding:8px 10px;border-bottom:1px solid var(--border);vertical-align:top}.features th{font-size:11px;text-transform:uppercase;color:var(--muted);letter-spacing:.4px}.features td.desc{color:var(--muted);max-width:320px}.features td.value{font-family:ui-monospace,monospace}.features tr.code-row td{background:var(--panel-2)}.features tr.code-row pre{margin:0;padding:10px;background:var(--panel-2);border-radius:6px;overflow:auto;max-height:260px}.row-actions{white-space:nowrap}.badge{display:inline-block;padding:2px 8px;border-radius:999px;font-size:11px;background:var(--panel-2);color:var(--muted);border:1px solid var(--border)}.badge.generating,.badge.executing,.badge.pending{background:var(--warn-soft);color:var(--warn);border-color:#f4d7a3}.badge.computed{background:var(--accent-2-soft);color:var(--accent-2);border-color:#b9e3c5}.badge.error{background:var(--err-soft);color:var(--err);border-color:#f3b9b9}.obj .kv{margin-right:10px}.obj .kv b{color:var(--muted);font-weight:500}.err{color:var(--err)}.results-summary{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;margin-bottom:10px}.stat{background:var(--panel-2);border:1px solid var(--border);border-radius:8px;padding:8px;text-align:center}.stat b{display:block;font-size:18px}.stat span{font-size:11px;color:var(--muted)}.results-list{list-style:none;padding:0;margin:12px 0 0;display:flex;flex-direction:column;gap:6px}.results-list li{background:var(--panel-2);border:1px solid var(--border);border-radius:8px;padding:8px 10px}.r-head{display:flex;justify-content:space-between;font-size:12px}.r-value{font-family:ui-monospace,monospace;color:var(--text);margin-top:2px;font-size:13px;word-break:break-word}.template-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:12px}.template-card{background:var(--panel-2);border:1px solid var(--border);border-radius:8px;padding:12px}.template-card h4{margin:0 0 4px;font-size:14px}.template-card p{margin:0 0 8px;color:var(--muted);font-size:12px}.template-card ul{margin:0;padding-left:14px;display:flex;flex-direction:column;gap:4px}.template-card li{font-size:12px}.template-card li code{color:var(--accent);margin-right:6px}.template-card li span{color:var(--muted)}.toasts{position:fixed;top:60px;right:16px;display:flex;flex-direction:column;gap:8px;z-index:9999}.toast{background:var(--panel);border:1px solid var(--border);border-radius:8px;padding:10px 14px;min-width:200px;box-shadow:var(--shadow);font-size:13px}.toast.error{border-color:#f3b9b9;color:var(--err)}.toast.success{border-color:#b9e3c5;color:var(--accent-2)}.spinner{width:18px;height:18px;border-radius:50%;border:2px solid var(--border);border-top-color:var(--accent);animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a59;z-index:1000;display:grid;place-items:center;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);animation:fadeIn .12s ease-out}.modal{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);width:min(900px,95vw);max-height:85vh;display:flex;flex-direction:column;animation:slideUp .16s ease-out}.modal-head{display:flex;justify-content:space-between;align-items:center;padding:14px 18px;border-bottom:1px solid var(--border)}.modal-head h3{margin:0;font-size:14px;text-transform:none;color:var(--text);letter-spacing:0}.modal-body{padding:14px 18px;overflow:auto;flex:1}.modal-foot{padding:12px 18px;border-top:1px solid var(--border);display:flex;align-items:center;gap:8px}.modal-foot .spacer{flex:1}.fs-row{display:flex;gap:14px;align-items:flex-end;margin-bottom:12px;flex-wrap:wrap}.field.inline{flex-direction:column;min-width:180px;margin:0}.fs-detected{display:flex;gap:6px;align-items:center;flex-wrap:wrap;padding-bottom:6px}.chip.sm{padding:2px 8px;font-size:11px;background:var(--panel-2);color:var(--muted);cursor:pointer}.chip.sm:hover{color:var(--text);border-color:var(--accent)}.inspect-table-wrap{border:1px solid var(--border);border-radius:8px;overflow:auto;max-height:50vh}.inspect-table{width:100%;border-collapse:collapse;font-size:13px}.inspect-table th,.inspect-table td{padding:8px 10px;border-bottom:1px solid var(--border);text-align:left;vertical-align:middle}.inspect-table th{background:var(--panel-2);font-size:11px;text-transform:uppercase;letter-spacing:.4px;color:var(--muted);position:sticky;top:0;z-index:1}.inspect-table th.center,.inspect-table td.center{text-align:center}.inspect-table th.num,.inspect-table td.num{text-align:right}.inspect-table .mono{font-family:ui-monospace,monospace;font-size:12px}.inspect-table tr.signal-row{background:#4f8ff70f}.inspect-table tr.time-row{background:#7ad97a12}.inspect-table td.preview{color:var(--muted);max-width:240px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.inspect-table input[type=checkbox],.inspect-table input[type=radio]{width:auto;accent-color:var(--accent)}.tag{display:inline-block;margin-left:8px;padding:1px 6px;border-radius:999px;font-size:10px;background:var(--accent-2-soft);color:var(--accent-2);border:1px solid #b9e3c5}.tag.warn{background:var(--warn-soft);color:var(--warn);border-color:#f4d7a3}.checkbox{display:flex;gap:6px;align-items:center;margin-top:10px;font-size:12px;color:var(--muted);cursor:pointer}.checkbox input{width:auto;accent-color:var(--accent);margin:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(8px);opacity:0}to{transform:translateY(0);opacity:1}}.tabs{display:flex;gap:2px;border-bottom:1px solid var(--border);padding:0 4px}.tab{background:transparent;border:1px solid transparent;border-bottom:none;border-radius:8px 8px 0 0;padding:8px 14px;color:var(--muted);font-weight:500;font-size:13px;position:relative;bottom:-1px}.tab.active{background:var(--panel);border-color:var(--border);color:var(--text)}.tab-badge{background:var(--accent);color:var(--on-accent);border-radius:999px;padding:1px 7px;font-size:10px;margin-left:6px;font-weight:700}.tab-content{flex:1;min-height:0;overflow:auto;display:flex;flex-direction:column;gap:12px}.tab-content>*{flex-shrink:0}.tbl-wrap{border:1px solid var(--border);border-radius:8px;overflow:auto;max-height:420px}.tbl{width:100%;border-collapse:collapse;font-size:13px}.tbl th,.tbl td{padding:7px 10px;border-bottom:1px solid var(--border);text-align:left;vertical-align:middle}.tbl th{background:var(--panel-2);font-size:11px;text-transform:uppercase;letter-spacing:.4px;color:var(--muted);position:sticky;top:0;z-index:1;-webkit-user-select:none;user-select:none}.tbl th.sortable{cursor:pointer}.tbl th.sortable:hover{color:var(--text)}.tbl .sort-mark{color:var(--accent)}.tbl tr.err{background:#f07a7a0d}.tbl .mono{font-family:ui-monospace,monospace;font-size:12px}.tbl .small{font-size:11px}.tbl .edit-cell{cursor:text;display:inline-block;min-width:60px}.tbl .edit-cell:hover{text-decoration:underline dotted;text-underline-offset:2px}.tbl .placeholder{color:var(--muted);font-style:italic}.tbl .cell-input{padding:3px 6px;font-size:12px;min-width:80px}.tbl .errbox{margin:0;padding:8px;background:var(--err-soft);color:var(--err);font-size:11px;white-space:pre-wrap;word-break:break-word}.table-toolbar{display:flex;align-items:center;gap:8px;padding:6px 0;font-size:12px;color:var(--muted)}.table-toolbar .filter{width:220px;padding:5px 8px;font-size:12px}.table-toolbar .count{font-size:11px}.table-toolbar .spacer{flex:1}.kbd{background:var(--panel-2);border:1px solid var(--border);border-radius:4px;padding:1px 6px;font-family:ui-monospace,monospace;font-size:11px;color:var(--accent)}.chip.computed,.chip.ok{background:var(--accent-2-soft);color:var(--accent-2);border-color:#b9e3c5}.chip.error{background:var(--err-soft);color:var(--err);border-color:#f3b9b9}.chip.computing,.chip.pending{background:var(--warn-soft);color:var(--warn);border-color:#f4d7a3}.chip.original{background:var(--accent-soft);color:var(--accent);border-color:#c5dafa}.chip.derived{background:var(--accent-3-soft);color:var(--accent-3);border-color:#d6c8f3}.chip.mini{padding:1px 8px;font-size:11px;margin-right:4px}.dot{width:8px;height:8px;border-radius:999px;display:inline-block;background:var(--accent);margin-right:6px;vertical-align:middle}.dot.derived{background:var(--accent-3)}.dot.original{background:var(--accent)}.dot-sq{width:10px;height:10px;border-radius:3px;display:inline-block;vertical-align:middle}.signal-versions .version-list{display:flex;flex-direction:column;gap:2px}.version-row{display:flex;align-items:center;gap:4px;background:var(--panel-2);border:1px solid var(--border);border-radius:6px;padding:4px 6px}.version-row.indent{margin-left:14px;border-left:2px solid var(--border)}.version-row.active{border-color:var(--accent);background:var(--accent-soft)}.version-row .v-main{flex:1;background:transparent;border:none;text-align:left;padding:2px 4px;display:flex;align-items:center;gap:6px;font-size:12px}.version-row .v-name{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.version-row .v-meta{color:var(--muted);font-size:10px}.feature-form,.compute-table,.label-panel,.dataset-info{display:flex;flex-direction:column;gap:10px}.form-head{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.form-head h3{margin:0}.form-head p{margin:0;flex:1 1 100%}.mode-switch{margin-left:auto;display:flex;gap:2px}.mode-switch .mode{padding:4px 10px;font-size:12px;border-radius:6px;background:transparent;border:1px solid var(--border);color:var(--muted)}.mode-switch .mode.active{background:var(--accent);color:var(--on-accent);border-color:var(--accent);font-weight:600}.direct-mode,.ai-mode{display:flex;flex-direction:column;gap:8px}.direct-mode .field.grow{flex:1}.direct-mode .row,.ai-mode .row{display:flex;gap:8px;align-items:flex-end}.direct-mode .row .field{flex:1;margin:0}.ai-mode .suggestion{background:var(--panel-2);border:1px solid var(--border);border-radius:8px;padding:10px;display:flex;flex-direction:column;gap:8px}.compute-add{display:grid;grid-template-columns:180px 1fr auto;gap:6px}.compute-add .narrow{font-family:ui-monospace,monospace}.ref-chips{display:flex;flex-wrap:wrap;gap:4px;align-items:center}.label-add{display:grid;grid-template-columns:200px 1fr auto auto auto;gap:6px}.label-add input{font-size:12px}.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:8px}.stat{background:var(--panel-2);border:1px solid var(--border);border-radius:8px;padding:10px;text-align:left;display:flex;flex-direction:column;gap:2px}.stat-label{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.3px}.stat-value{font-size:18px;font-weight:600}button.danger{color:var(--err);border-color:#f3b9b9}button.danger:hover{background:var(--err-soft)}.plot-controls{margin-left:auto;display:flex;gap:8px;align-items:center;flex-wrap:wrap}.hero{padding:30px;color:var(--text)}.hero h1{font-size:28px;margin:0 0 6px}.hero p{color:var(--muted);margin:0 0 20px}.hero-pipeline{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}.hero-pipeline li{background:var(--panel-2);border:1px solid var(--border);border-radius:8px;padding:10px 12px;font-size:13px;display:flex;align-items:center;gap:10px}.hero-pipeline b{background:var(--accent);color:var(--on-accent);width:22px;height:22px;display:grid;place-items:center;border-radius:999px;font-size:12px}.err-inline{color:var(--err);font-size:11px;font-family:ui-monospace,monospace}.spinner.tiny{width:12px;height:12px;border-width:1.5px;display:inline-block;vertical-align:middle}.feature-chips{display:flex;align-items:center;flex-wrap:wrap;gap:6px;padding:6px 0 8px}.feature-chip{font-size:11px;font-family:ui-monospace,monospace;padding:2px 8px;border-radius:999px;border:1px solid;background:transparent;cursor:pointer;line-height:1.5;transition:background .12s,color .12s}.feature-chip:hover{filter:brightness(1.15)}.feature-chip.on{font-weight:600}.ml-view{display:grid;grid-template-columns:360px 1fr;gap:14px;padding:14px;height:100%;overflow:hidden}.ml-side{display:flex;flex-direction:column;gap:14px;overflow-y:auto;min-height:0;padding-right:4px}.ml-main{display:flex;flex-direction:column;gap:14px;overflow-y:auto;min-height:0}.ml-form{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);padding:14px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:12px}.ml-form h3{margin:0}.ml-feature-chips{display:flex;flex-wrap:wrap;gap:6px;max-height:180px;overflow-y:auto;padding:6px;border:1px solid var(--border);border-radius:8px;background:var(--panel-2)}.feature-chip.incomplete{border-style:dashed;opacity:.7}.feature-chip.on{background:var(--accent-soft);border-color:var(--accent);color:var(--accent)}.feature-chip.computed{border-color:var(--accent-3);color:var(--accent-3)}.feature-chip.computed.on{background:var(--accent-3-soft);color:var(--accent-3);border-color:var(--accent-3)}.feature-chip.computed i{margin-right:4px;opacity:.75}.ml-knobs{display:flex;flex-wrap:wrap;gap:12px;align-items:flex-end}.ml-knobs .field.inline{min-width:100px;max-width:130px}.ml-knobs .checkbox{display:inline-flex;align-items:center;gap:6px;font-size:13px;cursor:pointer}.ml-train-btn{align-self:flex-start;display:inline-flex;align-items:center;gap:6px;padding:8px 18px}.ml-saved{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);padding:12px;box-shadow:var(--shadow-sm)}.ml-saved h3{margin:0 0 8px}.ml-saved-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px;max-height:240px;overflow-y:auto}.ml-saved-list li{border:1px solid var(--border);border-radius:6px;padding:6px 8px;background:var(--panel-2)}.ml-saved-head{display:flex;align-items:center;gap:8px;margin-bottom:2px}.ml-saved-head .spacer{flex:1}.ml-saved-head .x{padding:2px 6px;font-size:12px;border:1px solid var(--border);background:transparent;border-radius:4px}.ml-saved-head .x:hover{color:#d33;border-color:#d33}.ml-results{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);padding:14px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:14px}.ml-results.empty{display:flex;align-items:center;justify-content:center;min-height:200px}.ml-results-head{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.ml-results-head h3{margin:0;display:inline-flex;align-items:center;gap:6px}.ml-results-head .spacer{flex:1}.metrics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:10px}.metric-card{background:var(--panel-2);border:1px solid var(--border);border-radius:8px;padding:10px 12px;display:flex;flex-direction:column;gap:2px}.metric-value{font-size:20px;font-weight:700;color:var(--accent)}.metric-label{font-size:11px;text-transform:uppercase;color:var(--muted);letter-spacing:.04em}.cm-wrap h4{margin:0 0 8px}.cm{border-collapse:collapse;font-size:12px}.cm th,.cm td{border:1px solid var(--border);padding:6px 10px;text-align:center;min-width:48px}.cm th{background:var(--panel-2);font-weight:600;color:var(--muted)}.cm-cell{font-variant-numeric:tabular-nums}.cm-cell.diag{font-weight:700;color:var(--accent)}.feat-imp h4{margin:0 0 8px}.feat-imp ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:4px}.feat-imp li{display:grid;grid-template-columns:minmax(80px,200px) 1fr 60px;align-items:center;gap:8px;font-size:12px}.fi-name{color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.fi-bar{display:block;height:8px;background:var(--panel-2);border-radius:4px;overflow:hidden}.fi-bar>span{display:block;height:100%;background:var(--accent);border-radius:4px}.fi-val{color:var(--muted);text-align:right}.roc h4{margin:0 0 6px}.roc-svg{background:var(--panel-2);border:1px solid var(--border);border-radius:6px}.roc-diag{stroke:var(--border-strong);stroke-dasharray:4 4;stroke-width:1}.roc-axis{stroke:var(--border-strong);stroke-width:1}.roc-line{stroke:var(--accent);stroke-width:2;fill:none}.roc-pt{fill:var(--accent);opacity:.7}.label-dist{display:flex;flex-direction:column;gap:4px;margin-top:6px}.label-dist-row{display:grid;grid-template-columns:80px 1fr 40px;align-items:center;gap:6px;font-size:11px}.label-dist-key{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--muted)}.label-dist-bar{display:block;height:6px;background:var(--panel-2);border-radius:3px;overflow:hidden}.label-dist-bar>span{display:block;height:100%;background:var(--accent-3);border-radius:3px}.label-dist-count{font-family:ui-monospace,monospace;text-align:right;color:var(--muted)}.ml-predict{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);padding:14px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:10px}.ml-predict h3{margin:0;display:inline-flex;align-items:center;gap:6px}.predict-result{margin-top:6px}.predict-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:4px;max-height:220px;overflow-y:auto}.predict-list li{display:flex;align-items:center;gap:8px;padding:4px 8px;background:var(--panel-2);border:1px solid var(--border);border-radius:4px;font-size:13px}.predict-list li strong{color:var(--accent)}.ml-data{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);padding:14px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:10px}.ml-data>h3{margin:0}.ml-data-head{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.ml-data-head h3{margin:0;display:inline-flex;align-items:center;gap:6px}.ml-data-head .spacer{flex:1}.ml-data-head .filter.small{font-size:12px;padding:3px 8px;width:160px}.ml-data-head .checkbox.small{font-size:12px;display:inline-flex;align-items:center;gap:4px}.ml-data-wrap{overflow:auto;max-height:420px;border:1px solid var(--border);border-radius:8px}.ml-data-table{width:100%;border-collapse:separate;border-spacing:0;font-size:12px}.ml-data-table thead th{position:sticky;top:0;z-index:2;background:var(--panel-2);border-bottom:1px solid var(--border);padding:6px 10px;font-weight:600;text-align:left;white-space:nowrap;font-size:11px;color:var(--muted);letter-spacing:.3px;cursor:pointer}.ml-data-table thead th.sortable:hover{color:var(--text);background:var(--panel)}.ml-data-table thead th.feat.selected{background:var(--accent-soft);color:var(--accent);border-bottom-color:var(--accent)}.ml-data-table thead th.feat.computed{color:var(--accent-3)}.ml-data-table thead th.feat.selected.computed{background:var(--accent-3-soft);color:var(--accent-3);border-bottom-color:var(--accent-3)}.ml-data-table thead th.lbl{background:var(--accent-2-soft);color:var(--accent-2)}.ml-data-table thead th.lbl.target{background:var(--accent-2);color:var(--on-accent);border-bottom-color:var(--accent-2)}.ml-data-table thead th.lbl.target i{margin-right:4px}.ml-data-table thead th i{margin-right:4px;opacity:.8}.ml-data-table tbody td{padding:5px 10px;border-bottom:1px solid var(--border);white-space:nowrap}.ml-data-table tbody tr:hover td{background:var(--accent-soft)}.ml-data-table .num{text-align:right}.ml-data-table .num.selected{background:#2563eb0f;color:var(--text)}.ml-data-table .lbl-cell{text-align:right;color:var(--accent-2);font-weight:600}.ml-data-table .lbl-cell.target{background:#16a34a1a}.ml-data-table .missing{color:var(--muted)}.ml-data-table .missing-mark{color:#c08400;background:#c084001a;padding:0 6px;border-radius:3px;font-size:11px}.ml-data-table .rec-name{font-weight:500;color:var(--text);max-width:220px;overflow:hidden;text-overflow:ellipsis}.ml-data-table .sticky-col{position:sticky;left:0;z-index:1;background:var(--panel)}.ml-data-table thead .sticky-col{z-index:3;background:var(--panel-2)}.ml-data-table tbody tr:hover .sticky-col{background:var(--accent-soft)}.value-inspect-btn{display:inline-flex;align-items:center;gap:4px;background:var(--panel-2);border:1px solid var(--border);border-radius:4px;padding:2px 6px;font-family:ui-monospace,monospace;font-size:12px;cursor:pointer;color:var(--accent)}.value-inspect-btn:hover{background:var(--accent-soft);border-color:var(--accent)}.value-inspector{background:var(--panel-2);border:1px solid var(--border);border-radius:6px;padding:8px;margin:4px 0;max-height:320px;overflow:hidden;display:flex;flex-direction:column}.value-inspector-head{display:flex;align-items:center;gap:8px;flex-wrap:wrap;padding-bottom:6px;border-bottom:1px dashed var(--border);margin-bottom:6px;font-size:12px}.value-inspector-head .spacer{flex:1}.value-inspector-head .filter.small{font-size:12px;padding:2px 6px;width:180px}.value-inspector-rows{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:4px;overflow-y:auto}.value-inspector-row{display:grid;grid-template-columns:60px 1fr auto;align-items:center;gap:6px;padding:2px 6px;border:1px solid var(--border);border-radius:4px;background:var(--panel);font-size:12px}.value-inspector-row .key{color:var(--muted)}.value-inspector-row .val{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.value-inspector-row .x{padding:2px 6px;font-size:11px;border:1px solid var(--border);background:transparent;border-radius:4px;color:var(--muted)}.value-inspector-row .x:hover{color:var(--accent);border-color:var(--accent)}.value-inspector-raw{margin:0;font-family:ui-monospace,monospace;font-size:11px;background:var(--panel);border:1px solid var(--border);border-radius:4px;padding:6px 8px;overflow:auto;max-height:260px}.ref-chip-group{display:inline-flex;flex-direction:column;position:relative}.chip.mini.array{border-color:var(--accent-3);color:var(--accent-3)}.chip.mini.object{border-color:var(--accent-2);color:var(--accent-2)}.chip-meta{margin-left:4px;font-size:10px;font-family:ui-monospace,monospace;opacity:.7}.ref-subpicker{position:absolute;top:100%;left:0;margin-top:4px;z-index:20;min-width:280px;max-width:540px;max-height:320px;overflow:auto;background:var(--panel);border:1px solid var(--border-strong);border-radius:6px;box-shadow:var(--shadow-lg);padding:8px}.ref-subpicker-head{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-bottom:8px;padding-bottom:6px;border-bottom:1px dashed var(--border)}.ref-subpicker-head .filter.small{font-size:12px;padding:2px 6px;flex:1;min-width:120px}.chip.mini.whole{background:var(--accent-soft);border-color:var(--accent);color:var(--accent)}.ref-subpicker-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:4px}.chip.mini.sub{display:flex;flex-direction:column;align-items:flex-start;gap:1px;padding:4px 6px;background:var(--panel-2);text-align:left}.chip.mini.sub .sub-key{font-size:11px;color:var(--accent)}.chip.mini.sub .sub-hint{font-size:10px;color:var(--muted);max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chip.mini.sub:hover{background:var(--accent-soft);border-color:var(--accent)}@media (max-width: 1100px){.workspace{grid-template-columns:1fr;grid-auto-rows:min-content;overflow:auto}.side-left,.main{overflow:visible}.landing{grid-template-columns:1fr;padding:20px}.ml-view{grid-template-columns:1fr;overflow:auto;height:auto}.ml-side,.ml-main{overflow:visible}}
