*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.sticky{position:sticky}.inline-block{display:inline-block}.flex{display:flex}.grid{display:grid}.border{border-width:1px}.bg-none{background-image:none}.outline{outline-style:solid}.blur{--tw-blur: blur(8px);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}:root{--bg: #0c0c14;--bg-node: #14141e;--bg-bar: #09090f;--bg-ctx: #111118;--text: #e2e2f0;--text-muted:#52526e;--border: rgba(255,255,255,.055);--border-s: rgba(255,255,255,.12);--accent: #7F77DD;--dot: rgba(255,255,255,.032);--shadow: 0 8px 32px rgba(0,0,0,.6);--shadow-sm: 0 2px 12px rgba(0,0,0,.4)}html.light{--bg: #ecebe6;--bg-node: #ffffff;--bg-bar: #f0eeea;--bg-ctx: #f5f4f0;--text: #18181f;--text-muted:#8888aa;--border: rgba(0,0,0,.07);--border-s: rgba(0,0,0,.13);--dot: rgba(0,0,0,.04);--shadow: 0 8px 32px rgba(0,0,0,.12);--shadow-sm: 0 2px 12px rgba(0,0,0,.08)}*,*:before,*:after{box-sizing:border-box}html,body,#root{height:100%;margin:0;padding:0}body{background:var(--bg);color:var(--text);font-family:system-ui,-apple-system,Segoe UI,sans-serif;-webkit-font-smoothing:antialiased}.app-root{display:flex;flex-direction:column;height:100vh;overflow:hidden}.topbar{display:flex;align-items:center;gap:6px;height:46px;padding:0 14px;background:var(--bg-bar);border-bottom:.5px solid var(--border-s);flex-shrink:0;-webkit-user-select:none;-moz-user-select:none;user-select:none;z-index:100}.topbar-logo{font-size:18px;color:var(--accent);margin-right:6px;opacity:.9}.topbar-sep{width:.5px;height:18px;background:var(--border-s);flex-shrink:0}.topbar-tabs{display:flex;gap:2px;overflow-x:auto;scrollbar-width:none;min-width:0}.topbar-tabs::-webkit-scrollbar{display:none}.tab-btn{display:flex;align-items:center;gap:5px;padding:4px 12px;border-radius:6px;font-size:12px;color:var(--text-muted);cursor:pointer;border:.5px solid transparent;background:transparent;white-space:nowrap;transition:all .14s}.tab-btn:hover{color:var(--text);background:var(--border)}.tab-btn.active{color:var(--text);background:#7f77dd1a;border-color:#7f77dd40}.topbar-actions{margin-left:auto;display:flex;gap:3px;align-items:center;flex-shrink:0}.icon-btn{width:30px;height:30px;border-radius:7px;display:flex;align-items:center;justify-content:center;color:var(--text-muted);cursor:pointer;font-size:16px;background:transparent;border:.5px solid transparent;transition:all .14s}.icon-btn:hover{color:var(--text);background:var(--border);border-color:var(--border-s)}.icon-btn.active{color:var(--accent);background:#7f77dd1f;border-color:#7f77dd4d}.guest-label{font-size:10px;color:var(--accent);background:#7f77dd1a;padding:2px 8px;border-radius:10px;border:.5px solid rgba(127,119,221,.25)}.canvas-container{flex:1;position:relative;overflow:hidden;background:var(--bg)}.canvas-loading{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:13px;z-index:10;background:var(--bg)}.empty-hint{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;color:var(--text-muted);font-size:13px;pointer-events:none;opacity:.4;line-height:2.2}.empty-hint kbd{background:var(--border-s);padding:1px 6px;border-radius:4px;font-size:11px;font-family:monospace}.saving-badge{position:absolute;bottom:38px;right:14px;background:var(--accent);color:#fff;padding:5px 13px;border-radius:8px;font-size:11px;font-weight:500;pointer-events:none;animation:fadeUp .2s ease}.guest-badge{position:absolute;top:12px;right:14px;z-index:5;background:var(--bg-bar);border:.5px solid var(--border-s);border-radius:20px;padding:3px 11px;font-size:10px;color:var(--text-muted);pointer-events:none}@keyframes fadeUp{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}.statusbar{height:26px;background:var(--bg-bar);border-top:.5px solid var(--border);display:flex;align-items:center;padding:0 14px;gap:14px;font-size:10.5px;color:var(--text-muted);flex-shrink:0;-webkit-user-select:none;-moz-user-select:none;user-select:none;overflow:hidden;white-space:nowrap}.statusbar kbd{background:var(--border-s);padding:1px 5px;border-radius:3px;font-size:9px;font-family:monospace}.sb-divider{opacity:.25}.bubble{width:220px;background:var(--bg-node);border:1px solid var(--border-s);border-radius:10px;cursor:grab;font-family:inherit;box-shadow:var(--shadow-sm);transition:border-color .15s,box-shadow .15s;position:relative}.bubble:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;border-radius:10px 10px 0 0;background:var(--nc, var(--accent));opacity:.8}.bubble:active{cursor:grabbing}.bubble.selected{border-color:var(--nc, var(--accent));box-shadow:0 0 0 1px var(--nc, var(--accent)),var(--shadow)}.bubble.collapsed:before{border-radius:10px}.bubble.locked{opacity:.7}.bubble-header{display:flex;align-items:center;gap:6px;padding:9px 10px 8px;border-bottom:.5px solid var(--border)}.bubble.collapsed .bubble-header{border-bottom:none}.bubble-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.bubble-title{font-size:11.5px;font-weight:500;color:var(--text);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.bubble-title-input{background:transparent;border:none;outline:none;font-size:11.5px;font-weight:500;color:var(--text);flex:1;min-width:0;width:0;font-family:inherit}.bubble-icon{font-size:13px}.bubble-lock{font-size:9px;color:var(--text-muted)}.bubble-collapse-btn{background:none;border:none;cursor:pointer;color:var(--text-muted);font-size:11px;padding:0 2px;line-height:1;transition:color .1s}.bubble-collapse-btn:hover{color:var(--text)}.bubble-body{padding:8px 10px 10px}.bubble-text{font-size:11px;color:var(--text-muted);line-height:1.65;white-space:pre-wrap;word-break:break-word;min-height:28px}.bubble-placeholder{opacity:.35;font-style:italic}.bubble-textarea{width:100%;background:transparent;border:none;outline:none;resize:none;font-size:11px;color:var(--text);line-height:1.65;font-family:inherit;box-sizing:border-box;min-height:56px}.bubble-status{height:2.5px;margin:0 -1px -1px;border-radius:0 0 10px 10px}.bubble-toolbar{display:flex;align-items:center;gap:3px;padding:5px 8px;background:#00000040;border-top:.5px solid var(--border);border-radius:0 0 9px 9px}.btb-color{width:13px;height:13px;border-radius:50%;border:none;cursor:pointer;border:2px solid transparent;transition:transform .1s}.btb-color:hover{transform:scale(1.3)}.btb-sep{width:.5px;height:14px;background:var(--border-s);margin:0 2px}.btb-btn{padding:2px 6px;background:transparent;border:none;color:var(--text-muted);font-size:13px;cursor:pointer;border-radius:4px;transition:all .1s}.btb-btn:hover{background:var(--border);color:var(--text)}.btb-btn.danger:hover{background:#e24b4a26;color:#e24b4a}.bubble-sticky{background:#1a1800!important;border-color:#f5e84e44!important}.bubble-sticky:before{background:#f5e84e}.bubble-sticky .bubble-title{color:#f5e84e}.bubble-sticky .bubble-text{color:#ccc188}.bubble-glass{background:#ffffff0d!important;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-color:#ffffff26!important}.bubble-terminal{background:#020c02!important;border-color:#00ff4133!important;font-family:monospace!important}.bubble-terminal:before{background:#00ff41}.bubble-terminal .bubble-title{color:#00ff41!important;font-size:10px!important}.bubble-terminal .bubble-text{color:#0c3!important;font-size:10px!important}.bubble-minimal{background:transparent!important;border-color:var(--border)!important;box-shadow:none!important}.bubble-minimal:before{display:none}.image-node{width:220px;background:var(--bg-node);border:1px solid var(--border-s);border-radius:10px;cursor:grab;box-shadow:var(--shadow-sm);overflow:hidden;transition:border-color .15s,box-shadow .15s}.image-node.selected{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent),var(--shadow)}.image-node-header{display:flex;align-items:center;gap:6px;padding:7px 10px;border-bottom:.5px solid var(--border)}.image-node-label{font-size:10.5px;font-weight:500;color:var(--text-muted);flex:1}.image-node-delete{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:13px;padding:1px 3px;border-radius:4px;transition:all .1s}.image-node-delete:hover{background:#e24b4a26;color:#e24b4a}.image-node-preview{width:100%;display:block;max-height:200px;-o-object-fit:cover;object-fit:cover}.image-node-drop{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px 16px;gap:6px;color:var(--text-muted);font-size:11px;text-align:center}.react-flow__pane{cursor:default}.react-flow__node{background:none!important;border:none!important;border-radius:0!important;padding:0!important;width:auto!important}.react-flow__handle{width:10px!important;height:10px!important;background:var(--bg)!important;border:1.5px solid var(--border-s)!important;border-radius:50%!important;transition:all .14s}.react-flow__handle:hover{background:var(--accent)!important;border-color:var(--accent)!important;box-shadow:0 0 6px var(--accent)}.react-flow__handle-left{left:-5px!important}.react-flow__handle-right{right:-5px!important}.react-flow__edge-path{stroke-width:1.5!important;stroke-opacity:.65;transition:stroke-opacity .15s}.react-flow__edge:hover .react-flow__edge-path{stroke-opacity:1}.react-flow__edge.selected .react-flow__edge-path{stroke-opacity:1;filter:drop-shadow(0 0 4px currentColor)}.react-flow__controls{background:var(--bg-bar)!important;border:.5px solid var(--border-s)!important;border-radius:10px!important;overflow:hidden;box-shadow:var(--shadow-sm)!important;bottom:38px;left:14px}.react-flow__controls-button{background:transparent!important;border:none!important;border-bottom:.5px solid var(--border)!important;color:var(--text-muted)!important;width:28px!important;height:28px!important;transition:background .1s}.react-flow__controls-button:hover{background:var(--border)!important}.react-flow__controls-button svg{fill:currentColor!important;width:12px!important;height:12px!important}.react-flow__controls-button:last-child{border-bottom:none!important}.react-flow__background{background:var(--bg)!important}.react-flow__minimap{border-radius:8px!important;overflow:hidden;border:.5px solid var(--border-s)!important}.ctx-menu{position:absolute;z-index:500;background:var(--bg-ctx);border:.5px solid var(--border-s);border-radius:10px;padding:4px;min-width:166px;box-shadow:var(--shadow);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.ctx-item{display:flex;align-items:center;gap:9px;padding:6px 10px;border-radius:6px;font-size:12px;color:var(--text);cursor:pointer;transition:background .1s}.ctx-item:hover{background:var(--border)}.ctx-item .ti{font-size:14px;color:var(--text-muted)}.ctx-item.danger,.ctx-item.danger .ti{color:#e24b4a}.ctx-sep{height:.5px;background:var(--border);margin:3px 0}.ctx-label{padding:4px 10px 2px;font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.07em}.ctx-swatches{display:flex;flex-wrap:wrap;gap:5px;padding:5px 10px 7px}.swatch{width:17px;height:17px;border-radius:50%;cursor:pointer;border:2px solid transparent;box-sizing:border-box;transition:transform .1s}.swatch:hover{transform:scale(1.25)}.swatch.active{border-color:#fffc}html.light .swatch.active{border-color:#0009}.ctx-shortcut{margin-left:auto;font-size:10px;color:var(--text-muted);font-family:monospace;opacity:.7}.search-overlay{position:absolute;top:12px;left:50%;transform:translate(-50%);width:360px;z-index:400;background:var(--bg-ctx);border:.5px solid var(--border-s);border-radius:12px;overflow:hidden;box-shadow:var(--shadow);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.search-input{width:100%;padding:12px 16px;box-sizing:border-box;background:transparent;border:none;outline:none;font-size:14px;color:var(--text);font-family:inherit;border-bottom:.5px solid var(--border)}.search-results{max-height:240px;overflow-y:auto}.search-item{padding:8px 16px;font-size:12px;color:var(--text-muted);cursor:pointer;border-bottom:.5px solid var(--border);line-height:1.5;transition:background .1s}.search-item:hover{background:var(--border);color:var(--text)}.search-item:last-child{border-bottom:none}.search-item-title{font-weight:500;color:var(--text)}.search-item-preview{font-size:10.5px;opacity:.6}.toast-container{position:fixed;bottom:34px;right:16px;z-index:900;display:flex;flex-direction:column;gap:6px;pointer-events:none;align-items:flex-end}.toast{padding:8px 16px;border-radius:9px;font-size:12px;font-weight:500;color:#fff;animation:toastIn .2s ease;box-shadow:0 4px 16px #0006}@keyframes toastIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}.toast-success{background:#1d9e75}.toast-error{background:#e24b4a}.toast-info{background:var(--accent)}.palette-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:700;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.palette{position:fixed;top:16%;left:50%;transform:translate(-50%);z-index:701;width:440px;max-width:95vw;background:var(--bg-ctx);border:.5px solid var(--border-s);border-radius:14px;overflow:hidden;box-shadow:var(--shadow)}.palette-header{display:flex;align-items:center;gap:10px;padding:13px 16px;border-bottom:.5px solid var(--border)}.palette-icon{color:var(--text-muted);font-size:17px}.palette-input{flex:1;background:transparent;border:none;outline:none;font-size:15px;color:var(--text);font-family:inherit}.palette-hint{font-size:10px;color:var(--text-muted)}.palette-list{max-height:280px;overflow-y:auto}.palette-item{display:flex;align-items:center;gap:10px;padding:10px 16px;cursor:pointer;font-size:12.5px;color:var(--text);border-bottom:.5px solid var(--border);transition:background .1s}.palette-item:hover{background:var(--border)}.palette-item:last-child{border-bottom:none}.palette-item-icon{color:var(--text-muted);width:20px;text-align:center;font-size:15px}.palette-item-label{flex:1}.palette-item-shortcut{font-size:10px;color:var(--text-muted);background:var(--border);padding:2px 7px;border-radius:5px;font-family:monospace}.palette-empty{padding:20px 16px;font-size:12px;color:var(--text-muted);text-align:center}.palette-footer{padding:7px 16px;font-size:10px;color:var(--text-muted);border-top:.5px solid var(--border);background:#0003}.settings-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:800;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.settings-panel{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:801;width:500px;max-width:95vw;max-height:82vh;background:var(--bg-ctx);border:.5px solid var(--border-s);border-radius:16px;overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--shadow)}.settings-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:.5px solid var(--border);flex-shrink:0}.settings-title{font-size:15px;font-weight:600;color:var(--text)}.settings-close{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:16px;padding:3px 7px;border-radius:6px}.settings-close:hover{background:var(--border);color:var(--text)}.settings-body{flex:1;overflow-y:auto;padding:12px 0}.settings-section{padding:10px 20px 14px;border-bottom:.5px solid var(--border)}.settings-section:last-child{border-bottom:none}.settings-section-title{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.09em;color:var(--text-muted);margin-bottom:12px}.settings-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;font-size:12.5px;color:var(--text)}.settings-toggle-group{display:flex;gap:3px}.stg-btn{padding:4px 11px;background:transparent;border:.5px solid var(--border-s);border-radius:6px;font-size:11px;color:var(--text-muted);cursor:pointer;transition:all .12s}.stg-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}.stg-btn:not(.active):hover{background:var(--border);color:var(--text)}.settings-switch{padding:3px 14px;border-radius:20px;font-size:10px;font-weight:500;border:.5px solid var(--border-s);background:transparent;color:var(--text-muted);cursor:pointer;transition:all .15s;min-width:48px}.settings-switch.on{background:var(--accent);border-color:var(--accent);color:#fff}.settings-note{font-size:11.5px;color:var(--text-muted);line-height:1.7;margin:4px 0 8px}.settings-note a{color:var(--accent);text-decoration:none}.settings-perms{font-size:11px;color:var(--text-muted);line-height:1.9;margin:4px 0 8px;opacity:.7}.settings-action-btn{padding:7px 16px;border-radius:8px;font-size:12px;cursor:pointer;background:var(--border);border:.5px solid var(--border-s);color:var(--text);transition:all .15s}.settings-action-btn:hover{background:var(--border-s)}.settings-action-btn.danger:hover{background:#e24b4a1f;color:#e24b4a;border-color:#e24b4a4d}.settings-shortcuts{display:grid;grid-template-columns:1fr 1fr;gap:5px}.settings-shortcut{display:flex;align-items:center;gap:7px;font-size:11.5px;color:var(--text-muted)}.settings-shortcut kbd{background:var(--border-s);padding:2px 6px;border-radius:4px;font-size:9.5px;white-space:nowrap;flex-shrink:0;font-family:monospace}.onboarding-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;z-index:600;background:#000000b3;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center}.onboarding-card{background:var(--bg-ctx);border:.5px solid var(--border-s);border-radius:18px;padding:36px;text-align:center;max-width:340px;width:90%;box-shadow:var(--shadow)}.onboarding-progress{display:flex;gap:7px;justify-content:center;margin-bottom:28px}.onboarding-dot{width:8px;height:8px;border-radius:50%;background:var(--border-s);cursor:pointer;transition:all .2s}.onboarding-dot.active{background:var(--accent);transform:scale(1.3)}.onboarding-dot.done{background:#1d9e75}.onboarding-icon{font-size:40px;margin-bottom:14px;color:var(--accent)}.onboarding-title{font-size:18px;font-weight:600;color:var(--text);margin:0 0 8px}.onboarding-desc{font-size:13px;color:var(--text-muted);line-height:1.75;margin:0 0 18px}.onboarding-key{display:inline-block;background:var(--bg-bar);border:.5px solid var(--border-s);border-radius:8px;padding:7px 18px;font-size:12px;color:var(--accent);font-family:monospace;margin-bottom:26px;letter-spacing:.06em}.onboarding-actions{display:flex;gap:8px;justify-content:center;flex-wrap:wrap}.onboarding-btn-primary{padding:10px 22px;background:var(--accent);color:#fff;border:none;border-radius:9px;font-size:13px;font-weight:500;cursor:pointer;transition:opacity .15s}.onboarding-btn-primary:hover{opacity:.88}.onboarding-btn-ghost{padding:10px 16px;background:transparent;color:var(--text-muted);border:.5px solid var(--border-s);border-radius:9px;font-size:13px;cursor:pointer}.onboarding-skip{background:none;border:none;color:var(--text-muted);font-size:11px;cursor:pointer;padding:4px 8px;width:100%;margin-top:4px;opacity:.45}.onboarding-skip:hover{opacity:1}.landing{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg);position:relative;overflow:hidden}.landing-bg{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;overflow:hidden}.landing-bubble{position:absolute;background:var(--bg-node);border:1px solid var(--border-s);border-radius:10px;padding:9px 15px;font-size:11px;color:var(--text-muted);opacity:.4;animation:float 7s ease-in-out infinite;box-shadow:var(--shadow-sm)}.lb1{left:8%;top:18%;animation-delay:0s;border-color:#7f77dd33}.lb2{left:62%;top:12%;animation-delay:1.2s;border-color:#1d9e7533}.lb3{left:72%;top:52%;animation-delay:2.4s;border-color:#d85a3033}.lb4{left:6%;top:64%;animation-delay:.6s;border-color:#d4537e33}.lb5{left:40%;top:76%;animation-delay:1.8s;border-color:#378add33}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-12px)}}.landing-lines{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%}.landing-lines path{fill:none;stroke:var(--accent);stroke-width:1;opacity:.06;stroke-dasharray:8 5;animation:dash 25s linear infinite}@keyframes dash{to{stroke-dashoffset:-120}}.landing-content{position:relative;z-index:1;text-align:center;max-width:500px;padding:32px 24px}.landing-logo{font-size:48px;color:var(--accent);margin-bottom:10px}.landing-title{font-size:38px;font-weight:700;color:var(--text);letter-spacing:-1.5px;margin:0 0 10px}.landing-tagline{font-size:15px;color:var(--text-muted);line-height:1.8;margin:0 0 32px}.landing-features{display:flex;flex-direction:column;gap:9px;margin-bottom:36px;text-align:left}.lf-item{display:flex;align-items:center;gap:12px;font-size:13px;color:var(--text-muted)}.lf-icon{color:var(--accent);width:18px;text-align:center;font-size:16px}.landing-actions{display:flex;flex-direction:column;gap:10px;align-items:center}.landing-btn-primary{width:100%;max-width:320px;padding:13px 20px;background:var(--accent);color:#fff;border:none;border-radius:11px;font-size:14px;font-weight:500;cursor:pointer;transition:opacity .15s}.landing-btn-primary:disabled{opacity:.45;cursor:not-allowed}.landing-btn-primary:not(:disabled):hover{opacity:.86}.landing-btn-ghost{width:100%;max-width:320px;padding:11px 20px;background:transparent;color:var(--text-muted);border:.5px solid var(--border-s);border-radius:11px;font-size:13px;cursor:pointer;transition:all .15s}.landing-btn-ghost:hover{color:var(--text);background:var(--border)}.landing-note{font-size:11px;color:var(--text-muted);opacity:.55;margin:4px 0 0}.landing-pat{width:100%;max-width:380px;text-align:left}.landing-pat-title{font-size:10.5px;font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:.07em;margin-bottom:7px}.landing-pat-help{font-size:11.5px;color:var(--text-muted);margin-bottom:12px;line-height:1.7}.landing-pat-help a{color:var(--accent);text-decoration:none}.landing-pat-help a:hover{text-decoration:underline}.landing-pat-actions{display:flex;gap:8px;margin-top:10px}.landing-pat-actions .landing-btn-primary,.landing-pat-actions .landing-btn-ghost{max-width:none;flex:1}.landing-loading-step{font-size:11px;color:var(--accent);margin-top:7px;text-align:center}.landing-perms{margin-top:14px;display:flex;flex-direction:column;gap:5px}.landing-perm{font-size:11px;color:var(--text-muted)}.landing-perm.ok{color:#1d9e75}.landing-perm.no{opacity:.45}.auth-input{width:100%;padding:11px 13px;background:var(--bg);border:.5px solid var(--border-s);border-radius:9px;color:var(--text);font-size:13px;font-family:monospace;outline:none;transition:border-color .15s;box-sizing:border-box}.auth-input:focus{border-color:var(--accent)}.auth-error{margin:8px 0 0;font-size:11px;color:#e24b4a;line-height:1.5}.canvas-dragover .react-flow__pane{outline:2px dashed var(--accent);outline-offset:-4px}.react-flow{direction:ltr}.react-flow__container{position:absolute;width:100%;height:100%;top:0;left:0}.react-flow__pane{z-index:1;cursor:grab}.react-flow__pane.selection{cursor:pointer}.react-flow__pane.dragging{cursor:grabbing}.react-flow__viewport{transform-origin:0 0;z-index:2;pointer-events:none}.react-flow__renderer{z-index:4}.react-flow__selection{z-index:6}.react-flow__nodesselection-rect:focus,.react-flow__nodesselection-rect:focus-visible{outline:none}.react-flow .react-flow__edges{pointer-events:none;overflow:visible}.react-flow__edge-path,.react-flow__connection-path{stroke:#b1b1b7;stroke-width:1;fill:none}.react-flow__edge{pointer-events:visibleStroke;cursor:pointer}.react-flow__edge.animated path{stroke-dasharray:5;animation:dashdraw .5s linear infinite}.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;-moz-user-select:none;user-select:none}.react-flow__connection{pointer-events:none}.react-flow__connection .animated{stroke-dasharray:5;animation:dashdraw .5s linear infinite}.react-flow__connectionline{z-index:1001}.react-flow__nodes{pointer-events:none;transform-origin:0 0}.react-flow__node{position:absolute;-webkit-user-select:none;-moz-user-select:none;user-select:none;pointer-events:all;transform-origin:0 0;box-sizing:border-box;cursor:grab}.react-flow__node.dragging{cursor:grabbing}.react-flow__nodesselection{z-index:3;transform-origin:left top;pointer-events:none}.react-flow__nodesselection-rect{position:absolute;pointer-events:all;cursor:grab}.react-flow__handle{position:absolute;pointer-events:none;min-width:5px;min-height:5px;width:6px;height:6px;background:#1a192b;border:1px solid white;border-radius:100%}.react-flow__handle.connectionindicator{pointer-events:all;cursor:crosshair}.react-flow__handle-bottom{top:auto;left:50%;bottom:-4px;transform:translate(-50%)}.react-flow__handle-top{left:50%;top:-4px;transform:translate(-50%)}.react-flow__handle-left{top:50%;left:-4px;transform:translateY(-50%)}.react-flow__handle-right{right:-4px;top:50%;transform:translateY(-50%)}.react-flow__edgeupdater{cursor:move;pointer-events:all}.react-flow__panel{position:absolute;z-index:5;margin:15px}.react-flow__panel.top{top:0}.react-flow__panel.bottom{bottom:0}.react-flow__panel.left{left:0}.react-flow__panel.right{right:0}.react-flow__panel.center{left:50%;transform:translate(-50%)}.react-flow__attribution{font-size:10px;background:#ffffff80;padding:2px 3px;margin:0}.react-flow__attribution a{text-decoration:none;color:#999}@keyframes dashdraw{0%{stroke-dashoffset:10}}.react-flow__edgelabel-renderer{position:absolute;width:100%;height:100%;pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-flow__edge.updating .react-flow__edge-path{stroke:#777}.react-flow__edge-text{font-size:10px}.react-flow__node.selectable:focus,.react-flow__node.selectable:focus-visible{outline:none}.react-flow__node-default,.react-flow__node-input,.react-flow__node-output,.react-flow__node-group{padding:10px;border-radius:3px;width:150px;font-size:12px;color:#222;text-align:center;border-width:1px;border-style:solid;border-color:#1a192b;background-color:#fff}.react-flow__node-default.selectable:hover,.react-flow__node-input.selectable:hover,.react-flow__node-output.selectable:hover,.react-flow__node-group.selectable:hover{box-shadow:0 1px 4px 1px #00000014}.react-flow__node-default.selectable.selected,.react-flow__node-default.selectable:focus,.react-flow__node-default.selectable:focus-visible,.react-flow__node-input.selectable.selected,.react-flow__node-input.selectable:focus,.react-flow__node-input.selectable:focus-visible,.react-flow__node-output.selectable.selected,.react-flow__node-output.selectable:focus,.react-flow__node-output.selectable:focus-visible,.react-flow__node-group.selectable.selected,.react-flow__node-group.selectable:focus,.react-flow__node-group.selectable:focus-visible{box-shadow:0 0 0 .5px #1a192b}.react-flow__node-group{background-color:#f0f0f040}.react-flow__nodesselection-rect,.react-flow__selection{background:#0059dc14;border:1px dotted rgba(0,89,220,.8)}.react-flow__nodesselection-rect:focus,.react-flow__nodesselection-rect:focus-visible,.react-flow__selection:focus,.react-flow__selection:focus-visible{outline:none}.react-flow__controls{box-shadow:0 0 2px 1px #00000014}.react-flow__controls-button{border:none;background:#fefefe;border-bottom:1px solid #eee;box-sizing:content-box;display:flex;justify-content:center;align-items:center;width:16px;height:16px;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;padding:5px}.react-flow__controls-button:hover{background:#f4f4f4}.react-flow__controls-button svg{width:100%;max-width:12px;max-height:12px}.react-flow__controls-button:disabled{pointer-events:none}.react-flow__controls-button:disabled svg{fill-opacity:.4}.react-flow__minimap{background-color:#fff}.react-flow__minimap svg{display:block}.react-flow__resize-control{position:absolute}.react-flow__resize-control.left,.react-flow__resize-control.right{cursor:ew-resize}.react-flow__resize-control.top,.react-flow__resize-control.bottom{cursor:ns-resize}.react-flow__resize-control.top.left,.react-flow__resize-control.bottom.right{cursor:nwse-resize}.react-flow__resize-control.bottom.left,.react-flow__resize-control.top.right{cursor:nesw-resize}.react-flow__resize-control.handle{width:4px;height:4px;border:1px solid #fff;border-radius:1px;background-color:#3367d9;transform:translate(-50%,-50%)}.react-flow__resize-control.handle.left{left:0;top:50%}.react-flow__resize-control.handle.right{left:100%;top:50%}.react-flow__resize-control.handle.top{left:50%;top:0}.react-flow__resize-control.handle.bottom{left:50%;top:100%}.react-flow__resize-control.handle.top.left,.react-flow__resize-control.handle.bottom.left{left:0}.react-flow__resize-control.handle.top.right,.react-flow__resize-control.handle.bottom.right{left:100%}.react-flow__resize-control.line{border-color:#3367d9;border-width:0;border-style:solid}.react-flow__resize-control.line.left,.react-flow__resize-control.line.right{width:1px;transform:translate(-50%);top:0;height:100%}.react-flow__resize-control.line.left{left:0;border-left-width:1px}.react-flow__resize-control.line.right{left:100%;border-right-width:1px}.react-flow__resize-control.line.top,.react-flow__resize-control.line.bottom{height:1px;transform:translateY(-50%);left:0;width:100%}.react-flow__resize-control.line.top{top:0;border-top-width:1px}.react-flow__resize-control.line.bottom{border-bottom-width:1px;top:100%}
