.node-canvas{position:relative;width:100%;height:100%;min-height:calc(100vh - 64px);background:#1A1A1A;overflow:hidden;cursor:grab}.node-canvas:active{cursor:grabbing}.node-canvas:before{content:"";position:absolute;inset:0;background-image:radial-gradient(circle,rgba(255,255,255,.06) 1px,transparent 0);background-size:30px 30px;pointer-events:none}[data-theme=dark] .node-canvas{background:hsl(222,47%,5%)}[data-theme=dark] .node-canvas:before{background-image:radial-gradient(circle,rgba(108,59,250,.06) 1px,transparent 0)}.node{position:absolute;width:280px;background:var(--bg-card,#fff);border:1px solid var(--border-default,rgba(0,0,0,.08));border-radius:16px;cursor:move;-webkit-user-select:none;-moz-user-select:none;user-select:none;box-shadow:0 2px 8px rgba(0,0,0,.15),0 8px 24px rgba(0,0,0,.12),0 20px 60px rgba(0,0,0,.08);transition:border-color .15s cubic-bezier(.16,1,.3,1),box-shadow .15s cubic-bezier(.16,1,.3,1),transform .15s cubic-bezier(.16,1,.3,1)}.node:hover{border-color:var(--border-strong,rgba(0,0,0,.15));box-shadow:0 4px 12px rgba(0,0,0,.18),0 12px 32px rgba(0,0,0,.15),0 24px 72px rgba(0,0,0,.1);transform:translateY(-1px)}.node--selected{box-shadow:0 4px 12px rgba(0,0,0,.18),0 12px 32px rgba(0,0,0,.15),0 0 0 2px var(--accent-primary,#C9A96E),0 0 30px var(--accent-glow,rgba(201,169,110,.2))}.node--running,.node--selected{border-color:var(--accent-primary,#C9A96E)}.node--running{animation:nodeGlow 1.5s ease-in-out infinite}.node--done{border-color:#4CAF50}@keyframes nodeGlow{0%,to{box-shadow:0 4px 12px rgba(0,0,0,.18),0 12px 32px rgba(0,0,0,.15),0 0 0 2px var(--accent-primary,#C9A96E),0 0 24px var(--accent-glow,rgba(201,169,110,.2))}50%{box-shadow:0 4px 12px rgba(0,0,0,.18),0 12px 32px rgba(0,0,0,.15),0 0 0 3px var(--accent-primary,#C9A96E),0 0 50px var(--accent-glow,rgba(201,169,110,.4))}}.node__reflection{position:absolute;bottom:-30px;left:10%;right:10%;height:30px;background:inherit;border-radius:0 0 16px 16px;transform:scaleY(-.35);transform-origin:top center;filter:blur(6px);opacity:.08;pointer-events:none;z-index:-1;mask-image:linear-gradient(180deg,rgba(0,0,0,.5),transparent);-webkit-mask-image:linear-gradient(180deg,rgba(0,0,0,.5),transparent)}.node__header{display:flex;align-items:center;gap:10px;padding:12px 14px;border-bottom:1px solid var(--border-subtle,rgba(0,0,0,.05));border-radius:16px 16px 0 0;background:var(--bg-secondary,#F0EEE9);font-family:Raleway,sans-serif;font-size:.75rem;position:relative;z-index:6;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-primary,#1A1A1A)}.node__header-text{flex:1;min-width:0}.node--selected .node__header{background:linear-gradient(135deg,rgba(201,169,110,.1),rgba(201,169,110,.05))}.node--running .node__header{background:linear-gradient(135deg,rgba(201,169,110,.2),rgba(201,169,110,.1))}[data-theme=dark] .node--selected .node__header{background:linear-gradient(135deg,rgba(108,59,250,.15),rgba(108,59,250,.05))}[data-theme=dark] .node--running .node__header{background:linear-gradient(135deg,rgba(108,59,250,.25),rgba(108,59,250,.1))}.node__icon{width:28px;height:28px;display:flex;align-items:center;justify-content:center;font-size:1.1rem;background:var(--bg-card,#fff);border:1px solid var(--border-default,rgba(0,0,0,.08));border-radius:8px;flex-shrink:0}.node__title-text{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.node__subtitle{font-size:.6rem;font-weight:400;color:var(--text-tertiary,#888);text-transform:none;letter-spacing:normal;display:block;margin-top:2px}.node__delete{flex-shrink:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:none;border:1px solid transparent;border-radius:6px;color:var(--text-muted,#BBB);font-size:1.1rem;line-height:1;cursor:pointer;transition:all .15s;opacity:.4;position:relative;z-index:10}.node:hover .node__delete{opacity:1}.node__delete:hover{background:rgba(220,60,60,.08);border-color:rgba(220,60,60,.2);color:rgba(220,60,60,.8)}.node__body{padding:12px;gap:10px}.node__body,.node__slots{display:flex;flex-direction:column}.node__slots{gap:8px}.node__slot{border:1.5px dashed var(--border-strong,rgba(0,0,0,.15));border-radius:10px;padding:14px 12px;text-align:center;cursor:pointer;transition:all .2s;background:var(--bg-secondary,#F0EEE9);display:flex;flex-direction:column;align-items:center;gap:4px}.node__slot:hover{border-color:var(--accent-primary,#C9A96E);background:rgba(201,169,110,.05)}[data-theme=dark] .node__slot:hover{background:rgba(108,59,250,.08)}.node__slot--filled{border-style:solid;border-color:var(--accent-light,#E8D5A8);padding:6px}.node__slot-preview{display:flex;flex-direction:column;align-items:center;gap:4px}.node__slot-img,.node__slot-preview img{width:100%;max-height:120px;-o-object-fit:contain;object-fit:contain;border-radius:6px;background:var(--bg-primary,#FAFAFA)}.node__slot-label-small{font-family:Raleway,sans-serif;font-size:.55rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--accent-primary,#C9A96E);margin-top:2px}.node__slot-icon{font-size:1rem;color:var(--text-tertiary,#888)}.node__slot-label{font-family:Raleway,sans-serif;font-size:.68rem;color:var(--text-tertiary,#888);font-weight:500}.node__slot-req{color:var(--accent-primary,#C9A96E);margin-left:2px}.node__slot-hint{font-family:Raleway,sans-serif;font-size:.58rem;color:var(--text-muted,#BBB)}.node__empty-slot{padding:16px;text-align:center;border:1px dashed var(--border-default,rgba(0,0,0,.08))}.node__empty-slot,.node__preview{border-radius:10px;background:var(--bg-secondary,#F0EEE9)}.node__preview{position:relative;aspect-ratio:4/3;display:flex;align-items:center;justify-content:center;overflow:hidden;border:1px solid var(--border-subtle,rgba(0,0,0,.05));cursor:pointer}.node__preview img{width:100%;height:100%;-o-object-fit:contain;object-fit:contain;border-radius:10px;background:rgba(0,0,0,.15)}.node__preview-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.4);opacity:0;transition:opacity .2s;border-radius:10px;color:#fff;font-family:Raleway,sans-serif;font-size:.72rem;font-weight:500}.node__preview:hover .node__preview-overlay{opacity:1}.node__prompt{width:100%;padding:8px 12px;border:1px solid var(--border-default,rgba(0,0,0,.08));border-radius:8px;background:var(--bg-primary,#FAFAFA);color:var(--text-primary,#1A1A1A);font-family:Raleway,sans-serif;font-size:.75rem;outline:none;resize:none;min-height:52px;transition:border-color .2s}.node__prompt::-moz-placeholder{color:var(--text-muted,#BBB)}.node__prompt::placeholder{color:var(--text-muted,#BBB)}.node__prompt:focus{border-color:var(--accent-primary,#C9A96E);box-shadow:0 0 0 2px var(--accent-glow,rgba(201,169,110,.1))}.node__spinner{display:flex;flex-direction:column;align-items:center;gap:8px;padding:20px}.node__spinner-ring{width:32px;height:32px;border:2px solid var(--border-default,rgba(0,0,0,.08));border-top-color:var(--accent-primary,#c9a96e);border-radius:50%;animation:nodeSpin .8s linear infinite}@keyframes nodeSpin{to{transform:rotate(1turn)}}.node__spinner-text{font-family:Raleway,sans-serif;font-size:.68rem;color:var(--text-tertiary,#888);font-weight:500}.node__footer{padding:8px 14px;border-top:1px solid var(--border-subtle,rgba(0,0,0,.05));display:flex;align-items:center;justify-content:space-between}.node__footer-actions{display:flex;align-items:center;gap:6px}.node__action-btn{width:24px;height:24px;display:flex;align-items:center;justify-content:center;border:1px solid var(--border-default,rgba(0,0,0,.08));border-radius:6px;background:transparent;color:var(--text-tertiary,#888);font-size:.75rem;cursor:pointer;transition:all .15s}.node__action-btn:hover{border-color:var(--accent-primary,#C9A96E);color:var(--accent-primary,#C9A96E);background:rgba(201,169,110,.06)}[data-theme=dark] .node__action-btn:hover{background:rgba(108,59,250,.1)}.node__credit-cost{font-size:.58rem;letter-spacing:.06em}.node__credit-cost,.node__status{font-family:Raleway,sans-serif;font-weight:500;color:var(--text-muted,#BBB);text-transform:uppercase}.node__status{font-size:.62rem;letter-spacing:.08em}.node__status--ready,.node__status--running{color:var(--accent-primary,#C9A96E)}.node__status--running{animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.node__status--done{color:#4CAF50}.node__port-zone{position:absolute;width:36px;height:36px;cursor:crosshair;z-index:5;display:flex;align-items:center;justify-content:center}.node__port-zone--input{left:-18px;top:50%;transform:translateY(-50%)}.node__port-zone--slot-input{position:absolute;left:-18px;transform:translateY(-50%);width:36px;height:36px;cursor:crosshair;z-index:5;display:flex;align-items:center;justify-content:center}.node__port-zone--output{right:-18px;top:50%;transform:translateY(-50%)}.node__port{width:14px;height:14px;border-radius:50%;background:var(--bg-card,#fff);border:2.5px solid var(--border-strong,rgba(0,0,0,.15));transition:all .15s cubic-bezier(.16,1,.3,1);pointer-events:none}.node__port-zone:hover .node__port{border-color:var(--accent-primary,#C9A96E);transform:scale(1.4);box-shadow:0 0 12px var(--accent-glow,rgba(201,169,110,.4))}.node__port--connected{background:var(--accent-primary,#C9A96E);border-color:var(--accent-primary,#C9A96E)}.node__port--highlight{border-color:var(--accent-primary,#C9A96E);box-shadow:0 0 14px var(--accent-glow,rgba(201,169,110,.5));animation:portPulse 1s ease-in-out infinite}@keyframes portPulse{0%,to{box-shadow:0 0 8px var(--accent-glow,rgba(201,169,110,.3));transform:scale(1)}50%{box-shadow:0 0 18px var(--accent-glow,rgba(201,169,110,.6));transform:scale(1.3)}}.node-connection{fill:none;stroke:rgba(255,255,255,.15);stroke-width:2;pointer-events:none}.node-connection--active{stroke:var(--accent-primary,#C9A96E);filter:drop-shadow(0 0 6px var(--accent-glow,rgba(201,169,110,.3)))}.node-connection--flow{stroke-dasharray:6 4;animation:connectionFlow 1s linear infinite}@keyframes connectionFlow{to{stroke-dashoffset:-10}}.node-connection--dragging{stroke:var(--accent-light,#E8D5A8);stroke-width:2;stroke-dasharray:4 4}.node-connection__delete-dot{fill:transparent;stroke:none;pointer-events:all;transition:all .2s}.node-connection__hitbox{cursor:pointer}.node-connection__hitbox:hover~.node-connection--active{stroke:rgba(220,60,60,.7);filter:drop-shadow(0 0 8px rgba(220,60,60,.4))}.node-connection__hitbox:hover~.node-connection__delete-dot{fill:rgba(220,60,60,.85);r:10}.node-connection__delete-dot text{font-family:Raleway,sans-serif;font-size:10px;fill:#fff;pointer-events:none}.editor-bar{position:fixed;bottom:0;left:0;right:0;height:56px;background:rgba(26,26,26,.85);border-top:1px solid rgba(255,255,255,.08);display:flex;align-items:center;justify-content:space-between;padding:0 24px;z-index:100;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px)}[data-theme=dark] .editor-bar{background:hsla(222,47%,6%,.9);border-top-color:hsla(250,95%,63%,.1)}.node-sidebar{position:fixed;left:0;top:0;bottom:56px;width:240px;background:var(--bg-card,#fff);border-right:1px solid var(--border-default,rgba(0,0,0,.08));z-index:50;display:flex;flex-direction:column;overflow:hidden}.node-sidebar__header{padding:12px 12px 8px;border-bottom:1px solid var(--border-subtle,rgba(0,0,0,.05));display:flex;align-items:center;justify-content:space-between}.node-sidebar__title{font-family:Raleway,sans-serif;font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--text-primary,#1A1A1A)}.node-sidebar__list{flex:1;overflow-y:auto;padding:8px}.node-sidebar__item{display:flex;align-items:center;gap:10px;flex:1;padding:10px 12px;border-radius:10px;border:none;background:transparent;color:var(--text-secondary,#555);font-family:Raleway,sans-serif;font-size:.8rem;font-weight:400;cursor:pointer;transition:all .15s;text-align:left;min-width:0}.node-sidebar__item:hover{background:var(--bg-secondary,#F0EEE9);color:var(--text-primary,#1A1A1A)}.node-sidebar__item-icon{width:32px;height:32px;display:flex;align-items:center;justify-content:center;font-size:1rem;background:var(--bg-secondary,#F0EEE9);border:1px solid var(--border-subtle,rgba(0,0,0,.05));border-radius:8px;flex-shrink:0}.node-sidebar__item-name{font-weight:500;display:block}.node-sidebar__item-cost{font-size:.62rem;color:var(--text-muted,#BBB);display:block;margin-top:1px}.node-minimap{position:absolute;bottom:72px;right:16px;width:180px;height:120px;background:var(--bg-card,#fff);border:1px solid var(--border-default,rgba(0,0,0,.08));border-radius:8px;overflow:hidden;opacity:.7;transition:opacity .15s;box-shadow:var(--shadow-sm,0 1px 3px rgba(0,0,0,.06))}.node-minimap:hover{opacity:1}