@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap";*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--bg-primary: #08090c;--bg-secondary: #0e1016;--bg-tertiary: #14161e;--bg-elevated: #1a1d28;--border-subtle: rgba(255, 255, 255, .06);--border-default: rgba(255, 255, 255, .1);--border-strong: rgba(255, 255, 255, .18);--text-primary: rgba(255, 255, 255, .92);--text-secondary: rgba(255, 255, 255, .56);--text-tertiary: rgba(255, 255, 255, .32);--accent-green: #2dd4a0;--accent-blue: #2d80d4;--accent-purple: #a02dd4;--accent-yellow: #d4a82d;--accent-red: #d42d2d;--accent-pink: #d42da0;--accent-cyan: #2da0d4;--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono: "JetBrains Mono", "SF Mono", "Fira Code", monospace;--radius-sm: 4px;--radius-md: 6px;--radius-lg: 10px;--shadow-md: 0 4px 20px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 40px rgba(0, 0, 0, .6)}html,body{width:100%;height:100%;overflow:hidden;background:var(--bg-primary);color:var(--text-primary);font-family:var(--font-sans);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#app{width:100%;height:100%}.flx-app{display:flex;flex-direction:column;width:100%;height:100%}.flx-body{flex:1;display:flex;overflow:hidden}.flx-main{flex:1;position:relative;overflow:hidden}.flx-canvas-container{width:100%;height:100%;position:relative}.flx-canvas-container canvas{display:block;width:100%;height:100%}.flx-inspector-container{position:absolute;top:0;right:0;height:100%;z-index:10;pointer-events:none}.flx-inspector-container .flx-inspector{pointer-events:auto}.flx-sidebar{display:flex;flex-direction:column;width:48px;background:var(--bg-secondary);border-right:1px solid var(--border-subtle);padding:6px 0;gap:2px;flex-shrink:0;z-index:10}.flx-sidebar-tab{display:flex;flex-direction:column;align-items:center;gap:2px;padding:8px 4px;margin:0 4px;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--text-tertiary);cursor:pointer;transition:all .15s ease}.flx-sidebar-tab:hover:not(:disabled){color:var(--text-secondary);background:var(--bg-tertiary)}.flx-sidebar-tab.active{color:var(--accent-green);background:#2dd4a014}.flx-sidebar-tab:disabled{opacity:.3;cursor:not-allowed}.flx-sidebar-icon{font-size:16px;line-height:1}.flx-sidebar-label{font-family:var(--font-sans);font-size:9px;font-weight:500;letter-spacing:.3px;text-transform:uppercase}.flx-sidebar-spacer{flex:1}.flx-sidebar-settings{margin-bottom:4px}.flx-toolbar{display:flex;align-items:center;gap:12px;padding:0 16px;height:48px;background:var(--bg-secondary);border-bottom:1px solid var(--border-subtle);user-select:none;z-index:100}.flx-toolbar-section{display:flex;align-items:center;gap:6px}.flx-toolbar-brand{gap:8px;margin-right:8px}.flx-logo{font-size:18px;color:var(--accent-green);filter:drop-shadow(0 0 6px var(--accent-green))}.flx-title{font-size:13px;font-weight:700;letter-spacing:2px;color:var(--text-primary)}.flx-toolbar-controls{flex:1;gap:6px}.flx-toolbar-actions{gap:4px}.flx-separator{width:1px;height:24px;background:var(--border-subtle);margin:0 6px}.flx-btn{display:inline-flex;align-items:center;gap:5px;padding:5px 10px;border:1px solid var(--border-subtle);border-radius:var(--radius-sm);background:var(--bg-tertiary);color:var(--text-secondary);font-family:var(--font-sans);font-size:11px;font-weight:500;cursor:pointer;transition:all .15s ease}.flx-btn:hover:not(:disabled){background:var(--bg-elevated);color:var(--text-primary);border-color:var(--border-default)}.flx-btn:active:not(:disabled){transform:scale(.97)}.flx-btn:disabled{opacity:.35;cursor:not-allowed}.flx-btn-icon{font-size:12px}.flx-btn-run{color:var(--accent-green);border-color:#2dd4a033}.flx-btn-run:hover:not(:disabled){background:#2dd4a01a;border-color:#2dd4a066;box-shadow:0 0 12px #2dd4a026}.flx-btn-ghost{background:transparent;border-color:transparent}.flx-btn-ghost:hover:not(:disabled){background:var(--bg-tertiary);border-color:var(--border-subtle)}.flx-btn-help{text-decoration:none;min-width:32px;padding:6px 8px;font-weight:700;font-size:14px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center}.flx-btn-help .flx-btn-icon{font-family:Inter,system-ui,sans-serif}.flx-btn-primary{background:var(--accent-green);color:#000;border-color:var(--accent-green);font-weight:600}.flx-btn-primary:hover:not(:disabled){background:#3de8b2;border-color:#3de8b2}.flx-mode-group{display:flex;background:var(--bg-primary);border-radius:var(--radius-sm);border:1px solid var(--border-subtle);overflow:hidden}.flx-mode-btn{padding:4px 10px;border:none;background:transparent;color:var(--text-tertiary);font-family:var(--font-sans);font-size:10px;font-weight:500;cursor:pointer;transition:all .15s ease;text-transform:uppercase;letter-spacing:.5px}.flx-mode-btn:hover{color:var(--text-secondary);background:var(--bg-tertiary)}.flx-mode-btn.active{color:var(--accent-green);background:#2dd4a014}.flx-speed-control{display:flex;align-items:center;gap:6px}.flx-speed-label{font-size:10px;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px}.flx-speed-slider{-webkit-appearance:none;appearance:none;width:60px;height:3px;background:var(--bg-elevated);border-radius:2px;outline:none}.flx-speed-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:10px;height:10px;border-radius:50%;background:var(--accent-green);cursor:pointer}.flx-speed-value{font-size:10px;font-family:var(--font-mono);color:var(--text-secondary);min-width:28px}.flx-toolbar-status{gap:6px;margin-left:auto}.flx-status-indicator{width:7px;height:7px;border-radius:50%;background:var(--text-tertiary);transition:all .3s ease}.flx-status-indicator.running{background:var(--accent-green);box-shadow:0 0 8px var(--accent-green);animation:pulse 1.5s ease infinite}.flx-status-indicator.paused{background:var(--accent-yellow);box-shadow:0 0 8px var(--accent-yellow)}.flx-status-indicator.idle{background:var(--text-tertiary)}.flx-status-text{font-size:11px;color:var(--text-secondary);font-weight:500}.flx-replay-bar{display:flex;align-items:center;gap:8px;padding:4px 16px;background:var(--bg-primary);border-bottom:1px solid var(--border-subtle)}.flx-replay-slider{flex:1;-webkit-appearance:none;appearance:none;height:3px;background:var(--bg-elevated);border-radius:2px}.flx-replay-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:12px;height:12px;border-radius:50%;background:var(--accent-cyan);cursor:pointer}.flx-replay-time{font-size:10px;font-family:var(--font-mono);color:var(--text-tertiary)}.flx-inspector{width:0;min-width:0;height:100%;background:var(--bg-secondary);border-left:1px solid var(--border-subtle);overflow:hidden;transition:width .25s ease;display:flex;flex-direction:column}.flx-inspector.open{width:340px;min-width:340px}.flx-inspector-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--border-subtle)}.flx-inspector-title{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:var(--text-secondary)}.flx-inspector-close{background:none;border:none;color:var(--text-tertiary);font-size:18px;cursor:pointer;padding:0 4px;line-height:1}.flx-inspector-close:hover{color:var(--text-primary)}.flx-inspector-body{padding:16px;overflow-y:auto;height:calc(100% - 45px)}.flx-inspect-section{margin-bottom:16px}.flx-inspect-label{font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:var(--text-tertiary);margin-bottom:6px}.flx-inspect-value{font-size:13px;color:var(--text-primary);font-weight:500}.flx-inspect-badge{display:inline-block;padding:2px 8px;border-radius:var(--radius-sm);font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.flx-inspect-badge[data-kind=input]{background:#2dd4a026;color:var(--accent-green)}.flx-inspect-badge[data-kind=validation]{background:#d4a82d26;color:var(--accent-yellow)}.flx-inspect-badge[data-kind=auth]{background:#d42da026;color:var(--accent-pink)}.flx-inspect-badge[data-kind=transform]{background:#2da0d426;color:var(--accent-cyan)}.flx-inspect-badge[data-kind=enrichment]{background:#a02dd426;color:var(--accent-purple)}.flx-inspect-badge[data-kind=database]{background:#2dd4b026;color:#2dd4b0}.flx-inspect-badge[data-kind=external-api]{background:#d42d2d26;color:var(--accent-red)}.flx-inspect-badge[data-kind=condition]{background:#a0d42d26;color:#a0d42d}.flx-inspect-badge[data-kind=response]{background:#2d80d426;color:var(--accent-blue)}.flx-inspect-badge[data-kind=error]{background:#d42d2d26;color:var(--accent-red)}.flx-inspect-badge[data-kind=db-source]{background:#22c55e26;color:#22c55e}.flx-inspect-badge[data-kind=db-table]{background:#3b82f626;color:#3b82f6}.flx-inspect-badge[data-kind=db-relation]{background:#a855f726;color:#a855f7}.flx-inspect-badge[data-kind=db-query]{background:#0ea5e926;color:#0ea5e9}.flx-inspect-badge[data-kind=db-insert]{background:#22c55e26;color:#22c55e}.flx-inspect-badge[data-kind=db-update]{background:#f59e0b26;color:#f59e0b}.flx-inspect-badge[data-kind=db-delete]{background:#ef444426;color:#ef4444}.flx-inspect-badge[data-kind=db-join]{background:#6366f126;color:#6366f1}.flx-inspect-badge[data-kind=db-where]{background:#ec489926;color:#ec4899}.flx-inspect-badge[data-kind=db-aggregate]{background:#f472b626;color:#f472b6}.flx-inspect-badge[data-kind=db-transaction]{background:#fb923c26;color:#fb923c}.flx-inspect-badge[data-kind=db-result]{background:#2dd4a026;color:#2dd4a0}.flx-demo-tag-db{background:#3b82f626!important;color:#3b82f6!important}.flx-inspect-duration{font-size:12px;font-family:var(--font-mono);color:var(--accent-cyan)}.flx-inspect-pins{display:flex;flex-direction:column;gap:4px}.flx-inspect-pin{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--text-secondary);padding:3px 6px;border-radius:var(--radius-sm);background:var(--bg-primary)}.flx-pin-dot{width:6px;height:6px;border-radius:50%;border:1.5px solid var(--text-tertiary);background:transparent}.flx-pin-dot.connected{background:var(--accent-green);border-color:var(--accent-green)}.flx-pin-type{margin-left:auto;font-size:9px;font-family:var(--font-mono);color:var(--text-tertiary)}.flx-inspect-diff{display:flex;flex-direction:column;gap:2px;margin-bottom:16px}.flx-diff-line{display:flex;align-items:center;gap:6px;padding:4px 8px;border-radius:var(--radius-sm);font-family:var(--font-mono);font-size:11px;opacity:0;transform:translate(-8px);transition:all .2s ease}.flx-diff-line.animate-in{opacity:1;transform:translate(0)}.flx-diff-line.added{background:#2dd4a014;border-left:2px solid var(--accent-green)}.flx-diff-line.removed{background:#d42d2d14;border-left:2px solid var(--accent-red)}.flx-diff-line.changed{background:#d4a82d14;border-left:2px solid var(--accent-yellow)}.flx-diff-line.unchanged{background:transparent;border-left:2px solid transparent}.flx-diff-icon{font-weight:700;width:12px;text-align:center}.flx-diff-line.added .flx-diff-icon{color:var(--accent-green)}.flx-diff-line.removed .flx-diff-icon{color:var(--accent-red)}.flx-diff-line.changed .flx-diff-icon{color:var(--accent-yellow)}.flx-diff-line.unchanged .flx-diff-icon{color:var(--text-tertiary)}.flx-diff-key{color:var(--text-secondary);font-weight:500}.flx-diff-value{color:var(--text-tertiary);margin-left:auto;text-align:right;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:140px}.flx-inspect-json{font-family:var(--font-mono);font-size:10px;line-height:1.6;color:var(--text-secondary);background:var(--bg-primary);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:10px 12px;overflow-x:auto;white-space:pre-wrap;word-break:break-word;max-height:200px}.flx-inspect-error{display:flex;align-items:center;gap:8px;padding:8px 12px;background:#d42d2d1a;border:1px solid rgba(212,45,45,.2);border-radius:var(--radius-md);margin-bottom:12px;font-size:11px;color:var(--accent-red)}.flx-error-icon{font-size:14px}.flx-snapshot-timeline{display:flex;flex-direction:column;gap:2px}.flx-timeline-entry{display:flex;gap:10px;padding:8px 10px;border-radius:var(--radius-md);cursor:pointer;transition:background .15s ease}.flx-timeline-entry:hover{background:var(--bg-tertiary)}.flx-timeline-dot{width:8px;height:8px;border-radius:50%;margin-top:4px;flex-shrink:0}.flx-timeline-dot.success{background:var(--accent-green);box-shadow:0 0 6px var(--accent-green)}.flx-timeline-dot.error{background:var(--accent-red);box-shadow:0 0 6px var(--accent-red)}.flx-timeline-content{flex:1;min-width:0}.flx-timeline-node{font-size:11px;font-weight:500;color:var(--text-primary);margin-bottom:2px}.flx-timeline-duration{font-size:10px;font-family:var(--font-mono);color:var(--text-tertiary);margin-bottom:4px}.flx-timeline-changes{display:flex;flex-wrap:wrap;gap:3px}.flx-change-badge{display:inline-block;padding:1px 5px;border-radius:3px;font-size:9px;font-family:var(--font-mono)}.flx-change-badge.added{background:#2dd4a01f;color:var(--accent-green)}.flx-change-badge.removed{background:#d42d2d1f;color:var(--accent-red)}.flx-change-badge.changed{background:#d4a82d1f;color:var(--accent-yellow)}.flx-inspect-empty{display:flex;flex-direction:column;align-items:center;gap:12px;padding:40px 20px;text-align:center;color:var(--text-tertiary);font-size:12px}.flx-inspect-empty-icon{font-size:28px;opacity:.3}.flx-context-menu{position:fixed;z-index:1000;background:var(--bg-secondary);border:1px solid var(--border-default);border-radius:var(--radius-lg);padding:4px;min-width:180px;box-shadow:var(--shadow-lg);opacity:0;transform:scale(.95) translateY(-4px);pointer-events:none;transition:all .12s ease}.flx-context-menu.open{opacity:1;transform:scale(1) translateY(0);pointer-events:all}.flx-context-header{padding:6px 12px;font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:var(--text-tertiary)}.flx-context-item{display:flex;align-items:center;gap:8px;width:100%;padding:6px 12px;border:none;background:transparent;color:var(--text-secondary);font-family:var(--font-sans);font-size:12px;cursor:pointer;border-radius:var(--radius-sm);transition:all .1s ease;text-align:left}.flx-context-item:hover{background:var(--bg-tertiary);color:var(--text-primary)}.flx-context-separator{height:1px;background:var(--border-primary);margin:4px 8px}.flx-context-icon{width:18px;text-align:center;font-size:13px}.flx-modal-overlay{position:fixed;inset:0;z-index:2000;background:#0009;backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .2s ease}.flx-modal-overlay.open{opacity:1;pointer-events:all}.flx-modal{width:560px;max-height:80vh;background:var(--bg-secondary);border:1px solid var(--border-default);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);display:flex;flex-direction:column;transform:scale(.96);transition:transform .2s ease}.flx-modal-overlay.open .flx-modal{transform:scale(1)}.flx-modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border-subtle)}.flx-modal-title{font-size:14px;font-weight:600}.flx-modal-close{background:none;border:none;color:var(--text-tertiary);font-size:20px;cursor:pointer;padding:0 4px}.flx-modal-body{flex:1;padding:16px 20px;overflow-y:auto}.flx-modal-tabs{display:flex;gap:2px;margin-bottom:12px;background:var(--bg-primary);border-radius:var(--radius-sm);padding:2px}.flx-tab{flex:1;padding:6px 12px;border:none;background:transparent;color:var(--text-tertiary);font-family:var(--font-sans);font-size:11px;font-weight:500;cursor:pointer;border-radius:var(--radius-sm);transition:all .15s ease}.flx-tab.active{background:var(--bg-tertiary);color:var(--text-primary)}.flx-schema-input{width:100%;height:280px;background:var(--bg-primary);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:12px;color:var(--text-primary);font-family:var(--font-mono);font-size:11px;line-height:1.6;resize:none;outline:none}.flx-schema-input:focus{border-color:var(--accent-green);box-shadow:0 0 0 2px #2dd4a01a}.flx-schema-input::placeholder{color:var(--text-tertiary)}.flx-demo-list{display:flex;flex-direction:column;gap:8px}.flx-demo-card{padding:14px 16px;background:var(--bg-primary);border:1px solid var(--border-subtle);border-radius:var(--radius-md);cursor:pointer;transition:all .15s ease}.flx-demo-card:hover{border-color:var(--accent-green);background:#2dd4a008}.flx-demo-title{font-size:13px;font-weight:600;margin-bottom:4px}.flx-demo-desc{font-size:11px;color:var(--text-tertiary);font-family:var(--font-mono)}.flx-modal-footer{display:flex;justify-content:flex-end;gap:8px;padding:12px 20px;border-top:1px solid var(--border-subtle)}.flx-modal-cancel{padding:6px 14px}.flx-import-error{margin-top:10px;padding:8px 12px;background:#d42d2d1a;border:1px solid rgba(212,45,45,.25);border-radius:var(--radius-md);font-size:12px;color:var(--accent-red);line-height:1.4}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-10px)}to{opacity:1;transform:translate(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-subtle);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--border-default)}.flx-connection-tooltip{position:fixed;z-index:3000;background:var(--bg-secondary);border:1px solid var(--border-default);border-radius:var(--radius-md);padding:0;box-shadow:var(--shadow-lg);opacity:0;pointer-events:none;transition:opacity .15s ease;max-width:320px;max-height:260px;overflow:hidden}.flx-connection-tooltip.visible{opacity:1}.flx-tooltip-header{padding:6px 10px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--accent-cyan);background:var(--bg-tertiary);border-bottom:1px solid var(--border-subtle)}.flx-tooltip-json{font-family:var(--font-mono);font-size:10px;line-height:1.5;color:var(--text-secondary);padding:8px 10px;margin:0;white-space:pre-wrap;word-break:break-word;max-height:200px;overflow-y:auto}.flx-inspect-hint{margin-top:16px;padding:10px 12px;background:#2d80d40f;border:1px solid rgba(45,128,212,.15);border-radius:var(--radius-md);font-size:11px;color:var(--accent-blue);line-height:1.5}.flx-format-hint{margin-bottom:10px;padding:8px 12px;background:#2dd4a00d;border:1px solid rgba(45,212,160,.12);border-radius:var(--radius-md);font-size:11px;color:var(--text-secondary);line-height:1.5}.flx-format-hint strong{color:var(--accent-green)}.flx-demo-tag{display:inline-block;margin-top:6px;padding:2px 6px;border-radius:3px;font-size:9px;font-family:var(--font-mono);background:#2dd4a01a;color:var(--accent-green);text-transform:uppercase;letter-spacing:.5px}.flx-inspector.open{border-left-color:var(--accent-green)}.flx-inspector-tabs{display:flex;gap:0;border-bottom:1px solid var(--border-subtle);margin-bottom:12px}.flx-inspector-tab{flex:1;padding:8px 12px;background:transparent;border:none;border-bottom:2px solid transparent;color:var(--text-secondary);font-family:var(--font-sans);font-size:12px;font-weight:500;cursor:pointer;transition:all .2s}.flx-inspector-tab:hover{color:var(--text-primary);background:#ffffff08}.flx-inspector-tab.active{color:var(--accent-green);border-bottom-color:var(--accent-green)}.flx-inspector-tab-content{animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.flx-config-form{display:flex;flex-direction:column;gap:12px}.flx-config-field{display:flex;flex-direction:column;gap:4px}.flx-config-field label{font-size:11px;font-weight:500;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.flx-config-input,.flx-config-select,.flx-config-textarea{background:var(--bg-primary);border:1px solid var(--border-default);border-radius:var(--radius-sm);padding:6px 10px;color:var(--text-primary);font-family:var(--font-mono);font-size:12px;outline:none;transition:border-color .2s}.flx-config-input:focus,.flx-config-select:focus,.flx-config-textarea:focus{border-color:var(--accent-green)}.flx-config-select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%23888'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center;padding-right:24px}.flx-config-textarea{resize:vertical;min-height:60px}.flx-config-sm{padding:4px 6px;font-size:11px;flex:1;min-width:0}.flx-config-row{display:flex;align-items:center;gap:6px}.flx-config-arrow{color:var(--text-tertiary);font-size:12px;flex-shrink:0}.flx-config-checkbox{display:flex;align-items:center;gap:6px;font-size:10px;font-weight:500;color:var(--text-secondary);cursor:pointer;white-space:nowrap;flex-shrink:0;text-transform:uppercase;letter-spacing:.5px}.flx-config-checkbox input[type=checkbox]{-webkit-appearance:none;appearance:none;width:14px;height:14px;border:1.5px solid var(--border-strong);border-radius:3px;background:var(--bg-primary);cursor:pointer;position:relative;flex-shrink:0;transition:all .15s ease}.flx-config-checkbox input[type=checkbox]:checked{background:var(--accent-green);border-color:var(--accent-green)}.flx-config-checkbox input[type=checkbox]:checked:after{content:"";position:absolute;left:3.5px;top:1px;width:4px;height:8px;border:solid #000;border-width:0 2px 2px 0;transform:rotate(45deg)}.flx-config-checkbox input[type=checkbox]:hover{border-color:var(--accent-green)}.flx-config-list{display:flex;flex-direction:column;gap:6px}.flx-config-list-item{background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);padding:6px 8px;animation:fadeIn .15s ease}.flx-config-add-btn{background:transparent;border:1px dashed var(--border-default);border-radius:var(--radius-sm);padding:4px 10px;color:var(--accent-green);font-size:11px;font-family:var(--font-sans);cursor:pointer;transition:all .2s}.flx-config-add-btn:hover{background:#2dd4a014;border-color:var(--accent-green)}.flx-config-remove-btn{background:transparent;border:none;color:var(--text-tertiary);font-size:14px;cursor:pointer;padding:0 4px;flex-shrink:0;transition:color .2s}.flx-config-remove-btn:hover{color:var(--accent-red)}.flx-config-actions{margin-top:8px;display:flex;justify-content:flex-end}.flx-config-save{padding:6px 16px!important;font-size:12px!important;transition:all .2s}.flx-config-save.saved{background:var(--accent-green)!important;color:#000!important}.flx-export-modal{max-width:720px;width:90vw}.flx-export-content{max-height:60vh;overflow-y:auto}.flx-export-code{background:var(--bg-primary);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:16px;margin:0;font-family:var(--font-mono);font-size:12px;line-height:1.6;color:var(--text-primary);overflow-x:auto;white-space:pre;tab-size:2}.flx-export-code-inner{display:block}.flx-syntax-keyword{color:#c678dd}.flx-syntax-string{color:#98c379}.flx-syntax-number{color:#d19a66}.flx-syntax-comment{color:#5c6370;font-style:italic}.flx-syntax-builtin{color:#61afef}.flx-demo-tag-error{background:#d42d2d1a;color:var(--accent-red)}.flx-summary-banner{position:absolute;bottom:20px;left:50%;transform:translate(-50%) translateY(20px);z-index:50;display:flex;align-items:center;gap:10px;padding:10px 18px;border-radius:var(--radius-lg);background:var(--bg-secondary);border:1px solid var(--border-default);box-shadow:var(--shadow-lg);font-family:var(--font-sans);font-size:13px;font-weight:500;color:var(--text-primary);opacity:0;pointer-events:none;transition:opacity .3s ease,transform .3s ease;max-width:600px;cursor:pointer;user-select:none}.flx-summary-banner.open{opacity:1;pointer-events:auto;transform:translate(-50%) translateY(0)}.flx-summary-icon{font-size:16px;font-weight:700;flex-shrink:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:50%}.flx-summary-success .flx-summary-icon{background:#2dd4a026;color:var(--accent-green)}.flx-summary-warning .flx-summary-icon{background:#d4a82d26;color:var(--accent-yellow)}.flx-summary-error .flx-summary-icon{background:#d42d2d26;color:var(--accent-red)}.flx-summary-success{border-color:#2dd4a04d}.flx-summary-warning{border-color:#d4a82d4d}.flx-summary-error{border-color:#d42d2d4d}.flx-summary-message{flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.flx-summary-detail{font-size:11px;color:var(--text-tertiary);white-space:nowrap;flex-shrink:0}.flx-summary-dismiss{font-size:14px;color:var(--text-tertiary);flex-shrink:0;margin-left:4px;transition:color .15s}.flx-summary-banner:hover .flx-summary-dismiss{color:var(--text-secondary)}.flx-summary-expand{font-size:11px;color:var(--accent-cyan);cursor:pointer;flex-shrink:0;padding:2px 8px;border-radius:var(--radius-sm);transition:all .15s}.flx-summary-expand:hover{background:#2da0d41f}.flx-exec-log-overlay{position:fixed;inset:0;z-index:2000;background:#0009;backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .2s ease}.flx-exec-log-overlay.open{opacity:1;pointer-events:all}.flx-exec-log{width:520px;max-height:70vh;background:var(--bg-secondary);border:1px solid var(--border-default);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);display:flex;flex-direction:column;transform:scale(.96);transition:transform .2s ease}.flx-exec-log-overlay.open .flx-exec-log{transform:scale(1)}.flx-exec-log-header{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;border-bottom:1px solid var(--border-subtle)}.flx-exec-log-title{font-size:13px;font-weight:600;letter-spacing:.5px}.flx-exec-log-close{background:none;border:none;color:var(--text-tertiary);font-size:20px;cursor:pointer;padding:0 4px}.flx-exec-log-close:hover{color:var(--text-primary)}.flx-exec-log-body{flex:1;overflow-y:auto;padding:8px 12px}.flx-exec-log-empty{text-align:center;color:var(--text-tertiary);font-size:12px;padding:32px 0}.flx-exec-log-entry{display:flex;align-items:flex-start;gap:10px;padding:8px 10px;border-radius:var(--radius-md);transition:background .1s}.flx-exec-log-entry:hover{background:var(--bg-tertiary)}.flx-exec-log-entry.error{background:#d42d2d0d}.flx-exec-log-step{font-size:10px;font-family:var(--font-mono);color:var(--text-tertiary);min-width:18px;text-align:right;margin-top:3px;flex-shrink:0}.flx-exec-log-dot{width:8px;height:8px;border-radius:50%;margin-top:5px;flex-shrink:0}.flx-exec-log-dot.success{background:var(--accent-green);box-shadow:0 0 4px var(--accent-green)}.flx-exec-log-dot.error{background:var(--accent-red);box-shadow:0 0 4px var(--accent-red)}.flx-exec-log-info{flex:1;min-width:0}.flx-exec-log-node{display:flex;align-items:center;gap:8px}.flx-exec-log-label{font-size:12px;font-weight:500;color:var(--text-primary)}.flx-exec-log-kind{font-size:9px;font-family:var(--font-mono);color:var(--text-tertiary);background:var(--bg-primary);padding:1px 5px;border-radius:3px;text-transform:uppercase;letter-spacing:.3px}.flx-exec-log-detail{font-size:11px;font-family:var(--font-mono);color:var(--text-secondary);margin-top:3px;line-height:1.4}.flx-exec-log-error{font-size:11px;color:var(--accent-red);margin-top:3px}.flx-tab-has-data{color:var(--accent-cyan)}.flx-mobile-warning{position:fixed;inset:0;z-index:99999;display:flex;align-items:center;justify-content:center;background:#08090cf5;backdrop-filter:blur(12px);opacity:0;transition:opacity .35s ease}.flx-mobile-warning.visible{opacity:1}.flx-mobile-warning-card{max-width:360px;margin:0 24px;padding:40px 32px;text-align:center;background:var(--bg-tertiary);border:1px solid var(--border-default);border-radius:var(--radius-lg);box-shadow:0 0 60px #2dd4a014,var(--shadow-lg)}.flx-mobile-warning-icon{display:inline-flex;align-items:center;justify-content:center;width:80px;height:80px;margin-bottom:20px;border-radius:50%;background:#2dd4a014;color:var(--accent-green);border:1px solid rgba(45,212,160,.2)}.flx-mobile-warning-title{font-family:var(--font-sans);font-size:20px;font-weight:600;color:var(--text-primary);margin-bottom:12px;letter-spacing:-.02em}.flx-mobile-warning-text{font-size:14px;line-height:1.6;color:var(--text-secondary);margin-bottom:8px}.flx-mobile-warning-text strong{color:var(--accent-green);font-weight:600}.flx-mobile-warning-hint{font-size:13px;color:var(--text-tertiary);margin-bottom:28px}.flx-mobile-warning-btn{display:inline-block;padding:10px 28px;font-family:var(--font-sans);font-size:13px;font-weight:500;color:var(--text-secondary);background:transparent;border:1px solid var(--border-strong);border-radius:var(--radius-md);cursor:pointer;transition:all .2s ease;letter-spacing:.02em}.flx-mobile-warning-btn:hover{color:var(--text-primary);border-color:var(--accent-green);background:#2dd4a00f;box-shadow:0 0 20px #2dd4a01a}.flx-footer{display:flex;align-items:center;justify-content:space-between;padding:0 16px;height:32px;background:var(--bg-secondary);border-top:1px solid var(--border-subtle);flex-shrink:0;user-select:none}.flx-footer-brand{display:flex;align-items:center;gap:8px}.flx-footer-logo{height:16px;width:auto;opacity:.7;transition:opacity .2s ease}.flx-footer-logo:hover{opacity:1}.flx-footer-copy{font-size:10px;color:var(--text-tertiary);letter-spacing:.3px}.flx-footer-link{font-size:10px;color:var(--text-tertiary);text-decoration:none;letter-spacing:.3px;transition:color .2s ease}.flx-footer-link:hover{color:var(--accent-green)}@media(max-width:768px){html,body{overflow:auto;overflow-x:hidden}.flx-toolbar{height:auto;min-height:44px;padding:6px 10px;gap:8px;flex-wrap:wrap;overflow-x:auto;-webkit-overflow-scrolling:touch}.flx-toolbar-brand{margin-right:4px}.flx-title{font-size:11px;letter-spacing:1.5px}.flx-logo{font-size:14px}.flx-toolbar-controls{flex:none;order:3;width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:2px;scrollbar-width:none}.flx-toolbar-controls::-webkit-scrollbar{display:none}.flx-toolbar-actions{gap:2px}.flx-toolbar-status{margin-left:0}.flx-status-text{font-size:10px;max-width:80px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.flx-btn{padding:5px 8px;font-size:10px}.flx-btn-label{display:none}.flx-btn-icon{font-size:14px}.flx-mode-btn{padding:4px 7px;font-size:9px}.flx-speed-control{gap:4px}.flx-speed-slider{width:40px}.flx-separator{margin:0 3px;height:20px}.flx-body{flex-direction:column-reverse}.flx-sidebar{flex-direction:row;width:100%;height:44px;border-right:none;border-top:1px solid var(--border-subtle);padding:0 8px;gap:0;justify-content:center}.flx-sidebar-tab{flex-direction:row;padding:6px 12px;gap:5px;margin:4px 2px}.flx-sidebar-icon{font-size:14px}.flx-sidebar-label{font-size:10px}.flx-sidebar-spacer{display:none}.flx-sidebar-settings{margin-bottom:0;margin-left:auto}.flx-main{flex:1;min-height:0}.flx-inspector-container{position:fixed;inset:auto 0 44px;height:auto;max-height:50vh;z-index:200}.flx-inspector{width:0!important;min-width:0!important;height:auto!important;max-height:50vh;border-left:none!important;border-top:1px solid var(--border-default);transition:width .25s ease,min-width .25s ease}.flx-inspector.open{width:100%!important;min-width:100%!important}.flx-inspector-body{height:auto;max-height:calc(50vh - 45px)}.flx-modal{width:calc(100vw - 24px);max-height:85vh;margin:12px}.flx-export-modal{width:calc(100vw - 24px);max-width:none}.flx-schema-input{height:200px}.flx-exec-log{width:calc(100vw - 24px);max-height:80vh}.flx-summary-banner{max-width:calc(100vw - 32px);font-size:12px;padding:8px 14px;gap:8px;bottom:56px}.flx-summary-detail{display:none}.flx-footer{height:28px;padding:0 10px}.flx-footer-logo{height:14px}.flx-footer-copy,.flx-footer-link{font-size:9px}.flx-context-menu{left:50%!important;top:auto!important;bottom:56px!important;transform:translate(-50%) scale(.95) translateY(4px);min-width:200px}.flx-context-menu.open{transform:translate(-50%) scale(1) translateY(0)}}@media(max-width:420px){.flx-toolbar{padding:4px 6px;gap:4px}.flx-toolbar-brand{gap:5px}.flx-title{font-size:10px;letter-spacing:1px}.flx-mode-btn{padding:3px 5px;font-size:8px}.flx-speed-control{display:none}.flx-sidebar-tab{padding:5px 8px}.flx-sidebar-label{display:none}}.flx-settings-overlay{position:fixed;inset:0;z-index:10000;background:#0009;backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .2s ease}.flx-settings-overlay.open{opacity:1;pointer-events:auto}.flx-settings-modal{width:560px;max-width:94vw;max-height:80vh;background:var(--bg-secondary);border:1px solid var(--border-default);border-radius:var(--radius-lg);display:flex;flex-direction:column;box-shadow:var(--shadow-lg);transform:translateY(12px) scale(.97);transition:transform .2s ease}.flx-settings-overlay.open .flx-settings-modal{transform:translateY(0) scale(1)}.flx-settings-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border-subtle)}.flx-settings-title{font-size:16px;font-weight:600;color:var(--text-primary);letter-spacing:.5px}.flx-settings-close{background:none;border:none;color:var(--text-secondary);font-size:22px;cursor:pointer;padding:0 4px;line-height:1;border-radius:var(--radius-sm);transition:color .15s,background .15s}.flx-settings-close:hover{color:var(--text-primary);background:var(--border-subtle)}.flx-settings-tabs{display:flex;gap:0;border-bottom:1px solid var(--border-subtle);padding:0 20px}.flx-settings-tab{padding:10px 18px;background:none;border:none;border-bottom:2px solid transparent;color:var(--text-secondary);font-family:var(--font-sans);font-size:13px;font-weight:500;cursor:pointer;transition:color .15s,border-color .15s}.flx-settings-tab:hover{color:var(--text-primary)}.flx-settings-tab.active{color:var(--accent-green);border-bottom-color:var(--accent-green)}.flx-settings-body{flex:1;overflow-y:auto;padding:20px}.flx-settings-pane{display:none}.flx-settings-pane.active{display:block}.flx-setting-group{display:flex;flex-direction:column;gap:4px}.flx-setting-row{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:12px 14px;border-radius:var(--radius-md);transition:background .15s}.flx-setting-row:hover{background:var(--border-subtle)}.flx-setting-info{display:flex;flex-direction:column;gap:2px;min-width:0;flex:1}.flx-setting-label{font-size:13px;font-weight:500;color:var(--text-primary)}.flx-setting-desc{font-size:11px;color:var(--text-secondary);line-height:1.3}.flx-setting-control{display:flex;align-items:center;gap:8px;flex-shrink:0}.flx-toggle{position:relative;display:inline-block;width:38px;height:20px;cursor:pointer}.flx-toggle input{opacity:0;width:0;height:0}.flx-toggle-slider{position:absolute;inset:0;background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:20px;transition:background .2s,border-color .2s}.flx-toggle-slider:before{content:"";position:absolute;left:2px;top:50%;transform:translateY(-50%);width:14px;height:14px;background:var(--text-secondary);border-radius:50%;transition:transform .2s,background .2s}.flx-toggle input:checked+.flx-toggle-slider{background:#2dd4a033;border-color:var(--accent-green)}.flx-toggle input:checked+.flx-toggle-slider:before{transform:translateY(-50%) translate(18px);background:var(--accent-green)}.flx-theme-switch{display:flex;background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-md);overflow:hidden}.flx-theme-opt{padding:5px 14px;background:none;border:none;color:var(--text-secondary);font-family:var(--font-sans);font-size:12px;font-weight:500;cursor:pointer;transition:background .15s,color .15s}.flx-theme-opt.active{background:var(--accent-green);color:#000}.flx-setting-slider{width:100px;accent-color:var(--accent-green)}.flx-setting-slider-value{font-family:var(--font-mono);font-size:12px;color:var(--text-secondary);width:36px;text-align:right}.flx-setting-select{background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-sm);color:var(--text-primary);font-family:var(--font-sans);font-size:12px;padding:5px 8px;cursor:pointer}.flx-setting-select:focus{outline:none;border-color:var(--accent-green)}.flx-storage-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.flx-storage-title{font-size:13px;font-weight:600;color:var(--text-primary)}.flx-storage-total{font-family:var(--font-mono);font-size:12px;color:var(--accent-green)}.flx-storage-slot{margin-bottom:14px}.flx-storage-slot-header{display:flex;justify-content:space-between;margin-bottom:4px}.flx-storage-slot-label{font-size:12px;color:var(--text-secondary)}.flx-storage-slot-size{font-family:var(--font-mono);font-size:11px;color:var(--text-secondary)}.flx-storage-bar{height:6px;background:var(--bg-elevated);border-radius:3px;overflow:hidden}.flx-storage-bar-fill{height:100%;border-radius:3px;transition:width .3s ease;min-width:2px}.flx-bar-api{background:var(--accent-green)}.flx-bar-sm{background:var(--accent-purple)}.flx-bar-db{background:var(--accent-cyan)}.flx-bar-settings{background:var(--accent-yellow);opacity:.6}.flx-storage-actions{display:flex;gap:10px;margin-top:20px;padding-top:16px;border-top:1px solid var(--border-subtle)}.flx-btn-danger{padding:8px 16px;background:#d42d2d26;border:1px solid rgba(212,45,45,.3);border-radius:var(--radius-md);color:var(--accent-red);font-family:var(--font-sans);font-size:12px;font-weight:500;cursor:pointer;transition:background .15s}.flx-btn-danger:hover{background:#d42d2d40}.flx-btn-secondary{padding:8px 16px;background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-md);color:var(--text-secondary);font-family:var(--font-sans);font-size:12px;font-weight:500;cursor:pointer;transition:background .15s,color .15s}.flx-btn-secondary:hover{background:var(--border-subtle);color:var(--text-primary)}.flx-settings-footer{padding:12px 20px;border-top:1px solid var(--border-subtle);display:flex;justify-content:flex-end}html.flx-light{--bg-primary: #f5f6f8;--bg-secondary: #ffffff;--bg-tertiary: #eef0f4;--bg-elevated: #e8eaef;--border-subtle: rgba(0, 0, 0, .06);--border-default: rgba(0, 0, 0, .12);--border-strong: rgba(0, 0, 0, .2);--text-primary: rgba(0, 0, 0, .87);--text-secondary: rgba(0, 0, 0, .54);--text-tertiary: rgba(0, 0, 0, .32);--shadow-md: 0 4px 20px rgba(0, 0, 0, .1);--shadow-lg: 0 8px 40px rgba(0, 0, 0, .15)}html.flx-light body{background:var(--bg-primary)}html.flx-light .flx-sidebar{background:var(--bg-secondary);border-right-color:var(--border-default)}html.flx-light .flx-toolbar{background:var(--bg-secondary);border-bottom-color:var(--border-default)}html.flx-light .flx-btn{color:var(--text-secondary)}html.flx-light .flx-btn:hover:not(:disabled){background:var(--bg-tertiary);color:var(--text-primary)}html.flx-light .flx-mode-btn{color:var(--text-secondary);border-color:var(--border-default)}html.flx-light .flx-mode-btn.active{background:var(--accent-green);color:#000}html.flx-light .flx-sidebar-tab{color:var(--text-secondary)}html.flx-light .flx-sidebar-tab:hover{background:var(--bg-tertiary);color:var(--text-primary)}html.flx-light .flx-sidebar-tab.active{background:#2dd4a01f;color:#0a8a60;border-color:#2dd4a066}html.flx-light .flx-inspector{background:var(--bg-secondary);border-left-color:var(--border-default)}html.flx-light .flx-inspector-tab.active{color:var(--accent-green);border-bottom-color:var(--accent-green)}html.flx-light .flx-inspector input,html.flx-light .flx-inspector select,html.flx-light .flx-inspector textarea{background:var(--bg-tertiary);border-color:var(--border-default);color:var(--text-primary)}html.flx-light .flx-footer{background:var(--bg-secondary);border-top-color:var(--border-default)}html.flx-light .flx-context-menu{background:var(--bg-secondary);border-color:var(--border-default)}html.flx-light .flx-context-item:hover{background:var(--bg-tertiary)}html.flx-light .flx-import-overlay .flx-import-modal,html.flx-light .flx-export-overlay .flx-export-modal,html.flx-light .flx-settings-modal{background:var(--bg-secondary);border-color:var(--border-default)}html.flx-light .flx-speed-slider{accent-color:var(--accent-green)}html.flx-light .flx-status-text{color:var(--text-secondary)}html.flx-light .flx-connection-tooltip{background:var(--bg-secondary);border-color:var(--border-default);color:var(--text-primary)}html.flx-light .flx-summary-banner,html.flx-light .flx-exec-log{background:var(--bg-secondary);border-color:var(--border-default)}
