*,:after,:before{margin:0;padding:0;box-sizing:border-box}:root{--bg:#08090d;--bg2:#0c0d13;--surface:#111320;--surface2:#181a2a;--surface3:#1f2236;--border:hsla(0,0%,100%,.06);--border2:hsla(0,0%,100%,.1);--border3:hsla(0,0%,100%,.15);--text:#eaeaf4;--text2:#9a9ac0;--text3:#5e5e82;--text4:#3a3a58;--accent:#00dfa8;--accent-dim:#00c496;--accent-bg:rgba(0,223,168,.06);--accent-glow:rgba(0,223,168,.15);--accent-strong:rgba(0,223,168,.3);--blue:#4d8ef7;--blue-bg:rgba(77,142,247,.08);--orange:#f5a623;--orange-bg:rgba(245,166,35,.08);--pink:#e855a0;--pink-bg:rgba(232,85,160,.08);--purple:#9b6dff;--purple-bg:rgba(155,109,255,.08);--red:#f06;--r:8px;--r2:12px;--r3:16px;--mono:"Source Code Pro",monospace;--sans:"Outfit",sans-serif;--shadow-sm:0 2px 8px rgba(0,0,0,.3);--shadow:0 8px 32px rgba(0,0,0,.5);--shadow-lg:0 16px 48px rgba(0,0,0,.6)}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--sans);background:var(--bg);color:var(--text);height:100vh;overflow:hidden;font-size:13px}button,input,select,textarea{font-family:inherit;font-size:inherit}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-thumb{background:hsla(0,0%,100%,.08);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:hsla(0,0%,100%,.14)}.app{display:grid;grid-template-rows:40px 1fr auto;height:100vh}.topbar{background:rgba(17,19,32,.85);-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);border-bottom:1px solid var(--border);padding:0 20px;gap:12px;z-index:100}.logo,.topbar{display:flex;align-items:center}.logo{gap:9px;font-weight:800;font-size:15px;letter-spacing:-.3px;cursor:default}.logo-mark{width:24px;height:24px;filter:drop-shadow(0 2px 8px var(--accent-glow))}.logo-text{background:linear-gradient(135deg,var(--accent),#4d8ef7);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.tb-sep{width:1px;height:18px;background:hsla(0,0%,100%,.06);margin:0 6px}.tb-btn{height:28px;padding:0 8px;border:none;background:transparent;color:var(--text3);border-radius:var(--r);cursor:pointer;display:flex;align-items:center;gap:6px;font-weight:500;font-size:12px;transition:color .15s;white-space:nowrap;letter-spacing:.2px}.tb-btn:hover{color:var(--text)}.tb-btn-dim{opacity:.25;transition:opacity .15s,color .15s}.tb-btn-dim:hover{opacity:1}.tb-btn svg{width:16px;height:16px;opacity:.7}.tb-spacer{flex:1 1}.credits{font-family:var(--mono);font-size:11px;color:var(--text3);background:rgba(0,223,168,.04);padding:4px 12px;border-radius:100px;font-weight:500;border:1px solid hsla(0,0%,100%,.08);letter-spacing:.3px}.tb-avatar{width:32px;height:32px;background:linear-gradient(135deg,var(--accent),var(--blue));border-radius:50%;cursor:pointer;box-shadow:0 2px 8px rgba(0,0,0,.3)}.main-area{display:grid;grid-template-columns:1fr;overflow:hidden}.canvas-wrap{position:relative;overflow:hidden;background:var(--bg);cursor:-webkit-grab;cursor:grab}.canvas-wrap:active{cursor:-webkit-grabbing;cursor:grabbing}.canvas{width:8000px;height:8000px;transform-origin:0 0;background-image:radial-gradient(circle,hsla(0,0%,100%,.025) .7px,transparent 0);background-size:32px 32px}.canvas,.node{position:absolute}.node{background:var(--surface);border:1.5px solid var(--border2);border-radius:var(--r3);box-shadow:var(--shadow);-webkit-user-select:none;-moz-user-select:none;user-select:none;cursor:-webkit-grab;cursor:grab;transition:border-color .2s,box-shadow .25s,transform .15s;animation:nodeIn .4s cubic-bezier(.34,1.56,.64,1)}.node:active{cursor:-webkit-grabbing;cursor:grabbing}.node:hover{border-color:var(--border3);box-shadow:var(--shadow-lg)}.node.selected{border-color:var(--accent);box-shadow:var(--shadow-lg),0 0 0 2px var(--accent-glow)}@keyframes nodeIn{0%{opacity:0;transform:scale(.88)}to{opacity:1;transform:scale(1)}}.node-source{width:160px}.node-ai{width:280px}.node-image{width:320px}.node-image.selected{border-color:var(--accent)}.node-video{width:360px}.node-video.selected{border-color:var(--orange);box-shadow:var(--shadow-lg),0 0 0 2px rgba(245,166,35,.25)}.node-image{border-color:rgba(0,223,168,.3)}.node-video{border-color:rgba(245,166,35,.35)}.node-img{width:100%;aspect-ratio:4/3;background:var(--bg2);border-radius:14px 14px 0 0;overflow:hidden;position:relative;display:flex;align-items:center;justify-content:center}.node-img img,.node-img video{width:100%;height:100%;object-fit:cover}.node-img.drag-over{outline:2px dashed var(--accent);outline-offset:-2px;background:var(--accent-bg)}.rp-preview-img{width:100%;aspect-ratio:16/10;background:var(--bg2);border-radius:var(--r2);overflow:hidden;cursor:pointer;transition:all .2s;border:1.5px solid var(--border)}.rp-preview-img:hover{border-color:var(--border2)}.rp-preview-img img,.rp-preview-img video{width:100%;height:100%;object-fit:cover}.node-label{padding:12px 16px;font-size:12px;font-weight:600;color:var(--text2);display:flex;align-items:center;justify-content:space-between}.nl-tag{font-size:9px;padding:3px 10px;border-radius:100px;font-weight:600;background:var(--accent-bg);color:var(--accent);letter-spacing:.3px;border:1px solid rgba(0,223,168,.12)}.node-ai-info{padding:12px 16px 8px}.node-ai-title{font-size:13px;font-weight:700;margin-bottom:3px}.node-ai-desc{font-size:10px;color:var(--text3);line-height:1.6;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.node-ai-footer{padding:8px 16px 12px;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;margin-top:4px}.node-ai-model{font-size:10px;font-family:var(--mono);color:var(--text4)}.node-ai-refs{font-size:9px;background:var(--accent-bg);padding:2px 6px;border-radius:100px;border:1px solid rgba(0,223,168,.15);letter-spacing:.3px;margin-left:auto;margin-right:8px;line-height:1}.node-ai-cost,.node-ai-refs{font-family:var(--mono);color:var(--accent)}.node-ai-cost{font-size:10px;font-weight:600}.play-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.35);opacity:0;transition:opacity .2s;cursor:pointer;border-radius:14px 14px 0 0;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.node-ai:hover .play-overlay.has-play{opacity:1}.play-circle{padding:7px 14px;background:hsla(0,0%,100%,.95);color:#0a0a14;border-radius:100px;display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:800;letter-spacing:2px;box-shadow:0 4px 20px rgba(0,0,0,.4);transition:transform .15s}.play-circle:hover{transform:scale(1.06)}.port{width:12px;height:12px;border-radius:50%;background:var(--surface);border:2px solid var(--border3);position:absolute;cursor:crosshair;z-index:10;transition:all .15s}.port:hover{border-color:var(--accent);background:var(--accent);box-shadow:0 0 12px var(--accent-glow)}.port-out{right:-7px}.port-in,.port-out{top:50%;transform:translateY(-50%)}.port-in{left:-7px}.port-badge{left:-22px;top:50%;transform:translateY(-50%);min-width:16px;height:16px;padding:0 4px;border-radius:100px;font-family:var(--mono);font-size:9px;box-shadow:0 0 10px var(--accent-glow);pointer-events:none;line-height:1}.branch-btn,.port-badge{position:absolute;background:var(--accent);color:var(--bg);font-weight:700;display:flex;align-items:center;justify-content:center}.branch-btn{right:-14px;bottom:24px;width:28px;height:28px;border:none;border-radius:50%;font-size:15px;cursor:pointer;box-shadow:0 3px 14px var(--accent-glow);z-index:10;opacity:0;transition:all .2s}.node:hover .branch-btn{opacity:1}.branch-btn:hover{transform:scale(1.12);box-shadow:0 4px 20px var(--accent-strong)}.node-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;height:100%}.node-loader{width:24px;height:24px;border:2.5px solid hsla(0,0%,100%,.08);border-top:2.5px solid var(--accent);border-radius:50%;animation:spin .7s linear infinite}.node-loading span{font-size:10px;color:var(--text3);font-weight:500}@keyframes spin{to{transform:rotate(1turn)}}.loading-node{border-color:rgba(0,223,168,.3)!important;animation:nodeIn .4s cubic-bezier(.34,1.56,.64,1),pulse-border 2.5s ease-in-out infinite!important}@keyframes pulse-border{0%,to{box-shadow:var(--shadow),0 0 0 2px var(--accent-glow)}50%{box-shadow:var(--shadow),0 0 0 5px rgba(0,223,168,.06)}}.connections{position:absolute;inset:0;pointer-events:none;z-index:1;width:8000px;height:8000px}.conn-group{pointer-events:auto}.conn-hit{fill:none;stroke:transparent;stroke-width:18;cursor:pointer;pointer-events:stroke}.conn-line{fill:none;stroke-width:2;pointer-events:none;transition:stroke-width .15s,filter .15s}.conn-slot-default{stroke:var(--accent);filter:drop-shadow(0 0 6px rgba(0,223,168,.15))}.conn-slot-txt{stroke:var(--purple);filter:drop-shadow(0 0 6px rgba(155,109,255,.18))}.conn-slot-img-first{stroke:var(--accent);filter:drop-shadow(0 0 6px rgba(0,223,168,.18))}.conn-slot-img-last{stroke:var(--orange);filter:drop-shadow(0 0 6px rgba(245,166,35,.2))}.conn-line.conn-hover{stroke-width:3.5;filter:drop-shadow(0 0 10px rgba(255,255,255,.3))}.conn-line.conn-loading{stroke-dasharray:6 4;animation:conn-flow 1.1s linear infinite}@keyframes conn-dash{to{stroke-dashoffset:-10}}@keyframes conn-flow{to{stroke-dashoffset:-30}}.conn-disconnect{cursor:pointer;pointer-events:auto}.conn-disconnect circle{fill:rgba(17,19,32,.95);stroke:var(--border3);stroke-width:1;transition:fill .12s,stroke .12s}.conn-disconnect line{stroke:var(--text2);stroke-width:1.4;stroke-linecap:round}.conn-disconnect:hover circle{fill:rgba(255,50,80,.18);stroke:rgba(255,80,100,.55)}.conn-disconnect:hover line{stroke:#ff6078}.right-panel{background:rgba(17,19,32,.92);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-left:1px solid var(--border);display:flex;flex-direction:column;overflow-y:auto;overscroll-behavior:contain}.rp-header{padding:14px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:4px}.rp-tabs{display:flex;gap:2px;flex:1 1;background:hsla(0,0%,100%,.02);border-radius:var(--r);padding:2px}.rp-tab{flex:1 1;padding:7px 0;text-align:center;font-size:11px;font-weight:600;color:var(--text3);cursor:pointer;border-radius:6px;transition:all .15s;letter-spacing:.3px}.rp-tab:hover{color:var(--text2)}.rp-tab.active{background:var(--accent-bg);color:var(--accent);box-shadow:0 1px 4px rgba(0,0,0,.2)}.rp-preview{padding:14px 16px;border-bottom:1px solid var(--border)}.rp-preview-info{display:flex;justify-content:space-between;margin-top:10px;font-size:10px;color:var(--text3);font-weight:500}.rp-preview-info span:last-child{font-family:var(--mono);color:var(--text4)}.rp-body{padding:14px 16px}.rp-inspector{padding:14px 16px;border-bottom:1px solid var(--border);gap:12px}.inspector-empty,.rp-inspector{display:flex;flex-direction:column}.inspector-empty{min-height:160px;align-items:center;justify-content:center;gap:6px;opacity:.15;font-size:11px;font-weight:500;letter-spacing:.4px;text-align:center;color:var(--text)}.inspector-empty,.inspector-welcome{-webkit-user-select:none;-moz-user-select:none;user-select:none}.inspector-welcome{display:flex;flex-direction:column;gap:14px;padding:8px 2px}.welcome-title{font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--text);opacity:.3;padding-bottom:6px;border-bottom:1px solid var(--border)}.welcome-list{display:flex;flex-direction:column;gap:4px}.welcome-item{display:flex;align-items:center;gap:10px;padding:9px 8px;background:transparent;border:none;color:var(--text);opacity:.25;font-family:inherit;font-size:11px;font-weight:500;letter-spacing:.2px;text-align:left;cursor:pointer;border-radius:var(--r);transition:opacity .15s,background .15s}.welcome-item:hover{opacity:.8;background:hsla(0,0%,100%,.03)}.welcome-item-static{cursor:default}.welcome-item-static:hover{opacity:.3;background:transparent}.welcome-item svg{width:16px;height:16px;flex-shrink:0;opacity:.8}.insp-media{width:100%;aspect-ratio:16/10;background:var(--bg2);border-radius:var(--r2);overflow:hidden;border:1px solid var(--border);cursor:pointer;transition:border-color .15s;display:flex;align-items:center;justify-content:center;position:relative}.insp-media:hover{border-color:var(--border2)}.insp-media img,.insp-media video{width:100%;height:100%;object-fit:cover;display:block}.insp-media-state{align-items:center;justify-content:center;gap:8px;color:var(--text3);font-size:11px;padding:16px;text-align:center}.insp-body,.insp-media-state{display:flex;flex-direction:column}.insp-body{gap:6px}.insp-section-title{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:var(--text4);margin-bottom:2px;padding:0 2px}.insp-row{display:flex;align-items:center;justify-content:space-between;padding:6px 2px;border-bottom:1px solid var(--border);gap:12px}.insp-row:last-child{border-bottom:none}.insp-label{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:1.2px;color:var(--text4);flex-shrink:0}.insp-value{font-size:11px;color:var(--text2);font-weight:500;text-align:right;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:180px}.insp-value.mono{font-family:var(--mono);font-size:10px;color:var(--text2)}.insp-text-viewer{width:100%;max-height:220px;overflow-y:auto;overscroll-behavior:contain;background:rgba(155,109,255,.03);border:1px solid rgba(155,109,255,.14);border-radius:var(--r);padding:10px 12px;font-size:12px;color:var(--text);line-height:1.55;white-space:pre-wrap;word-break:break-word}.insp-prompt{font-size:11px;color:var(--text2);line-height:1.5;padding:8px 10px;background:hsla(0,0%,100%,.02);border:1px solid var(--border);border-radius:var(--r);cursor:pointer;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;transition:all .15s}.insp-prompt:hover{border-color:var(--border2);background:hsla(0,0%,100%,.035)}.insp-prompt.expanded{-webkit-line-clamp:unset;max-height:180px;overflow-y:auto}.insp-empty-inline{color:var(--text4);font-style:italic}.insp-actions{display:flex;gap:6px;flex-wrap:wrap;margin-top:6px}.insp-btn{flex:1 1;min-width:82px;height:30px;padding:0 10px;background:hsla(0,0%,100%,.04);border:1px solid var(--border2);border-radius:var(--r);color:var(--text);font-family:inherit;font-size:11px;font-weight:600;letter-spacing:.3px;cursor:pointer;transition:all .12s;display:flex;align-items:center;justify-content:center}.insp-btn:hover:not(:disabled){background:hsla(0,0%,100%,.08);border-color:var(--border3)}.insp-btn:disabled{opacity:.35;cursor:not-allowed}.insp-btn.primary{background:var(--accent-bg);border-color:rgba(0,223,168,.3);color:var(--accent)}.insp-btn.primary:hover:not(:disabled){background:rgba(0,223,168,.12);box-shadow:0 0 10px var(--accent-glow)}.insp-refs{display:grid;grid-template-columns:repeat(auto-fill,minmax(70px,1fr));grid-gap:6px;gap:6px;margin-bottom:4px}.insp-ref{position:relative;aspect-ratio:1;overflow:hidden;background:var(--bg2);border:1px solid var(--border2);border-radius:var(--r);padding:0;cursor:zoom-in;transition:border-color .15s}.insp-ref:hover{border-color:var(--border3)}.insp-ref img,.insp-ref video{width:100%;height:100%;object-fit:cover;display:block}.insp-ref-label{position:absolute;bottom:3px;left:4px;font-size:8px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;color:#fff;background:rgba(0,0,0,.55);padding:2px 6px;border-radius:100px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.presets-section{margin-bottom:16px}.presets-section-title{font-size:8px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:var(--text);opacity:.15;margin-bottom:8px;padding:0 2px}.chip-row{display:flex;flex-wrap:wrap;gap:5px}.chip{padding:5px 10px;border-radius:100px;background:transparent;border:1px solid var(--border2);color:var(--text2);font-family:inherit;font-size:10px;font-weight:500;letter-spacing:.2px;cursor:pointer;transition:all .12s;line-height:1}.chip:hover{border-color:var(--border3);background:hsla(0,0%,100%,.04);color:var(--text)}.chip:active{transform:scale(.96)}.model-select{display:flex;flex-direction:column;gap:3px}.model-opt{display:flex;align-items:center;gap:10px;padding:10px 12px;border:1px solid var(--border);border-radius:var(--r2);cursor:pointer;transition:all .15s}.model-opt:hover{border-color:var(--border2);background:hsla(0,0%,100%,.02)}.model-opt.active{border-color:rgba(0,223,168,.25);background:var(--accent-bg)}.model-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;box-shadow:0 0 6px currentColor}.model-info{flex:1 1;min-width:0}.model-name{font-size:12px;font-weight:600;letter-spacing:.1px}.model-desc{font-size:9px;color:var(--text3);margin-top:1px}.model-cost{font-family:var(--mono);font-size:10px;color:var(--orange);display:none}.model-tags{display:flex;gap:3px;flex-wrap:wrap}.model-tag{font-size:8px;padding:2px 7px;border-radius:100px;border:1px solid var(--border2);color:var(--text3);font-weight:600;white-space:nowrap;letter-spacing:.3px;text-transform:uppercase}.model-opt.active .model-tag{border-color:rgba(0,223,168,.2);color:var(--accent)}.res-toggle{display:flex;gap:4px;background:hsla(0,0%,100%,.02);border:1px solid var(--border);border-radius:var(--r);padding:3px}.res-toggle-wrap{flex-wrap:wrap}.res-toggle-wrap .res-pill{flex-grow:1;flex-shrink:0;flex-basis:calc(25% - 3px);min-width:58px}.res-pill{flex:1 1;height:30px;padding:0 12px;background:transparent;border:none;color:var(--text3);font-family:inherit;font-size:11px;font-weight:700;letter-spacing:.6px;border-radius:6px;cursor:pointer;transition:all .12s;display:flex;align-items:center;justify-content:center;gap:8px}.res-pill:hover{color:var(--text2)}.res-pill.active{background:var(--accent-bg);color:var(--accent);box-shadow:0 1px 4px rgba(0,0,0,.2)}.res-note{font-size:8px;font-weight:600;letter-spacing:.4px;color:var(--text4);text-transform:uppercase}.res-pill.active .res-note{color:var(--accent);opacity:.8}.bottom-bar{background:rgba(17,19,32,.9);-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);border-top:1px solid var(--border);padding:12px 20px;display:flex;align-items:flex-end;gap:12px;z-index:100}.prompt-area{flex:1 1;position:relative}.prompt-textarea{width:100%;background:hsla(0,0%,100%,.03);border:1.5px solid var(--border2);border-radius:var(--r2);padding:13px 18px;color:var(--text);font-size:13px;resize:none;outline:none;min-height:48px;max-height:120px;line-height:1.5;transition:all .2s;font-weight:400}.prompt-textarea:focus{border-color:var(--accent);background:rgba(0,223,168,.02);box-shadow:0 0 0 3px rgba(0,223,168,.06)}.prompt-textarea::placeholder{color:var(--text4)}.make-btn{height:48px;padding:0 28px;background:linear-gradient(135deg,var(--accent),#00c4a0);color:var(--bg);border:none;border-radius:var(--r2);font-weight:700;font-size:14px;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:8px;white-space:nowrap;flex-shrink:0;letter-spacing:.3px;box-shadow:0 4px 16px var(--accent-glow)}.make-btn:hover{box-shadow:0 6px 28px var(--accent-strong);transform:translateY(-1px)}.make-btn:active{transform:translateY(0)}.make-btn:disabled{opacity:.4;cursor:not-allowed;transform:none;box-shadow:none;background:var(--surface3)}.make-btn .cost-tag{font-family:var(--mono);font-size:10px;opacity:.6;font-weight:500}.status-float{position:fixed;bottom:82px;left:20px;font-size:10px;color:var(--text4);display:flex;align-items:center;gap:8px;z-index:50;font-weight:500}.status-float .st-dot{width:6px;height:6px;border-radius:50%;background:var(--accent);box-shadow:0 0 8px var(--accent-glow);animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.3}}.zoom-ctrl{position:fixed;bottom:82px;right:20px;display:flex;gap:2px;z-index:50;background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:2px}.zoom-btn{width:30px;height:28px;background:transparent;border:none;border-radius:6px;color:var(--text3);font-size:13px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .12s;font-weight:600}.zoom-btn:hover{background:hsla(0,0%,100%,.04);color:var(--text)}.zoom-label{font-family:var(--mono);font-size:10px;color:var(--text4);padding:0 6px;font-weight:500}.lightbox,.zoom-label{display:flex;align-items:center}.lightbox{position:fixed;inset:0;z-index:9999;background:rgba(0,0,0,.9);-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);justify-content:center;padding:20px;cursor:zoom-out;animation:lbIn .2s ease}@keyframes lbIn{0%{opacity:0}to{opacity:1}}.lightbox-content{max-width:92vw;max-height:92vh;display:flex;flex-direction:column;cursor:default;animation:lbScale .25s cubic-bezier(.34,1.56,.64,1)}@keyframes lbScale{0%{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}.lightbox-media{max-width:92vw;max-height:82vh;object-fit:contain;border-radius:var(--r2);box-shadow:0 24px 80px rgba(0,0,0,.6)}.lightbox-bar{display:flex;align-items:center;justify-content:space-between;padding:12px 4px;margin-top:10px}.lightbox-info{font-size:12px;color:var(--text2);font-weight:500}.lightbox-actions{display:flex;gap:6px}.lightbox-btn{padding:8px 18px;border-radius:var(--r);border:1px solid var(--border2);background:hsla(0,0%,100%,.06);color:var(--text);font-size:12px;font-weight:600;cursor:pointer;transition:all .15s;text-decoration:none;display:inline-flex;align-items:center;font-family:var(--sans)}.lightbox-btn:hover{background:hsla(0,0%,100%,.12);border-color:var(--border3)}.lightbox-btn:first-child{background:var(--accent);color:var(--bg);border-color:var(--accent)}.lightbox-btn:first-child:hover{box-shadow:0 4px 16px var(--accent-glow)}.lightbox-close{width:36px;padding:8px 0;text-align:center;font-size:16px}.lightbox-close:hover{background:rgba(255,50,50,.2);border-color:rgba(255,50,50,.3);color:#f66}.node-text{width:320px;border-color:rgba(155,109,255,.35)}.node-text.selected{border-color:var(--purple);box-shadow:var(--shadow-lg),0 0 0 2px rgba(155,109,255,.25)}.node-text-body{padding:14px 14px 12px;display:flex;flex-direction:column;gap:8px}.node-text-header{display:flex;align-items:center;justify-content:space-between}.node-text-badge{font-size:9px;font-weight:700;letter-spacing:1.2px;text-transform:uppercase;color:var(--purple);background:var(--purple-bg);padding:4px 8px;border-radius:100px;border:1px solid rgba(155,109,255,.25)}.node-text-area{width:100%;min-height:120px;max-height:150px;resize:none;overflow-y:auto;overscroll-behavior:contain;background:rgba(155,109,255,.04);border:1px solid rgba(155,109,255,.18);border-radius:var(--r);padding:10px 12px;color:var(--text);font-family:inherit;font-size:12px;line-height:1.5;outline:none;transition:all .15s;cursor:text}.node-text-area:focus{border-color:var(--purple);background:rgba(155,109,255,.07);box-shadow:0 0 0 3px rgba(155,109,255,.12)}.node-text-area::placeholder{color:var(--text4)}.node-text-thumb{position:relative;width:100%;height:60px;border-radius:var(--r);overflow:hidden;border:1px solid rgba(155,109,255,.25);background:var(--bg2);cursor:zoom-in;transition:all .15s}.node-text-thumb:hover{border-color:var(--purple);box-shadow:0 0 10px rgba(155,109,255,.18)}.node-text-thumb img,.node-text-thumb video{width:100%;height:100%;object-fit:cover;display:block}.node-text-thumb-label{position:absolute;bottom:4px;left:6px;font-size:8px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;color:#fff;background:rgba(0,0,0,.55);padding:2px 6px;border-radius:100px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.node-text-generate{background:var(--purple-bg);border:1px solid rgba(155,109,255,.35);color:var(--purple);font-size:10px;font-weight:700;letter-spacing:.4px;padding:4px 10px;border-radius:100px;cursor:pointer;transition:all .15s;font-family:inherit}.node-text-generate:hover:not(:disabled){background:rgba(155,109,255,.14);box-shadow:0 0 10px rgba(155,109,255,.25)}.node-text-generate:disabled{opacity:.5;cursor:not-allowed}.node-text-area:disabled{opacity:.6;cursor:wait}.node-delete{position:absolute;top:-8px;right:-8px;width:22px;height:22px;border-radius:50%;background:var(--surface2);border:1.5px solid var(--border3);color:var(--text2);font-size:14px;font-weight:700;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transform:scale(.8);transition:all .15s;z-index:11;padding:0}.node:hover .node-delete{opacity:1;transform:scale(1)}.node-delete:hover{background:rgba(255,50,80,.15);border-color:rgba(255,80,100,.5);color:#ff6078}.conn-line.conn-drag{stroke:var(--accent);stroke-width:2;stroke-dasharray:6 4;animation:conn-dash .6s linear infinite;filter:drop-shadow(0 0 6px var(--accent-glow));pointer-events:none}.port[data-port-kind=in]{cursor:crosshair}.port[data-port-kind=out]{cursor:-webkit-grab;cursor:grab}.port[data-port-kind=out]:active{cursor:-webkit-grabbing;cursor:grabbing}.drop-menu{position:fixed;z-index:9998;min-width:196px;background:rgba(17,19,32,.78);backdrop-filter:blur(28px) saturate(140%);-webkit-backdrop-filter:blur(28px) saturate(140%);border:1px solid var(--border3);border-radius:var(--r2);padding:6px;box-shadow:var(--shadow-lg),0 0 0 1px rgba(0,223,168,.12) inset;display:flex;flex-direction:column;gap:2px;animation:ctxIn .14s cubic-bezier(.34,1.56,.64,1);transform-origin:top left}.drop-menu-title{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:var(--text4);padding:8px 12px 6px}.drop-menu-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border:none;background:transparent;border-radius:var(--r);cursor:pointer;color:var(--text);text-align:left;transition:all .12s;font-family:inherit}.drop-menu-item:hover{background:hsla(0,0%,100%,.06)}.drop-icon{width:28px;height:28px;flex-shrink:0;border-radius:7px;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;background:hsla(0,0%,100%,.05);border:1px solid var(--border);transition:all .12s}.drop-body{display:flex;flex-direction:column;gap:1px;min-width:0;flex:1 1}.drop-name{font-size:12px;font-weight:600;color:var(--text);letter-spacing:.1px}.drop-desc{font-size:9px;color:var(--text3);font-weight:500}.drop-text .drop-icon{border-color:rgba(155,109,255,.3);color:var(--purple)}.drop-text .drop-icon,.drop-text:hover{background:var(--purple-bg)}.drop-image .drop-icon{border-color:rgba(0,223,168,.3);color:var(--accent)}.drop-image .drop-icon,.drop-image:hover{background:var(--accent-bg)}.drop-video .drop-icon{border-color:rgba(245,166,35,.3);color:var(--orange)}.drop-video .drop-icon,.drop-video:hover{background:var(--orange-bg)}.context-menu{position:fixed;z-index:9998;min-width:232px;background:rgba(17,19,32,.72);backdrop-filter:blur(28px) saturate(140%);-webkit-backdrop-filter:blur(28px) saturate(140%);border:1px solid var(--border3);border-radius:var(--r2);padding:6px;box-shadow:var(--shadow-lg),0 0 0 1px hsla(0,0%,100%,.02) inset;display:flex;flex-direction:column;gap:2px;animation:ctxIn .14s cubic-bezier(.34,1.56,.64,1);transform-origin:top left}@keyframes ctxIn{0%{opacity:0;transform:scale(.94) translateY(-4px)}to{opacity:1;transform:scale(1) translateY(0)}}.ctx-menu-title{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:var(--text4);padding:8px 12px 6px}.ctx-menu-sep{height:1px;background:var(--border);margin:4px 6px}.ctx-menu-item{display:flex;align-items:center;gap:10px;padding:9px 10px;border:none;background:transparent;border-radius:var(--r);cursor:pointer;color:var(--text);text-align:left;transition:all .12s;font-family:inherit}.ctx-menu-item:hover{background:hsla(0,0%,100%,.06)}.ctx-menu-item:active{transform:scale(.98)}.ctx-icon{width:30px;height:30px;flex-shrink:0;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;background:hsla(0,0%,100%,.05);border:1px solid var(--border);transition:all .12s}.ctx-body{display:flex;flex-direction:column;gap:1px;min-width:0;flex:1 1}.ctx-name{font-size:12px;font-weight:600;color:var(--text);letter-spacing:.1px}.ctx-desc{font-size:10px;color:var(--text3);font-weight:500}.ctx-text .ctx-icon{border-color:rgba(155,109,255,.3);color:var(--purple)}.ctx-text .ctx-icon,.ctx-text:hover{background:var(--purple-bg)}.ctx-text:hover .ctx-icon{box-shadow:0 0 12px rgba(155,109,255,.25)}.ctx-image .ctx-icon{border-color:rgba(0,223,168,.3);color:var(--accent)}.ctx-image .ctx-icon,.ctx-image:hover{background:var(--accent-bg)}.ctx-image:hover .ctx-icon{box-shadow:0 0 12px var(--accent-glow)}.ctx-video .ctx-icon{border-color:rgba(245,166,35,.3);color:var(--orange)}.ctx-video .ctx-icon,.ctx-video:hover{background:var(--orange-bg)}.ctx-video:hover .ctx-icon{box-shadow:0 0 12px rgba(245,166,35,.25)}.ctx-upload .ctx-icon{border-color:var(--border2);color:var(--text2)}.ctx-upload .ctx-icon,.ctx-upload:hover{background:hsla(0,0%,100%,.04)}.ctx-upload:hover .ctx-icon{color:var(--text)}.np-pills{display:flex;flex-wrap:wrap;gap:2px;padding:2px;background:hsla(0,0%,100%,.02);border:1px solid var(--border);border-radius:6px}.np-pill{padding:3px 7px;border:none;background:transparent;border-radius:4px;color:var(--text4);font-family:inherit;font-size:8px;font-weight:700;letter-spacing:.4px;text-transform:uppercase;cursor:pointer;line-height:1;transition:color .12s,background .12s;white-space:nowrap}.np-pill:hover{color:var(--text2)}.np-pills-cyan .np-pill.active{background:rgba(0,223,168,.08);color:var(--accent)}.np-pills-purple .np-pill.active{background:rgba(155,109,255,.08);color:var(--purple)}.np-pills-orange .np-pill.active{background:rgba(245,166,35,.08);color:var(--orange)}.ni{display:flex;flex-direction:column;gap:8px;padding:10px;font-size:10px}.ni-header{justify-content:space-between;gap:6px}.ni-header,.node-chevron{display:flex;align-items:center;cursor:pointer}.node-chevron{flex-shrink:0;width:18px;height:18px;padding:0;background:transparent;border:none;border-radius:4px;color:var(--text3);justify-content:center;transition:background .12s,color .12s}.node-chevron:hover{background:hsla(0,0%,100%,.06);color:var(--text)}.node-chevron svg{width:10px;height:10px}.node.collapsed{min-height:0;padding:0}.node-collapsed{position:relative;height:100%;width:100%;overflow:hidden;border-radius:14px;cursor:pointer}.nc-card{background:var(--bg2)}.nc-media{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}.nc-media-state{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:var(--bg2);color:var(--text4);font-size:10px;letter-spacing:.4px;text-transform:uppercase}.nc-media-empty{font-weight:600;opacity:.5}.nc-overlay{position:absolute;top:0;left:0;right:0;z-index:2;display:flex;align-items:center;gap:6px;padding:6px 8px;background:linear-gradient(180deg,rgba(8,9,13,.78),rgba(8,9,13,0));-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.nc-overlay-flat{position:static;background:hsla(0,0%,100%,.02);-webkit-backdrop-filter:none;backdrop-filter:none;border-bottom:1px solid var(--border)}.nc-label{font-size:8px;font-weight:800;letter-spacing:1.2px;text-transform:uppercase}.nc-engine{font-size:9px;font-family:var(--mono);color:var(--text2);letter-spacing:.2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100px;text-transform:lowercase}.nc-spacer{flex:1 1}.nc-reason{background:var(--surface);display:flex;flex-direction:column}.nc-text-body{flex:1 1;min-height:0;padding:8px 10px;font-size:11px;color:var(--text2);line-height:1.4;overflow:hidden;display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical}.nc-empty-text{color:var(--text4);font-style:italic}.ni-label{font-size:8px;font-weight:800;letter-spacing:1.5px;text-transform:uppercase;flex-shrink:0}.ni-label-cyan{color:var(--accent)}.ni-label-purple{color:var(--purple)}.ni-label-orange{color:var(--orange)}.ni-grid{display:grid;grid-gap:8px;gap:8px}.ni-grid-image{grid-template-columns:1fr 110px}.ni-grid-video{grid-template-columns:1fr 120px}.ni-controls{display:flex;flex-direction:column;gap:7px;min-width:0}.ni-result{background:var(--bg2);border-radius:var(--r);overflow:hidden;border:1px solid var(--border);min-height:120px;display:flex;align-items:center;justify-content:center}.ni-result img,.ni-result video{width:100%;height:100%;object-fit:cover;display:block}.ni-result-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;color:var(--text4);font-size:9px;padding:8px;text-align:center}.ni-result-empty{opacity:.5}.ni-prompt{width:100%;min-height:44px;max-height:90px;resize:none;overflow-y:auto;overscroll-behavior:contain;background:hsla(0,0%,100%,.02);border:1px solid var(--border);border-radius:var(--r);padding:6px 8px;color:var(--text);font-family:inherit;font-size:11px;line-height:1.45;outline:none;transition:border-color .15s}.ni-prompt:focus{border-color:var(--border3);background:hsla(0,0%,100%,.04)}.ni-prompt::placeholder{color:var(--text4);font-size:10px}.ni-prompt:disabled{opacity:.55;cursor:wait}.ni-section{display:flex;flex-direction:column;gap:3px}.ni-section-label{font-size:7px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--text4);opacity:.7;padding-left:2px}.ni-generate{height:30px;padding:0 10px;border:none;border-radius:var(--r);cursor:pointer;font-family:inherit;font-size:11px;font-weight:700;letter-spacing:.3px;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .15s}.ni-generate:disabled{opacity:.5;cursor:wait}.ni-cost-tag{font-family:var(--mono);font-size:9px;font-weight:600;opacity:.75}.ni-generate-cyan{background:var(--accent);color:var(--bg);box-shadow:0 2px 10px var(--accent-glow)}.ni-generate-cyan:hover:not(:disabled){box-shadow:0 4px 16px var(--accent-strong)}.ni-generate-purple{background:var(--purple);color:#fff;box-shadow:0 2px 10px rgba(155,109,255,.25)}.ni-generate-purple:hover:not(:disabled){box-shadow:0 4px 16px rgba(155,109,255,.45)}.ni-generate-orange{background:var(--orange);color:#1a1004;box-shadow:0 2px 10px rgba(245,166,35,.25)}.ni-generate-orange:hover:not(:disabled){box-shadow:0 4px 16px rgba(245,166,35,.45)}.ni-actions{display:flex;justify-content:flex-end}.ni-footer{display:flex;align-items:center;justify-content:space-between;gap:8px;padding-top:6px;border-top:1px solid var(--border)}.ni-meta{font-size:9px;font-family:var(--mono);color:var(--text4);letter-spacing:.3px}.ni-meta-cost{color:var(--accent);font-weight:600}.ni-refs-pill{font-size:8px;font-family:var(--mono);color:var(--accent);background:rgba(0,223,168,.08);padding:2px 6px;border-radius:100px;border:1px solid rgba(0,223,168,.18);letter-spacing:.3px;line-height:1;margin-left:auto;margin-right:6px}.ni-slot-row{display:flex;gap:4px}.ni-slot{flex:1 1;text-align:center;padding:4px;border-radius:4px;background:hsla(0,0%,100%,.02);border:1px dashed var(--border2);color:var(--text4);font-size:7px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;transition:all .15s}.ni-slot.wired{background:rgba(245,166,35,.08);border-color:rgba(245,166,35,.3);border-style:solid;color:var(--orange)}.ni-warn{font-size:9px;color:var(--orange);opacity:.7;letter-spacing:.3px;padding:0 2px;margin-top:-4px}.port-stack{position:absolute;left:-7px;top:0;bottom:0;display:flex;flex-direction:column;justify-content:space-around;padding:24px 0;z-index:10}.port-stack .port-in{position:relative;left:0;top:auto;transform:none}.port-slot-label{position:absolute;left:-18px;top:50%;transform:translateY(-50%);font-size:7px;font-family:var(--mono);font-weight:700;color:var(--text4);pointer-events:none}@media (max-width:768px){.app{grid-template-rows:48px 1fr auto}.topbar{padding:0 12px;gap:6px}.logo{font-size:15px;gap:6px}.logo-box{width:28px;height:28px;font-size:13px}.tb-btn{padding:0 8px;font-size:11px;height:32px}.credits{font-size:10px;padding:4px 10px}.tb-sep{display:none}.tb-avatar{width:28px;height:28px}.main-area{grid-template-columns:1fr;position:relative}.right-panel{position:fixed;bottom:0;left:0;right:0;top:48px;z-index:90;border-left:none;border-top:1px solid var(--border);overflow-y:auto}.rp-preview{padding:10px 12px}.rp-preview-img{aspect-ratio:16/9}.rp-body{padding:10px 12px}.presets-row{grid-template-columns:1fr 1fr 1fr 1fr;gap:4px}.preset-btn{padding:8px 2px 6px}.preset-icon{width:28px;height:28px;font-size:14px}.preset-name{font-size:8px}.model-opt{padding:8px 10px}.model-name{font-size:11px}.canvas-wrap{display:none}.bottom-bar{padding:8px 12px;gap:8px;position:fixed;bottom:0;left:0;right:0;z-index:95}.prompt-textarea{min-height:40px;padding:10px 14px;font-size:12px;border-radius:var(--r)}.make-btn{height:40px;padding:0 20px;font-size:13px;border-radius:var(--r)}.status-float,.zoom-ctrl{display:none}.lightbox{padding:10px}.lightbox-media{max-width:96vw;max-height:70vh}.lightbox-bar{flex-direction:column;gap:8px;align-items:stretch}.lightbox-info{text-align:center}.lightbox-actions{justify-content:center}.lightbox-btn{padding:10px 16px;font-size:11px}}@media (min-width:769px) and (max-width:1024px){.main-area{grid-template-columns:1fr}.node-source{width:200px}.node-ai{width:240px}.presets-row{gap:4px}.preset-icon{width:28px;height:28px;font-size:14px}}