@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&family=Noto+Sans+SC:wght@400;500;600;700&display=swap";:root{color:#f4f5fb;background:#0c0d12;font-family:Inter,Noto Sans SC,system-ui,sans-serif}*{box-sizing:border-box}html,body,#root{width:100%;height:100%;margin:0}body{overflow:hidden}button,input,textarea,select{font:inherit}button{cursor:pointer}.app-shell{background:#0c0d12;grid-template-rows:58px 1fr;width:100%;height:100%;display:grid}.topbar{z-index:5;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#121319f0;border-bottom:1px solid #242631;grid-template-columns:260px 1fr 330px;align-items:center;height:58px;padding:0 18px;display:grid}.brand{align-items:center;gap:8px;font-size:14px;display:flex}.brand-mark{background:linear-gradient(135deg,#765dec,#b26cff);border-radius:10px;place-items:center;width:32px;height:32px;display:grid}.brand b{font-size:15px}.brand span:last-child{color:#9da1ad}.workspace-title{color:#d9dcef;justify-self:center;font-size:13px}.top-hint{color:#8b90a1;justify-self:end;align-items:center;gap:7px;font-size:12px;display:flex}.canvas{-webkit-user-select:none;user-select:none;cursor:default;position:relative;overflow:hidden}.canvas.panning-left{cursor:grabbing}.canvas.panning-right{cursor:move}.canvas-bg{background:radial-gradient(circle at 1px 1px,#252936 1px,#0000 0) 0 0/24px 24px,radial-gradient(circle at 75% 20%,#6d55ff18,#0000 35%),#0b0c11;position:absolute;inset:0}.world{transform-origin:0 0;position:absolute;inset:0}.edge-layer{pointer-events:none;z-index:1;width:100%;height:100%;position:absolute;inset:0;overflow:visible}.edge-path{fill:none;stroke:#a997ff;stroke-width:2.5px;opacity:.92;filter:drop-shadow(0 0 5px #7660e899)}.edge-preview{fill:none;stroke:#8b79ee;stroke-width:2.5px;stroke-dasharray:8 8;opacity:1}.creative-node{z-index:2;background:linear-gradient(160deg,#1b1d27,#15161d);border:1px solid #3a3d49;border-radius:18px;flex-direction:column;width:390px;min-height:260px;display:flex;position:absolute;overflow:visible;box-shadow:0 24px 70px #0008}.creative-node.kind-prompt{border-color:#7d65db;box-shadow:0 0 0 1px #7d65db50,0 22px 80px #0009}.creative-node.kind-media{border-color:#4a5067;min-height:260px}.creative-node.kind-image{border-color:#8066d9}.creative-node.kind-video{border-color:#cc668e}.creative-node.is-selected{box-shadow:0 0 0 2px #f5d76e88,0 24px 70px #0008;border-color:#f5d76e!important}.node-head{cursor:grab;touch-action:none;border-bottom:1px solid #2d303a;align-items:center;gap:10px;height:58px;padding:0 14px;display:flex}.node-head:active{cursor:grabbing}.node-icon{color:#c9beff;background:#312a5a;border-radius:10px;flex:none;place-items:center;width:36px;height:36px;display:grid}.node-title{color:#fff;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;font-size:17px;font-weight:800;overflow:hidden}.drag-hint{color:#7d8291;letter-spacing:1px;opacity:0;border:1px solid #343846;border-radius:999px;flex:none;padding:3px 7px;font-size:10px;font-weight:700;transition:opacity .15s}.node-head:hover .drag-hint{opacity:1}.node-head input{color:#fff;background:0 0;border:0;outline:0;flex:1;min-width:0;font-size:17px;font-weight:800}.node-head button{color:#858a99;background:0 0;border:0;border-radius:9px;place-items:center;width:30px;height:30px;display:grid}.node-head button:hover{color:#fff;background:#2a2c36}.node-head .node-delete{color:#ff9aaa;cursor:pointer;opacity:.76;background:#351a23;flex:none}.node-head .node-delete:hover{color:#fff;opacity:1;background:#d94f6b}.creative-node textarea{resize:none;color:#d9dcef;background:0 0;border:0;outline:0;flex:auto;width:100%;min-height:96px;padding:22px 18px;font-size:17px;line-height:1.6}.creative-node textarea::placeholder{color:#666b7a}.node-params{border-top:1px solid #2a2d36;grid-template-columns:1fr 1.25fr .7fr;gap:8px;padding:12px 16px;display:grid}.node-params select{color:#dfe1ec;background:#101116;border:1px solid #343846;border-radius:10px;outline:0;min-width:0;height:40px;padding:0 10px;font-size:12px}.media-params{grid-template-columns:1.3fr 1fr 1fr}.media-params select:nth-child(n+4){grid-column:span 1}.reference-status{color:#777e91;background:#10111680;border:1px dashed #343846;border-radius:10px;margin:0 16px 8px;padding:8px 10px;font-size:12px}.reference-status.has-reference{color:#d5ceff;background:#2a2354a6;border-color:#7968d9}.creative-node.kind-media{background:#232428f2;border-color:#333742;border-radius:14px;min-height:168px;overflow:visible;box-shadow:0 18px 54px #0007}.creative-node.kind-media .handle{top:50%}.lib-node-top{cursor:grab;touch-action:none;align-items:center;gap:8px;min-height:54px;padding:10px 12px 6px;display:flex}.lib-node-top:active{cursor:grabbing}.lib-tool{color:#c9cbd2;background:#292a2f;border:1px solid #41444b;border-radius:8px;place-items:center;gap:1px;width:43px;height:38px;font-size:10px;line-height:1;display:grid}.lib-tool:hover{color:#fff;background:#30323a;border-color:#767a86}.lib-tool svg{color:#e0e2ec}.lib-tool .plus{font-size:16px;line-height:13px}.lib-ref-strip{flex:1;align-items:center;gap:5px;min-width:0;display:flex}.lib-ref-thumb{background:#121318;border:1px solid #555966;border-radius:7px;width:38px;height:38px;position:relative;overflow:hidden}.lib-ref-thumb img,.lib-ref-thumb video{object-fit:cover;width:100%;height:100%;display:block}.lib-ref-more{color:#ffe58b;background:#3a3218;border-radius:999px;place-items:center;min-width:26px;height:26px;font-size:11px;font-weight:800;display:grid}.lib-delete{margin-left:auto;color:#ff9aaa!important;background:#331e24!important}.lib-prompt{font-weight:600;color:#f7f7fa!important;min-height:76px!important;padding:8px 14px 4px!important;font-size:13px!important;line-height:1.55!important}.lib-prompt::placeholder{color:#8a8e99!important}.lib-bottom-bar{border-top:0;align-items:center;gap:9px;min-height:44px;padding:5px 10px 10px;display:flex}.lib-select-pill{color:#f0f2f7;white-space:nowrap;background:#23252b;border:1px solid #0000;border-radius:999px;align-items:center;gap:5px;max-width:150px;height:28px;padding:0 9px;font-size:12px;display:inline-flex;position:relative}.lib-select-pill:after{content:"⌄";color:#a6aab4;font-size:11px}.lib-select-pill:hover{background:#2a2c33;border-color:#515562}.lib-select-pill select{opacity:0;cursor:pointer;position:absolute;inset:0}.lib-ref-count{color:#8b8f9b;margin-left:auto;font-size:12px}.lib-ref-count.active{color:#ffe58b}.lib-credit{color:#c9bdff;font-size:12px;font-weight:800}.lib-run{color:#111217;background:#f2f3f5;border:0;border-radius:10px;place-items:center;width:30px;height:30px;font-size:18px;font-weight:900;line-height:1;display:grid}.lib-run:hover{background:#fff;transform:translateY(-1px)}.lib-run:disabled{opacity:.7;cursor:wait}.lib-output{border-radius:10px;margin:5px 12px 8px}.lib-output img,.lib-output video{max-height:180px}.lib-error{margin:6px 12px;padding:9px 10px;font-size:12px}.lib-generate-main{color:#fff;background:linear-gradient(135deg,#8b6cf0,#684bd6);border:0;border-radius:11px;justify-content:center;align-items:center;gap:8px;width:calc(100% - 24px);height:44px;margin:4px 12px 2px;font-size:15px;font-weight:900;display:flex;box-shadow:0 14px 32px #6f55ee35}.lib-generate-main:hover{filter:brightness(1.06);transform:translateY(-1px)}.lib-generate-main:disabled{opacity:.7;cursor:wait;transform:none}.media-tool-menu{z-index:28;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#171924f8;border:1px solid #7565d8;border-radius:14px;width:300px;max-height:380px;padding:9px;position:absolute;overflow:auto;box-shadow:0 22px 70px #000b}.tool-menu-title{color:#d8d0ff;border-bottom:1px solid #363153;margin-bottom:7px;padding:7px 9px 10px;font-size:12px;font-weight:900}.tool-menu-list{gap:7px;display:grid}.tool-menu-item{color:#edefff;text-align:left;background:0 0;border:0;border-radius:10px;gap:3px;width:100%;min-height:46px;padding:9px 10px;display:grid}.tool-menu-item:hover{background:#30294e}.tool-menu-item strong{font-size:13px}.tool-menu-item span{color:#aeb4c4;font-size:11px;line-height:1.4}.tool-menu-item em{color:#cfc8ff;background:#332c5c;border-radius:999px;justify-self:end;padding:3px 7px;font-size:10px;font-style:normal}.tool-menu-grid{grid-template-columns:repeat(3,1fr);gap:7px;display:grid}.tool-menu-grid button{color:#e9e9f3;background:#242631;border:1px solid #343846;border-radius:9px;height:36px;font-size:12px;font-weight:800}.tool-menu-grid button:hover{background:#30294e;border-color:#8b76ed}.tool-menu-item.asset-pick{grid-template-columns:46px 1fr auto;align-items:center}.tool-menu-thumb{background:#0d0f16;border-radius:8px;width:46px;height:36px;overflow:hidden}.tool-menu-thumb img,.tool-menu-thumb video{object-fit:cover;width:100%;height:100%;display:block}.run-btn{color:#fff;background:linear-gradient(135deg,#8b6cf0,#684bd6);border:0;border-radius:12px;justify-content:center;align-items:center;gap:9px;width:calc(100% - 32px);height:56px;margin:8px 16px 12px;font-size:18px;font-weight:800;display:flex;box-shadow:0 16px 38px #6f55ee35}.run-btn:disabled{opacity:.7;cursor:wait}.node-error{color:#ffb7c7;background:#3a1720;border:1px solid #763f4c;border-radius:10px;margin:0 16px 12px;padding:12px;font-size:13px;line-height:1.5}.media-output{background:#0e0f15;border:1px solid #343846;border-radius:12px;margin:0 16px 14px;overflow:hidden}.media-output img,.media-output video{object-fit:contain;background:#0b0c11;width:100%;max-height:260px;display:block}.node-foot{color:#6b7080;letter-spacing:4px;border-top:1px solid #2a2d36;align-items:center;height:36px;padding:0 16px;font-size:12px;font-weight:800;display:flex}.handle{z-index:4;background:#11131b;border:2px solid #d9dcef;border-radius:50%;width:12px;height:12px;padding:0;position:absolute;top:50%;transform:translateY(-50%)}.handle:hover{background:#7d65db;border-color:#9e8cff;width:18px;height:18px}.handle-left{left:-7px}.handle-right{right:-7px}.resize-handle{z-index:6;opacity:.58;background:0 0;border:0;width:18px;height:18px;padding:0;position:absolute}.resize-handle:after{content:"";border-style:solid;border-color:#8277c9;position:absolute;inset:4px}.resize-handle:hover{opacity:1}.resize-handle:hover:after{border-color:#b9adff}.resize-nw{cursor:nwse-resize;top:8px;left:8px}.resize-nw:after{border-width:2px 0 0 2px;border-radius:7px 0 0}.resize-ne{cursor:nesw-resize;top:8px;right:8px}.resize-ne:after{border-width:2px 2px 0 0;border-radius:0 7px 0 0}.resize-sw{cursor:nesw-resize;bottom:8px;left:8px}.resize-sw:after{border-width:0 0 2px 2px;border-radius:0 0 0 7px}.resize-se{cursor:nwse-resize;bottom:8px;right:8px}.resize-se:after{border-width:0 2px 2px 0;border-radius:0 0 7px}.selection-box{z-index:30;pointer-events:none;background:#f5d76e22;border:1px solid #f5d76e;border-radius:10px;position:absolute;box-shadow:inset 0 0 0 1px #0005}.context-menu{z-index:20;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#191b24f6;border:1px solid #52498a;border-radius:12px;min-width:180px;padding:8px;position:absolute;box-shadow:0 18px 60px #0009}.context-title{color:#c6bfff;border-bottom:1px solid #39344e;margin-bottom:5px;padding:8px 9px 9px;font-size:12px}.context-menu button{color:#e4e6ee;text-align:left;background:0 0;border:0;border-radius:8px;align-items:center;gap:9px;width:100%;height:36px;display:flex}.context-menu button:hover{background:#393253}.mention-menu{z-index:25;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#171924f8;border:1px solid #7666d9;border-radius:14px;width:260px;max-height:320px;padding:8px;position:absolute;overflow:auto;box-shadow:0 22px 70px #000b}.mention-title{color:#d8d0ff;border-bottom:1px solid #363153;margin-bottom:6px;padding:7px 9px 9px;font-size:12px;font-weight:800}.mention-menu button{color:#edefff;text-align:left;background:0 0;border:0;border-radius:10px;grid-template-columns:48px 1fr auto;align-items:center;gap:9px;width:100%;min-height:50px;padding:6px;display:grid}.mention-menu button:hover{background:#30294e}.mention-menu img,.mention-menu video{object-fit:cover;background:#0d0f16;border-radius:8px;width:48px;height:38px}.mention-menu span{white-space:nowrap;text-overflow:ellipsis;min-width:0;font-size:12px;font-weight:700;overflow:hidden}.mention-menu em{color:#cfc8ff;background:#332c5c;border-radius:999px;padding:3px 6px;font-size:10px;font-style:normal}.mention-empty{color:#858a99;text-align:center;padding:16px 10px;font-size:12px;line-height:1.5}.asset-library{z-index:5;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#161821e8;border:1px solid #363a49;border-radius:16px;flex-direction:column;width:230px;max-height:calc(100% - 36px);padding:13px;display:flex;position:absolute;top:18px;right:18px;box-shadow:0 22px 70px #0008}.asset-library-head{color:#f0effa;justify-content:space-between;align-items:center;font-size:14px;font-weight:800;display:flex}.asset-library-head span{align-items:center;gap:8px;display:flex}.asset-library-head em{color:#cfc8ff;text-align:center;background:#36315f;border-radius:999px;min-width:24px;padding:3px 7px;font-size:11px;font-style:normal}.asset-library p{color:#858a9a;margin:10px 0 12px;font-size:11px;line-height:1.5}.asset-list{gap:9px;display:grid;overflow:auto}.asset-card{color:#e5e4ef;text-align:left;background:#20232e;border:1px solid #3a3e4e;border-radius:10px;padding:0;overflow:hidden}.asset-card:hover{border-color:#8b76ed}.asset-card img,.asset-card video{object-fit:cover;background:#0e1016;width:100%;height:96px;display:block}.asset-card span{padding:7px 9px;font-size:11px;display:block}.asset-empty{color:#727889;text-align:center;border:1px dashed #3b3f4e;border-radius:10px;padding:26px 8px;font-size:12px;line-height:1.6}.selection-toolbar{z-index:35;color:#f3f0ff;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#171924ee;border:1px solid #4a5067;border-radius:999px;align-items:center;gap:8px;padding:9px;display:flex;position:absolute;bottom:24px;left:50%;transform:translate(-50%);box-shadow:0 18px 60px #000a}.selection-toolbar span{color:#d8d0ff;padding:0 8px;font-size:12px;font-weight:800}.selection-toolbar button{color:#fff;background:#342d5d;border:0;border-radius:999px;height:32px;padding:0 12px;font-size:12px;font-weight:800}.selection-toolbar button:hover{background:#5e4bd6}.selection-toolbar button.danger{color:#ffb7c7;background:#4b1e2a}.selection-toolbar button.danger:hover{color:#fff;background:#d94f6b}.zoom-pill{color:#222;background:#f2f3f5;border-radius:999px;padding:9px 14px;font-size:12px;position:absolute;bottom:20px;left:50%;transform:translate(-50%);box-shadow:0 10px 35px #0008}.toast{z-index:50;color:#fff;background:#202230f0;border:1px solid #3a3d49;border-radius:999px;padding:10px 16px;position:fixed;bottom:34px;left:50%;transform:translate(-50%);box-shadow:0 14px 45px #0008}
