:root{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.5}*{box-sizing:border-box}html,body,#root{width:100%;height:100%;margin:0;padding:0}body{color:#e6e8ec;background:#0f1115}button{font-family:inherit}.catalog{color:#e6e8ec;background:#0f1115;flex-direction:column;min-height:100vh;display:flex}.catalog__header{background:#12141a;border-bottom:1px solid #1f2230;align-items:center;gap:20px;padding:20px 40px;display:flex}.catalog__back{color:#e6e8ec;cursor:pointer;background:#1f2330;border:1px solid #2e3342;border-radius:6px;padding:8px 14px;font-size:13px}.catalog__back:hover{background:#272c3a;border-color:#3b82f6}.catalog__header h1{margin:0;font-size:20px;font-weight:600}.catalog__subtitle{color:#94a3b8;margin:2px 0 0;font-size:12px}.catalog__status{text-align:center;color:#94a3b8;padding:40px}.catalog__status--error{color:#fca5a5}.catalog__body{flex:1;grid-template-columns:300px 1fr;display:grid;overflow:hidden}.catalog__sidebar{background:#12141a;border-right:1px solid #1f2230;padding:16px;overflow-y:auto}.catalog__systems{flex-direction:column;gap:6px;margin-bottom:20px;display:flex}.catalog__system{color:#cbd5e1;cursor:pointer;border:1px solid #252935;border-left:3px solid var(--sys-color,#6b7280);background:#1a1d26;border-radius:6px;justify-content:space-between;align-items:center;padding:10px 14px;font-size:14px;display:flex}.catalog__system:hover{background:#22262f}.catalog__system--active{border-color:var(--sys-color,#3b82f6);color:#e6e8ec;background:#22262f}.catalog__system-name{font-weight:600}.catalog__system-count{color:#6b7280;background:#0f1115;border-radius:10px;padding:2px 8px;font-size:11px}.catalog__tables{border-top:1px solid #252935;padding-top:16px}.catalog__tables h3{text-transform:uppercase;letter-spacing:.5px;color:#6b7280;margin:0 0 12px;font-size:11px;font-weight:500}.catalog__table{text-align:left;cursor:pointer;background:0 0;border:1px solid #0000;border-radius:4px;width:100%;margin-bottom:4px;padding:8px 12px;display:block}.catalog__table:hover{background:#1a1d26}.catalog__table--active{background:#1a1d26;border-color:#3b82f6}.catalog__table-name{color:#e6e8ec;font-size:13px;font-weight:500}.catalog__table-meta{color:#6b7280;margin-top:2px;font-size:10px}.catalog__main{padding:32px 40px;overflow-y:auto}.catalog__empty{color:#6b7280;text-align:center;padding:60px 20px}.catalog__detail-header{align-items:baseline;gap:16px;margin-bottom:12px;display:flex}.catalog__detail h2{color:#e6e8ec;margin:0;font-size:22px;font-weight:600}.catalog__path{color:#6b7280;background:#12141a;border-radius:4px;padding:4px 8px;font-family:monospace;font-size:11px}.catalog__desc{color:#cbd5e1;margin:0 0 24px;font-size:14px;line-height:1.6}.catalog__meta-row{color:#cbd5e1;border-top:1px solid #1f2230;gap:16px;padding:10px 0;font-size:13px;display:flex}.catalog__meta-label{color:#6b7280;text-transform:uppercase;letter-spacing:.5px;flex-shrink:0;width:60px;padding-top:1px;font-size:11px;font-weight:500}.catalog__meta-row code{color:#60a5fa;background:#12141a;border-radius:3px;padding:2px 6px;font-family:monospace;font-size:12px}.catalog__meta-row--fk div{margin-bottom:4px}.catalog__fields{border-top:1px solid #1f2230;margin-top:24px;padding-top:20px}.catalog__fields-title{text-transform:uppercase;letter-spacing:.5px;color:#6b7280;margin-bottom:12px;font-size:11px;font-weight:500}.catalog__field-table{border-collapse:collapse;width:100%}.catalog__field-table th{text-align:left;color:#94a3b8;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid #2a2e3a;padding:8px 12px;font-size:11px;font-weight:500}.catalog__field-table td{color:#cbd5e1;border-bottom:1px solid #1f2230;padding:10px 12px;font-size:13px;line-height:1.5}.catalog__field-table td:first-child{width:200px}.catalog__field-table code{color:#60a5fa;background:#12141a;border-radius:3px;padding:2px 8px;font-family:monospace;font-size:12px}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;background:#0009;justify-content:center;align-items:center;padding:40px;display:flex;position:fixed;inset:0}.modal{background:#1a1d26;border:1px solid #2a2e3a;border-radius:12px;flex-direction:column;width:100%;max-width:640px;max-height:80vh;animation:.2s ease-out modal-in;display:flex;overflow:hidden;box-shadow:0 20px 60px #00000080}@keyframes modal-in{0%{opacity:0;transform:translateY(12px)scale(.96)}to{opacity:1;transform:translateY(0)scale(1)}}.modal__header{border-bottom:1px solid #252935;justify-content:space-between;align-items:flex-start;padding:20px 24px 16px;display:flex}.modal__kicker{color:#f59e0b;text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px;font-size:11px;font-weight:500}.modal__title{color:#e6e8ec;margin:0;font-size:18px;font-weight:600}.modal__close{color:#94a3b8;cursor:pointer;background:0 0;border:1px solid #2a2e3a;border-radius:6px;width:32px;height:32px;font-size:20px;line-height:1}.modal__close:hover{color:#e6e8ec;background:#22262f}.modal__body{flex:1;padding:24px;overflow-y:auto}.modal__loading{text-align:center;color:#94a3b8;padding:40px 20px}.modal__loading-hint{opacity:.6;margin-top:8px;font-size:12px}.spinner{border:3px solid #2a2e3a;border-top-color:#f59e0b;border-radius:50%;width:32px;height:32px;margin:0 auto 16px;animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.modal__error{color:#fca5a5;background:#7f1d1d33;border:1px solid #dc2626;border-radius:8px;padding:16px 20px}.modal__error strong{color:#fca5a5;margin-bottom:8px;font-size:14px;display:block}.modal__error p{margin:4px 0;font-size:13px;line-height:1.5}.modal__error-hint{color:#f87171;margin-top:12px;font-size:12px}.modal__error code{background:#1a1d26;border-radius:3px;padding:1px 6px;font-family:monospace;font-size:11px}.modal__insight{color:#e6e8ec;white-space:pre-wrap;font-size:14px;line-height:1.8}.dashboard{color:#e6e8ec;background:#0f1115;min-height:100vh;padding:32px 40px}.dashboard__header{border-bottom:1px solid #1f2230;justify-content:space-between;align-items:center;margin-bottom:32px;padding-bottom:20px;display:flex}.dashboard__header h1{color:#e6e8ec;margin:0;font-size:24px;font-weight:600}.dashboard__subtitle{color:#94a3b8;margin:4px 0 0;font-size:12px}.dashboard__header-actions{gap:10px;display:flex}.dashboard__catalog-btn{color:#cbd5e1;cursor:pointer;background:#1f2330;border:1px solid #2e3342;border-radius:6px;padding:10px 18px;font-size:14px;font-weight:500}.dashboard__catalog-btn:hover{color:#e6e8ec;background:#272c3a;border-color:#f59e0b}.dashboard__add-btn{color:#fff;cursor:pointer;background:#3b82f6;border:none;border-radius:6px;padding:10px 20px;font-size:14px;font-weight:500}.dashboard__add-btn:hover{background:#2563eb}.dashboard__status{color:#94a3b8;background:#1a1d26;border-radius:6px;margin-bottom:16px;padding:12px 16px;font-size:13px}.dashboard__status--error{color:#fca5a5;background:#7f1d1d33;border:1px solid #dc2626}.dashboard__empty{text-align:center;color:#94a3b8;padding:60px 20px}.dashboard__empty-icon{margin-bottom:16px;font-size:48px}.dashboard__empty-hint{opacity:.7;margin-top:8px;font-size:13px}.dashboard__grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px;display:grid}.dashboard__card{background:#1a1d26;border:1px solid #252935;border-radius:10px;transition:border-color .15s;overflow:hidden}.dashboard__card:hover{border-color:#3b82f6}.dashboard__card-header{border-bottom:1px solid #252935;justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.dashboard__card-title{color:#cbd5e1;font-size:13px;font-weight:500}.dashboard__card-actions{gap:6px;display:flex}.dashboard__card-btn{color:#94a3b8;cursor:pointer;background:0 0;border:1px solid #2a2e3a;border-radius:4px;width:26px;height:26px;padding:0;font-size:14px}.dashboard__card-btn:hover{color:#e6e8ec;background:#22262f;border-color:#3b82f6}.dashboard__card-btn--danger:hover{color:#fca5a5;background:#7f1d1d33;border-color:#dc2626}.dashboard__card-btn--ai{color:#f59e0b}.dashboard__card-btn--ai:hover{color:#fbbf24;background:#451a0333;border-color:#f59e0b}.dashboard__card-body{justify-content:center;align-items:center;min-height:140px;padding:16px;display:flex}.dashboard__card-loading{color:#6b7280;font-size:12px}.dashboard__card-error{color:#fca5a5;text-align:center;font-size:12px}.card-number{text-align:center;width:100%}.card-number__title{color:#94a3b8;margin-bottom:8px;font-size:12px}.card-number__value{color:#e6e8ec;font-size:36px;font-weight:600;line-height:1.1}.card-number__unit{color:#94a3b8;margin-left:6px;font-size:16px;font-weight:400}.card-chart{width:100%}.card-chart__title{color:#94a3b8;text-align:center;margin-bottom:8px;font-size:12px}.card-raw{color:#6b7280;max-height:120px;font-family:monospace;font-size:10px;overflow:auto}.card-insight{width:100%}.card-insight__title{color:#f59e0b;margin-bottom:10px;font-size:12px;font-weight:500}.card-insight__text{color:#cbd5e1;white-space:pre-wrap;max-height:220px;font-size:12px;line-height:1.6;overflow-y:auto}.card-insight__text--error{color:#fca5a5}.react-flow{direction:ltr}.react-flow__container{width:100%;height:100%;position:absolute;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:1px;fill:none}.react-flow__edge{pointer-events:visibleStroke;cursor:pointer}.react-flow__edge.animated path{stroke-dasharray:5;animation:.5s linear infinite dashdraw}.react-flow__edge.animated path.react-flow__edge-interaction{stroke-dasharray: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;user-select:none}.react-flow__connection{pointer-events:none}.react-flow__connection .animated{stroke-dasharray:5;animation:.5s linear infinite dashdraw}.react-flow__connectionline{z-index:1001}.react-flow__nodes{pointer-events:none;transform-origin:0 0}.react-flow__node{-webkit-user-select:none;user-select:none;pointer-events:all;transform-origin:0 0;box-sizing:border-box;cursor:-webkit-grab;cursor:grab;position:absolute}.react-flow__node.dragging{cursor:-webkit-grabbing;cursor:grabbing}.react-flow__nodesselection{z-index:3;transform-origin:0 0;pointer-events:none}.react-flow__nodesselection-rect{pointer-events:all;cursor:-webkit-grab;cursor:grab;position:absolute}.react-flow__handle{pointer-events:none;background:#1a192b;border:1px solid #fff;border-radius:100%;width:6px;min-width:5px;height:6px;min-height:5px;position:absolute}.react-flow__handle.connectionindicator{pointer-events:all;cursor:crosshair}.react-flow__handle-bottom{top:auto;bottom:-4px;left:50%;transform:translate(-50%)}.react-flow__handle-top{top:-4px;left:50%;transform:translate(-50%)}.react-flow__handle-left{top:50%;left:-4px;transform:translateY(-50%)}.react-flow__handle-right{top:50%;right:-4px;transform:translateY(-50%)}.react-flow__edgeupdater{cursor:move;pointer-events:all}.react-flow__panel{z-index:5;margin:15px;position:absolute}.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{background:#ffffff80;margin:0;padding:2px 3px;font-size:10px}.react-flow__attribution a{color:#999;text-decoration:none}@keyframes dashdraw{0%{stroke-dashoffset:10px}}.react-flow__edgelabel-renderer{pointer-events:none;-webkit-user-select:none;user-select:none;width:100%;height:100%;position:absolute}.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{color:#222;text-align:center;background-color:#fff;border:1px solid #1a192b;border-radius:3px;width:150px;padding:10px;font-size:12px}.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 #0059dccc}.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{box-sizing:content-box;cursor:pointer;-webkit-user-select:none;user-select:none;background:#fefefe;border:none;border-bottom:1px solid #eee;justify-content:center;align-items:center;width:16px;height:16px;padding:5px;display:flex}.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{background-color:#3367d9;border:1px solid #fff;border-radius:1px;width:4px;height:4px;transform:translate(-50%,-50%)}.react-flow__resize-control.handle.left{top:50%;left:0}.react-flow__resize-control.handle.right{top:50%;left:100%}.react-flow__resize-control.handle.top{top:0;left:50%}.react-flow__resize-control.handle.bottom{top:100%;left:50%}.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:0 solid #3367d9}.react-flow__resize-control.line.left,.react-flow__resize-control.line.right{width:1px;height:100%;top:0;transform:translate(-50%)}.react-flow__resize-control.line.left{border-left-width:1px;left:0}.react-flow__resize-control.line.right{border-right-width:1px;left:100%}.react-flow__resize-control.line.top,.react-flow__resize-control.line.bottom{width:100%;height:1px;left:0;transform:translateY(-50%)}.react-flow__resize-control.line.top{border-top-width:1px;top:0}.react-flow__resize-control.line.bottom{border-bottom-width:1px;top:100%}.ctx-menu{z-index:200;background:#1a1d26;border:1px solid #2a2e3a;border-radius:8px;min-width:180px;padding:4px;animation:.1s ease-out ctx-in;position:fixed;box-shadow:0 8px 24px #00000080}@keyframes ctx-in{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.ctx-menu__item{color:#cbd5e1;text-align:left;cursor:pointer;background:0 0;border:none;border-radius:4px;align-items:center;gap:10px;width:100%;padding:8px 14px;font-size:13px;display:flex}.ctx-menu__item:hover:not(:disabled){color:#e6e8ec;background:#22262f}.ctx-menu__item:disabled{color:#475569;cursor:not-allowed}.ctx-menu__item--danger:hover:not(:disabled){color:#fca5a5;background:#7f1d1d33}.ctx-menu__icon{text-align:center;width:18px;font-size:14px}.gen-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;background:#0009;justify-content:center;align-items:center;padding:40px;display:flex;position:fixed;inset:0}.gen-modal{background:#1a1d26;border:1px solid #2a2e3a;border-radius:12px;flex-direction:column;width:100%;max-width:560px;animation:.2s ease-out gen-in;display:flex;overflow:hidden;box-shadow:0 20px 60px #00000080}@keyframes gen-in{0%{opacity:0;transform:translateY(12px)scale(.96)}to{opacity:1;transform:translateY(0)scale(1)}}.gen-modal__header{border-bottom:1px solid #252935;justify-content:space-between;align-items:flex-start;padding:20px 24px 16px;display:flex}.gen-modal__kicker{color:#f59e0b;text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px;font-size:11px;font-weight:500}.gen-modal__title{color:#e6e8ec;margin:0;font-size:16px;font-weight:600}.gen-modal__close{color:#94a3b8;cursor:pointer;background:0 0;border:1px solid #2a2e3a;border-radius:6px;width:32px;height:32px;font-size:20px;line-height:1}.gen-modal__close:hover{color:#e6e8ec;background:#22262f}.gen-modal__body{padding:20px 24px}.gen-modal__textarea{color:#e6e8ec;resize:vertical;background:#12141a;border:1px solid #252935;border-radius:6px;width:100%;padding:12px;font-family:inherit;font-size:14px}.gen-modal__textarea:focus{border-color:#f59e0b;outline:none}.gen-modal__samples{flex-wrap:wrap;align-items:center;gap:6px;margin-top:12px;display:flex}.gen-modal__samples-label{color:#6b7280;margin-right:4px;font-size:11px}.gen-modal__sample{color:#94a3b8;cursor:pointer;background:#12141a;border:1px solid #252935;border-radius:12px;padding:4px 10px;font-size:11px}.gen-modal__sample:hover:not(:disabled){color:#e6e8ec;background:#1f2330;border-color:#f59e0b}.gen-modal__sample:disabled{opacity:.4;cursor:not-allowed}.gen-modal__error{color:#fca5a5;background:#7f1d1d33;border:1px solid #dc2626;border-radius:6px;margin-top:12px;padding:10px 14px;font-size:12px}.gen-modal__hint{color:#6b7280;margin-top:16px;font-size:11px;line-height:1.6}.gen-modal__footer{background:#12141a;border-top:1px solid #252935;justify-content:flex-end;gap:8px;padding:16px 24px;display:flex}.gen-modal__btn{color:#e6e8ec;cursor:pointer;background:#1f2330;border:1px solid #2e3342;border-radius:6px;padding:8px 16px;font-size:13px;font-weight:500}.gen-modal__btn:hover:not(:disabled){background:#272c3a}.gen-modal__btn:disabled{opacity:.4;cursor:not-allowed}.gen-modal__btn--primary{color:#0f1115;background:#f59e0b;border-color:#f59e0b;font-weight:600}.gen-modal__btn--primary:hover:not(:disabled){background:#fbbf24;border-color:#fbbf24}.block-node{color:#e6e8ec;background:#1a1d26;border:2px solid #3b82f6;border-radius:8px;min-width:180px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:12px;position:relative;overflow:visible;box-shadow:0 2px 8px #0000004d}.block-node--selected{box-shadow:0 0 0 2px #60a5fa80,0 2px 8px #0000004d}.block-node__header{color:#fff;background:#3b82f6;border-radius:6px 6px 0 0;justify-content:space-between;align-items:center;padding:6px 12px;font-weight:600;display:flex}.block-node__label{font-size:13px}.block-node__category{text-transform:uppercase;letter-spacing:.5px;opacity:.8;font-family:monospace;font-size:9px}.block-node__section{border-top:1px solid #252935;padding:4px 0}.block-node__section:last-child{border-bottom:none;border-radius:0 0 6px 6px}.block-node__row{align-items:center;height:22px;padding:0 14px;display:flex;position:relative}.block-node__row--in{justify-content:flex-start}.block-node__row--out{justify-content:flex-end}.block-node__port-name{color:#94a3b8;font-family:monospace;font-size:11px}.block-node .react-flow__handle{background:#60a5fa;border:2px solid #0f1115;border-radius:50%;width:12px;height:12px}.block-node .react-flow__handle-left{left:-6px}.block-node .react-flow__handle-right{right:-6px}.block-node .react-flow__handle:hover{cursor:crosshair;background:#3b82f6;transform:scale(1.3)}.block-node .react-flow__handle-connecting,.block-node .react-flow__handle-valid{background:#10b981}.flow-editor{color:#e6e8ec;background:#0f1115;grid-template:"topbar topbar topbar"48px"palette canvas property"1fr/220px 1fr 280px;height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;display:grid}.flow-editor__topbar{background:#12141a;border-bottom:1px solid #1f2230;grid-area:topbar;align-items:center;gap:12px;padding:0 16px;display:flex}.topbar__btn{color:#e6e8ec;cursor:pointer;background:#1f2330;border:1px solid #2e3342;border-radius:6px;padding:6px 14px;font-size:13px;font-weight:500}.topbar__btn:hover:not(:disabled){background:#272c3a;border-color:#3b82f6}.topbar__btn:disabled{opacity:.4;cursor:not-allowed}.topbar__btn--primary{color:#fff;background:#3b82f6;border-color:#3b82f6}.topbar__btn--primary:hover:not(:disabled){background:#2563eb;border-color:#2563eb}.topbar__btn--ai{color:#f59e0b;background:#451a0333;border-color:#f59e0b55;margin-left:auto}.topbar__btn--ai:hover:not(:disabled){background:#451a0366;border-color:#f59e0b}.topbar__title{color:#e6e8ec;background:#1a1d26;border:1px solid #252935;border-radius:6px;flex:1;max-width:400px;padding:6px 12px;font-size:14px;font-weight:500}.topbar__title:focus{border-color:#3b82f6;outline:none}.node-palette{grid-area:palette}.flow-editor__canvas{grid-area:canvas}.property-panel{grid-area:property}.flow-editor__canvas{flex-direction:column;min-width:0;display:flex;position:relative}.flow-editor__runbar{z-index:10;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#1e2028f2;border:1px solid #2a2e3a;border-radius:8px;align-items:center;gap:12px;padding:8px 16px;display:flex;position:absolute;top:12px;left:50%;transform:translate(-50%)}.runbar__btn{color:#e6e8ec;cursor:pointer;background:#1f2330;border:1px solid #2e3342;border-radius:6px;padding:6px 14px;font-size:13px;font-weight:500}.runbar__btn:disabled{opacity:.4;cursor:not-allowed}.runbar__btn:hover:not(:disabled){background:#272c3a;border-color:#3b82f6}.runbar__btn--primary{color:#fff;background:#3b82f6;border-color:#3b82f6}.runbar__btn--primary:hover:not(:disabled){background:#2563eb;border-color:#2563eb}.runbar__btn--danger:hover:not(:disabled){background:#7f1d1d;border-color:#dc2626}.flow-editor__hint{color:#94a3b8;font-size:12px}.node-palette{background:#12141a;border-right:1px solid #1f2230;padding:16px;overflow-y:auto}.node-palette h2{color:#e6e8ec;margin:0 0 16px;font-size:14px;font-weight:600}.node-palette h3{text-transform:uppercase;color:#6b7280;letter-spacing:.5px;margin:16px 0 8px;font-size:11px;font-weight:500}.node-palette__item{color:#e6e8ec;text-align:left;cursor:pointer;background:#1a1d26;border:1px solid #252935;border-radius:6px;flex-direction:column;align-items:flex-start;width:100%;margin-bottom:6px;padding:8px 12px;transition:all .15s;display:flex}.node-palette__item:hover{background:#22262f;border-color:#3b82f6}.node-palette__label{font-size:13px;font-weight:500}.node-palette__type{color:#6b7280;margin-top:2px;font-family:monospace;font-size:10px}.property-panel{background:#12141a;border-left:1px solid #1f2230;padding:16px;overflow-y:auto}.property-panel h2{margin:0 0 8px;font-size:14px;font-weight:600}.property-panel__hint{color:#94a3b8;margin:0 0 16px;font-size:12px}.property-panel__empty{color:#6b7280;font-size:12px}.field{flex-direction:column;margin-bottom:12px;display:flex}.field label{color:#cbd5e1;margin-bottom:4px;font-size:12px;font-weight:500}.field input,.field select{color:#e6e8ec;background:#1a1d26;border:1px solid #252935;border-radius:4px;padding:6px 8px;font-size:13px}.field input:focus,.field select:focus{border-color:#3b82f6;outline:none}.field small{color:#6b7280;margin-top:4px;font-size:10px}.field__cols-hint{word-break:break-all;margin-top:6px;font-size:10px;line-height:1.5;color:#f59e0b!important}.result-display{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:10;background:#14161cf2;border:1px solid #2a2e3a;border-radius:8px;min-width:300px;max-width:600px;padding:16px 20px;position:absolute;bottom:20px;left:50%;transform:translate(-50%)}.result-display--error{color:#fca5a5;border-color:#dc2626}.result-cards{flex-wrap:wrap;gap:12px;margin-top:8px;display:flex}.kpi-card{background:#1a1d26;border:1px solid #2a2e3a;border-radius:8px;min-width:140px;padding:16px 20px}.kpi-card__title{color:#94a3b8;margin-bottom:4px;font-size:12px}.kpi-card__value{color:#e6e8ec;font-size:28px;font-weight:600}.kpi-card__unit{color:#94a3b8;margin-left:4px;font-size:14px;font-weight:400}.result-raw{background:#0a0c10;border-radius:4px;max-height:200px;padding:8px;font-family:monospace;font-size:11px;overflow:auto}.react-flow__node-default{color:#e6e8ec;background:#1a1d26;border:1px solid #3b82f6;border-radius:6px;min-width:120px;padding:8px 12px;font-size:12px}.react-flow__node-default.selected{border-color:#60a5fa;box-shadow:0 0 0 2px #3b82f64d}.react-flow__edge-path{stroke:#475569}.react-flow__edge.selected .react-flow__edge-path,.react-flow__edge:hover .react-flow__edge-path{stroke:#3b82f6}.react-flow__handle{background:#3b82f6;border:2px solid #12141a;width:10px;height:10px}.react-flow__controls{background:#1a1d26;border:1px solid #2a2e3a}.react-flow__controls button{color:#e6e8ec;background:#1a1d26;border-bottom:1px solid #2a2e3a}.react-flow__controls button:hover{background:#22262f}
