@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";@import"https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@400;500;600&display=swap";@import"https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.4.0/css/all.min.css";#app{min-height:100vh;background:var(--color-background)}:root{--color-bg-light: #F6F8FA;--color-bg-dark: #0E1117;--color-surface-light: #FFFFFF;--color-surface-dark: #161B22;--color-border-light: rgba(0,0,0,.08);--color-border-dark: rgba(255,255,255,.08);--color-primary: #007AFF;--color-primary-hover: #005FCC;--color-primary-light: rgba(0, 122, 255, .1);--color-primary-dark: #0051D5;--color-primary-subtle: rgba(0, 122, 255, .05);--color-primary-gradient: linear-gradient(135deg, #007AFF 0%, #64D2FF 100%);--color-accent-cyan: #64D2FF;--color-accent-amber: #FF9500;--color-accent-green: #30D158;--color-accent-red: #FF453A;--gradient-flow-blue: linear-gradient(135deg, #007AFF 0%, #64D2FF 100%);--gradient-warning-amber: linear-gradient(135deg, #FF9500 0%, #FFD60A 100%);--gradient-data-green: linear-gradient(135deg, #30D158 0%, #34C759 100%);--gradient-error-red: linear-gradient(135deg, #FF453A 0%, #FF6B6B 100%);--gradient-success: linear-gradient(135deg, #30D158 0%, #34C759 100%);--gradient-primary: linear-gradient(135deg, #007AFF 0%, #5AC8FA 100%);--gradient-text: linear-gradient(135deg, #007AFF 0%, #5AC8FA 100%);--color-background: #FFFFFF;--color-background-elevated: #FFFFFF;--color-background-subtle: #F8FAFC;--color-background-secondary: #F1F5F9;--color-background-tertiary: #E2E8F0;--color-background-hover: rgba(0, 122, 255, .04);--color-background-disabled: #F1F5F9;--color-background-code: #F8FAFC;--color-background-canvas: #FAFBFC;--color-canvas-bg: #F6F8FA;--color-canvas-bg-dark: #0E1117;--glass-bg: rgba(255, 255, 255, .85);--glass-border: rgba(0, 0, 0, .08);--glass-backdrop: blur(20px);--glass-shadow: 0 8px 32px rgba(0, 0, 0, .08);--color-text-primary: #0E1117;--color-text-secondary: #4B5563;--color-text-tertiary: #6B7280;--color-text-disabled: #9CA3AF;--color-text-inverse: #FFFFFF;--color-text-code: #1F2937;--color-text-accent: var(--color-primary);--color-text-muted: #64748B;--color-border: rgba(0, 0, 0, .08);--color-border-subtle: rgba(0, 0, 0, .04);--color-border-hover: rgba(0, 122, 255, .2);--color-border-focus: var(--color-primary);--color-border-error: var(--color-accent-red);--color-border-light: rgba(0, 0, 0, .06);--color-success: #30D158;--color-success-light: rgba(48, 209, 88, .1);--color-success-subtle: rgba(48, 209, 88, .05);--color-success-hover: #28CA4A;--color-success-dark: #248A3D;--color-warning: #FF9500;--color-warning-light: rgba(255, 149, 0, .1);--color-warning-subtle: rgba(255, 149, 0, .05);--color-warning-hover: #FF8F00;--color-warning-dark: #CC7A00;--color-danger: #FF453A;--color-danger-light: rgba(255, 69, 58, .1);--color-danger-subtle: rgba(255, 69, 58, .05);--color-danger-hover: #FF3B30;--color-danger-dark: #CC362B;--color-info: #64D2FF;--color-info-light: rgba(100, 210, 255, .1);--color-info-subtle: rgba(100, 210, 255, .05);--color-info-hover: #4FC3F7;--color-info-dark: #33B5E5;--color-canvas-grid: rgba(0, 122, 255, .15);--color-canvas-grid-dots: rgba(0, 0, 0, .2);--color-connector: rgba(100, 210, 255, .6);--color-connector-active: var(--color-accent-cyan);--color-api-node: var(--color-primary);--color-api-node-light: rgba(0, 122, 255, .08);--color-api-node-gradient: var(--gradient-flow-blue);--color-functional-node: var(--color-accent-amber);--color-functional-node-light: rgba(255, 149, 0, .08);--color-functional-node-gradient: var(--gradient-warning-amber);--color-transform-node: var(--color-accent-amber);--color-transform-node-light: rgba(255, 149, 0, .08);--color-transform-node-gradient: var(--gradient-warning-amber);--color-condition-node: var(--color-accent-cyan);--color-condition-node-light: rgba(100, 210, 255, .08);--color-condition-node-gradient: linear-gradient(135deg, #64D2FF 0%, #81E6FF 100%);--color-output-node: var(--color-accent-green);--color-output-node-light: rgba(48, 209, 88, .08);--color-output-node-gradient: var(--gradient-data-green);--color-error-node: var(--color-accent-red);--color-error-node-light: rgba(255, 69, 58, .08);--color-error-node-gradient: var(--gradient-error-red);--font-family-base: "Inter", "SF Pro Text", "Segoe UI", sans-serif;--font-family-mono: "JetBrains Mono", "Fira Code", "SF Mono", monospace;--font-size-xs: 11px;--font-size-sm: 13px;--font-size-md: 14px;--font-size-lg: 16px;--font-size-xl: 20px;--font-size-2xl: 28px;--font-size-3xl: 36px;--font-size-4xl: 48px;--font-weight-light: 300;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--line-height-tight: 1.2;--line-height-normal: 1.5;--line-height-loose: 1.8;--letter-spacing-tight: -.01em;--letter-spacing-normal: .02em;--letter-spacing-wide: .04em;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--spacing-2xl: 48px;--spacing-3xl: 64px;--spacing-4xl: 96px;--radius-xs: 4px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px;--radius-2xl: 24px;--radius-full: 9999px;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .03);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .07);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .08);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .08);--shadow-2xl: 0 25px 50px -12px rgba(0, 0, 0, .15);--shadow-card: var(--glass-shadow);--shadow-inner: inset 0 2px 4px 0 rgba(0, 0, 0, .04);--shadow-none: none;--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-normal: .25s cubic-bezier(.4, 0, .2, 1);--transition-slow: .35s cubic-bezier(.4, 0, .2, 1);--transition-spring: .3s cubic-bezier(.34, 1.56, .64, 1);--z-dropdown: 1000;--z-sticky: 1010;--z-fixed: 1020;--z-modal-backdrop: 1030;--z-modal: 1040;--z-popover: 1050;--z-tooltip: 1060;--z-toast: 1070;--z-alert: 1080}*{box-sizing:border-box}.light-theme{color-scheme:light;--color-background: #FFFFFF;--color-background-elevated: #FFFFFF;--color-background-subtle: #F8FAFC;--color-text-primary: #0E1117;--color-text-secondary: #4B5563;--glass-bg: rgba(255, 255, 255, .85);--glass-border: rgba(0, 0, 0, .08)}html{font-size:16px;line-height:var(--line-height-normal);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color-scheme:light}body{margin:0;padding:0;font-family:var(--font-family-base);background-color:var(--color-background);color:var(--color-text-primary);overflow:hidden;font-feature-settings:"kern" 1,"liga" 1,"calt" 1}h1,h2,h3,h4,h5,h6{margin:0;font-weight:var(--font-weight-semibold);line-height:var(--line-height-tight);color:var(--color-text-primary);letter-spacing:var(--letter-spacing-tight)}h1{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold)}h2{font-size:var(--font-size-xl)}h3{font-size:var(--font-size-lg)}h4{font-size:var(--font-size-md);font-weight:var(--font-weight-medium)}h5{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium)}h6{font-size:var(--font-size-xs);font-weight:var(--font-weight-medium)}p{margin:0;line-height:var(--line-height-normal);color:var(--color-text-secondary)}.glass-panel{background:var(--glass-bg);backdrop-filter:var(--glass-backdrop);-webkit-backdrop-filter:var(--glass-backdrop);border:1px solid var(--glass-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-card)}.glass-button{background:var(--glass-bg);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid var(--glass-border);transition:all var(--transition-spring)}.glass-button:hover{background:#ffffffe6;transform:translateY(-1px);box-shadow:var(--shadow-lg)}.node-api{background:var(--color-api-node-gradient);border-color:var(--color-api-node);color:#fff}.node-transform{background:var(--color-transform-node-gradient);border-color:var(--color-transform-node);color:#fff}.node-condition{background:var(--color-condition-node-gradient);border-color:var(--color-condition-node);color:#fff}.node-output{background:var(--color-output-node-gradient);border-color:var(--color-output-node);color:#fff}.node-error{background:var(--color-error-node-gradient);border-color:var(--color-error-node);color:#fff}.text-xs{font-size:var(--font-size-xs)}.text-sm{font-size:var(--font-size-sm)}.text-md{font-size:var(--font-size-md)}.text-lg{font-size:var(--font-size-lg)}.text-xl{font-size:var(--font-size-xl)}.text-2xl{font-size:var(--font-size-2xl)}.font-light{font-weight:var(--font-weight-light)}.font-normal{font-weight:var(--font-weight-normal)}.font-medium{font-weight:var(--font-weight-medium)}.font-semibold{font-weight:var(--font-weight-semibold)}.font-bold{font-weight:var(--font-weight-bold)}.text-primary{color:var(--color-text-primary)}.text-secondary{color:var(--color-text-secondary)}.text-tertiary{color:var(--color-text-tertiary)}.text-accent{color:var(--color-text-accent)}.text-inverse{color:var(--color-text-inverse)}.p-xs{padding:var(--spacing-xs)}.p-sm{padding:var(--spacing-sm)}.p-md{padding:var(--spacing-md)}.p-lg{padding:var(--spacing-lg)}.p-xl{padding:var(--spacing-xl)}.m-xs{margin:var(--spacing-xs)}.m-sm{margin:var(--spacing-sm)}.m-md{margin:var(--spacing-md)}.m-lg{margin:var(--spacing-lg)}.m-xl{margin:var(--spacing-xl)}.gap-xs{gap:var(--spacing-xs)}.gap-sm{gap:var(--spacing-sm)}.gap-md{gap:var(--spacing-md)}.gap-lg{gap:var(--spacing-lg)}.gap-xl{gap:var(--spacing-xl)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.justify-start{justify-content:flex-start}.justify-end{justify-content:flex-end}.grid{display:grid}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.rounded-xs{border-radius:var(--radius-xs)}.rounded-sm{border-radius:var(--radius-sm)}.rounded-md{border-radius:var(--radius-md)}.rounded-lg{border-radius:var(--radius-lg)}.rounded-xl{border-radius:var(--radius-xl)}.rounded-2xl{border-radius:var(--radius-2xl)}.rounded-full{border-radius:var(--radius-full)}.shadow-sm{box-shadow:var(--shadow-sm)}.shadow-md{box-shadow:var(--shadow-md)}.shadow-lg{box-shadow:var(--shadow-lg)}.shadow-xl{box-shadow:var(--shadow-xl)}.shadow-2xl{box-shadow:var(--shadow-2xl)}.shadow-none{box-shadow:var(--shadow-none)}.focus-ring:focus{outline:none;box-shadow:0 0 0 3px var(--color-primary-light);border-color:var(--color-border-focus)}.transition{transition:all var(--transition-normal)}.transition-fast{transition:all var(--transition-fast)}.transition-slow{transition:all var(--transition-slow)}.transition-spring{transition:all var(--transition-spring)}.flow-connector{stroke:var(--color-connector);stroke-width:2px;fill:none;transition:all var(--transition-normal)}.flow-connector:hover,.flow-connector.active{stroke:var(--color-connector-active);stroke-width:3px;filter:drop-shadow(0 0 8px var(--color-connector-active))}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}@keyframes pulse-glow{0%,to{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(1.02)}}@keyframes flow-data{0%{stroke-dashoffset:20}to{stroke-dashoffset:0}}.pulse-glow{animation:pulse-glow 2s ease-in-out infinite}.flow-data{stroke-dasharray:5,5;animation:flow-data 1s linear infinite}@media (max-width: 768px){:root{--font-size-xs: 10px;--font-size-sm: 12px;--font-size-md: 13px;--font-size-lg: 15px;--font-size-xl: 18px;--font-size-2xl: 24px;--spacing-xs: 2px;--spacing-sm: 4px;--spacing-md: 8px;--spacing-lg: 12px;--spacing-xl: 16px}}.vue-flow{position:relative;width:100%;height:100%;overflow:hidden;z-index:0;direction:ltr}.vue-flow__container{position:absolute;height:100%;width:100%;left:0;top:0}.vue-flow__pane{z-index:1}.vue-flow__pane.draggable{cursor:grab}.vue-flow__pane.selection{cursor:pointer}.vue-flow__pane.dragging{cursor:grabbing}.vue-flow__transformationpane{transform-origin:0 0;z-index:2;pointer-events:none}.vue-flow__viewport{z-index:4;overflow:clip}.vue-flow__selection{z-index:6}.vue-flow__edge-labels{position:absolute;width:100%;height:100%;pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.vue-flow__nodesselection-rect:focus,.vue-flow__nodesselection-rect:focus-visible{outline:none}.vue-flow .vue-flow__edges{pointer-events:none;overflow:visible}.vue-flow__edge-path,.vue-flow__connection-path{stroke:#b1b1b7;stroke-width:1;fill:none}.vue-flow__edge{pointer-events:visibleStroke;cursor:pointer}.vue-flow__edge.animated path{stroke-dasharray:5;animation:dashdraw .5s linear infinite}.vue-flow__edge.animated path.vue-flow__edge-interaction{stroke-dasharray:none;animation:none}.vue-flow__edge.inactive{pointer-events:none}.vue-flow__edge.selected,.vue-flow__edge:focus,.vue-flow__edge:focus-visible{outline:none}.vue-flow__edge.selected .vue-flow__edge-path,.vue-flow__edge:focus .vue-flow__edge-path,.vue-flow__edge:focus-visible .vue-flow__edge-path{stroke:#555}.vue-flow__edge-textwrapper{pointer-events:all}.vue-flow__edge-text{pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.vue-flow__connection{pointer-events:none}.vue-flow__connection .animated{stroke-dasharray:5;animation:dashdraw .5s linear infinite}.vue-flow__connectionline{z-index:1001}.vue-flow__nodes{pointer-events:none;transform-origin:0 0}.vue-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:default}.vue-flow__node.draggable{cursor:grab;pointer-events:all}.vue-flow__node.draggable.dragging{cursor:grabbing}.vue-flow__nodesselection{z-index:3;transform-origin:left top;pointer-events:none}.vue-flow__nodesselection-rect{position:absolute;pointer-events:all;cursor:grab}.vue-flow__nodesselection-rect.dragging{cursor:grabbing}.vue-flow__handle{position:absolute;pointer-events:none;min-width:5px;min-height:5px}.vue-flow__handle.connectable{pointer-events:all;cursor:crosshair}.vue-flow__handle-bottom{left:50%;bottom:0;transform:translate(-50%,50%)}.vue-flow__handle-top{left:50%;top:0;transform:translate(-50%,-50%)}.vue-flow__handle-left{top:50%;left:0;transform:translate(-50%,-50%)}.vue-flow__handle-right{top:50%;right:0;transform:translate(50%,-50%)}.vue-flow__edgeupdater{cursor:move;pointer-events:all}.vue-flow__panel{position:absolute;z-index:5;margin:15px}.vue-flow__panel.top{top:0}.vue-flow__panel.bottom{bottom:0}.vue-flow__panel.left{left:0}.vue-flow__panel.right{right:0}.vue-flow__panel.center{left:50%;transform:translate(-50%)}@keyframes dashdraw{0%{stroke-dashoffset:10}}:root{--vf-node-bg: #fff;--vf-node-text: #222;--vf-connection-path: #b1b1b7;--vf-handle: #555}.vue-flow__edge.updating .vue-flow__edge-path{stroke:#777}.vue-flow__edge-text{font-size:10px}.vue-flow__edge-textbg{fill:#fff}.vue-flow__connection-path{stroke:var(--vf-connection-path)}.vue-flow__node{cursor:grab}.vue-flow__node.selectable:focus,.vue-flow__node.selectable:focus-visible{outline:none}.vue-flow__node-default,.vue-flow__node-input,.vue-flow__node-output{padding:10px;border-radius:3px;width:150px;font-size:12px;text-align:center;border-width:1px;border-style:solid;color:var(--vf-node-text);background-color:var(--vf-node-bg);border-color:var(--vf-node-color)}.vue-flow__node-default.selected,.vue-flow__node-default.selected:hover,.vue-flow__node-input.selected,.vue-flow__node-input.selected:hover,.vue-flow__node-output.selected,.vue-flow__node-output.selected:hover{box-shadow:0 0 0 .5px var(--vf-box-shadow)}.vue-flow__node-default.selected,.vue-flow__node-default:focus,.vue-flow__node-default:focus-visible,.vue-flow__node-input.selected,.vue-flow__node-input:focus,.vue-flow__node-input:focus-visible,.vue-flow__node-output.selected,.vue-flow__node-output:focus,.vue-flow__node-output:focus-visible{outline:none;border:1px solid #555}.vue-flow__node-default .vue-flow__handle,.vue-flow__node-input .vue-flow__handle,.vue-flow__node-output .vue-flow__handle{background:var(--vf-handle)}.vue-flow__node-default.selectable:hover,.vue-flow__node-input.selectable:hover,.vue-flow__node-output.selectable:hover{box-shadow:0 1px 4px 1px #00000014}.vue-flow__node-input{--vf-node-color: var(--vf-node-color, #0041d0);--vf-handle: var(--vf-node-color, #0041d0);--vf-box-shadow: var(--vf-node-color, #0041d0);background:var(--vf-node-bg);border-color:var(--vf-node-color, #0041d0)}.vue-flow__node-input.selected,.vue-flow__node-input:focus,.vue-flow__node-input:focus-visible{outline:none;border:1px solid var(--vf-node-color, #0041d0)}.vue-flow__node-default{--vf-handle: var(--vf-node-color, #1a192b);--vf-box-shadow: var(--vf-node-color, #1a192b);background:var(--vf-node-bg);border-color:var(--vf-node-color, #1a192b)}.vue-flow__node-default.selected,.vue-flow__node-default:focus,.vue-flow__node-default:focus-visible{outline:none;border:1px solid var(--vf-node-color, #1a192b)}.vue-flow__node-output{--vf-handle: var(--vf-node-color, #ff0072);--vf-box-shadow: var(--vf-node-color, #ff0072);background:var(--vf-node-bg);border-color:var(--vf-node-color, #ff0072)}.vue-flow__node-output.selected,.vue-flow__node-output:focus,.vue-flow__node-output:focus-visible{outline:none;border:1px solid var(--vf-node-color, #ff0072)}.vue-flow__nodesselection-rect,.vue-flow__selection{background:#0059dc14;border:1px dotted rgba(0,89,220,.8)}.vue-flow__nodesselection-rect:focus,.vue-flow__nodesselection-rect:focus-visible,.vue-flow__selection:focus,.vue-flow__selection:focus-visible{outline:none}.vue-flow__handle{width:6px;height:6px;background:var(--vf-handle);border:1px solid #fff;border-radius:100%}.vue-flow__controls{box-shadow:0 0 2px 1px #00000014}.vue-flow__controls-button{background:#fefefe;border:none;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;user-select:none;padding:5px}.vue-flow__controls-button svg{width:100%;max-width:12px;max-height:12px}.vue-flow__controls-button:hover{background:#f4f4f4}.vue-flow__controls-button:disabled{pointer-events:none}.vue-flow__controls-button:disabled svg{fill-opacity:.4}#app{min-height:100vh;display:flex;flex-direction:column;font-family:var(--font-family-base);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:var(--color-text-primary);background:var(--color-background-canvas)}.app-layout{display:flex;flex-direction:column;min-height:100vh;background:var(--color-background-canvas)}.app-header{height:64px;background:var(--glass-bg);backdrop-filter:var(--glass-backdrop);-webkit-backdrop-filter:var(--glass-backdrop);border-bottom:1px solid var(--glass-border);display:flex;align-items:center;justify-content:space-between;padding:0 var(--spacing-xl);position:sticky;top:0;z-index:var(--z-sticky);box-shadow:var(--shadow-sm)}.header-brand{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-primary);text-decoration:none;display:flex;align-items:center;gap:var(--spacing-sm);transition:all var(--transition-normal)}.header-brand:hover{color:var(--color-primary-hover);transform:translateY(-1px)}.header-brand:before{content:"F";width:32px;height:32px;background:var(--gradient-flow-blue);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:var(--font-weight-bold);font-size:var(--font-size-lg)}.header-user{display:flex;align-items:center;gap:var(--spacing-md)}.user-avatar{width:40px;height:40px;border-radius:var(--radius-full);background:var(--gradient-flow-blue);color:#fff;display:flex;align-items:center;justify-content:center;font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);cursor:pointer;transition:all var(--transition-spring);border:2px solid var(--glass-border)}.user-avatar:hover{transform:scale(1.05);box-shadow:var(--shadow-lg)}.app-main{display:flex;flex:1}.app-sidebar{width:64px;background:var(--glass-bg);backdrop-filter:var(--glass-backdrop);-webkit-backdrop-filter:var(--glass-backdrop);border-right:1px solid var(--glass-border);padding:var(--spacing-md);min-height:calc(100vh - 112px);display:flex;flex-direction:column;align-items:center;justify-content:flex-start;gap:var(--spacing-sm)}.sidebar-nav{display:flex;flex-direction:column;gap:var(--spacing-sm);width:100%}.sidebar-nav-item{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-lg);color:var(--color-text-secondary);cursor:pointer;position:relative;transition:all var(--transition-spring);background:transparent;border:1px solid transparent}.sidebar-nav-item:hover{background:var(--color-background-hover);color:var(--color-text-primary);transform:scale(1.05);border-color:var(--color-border-hover)}.sidebar-nav-item.active{background:var(--gradient-flow-blue);color:#fff;box-shadow:var(--shadow-md);transform:scale(1.05)}.sidebar-nav-item i{font-size:var(--font-size-md)}.app-content{flex:1;padding:var(--spacing-sm);background:var(--color-background-canvas);height:calc(100vh - 120px);overflow-y:auto}.app-footer{height:48px;background:var(--glass-bg);backdrop-filter:var(--glass-backdrop);-webkit-backdrop-filter:var(--glass-backdrop);border-top:1px solid var(--glass-border);display:flex;align-items:center;justify-content:center;padding:0 var(--spacing-xl);color:var(--color-text-secondary);font-size:var(--font-size-sm)}.page-layout{max-width:1400px;margin:0 auto;padding:var(--spacing-xl);display:grid;grid-template-columns:1fr 320px;gap:var(--spacing-xl);min-height:100%}.page-layout.full-width{grid-template-columns:1fr;max-width:none}.page-main{background:var(--glass-bg);backdrop-filter:var(--glass-backdrop);-webkit-backdrop-filter:var(--glass-backdrop);border:1px solid var(--glass-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-card);overflow:hidden}.page-sidebar{background:var(--glass-bg);backdrop-filter:var(--glass-backdrop);-webkit-backdrop-filter:var(--glass-backdrop);border:1px solid var(--glass-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-card);height:fit-content}.page-header{padding:var(--spacing-xl);border-bottom:1px solid var(--color-border-subtle);background:var(--color-background-subtle)}.page-title{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin-bottom:var(--spacing-sm);background:var(--gradient-flow-blue);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.page-description{color:var(--color-text-secondary);font-size:var(--font-size-md);line-height:var(--line-height-normal)}.card{background:var(--glass-bg);backdrop-filter:var(--glass-backdrop);-webkit-backdrop-filter:var(--glass-backdrop);border:1px solid var(--glass-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);transition:all var(--transition-spring)}.card:hover{transform:translateY(-2px);box-shadow:var(--shadow-xl);border-color:var(--color-border-hover)}.card-header{padding:var(--spacing-lg);border-bottom:1px solid var(--color-border-subtle);background:var(--color-background-subtle);border-top-left-radius:var(--radius-lg);border-top-right-radius:var(--radius-lg)}.card-body{padding:var(--spacing-lg)}.card-footer{padding:var(--spacing-lg);border-top:1px solid var(--color-border-subtle);background:var(--color-background-subtle);border-bottom-left-radius:var(--radius-lg);border-bottom-right-radius:var(--radius-lg)}.form-group{margin-bottom:var(--spacing-lg)}.form-label{display:block;font-weight:var(--font-weight-medium);color:var(--color-text-primary);margin-bottom:var(--spacing-sm);font-size:var(--font-size-sm)}.form-input{width:100%;padding:var(--spacing-md) var(--spacing-lg);border:1px solid var(--color-border);border-radius:var(--radius-lg);font-size:var(--font-size-md);font-family:var(--font-family-base);background:var(--glass-bg);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);color:var(--color-text-primary);transition:all var(--transition-normal)}.form-input:focus{outline:none;border-color:var(--color-border-focus);box-shadow:0 0 0 3px var(--color-primary-light);background:var(--color-background-elevated)}.form-input:invalid{border-color:var(--color-danger);box-shadow:0 0 0 3px var(--color-danger-subtle)}.form-error{color:var(--color-danger);font-size:var(--font-size-sm);margin-top:var(--spacing-xs);display:flex;align-items:center;gap:var(--spacing-xs)}.form-error:before{content:"⚠️"}.btn{display:inline-flex;align-items:center;justify-content:center;padding:var(--spacing-md) var(--spacing-lg);border:1px solid var(--color-border);border-radius:var(--radius-lg);font-size:var(--font-size-md);font-weight:var(--font-weight-medium);font-family:var(--font-family-base);text-decoration:none;cursor:pointer;min-height:44px;background:var(--glass-bg);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);color:var(--color-text-primary);transition:all var(--transition-spring);gap:var(--spacing-sm)}.btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:var(--shadow-lg);border-color:var(--color-border-hover)}.btn:active{transform:translateY(0)}.btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.btn-primary{background:var(--gradient-flow-blue);color:#fff;border-color:var(--color-primary);font-weight:var(--font-weight-semibold)}.btn-primary:hover:not(:disabled){background:var(--color-primary-hover);box-shadow:0 8px 25px #007aff4d}.btn-secondary{background:var(--glass-bg);color:var(--color-text-primary);border:1px solid var(--color-border)}.btn-success{background:var(--gradient-data-green);color:#fff;border-color:var(--color-success)}.btn-warning{background:var(--gradient-warning-amber);color:#fff;border-color:var(--color-warning)}.btn-danger{background:var(--gradient-error-red);color:#fff;border-color:var(--color-danger)}.btn-sm{padding:var(--spacing-sm) var(--spacing-md);font-size:var(--font-size-sm);min-height:36px}.btn-lg{padding:var(--spacing-lg) var(--spacing-xl);font-size:var(--font-size-lg);min-height:52px}.alert{padding:var(--spacing-lg);border-radius:var(--radius-lg);margin-bottom:var(--spacing-lg);border:1px solid var(--color-border);background:var(--glass-bg);backdrop-filter:var(--glass-backdrop);-webkit-backdrop-filter:var(--glass-backdrop);display:flex;align-items:center;gap:var(--spacing-md)}.alert-success{border-color:var(--color-success);background:var(--color-success-subtle)}.alert-warning{border-color:var(--color-warning);background:var(--color-warning-subtle)}.alert-danger{border-color:var(--color-danger);background:var(--color-danger-subtle)}.alert-info{border-color:var(--color-info);background:var(--color-info-subtle)}.loading-spinner{display:inline-block;width:20px;height:20px;border:2px solid var(--color-border);border-radius:var(--radius-full);border-top-color:var(--color-primary);animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-overlay{position:fixed;inset:0;background:var(--glass-bg);backdrop-filter:var(--glass-backdrop);-webkit-backdrop-filter:var(--glass-backdrop);display:flex;align-items:center;justify-content:center;z-index:var(--z-modal);flex-direction:column;gap:var(--spacing-lg)}.empty-state{text-align:center;padding:var(--spacing-4xl) var(--spacing-xl);color:var(--color-text-tertiary)}.empty-state-icon{font-size:var(--font-size-4xl);margin-bottom:var(--spacing-xl);opacity:.5;background:var(--gradient-flow-blue);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.empty-state-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);margin-bottom:var(--spacing-md);color:var(--color-text-secondary)}.empty-state-description{font-size:var(--font-size-md);margin-bottom:var(--spacing-xl);line-height:var(--line-height-normal)}.vue-flow__pane{background:var(--color-background-canvas)}.vue-flow__background{background-color:var(--color-background-canvas)}.vue-flow__background pattern circle{fill:var(--color-canvas-grid)}.vue-flow__edge-path{stroke:var(--color-connector);stroke-width:2px}.vue-flow__edge.selected .vue-flow__edge-path{stroke:var(--color-connector-active);stroke-width:3px;filter:drop-shadow(0 0 8px var(--color-connector-active))}.vue-flow__node{border-radius:var(--radius-lg);box-shadow:var(--shadow-card);border:1px solid var(--glass-border);background:var(--glass-bg);backdrop-filter:var(--glass-backdrop);-webkit-backdrop-filter:var(--glass-backdrop)}.vue-flow__handle{background:var(--color-connector);border:2px solid white;border-radius:var(--radius-full);width:12px;height:12px}.vue-flow__controls{background:var(--glass-bg);backdrop-filter:var(--glass-backdrop);-webkit-backdrop-filter:var(--glass-backdrop);border:1px solid var(--glass-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-card)}.vue-flow__controls button{background:transparent;border:none;color:var(--color-text-primary);transition:all var(--transition-normal)}.vue-flow__controls button:hover{background:var(--color-background-hover);color:var(--color-primary)}.vue-flow__minimap{background:var(--glass-bg);backdrop-filter:var(--glass-backdrop);-webkit-backdrop-filter:var(--glass-backdrop);border:1px solid var(--glass-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-card)}body>.dropdown-menu{z-index:1001!important;position:fixed!important;background:var(--glass-bg);backdrop-filter:var(--glass-backdrop);-webkit-backdrop-filter:var(--glass-backdrop);border:1px solid var(--glass-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl)}@media (max-width: 1024px){.page-layout{grid-template-columns:1fr;gap:var(--spacing-lg)}.page-sidebar{order:-1}}@media (max-width: 768px){.app-header{padding:0 var(--spacing-lg)}.app-content,.page-layout{padding:var(--spacing-lg)}.app-sidebar{width:56px;padding:var(--spacing-sm)}.sidebar-nav-item{width:36px;height:36px}}
