:root{--bg: #101113;--panel: #18191c;--panel-2: #1e2024;--panel-3: #26282d;--border: #2e3038;--border-2: #3d404a;--text: #edeef0;--text-dim: #a0a3ad;--text-faint: #6b6f7b;--green: #34d27b;--green-deep: #1c5b3c;--green-bg: #11301f;--amber: #e8b765;--red: #ff6259;--blue: #6aa7ff;--radius: 14px;--radius-sm: 9px;--font: "Instrument Sans", -apple-system, sans-serif;--mono: "IBM Plex Mono", monospace;--shadow: 0 12px 36px rgba(0, 0, 0, .45);--ring: 0 0 0 2px rgba(52, 210, 123, .4);--inv: #fff;--section-neutral-frame: var(--border-2);--section-neutral-fill: color-mix(in srgb, var(--panel-2) 28%, transparent);--section-neutral-mini: var(--border-2);--section-green-frame: color-mix(in srgb, var(--green) 55%, var(--border));--section-green-fill: color-mix(in srgb, var(--green) 10%, transparent);--section-green-mini: color-mix(in srgb, var(--green) 62%, var(--panel-3));--section-amber-frame: color-mix(in srgb, var(--amber) 52%, var(--border));--section-amber-fill: color-mix(in srgb, var(--amber) 10%, transparent);--section-amber-mini: color-mix(in srgb, var(--amber) 58%, var(--panel-3));--section-rust-frame: color-mix(in srgb, var(--red) 42%, var(--border));--section-rust-fill: color-mix(in srgb, var(--red) 8%, transparent);--section-rust-mini: color-mix(in srgb, var(--red) 48%, var(--panel-3));--section-blue-frame: color-mix(in srgb, var(--blue) 42%, var(--border));--section-blue-fill: color-mix(in srgb, var(--blue) 8%, transparent);--section-blue-mini: color-mix(in srgb, var(--blue) 50%, var(--panel-3))}[data-theme=light]{--bg: #f8f9fb;--panel: #ffffff;--panel-2: #f1f2f5;--panel-3: #e8eaef;--border: #dfe1e6;--border-2: #c7cad1;--text: #1a1d24;--text-dim: #505664;--text-faint: #8b91a0;--green: #16a34a;--green-deep: #bbf0cd;--green-bg: #ecfdf3;--amber: #ca8a04;--red: #dc2626;--blue: #3b82f6;--shadow: 0 8px 28px rgba(0, 0, 0, .08);--ring: 0 0 0 2px rgba(22, 163, 74, .3);--inv: #fff}[data-theme=light] .btn-white{background:var(--text);color:#fff;border-color:var(--text)}[data-theme=light] .tool-btn.primary{background:var(--text);color:#fff}[data-theme=light] .modal-overlay{background:#00000040;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}[data-theme=light] .react-flow__edge-path{stroke:var(--border-2)}[data-theme=light] .stop-square{background:#fff}[data-theme=light] .roots-send{background:var(--text);color:#fff}[data-theme=light] .node-status-badge{color:#fff}[data-theme=light] .plan-btn.go{background:var(--text);color:#fff}[data-theme=light] .roots-corner{background:var(--panel);border-color:var(--border-2)}[data-theme=light] .kb-panel{box-shadow:0 8px 28px #0000001f}[data-theme=light] .technique-run:hover,[data-theme=light] .tb-primary,[data-theme=light] .tech-lib-cat.active,[data-theme=light] .app-run-btn{color:#fff}[data-theme=light] .screen-transition-panel{background:#ffffffeb;border-color:var(--border);box-shadow:0 24px 60px #0000001a}[data-theme=light] .screen-transition:before{background:#f8f9fbcc;-webkit-backdrop-filter:blur(11px);backdrop-filter:blur(11px)}[data-theme=light] .palette{background:var(--panel);border-color:var(--border-2);box-shadow:var(--shadow);-webkit-backdrop-filter:none;backdrop-filter:none}[data-theme=light] .node-ctx-menu{background:var(--panel)}[data-theme=light] .frame-ops{background:#fff9}[data-theme=light] .doc-loading{background:#ffffffbf}[data-theme=light] .fs-hover{background:#ffffffb3}[data-theme=light] .canvas-search{background:var(--panel);border-color:var(--border-2)}[data-theme=light] .batch-progress-label{background:#ffffffb3}[data-theme=light] .technique-overlay{background:#f8f9fbeb;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}[data-theme=light] .gen-node{box-shadow:0 2px 12px #0000000f,0 0 0 1px var(--border)}[data-theme=light] .gen-node.selected{box-shadow:0 0 0 1.5px var(--text-dim),0 4px 16px #00000014}[data-theme=light] .gen-node.status-running{box-shadow:0 0 0 1.5px var(--green-deep),0 0 20px #16a34a1a}[data-theme=light] .gen-node.status-failed{border-color:#fca5a5}[data-theme=light] .gen-node.status-awaiting{border-color:#fcd34d}[data-theme=light] .action-node-v2{border-color:#c4b5fd;box-shadow:0 2px 12px #0000000f}[data-theme=light] .action-node-v2.selected{border-color:#8b5cf6}[data-theme=light] .doc-node{box-shadow:0 2px 12px #0000000f}[data-theme=light] .toast{background:var(--panel);border-color:#ca8a044d}[data-theme=light] .roots{background:#fffffff7;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}[data-theme=light] .queue-widget{background:var(--panel)}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{background:var(--bg);color:var(--text);font-family:var(--font);font-size:14px;overflow:hidden}button{font-family:var(--font);cursor:pointer;border:none;background:none;color:inherit}input,textarea,select{font-family:var(--font);color:var(--text)}:focus-visible{outline:2px solid rgba(52,210,123,.65);outline-offset:2px}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-thumb{background:#333;border-radius:4px}.app{position:relative;width:100%;height:100%}.ui-button,.ui-input,.ui-textarea,.ui-badge,.ui-dialog-content{border:1px solid var(--border);background:var(--panel);color:var(--text)}.ui-button{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:36px;padding:8px 14px;border-radius:9px;font-size:13.5px;font-weight:500;line-height:1;transition:background-color .14s ease,border-color .14s ease,color .14s ease,transform .14s ease,opacity .14s ease}.ui-button:hover:not(:disabled){background:var(--panel-3);border-color:var(--border-2)}.ui-button:disabled{opacity:.5;cursor:not-allowed}.ui-button--default{background:var(--green-bg);border-color:var(--green-deep);color:var(--green)}.ui-button--default:hover:not(:disabled){background:#16402a;border-color:var(--green)}.ui-button--secondary{background:var(--panel-3);color:var(--text-dim)}.ui-button--secondary:hover:not(:disabled){color:var(--text)}.ui-button--outline{background:transparent}.ui-button--ghost{background:transparent;border-color:transparent}.ui-button--ghost:hover:not(:disabled){background:var(--panel-3);border-color:var(--panel-3)}.ui-button--destructive{background:#dc32321f;border-color:#dc323240;color:#e06060}.ui-button--destructive:hover:not(:disabled){background:#dc323233;border-color:#dc323259}.ui-button--icon{width:36px;height:36px;padding:0;border-radius:9px}.ui-button--sm{min-height:32px;padding:6px 12px;font-size:12.5px}.ui-button--lg{min-height:42px;padding:10px 16px;font-size:14px}.ui-input,.ui-textarea{width:100%;border-radius:9px;padding:9px 12px;font-size:13.5px;outline:none;transition:border-color .14s ease,background-color .14s ease,box-shadow .14s ease}.ui-input{min-height:36px}.ui-textarea{min-height:100px;resize:vertical;line-height:1.5}.ui-input:focus,.ui-textarea:focus{border-color:var(--green);box-shadow:var(--ring)}.ui-badge{display:inline-flex;align-items:center;gap:6px;min-height:22px;padding:3px 8px;border-radius:999px;font-size:11px;font-weight:600;color:var(--text-dim);background:var(--panel-3)}.ui-badge--success{color:var(--green);background:#34d27b1f;border-color:#34d27b33}.ui-badge--warning{color:var(--amber);background:#e8b7651f;border-color:#e8b7653d}.ui-badge--destructive{color:var(--red);background:#ff62591f;border-color:#ff62593d}.ui-dialog-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;display:grid;place-items:center;padding:20px;background:#00000080;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.ui-dialog-content{width:min(560px,calc(100vw - 32px));max-height:min(84vh,900px);overflow:auto;border-radius:14px;box-shadow:var(--shadow)}.ui-dialog-header,.ui-dialog-footer{display:flex;align-items:center;justify-content:space-between;gap:12px}.ui-dialog-header{padding:16px 18px 14px;border-bottom:1px solid var(--border)}.ui-dialog-title{margin:0;font-size:15px;font-weight:600;letter-spacing:-.01em}.ui-dialog-description{margin:4px 0 0;color:var(--text-dim);font-size:12.5px;line-height:1.5}.ui-dialog-footer{padding:14px 18px 16px;border-top:1px solid var(--border)}.fv .ui-button,.fv .ui-input,.fv .ui-textarea,.fv .ui-badge,.fv .ui-dialog-content{background:#fff;border-color:#e6e6ea;color:#1c1d22}.fv .ui-button:hover:not(:disabled){background:#f7f7f9;border-color:#d8dbe2}.fv .ui-button--default{background:#e9f7ef;border-color:#a7e0bf;color:#15803d}.fv .ui-button--default:hover:not(:disabled){background:#def3e6;border-color:#8fd0ad}.fv .ui-button--secondary{background:#f4f4f6;color:#4a4b52}.fv .ui-button--secondary:hover:not(:disabled){color:#1c1d22}.fv .ui-button--ghost{background:transparent;border-color:transparent}.fv .ui-button--ghost:hover:not(:disabled){background:#f4f4f6;border-color:#f4f4f6}.fv .ui-input,.fv .ui-textarea{background:#fff}.screen-transition{position:fixed;top:0;right:0;bottom:0;left:0;z-index:2000;display:grid;place-items:center;pointer-events:none;opacity:0;visibility:hidden;transition:opacity .18s ease,visibility 0s linear .18s}.screen-transition.active{opacity:1;visibility:visible;transition:opacity .16s ease,visibility 0s}.screen-transition:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.02) 1px,transparent 1px),#060707b8;background-size:34px 34px,34px 34px,auto;-webkit-backdrop-filter:blur(11px) saturate(1.08);backdrop-filter:blur(11px) saturate(1.08)}.screen-transition-panel{position:relative;width:min(340px,calc(100vw - 48px));min-height:250px;display:grid;justify-items:center;align-content:center;gap:12px;padding:28px;border:1px solid rgba(255,255,255,.12);border-radius:18px;background:#101110e0;box-shadow:0 24px 80px #00000094,inset 0 1px #ffffff0f;overflow:hidden}.screen-transition-panel:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(120deg,transparent 0%,rgba(52,210,123,.09) 42%,transparent 64%),radial-gradient(circle at 50% 28%,rgba(232,183,101,.1),transparent 34%);transform:translate(-34%);animation:transition-panel-sweep 1.4s ease-in-out infinite}.screen-transition-visual,.screen-transition-lottie,.screen-transition-static{position:relative;z-index:1;width:156px;height:156px}.screen-transition-lottie{position:absolute;top:0;right:0;bottom:0;left:0;opacity:.72}.screen-transition-static{border:2px solid rgba(52,210,123,.38);border-top-color:var(--green);border-radius:50%}.screen-transition-nodes{position:absolute;top:24px;right:24px;bottom:24px;left:24px;border:1px solid rgba(52,210,123,.18);border-radius:50%;animation:transition-node-orbit 1.6s linear infinite}.screen-transition-nodes span{position:absolute;width:32px;height:32px;border-radius:9px;border:1px solid rgba(255,255,255,.14);box-shadow:0 0 20px #34d27b2e}.screen-transition-nodes span:nth-child(1){left:8px;top:8px;background:#ececec}.screen-transition-nodes span:nth-child(2){right:8px;top:8px;background:var(--green);animation-delay:-.12s}.screen-transition-nodes span:nth-child(3){left:8px;bottom:8px;background:var(--blue);animation-delay:-.24s}.screen-transition-nodes span:nth-child(4){right:8px;bottom:8px;background:var(--amber);animation-delay:-.36s}.screen-transition-nodes i{position:absolute;left:28px;right:28px;top:calc(50% - 1px);height:2px;border-radius:999px;background:linear-gradient(90deg,transparent,var(--green),transparent);box-shadow:0 0 18px #34d27b8c;animation:transition-signal .86s ease-in-out infinite}.screen-transition-nodes span{animation:transition-node-pulse .86s ease-in-out infinite}.screen-transition-copy{position:relative;z-index:1;display:grid;gap:4px;text-align:center}.screen-transition-copy span{color:var(--green);font-family:var(--mono);font-size:10.5px;text-transform:uppercase;letter-spacing:.08em}.screen-transition-copy b{color:var(--text);font-size:14px;font-weight:650}.screen-transition-progress{position:relative;z-index:1;width:188px;height:4px;margin-top:6px;overflow:hidden;border-radius:999px;background:#ffffff14}.screen-transition-progress i{display:block;width:44%;height:100%;border-radius:inherit;background:linear-gradient(90deg,var(--green),var(--amber),var(--blue));animation:transition-progress .72s cubic-bezier(.42,0,.18,1) infinite}@keyframes transition-progress{0%{transform:translate(-110%)}to{transform:translate(250%)}}@keyframes transition-panel-sweep{0%,to{transform:translate(-38%);opacity:.5}50%{transform:translate(38%);opacity:1}}@keyframes transition-node-orbit{to{transform:rotate(360deg)}}@keyframes transition-node-pulse{0%,to{transform:scale(.82);filter:brightness(.88)}50%{transform:scale(1);filter:brightness(1.08)}}@keyframes transition-signal{0%,to{transform:rotate(0) scaleX(.62);opacity:.45}50%{transform:rotate(90deg) scaleX(1);opacity:1}}@media (prefers-reduced-motion: reduce){.screen-transition,.screen-transition.active,.screen-transition-panel:after,.screen-transition-progress i,.screen-transition-nodes,.screen-transition-nodes span,.screen-transition-nodes i{animation:none;transition:none}.screen-transition-progress i{transform:none;width:100%}}.react-flow{background:var(--bg)}.react-flow__attribution{display:none}.react-flow__edge-path{stroke:#4a4a4a;stroke-width:1.6}.react-flow__edge.selected .react-flow__edge-path,.react-flow__edge:hover .react-flow__edge-path{stroke:var(--green)}.react-flow__handle{width:14px;height:14px;border-radius:50%;background:var(--panel-3);border:2px solid var(--border-2);transition:all .15s}.react-flow__handle:hover{background:var(--green);border-color:var(--green);transform:scale(1.2)}.react-flow__node{font-family:var(--font)}.topbar{position:absolute;top:0;left:0;right:0;z-index:45;display:flex;align-items:center;justify-content:space-between;padding:14px 18px;pointer-events:none}.topbar>*{pointer-events:auto}.topbar-left{display:flex;align-items:center;gap:12px}.logo-mark{display:grid;grid-template-columns:1fr 1fr;gap:2.5px;width:22px;height:22px}.logo-mark span{background:var(--text);border-radius:3px}.logo-mark span:last-child{background:var(--green)}.proj-meta{line-height:1.25}.proj-name{font-weight:600;font-size:13.5px;display:flex;align-items:center;gap:6px}.proj-name .chev{color:var(--text-faint);font-size:10px}.proj-ws{color:var(--text-faint);font-size:11.5px}.topbar-right{display:flex;gap:10px}.btn{display:inline-flex;align-items:center;gap:7px;min-height:36px;padding:8px 14px;border-radius:9px;font-size:13px;font-weight:500;border:1px solid var(--border);background:var(--panel);color:var(--text);transition:background-color .14s ease,border-color .14s ease,color .14s ease,transform .14s ease,opacity .14s ease}.btn:hover{background:var(--panel-3);border-color:var(--border-2)}.btn-green{background:var(--green-bg);border-color:var(--green-deep);color:var(--green)}.btn-green:hover{background:#16402a}.btn-white{background:var(--text);color:#111;border-color:var(--text)}.btn-white:hover{background:#fff}.btn-sm{min-height:32px;padding:6px 12px;font-size:12.5px;border-radius:9px;border:1px solid var(--border);background:var(--panel);color:var(--text);cursor:pointer;transition:background-color .14s ease,border-color .14s ease,color .14s ease,transform .14s ease,opacity .14s ease}.btn-sm:hover{background:var(--panel-3);border-color:var(--border-2)}.btn-sm.btn-green{background:var(--green-bg);border-color:var(--green-deep);color:var(--green)}.btn-sm.btn-green:hover{background:#16402a}.btn-sm.btn-danger{background:#dc32321f;border-color:#dc32324d;color:#e06060}.btn-sm.btn-danger:hover{background:#dc323240}.toolbar{position:absolute;left:14px;top:50%;transform:translateY(-50%);z-index:30;display:flex;flex-direction:column;gap:4px;align-items:center;background:var(--panel);border:1px solid var(--border);border-radius:18px;padding:8px 6px;box-shadow:var(--shadow)}.tool-btn{width:38px;height:38px;border-radius:9px;display:grid;place-items:center;color:var(--text-dim);font-size:16px;transition:background-color .14s ease,border-color .14s ease,color .14s ease,transform .14s ease;position:relative;background:transparent;border:1px solid transparent}.tool-btn:hover{background:var(--panel-3);color:var(--text);border-color:var(--border)}.tool-btn.primary{background:var(--text);color:#111;border-radius:50%;border-color:var(--text)}.tool-btn.primary:hover{background:#fff;transform:scale(1.03)}.tool-btn .tip{position:absolute;left:48px;top:50%;transform:translateY(-50%);background:var(--panel-3);border:1px solid var(--border);color:var(--text);font-size:11.5px;padding:4px 9px;border-radius:7px;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .12s}.tool-btn:hover .tip{opacity:1}.tool-avatar{width:34px;height:34px;border-radius:50%;background:#7a4a2c;color:#fff;display:grid;place-items:center;font-weight:700;font-size:13px;margin-top:4px}.canvas-hint{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;z-index:5;pointer-events:none}.hint-line{color:var(--text-dim);font-size:13.5px;display:flex;gap:6px;align-items:center}.kbd{background:var(--panel-2);border:1px solid var(--border-2);border-bottom-width:2px;border-radius:6px;padding:2px 7px;font-size:11px;font-family:var(--mono);color:var(--text)}.hint-chips{display:flex;gap:8px;pointer-events:auto;flex-wrap:wrap;justify-content:center;max-width:640px}.chip{display:inline-flex;align-items:center;gap:6px;background:var(--panel);border:1px solid var(--border);border-radius:999px;padding:7px 13px;font-size:12.5px;color:var(--text-dim);transition:all .15s}.chip:hover{color:var(--text);border-color:var(--border-2);background:var(--panel-2)}.palette{position:absolute;z-index:60;width:300px;max-width:92vw;background:#161616f7;border:1px solid var(--border-2);border-radius:16px;box-shadow:var(--shadow);overflow:hidden;animation:pop .14s ease-out;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}@keyframes pop{0%{opacity:0;transform:scale(.96) translateY(4px)}}.palette-search{display:flex;align-items:center;gap:8px;padding:12px 14px;border-bottom:1px solid var(--border);color:var(--text-faint)}.palette-search input{flex:1;background:none;border:none;outline:none;font-size:13.5px;color:var(--text)}.palette-section{padding:8px 14px 2px;font-size:11px;color:var(--text-faint);font-weight:600}.palette-list{padding:4px 6px 6px;max-height:380px;overflow-y:auto}.palette-item{display:flex;align-items:center;gap:11px;width:100%;padding:9px;border-radius:10px;text-align:left;transition:background .1s}.palette-item:hover,.palette-item.active{background:var(--panel-3)}.palette-icon{width:30px;height:30px;border-radius:8px;background:var(--panel-3);border:1px solid var(--border);display:grid;place-items:center;font-size:13px;color:var(--text-dim);flex-shrink:0}.palette-icon.svg-icon{border:none}.palette-item:hover .palette-icon{color:var(--text)}.palette-item:hover .palette-icon.svg-icon{filter:brightness(1.3)}.palette-label{flex:1}.palette-label b{display:block;font-size:13px;font-weight:600}.palette-label span{font-size:11.5px;color:var(--text-faint)}.palette-key{font-family:var(--mono);font-size:10.5px;color:var(--text-faint);background:var(--panel-3);border:1px solid var(--border);border-radius:5px;padding:2px 6px}.palette-footer{display:flex;border-top:1px solid var(--border);background:var(--panel-2)}.palette-footer button{flex:1;padding:9px 0;font-size:10.5px;color:var(--text-faint);display:flex;flex-direction:column;align-items:center;gap:3px}.palette-footer button:hover{color:var(--text)}.palette-footer button{position:relative}.palette-footer .f-icon{font-size:13px}.palette-footer-tip{position:absolute;bottom:100%;left:50%;transform:translate(-50%);background:var(--panel);border:1px solid var(--border-2);border-radius:8px;padding:6px 10px;font-size:11px;color:var(--text-dim);white-space:normal;width:180px;text-align:center;pointer-events:none;z-index:70;box-shadow:0 8px 24px #00000080;animation:pop .12s ease-out}.palette-tooltip{position:absolute;left:calc(100% + 8px);top:40px;width:240px;background:#161616fa;border:1px solid var(--border-2);border-radius:12px;padding:14px;box-shadow:0 12px 36px #0000008c;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);animation:pop .12s ease-out;z-index:65}.pt-title{font-size:13px;font-weight:600;margin-bottom:6px;color:var(--green)}.pt-desc{font-size:11.5px;color:var(--text-dim);line-height:1.45;margin-bottom:10px}.pt-row{font-size:11px;color:var(--text-dim);margin-bottom:4px;display:flex;gap:6px}.pt-label{font-weight:600;color:var(--text-faint);min-width:52px;flex-shrink:0}.gen-node{width:340px;background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);overflow:visible;transition:border-color .15s,box-shadow .15s;box-shadow:0 8px 28px #0006}.gen-node.selected{border-color:var(--text-dim);box-shadow:0 0 0 1.5px var(--text-dim),var(--shadow)}.gen-node.status-running{border-color:var(--green-deep);box-shadow:0 0 0 1.5px var(--green-deep),0 0 32px #34d27b26}.gen-node.status-failed{border-color:#5b2320}.gen-node.status-awaiting{border-color:#5b4a20}.gen-node.spawned{animation:spawn .4s cubic-bezier(.2,1.4,.4,1)}@keyframes spawn{0%{opacity:0;transform:scale(.7)}}.group-shell{width:100%;height:100%;position:relative;--group-frame-border: var(--section-neutral-frame);--group-frame-fill: var(--section-neutral-fill);--group-frame-strong: var(--section-neutral-frame)}.group-shell.group-color-green{--group-frame-border: var(--section-green-frame);--group-frame-fill: var(--section-green-fill);--group-frame-strong: var(--section-green-frame)}.group-shell.group-color-amber{--group-frame-border: var(--section-amber-frame);--group-frame-fill: var(--section-amber-fill);--group-frame-strong: var(--section-amber-frame)}.group-shell.group-color-rust{--group-frame-border: var(--section-rust-frame);--group-frame-fill: var(--section-rust-fill);--group-frame-strong: var(--section-rust-frame)}.group-shell.group-color-blue{--group-frame-border: var(--section-blue-frame);--group-frame-fill: var(--section-blue-fill);--group-frame-strong: var(--section-blue-frame)}.group-frame{width:100%;height:100%;position:relative;border:1.5px dashed var(--group-frame-border);border-radius:18px;background:var(--group-frame-fill);transition:border-color .15s,background .15s,box-shadow .15s}.group-frame.selected{border-color:var(--group-frame-strong);box-shadow:0 0 0 1px var(--group-frame-strong)}.group-frame.agg-running{box-shadow:inset 0 0 0 1px var(--green-deep)}.group-frame.agg-failed{box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--red) 38%,var(--border))}.group-head{position:absolute;top:0;left:0;right:0;display:flex;align-items:center;gap:7px;padding:10px 12px}.group-name{font-size:11.5px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--text-faint);cursor:text;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:min(360px,calc(100% - 122px))}.group-rename{background:var(--panel-3);border:1px solid var(--border);border-radius:6px;color:var(--text);font-size:11.5px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;padding:2px 6px;outline:none;width:160px}.group-chevron,.group-x,.group-icon-btn{background:none;border:none;color:var(--text-faint);cursor:pointer;font-size:12px;line-height:1;padding:2px 4px}.group-icon-btn{width:22px;height:22px;display:inline-grid;place-items:center;border-radius:7px;opacity:.72}.group-icon-btn svg{width:13px;height:13px;fill:none;stroke:currentColor;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}.group-chevron:hover,.group-x:hover,.group-icon-btn:hover{color:var(--text);background:var(--panel-2);opacity:1}.group-x{margin-left:auto;opacity:0;transition:opacity .15s}.group-frame:hover .group-x{opacity:1}.group-actions{display:flex;align-items:center;gap:4px}.group-color-wrap{position:relative}.group-color-btn{gap:4px;grid-template-columns:7px 13px}.group-color-dot,.group-swatch span{width:7px;height:7px;border-radius:50%;background:var(--group-frame-strong);box-shadow:0 0 0 1px var(--panel-3)}.group-color-menu{position:absolute;top:28px;right:0;z-index:30;min-width:128px;padding:6px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--panel);box-shadow:var(--shadow);display:grid;gap:3px;pointer-events:auto}.react-flow__node-group:has(.group-color-menu){z-index:1000!important}.group-swatch{display:flex;align-items:center;gap:8px;width:100%;padding:6px 7px;border:1px solid transparent;border-radius:7px;background:transparent;color:var(--text-dim);font-size:11.5px;text-align:left;cursor:pointer}.group-swatch.group-color-neutral{--group-frame-strong: var(--section-neutral-frame)}.group-swatch.group-color-green{--group-frame-strong: var(--section-green-frame)}.group-swatch.group-color-amber{--group-frame-strong: var(--section-amber-frame)}.group-swatch.group-color-rust{--group-frame-strong: var(--section-rust-frame)}.group-swatch.group-color-blue{--group-frame-strong: var(--section-blue-frame)}.group-swatch:hover,.group-swatch.on{color:var(--text);background:var(--panel-2);border-color:var(--border)}.group-frame.collapsed{display:flex;align-items:center;gap:8px;padding:0 14px;background:color-mix(in srgb,var(--group-frame-fill) 56%,var(--panel));border-style:solid;border-radius:14px;box-shadow:0 8px 28px #0006}.group-frame.collapsed .group-name{cursor:default}.group-meta{font-size:11px;color:var(--text-faint);margin-left:auto;white-space:nowrap}.group-frame.collapsed.agg-running .group-meta{color:var(--green-deep)}.group-frame.collapsed.agg-failed .group-meta{color:color-mix(in srgb,var(--red) 70%,var(--text-dim))}.group-resize-line,.group-resize-handle{opacity:0;transition:opacity .15s}.group-shell:hover .group-resize-line,.group-shell:hover .group-resize-handle,.group-shell.selected .group-resize-line,.group-shell.selected .group-resize-handle{opacity:1}.group-resize-line{border-color:var(--group-frame-strong)!important}.group-resize-line.line.right{width:8px;transform:translate(-50%)}.group-resize-line.line.bottom{height:8px;transform:translateY(-50%)}.group-resize-handle.handle{width:10px;height:10px;border-radius:3px;border:1px solid var(--panel);background:var(--group-frame-strong);box-shadow:0 0 0 1px var(--border)}.node-head{display:flex;align-items:center;gap:8px;padding:10px 12px;border-bottom:1px solid var(--border)}.node-kind-icon{width:22px;height:22px;border-radius:6px;display:grid;place-items:center;font-size:11px;background:var(--panel-3);border:1px solid var(--border);color:var(--text-dim)}.node-title{flex:1;font-size:12.5px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.node-agent-badge{font-size:9.5px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--amber);background:#e8b7651f;border:1px solid rgba(232,183,101,.3);padding:2px 7px;border-radius:999px}.verdict-chip{font-size:9.5px;font-weight:800;letter-spacing:.04em;text-transform:uppercase;padding:2px 7px;border-radius:999px}.verdict-chip.pass{color:var(--green);background:#34d27b1f;border:1px solid rgba(52,210,123,.35)}.verdict-chip.fail{color:var(--red);background:#ff62591f;border:1px solid rgba(255,98,89,.35)}.retry-chip{font-size:9.5px;font-weight:700;letter-spacing:.03em;color:var(--blue);background:#6aa7ff1a;border:1px solid rgba(106,167,255,.3);padding:2px 7px;border-radius:999px}.unverified-badge{font-size:9.5px;font-weight:800;letter-spacing:.04em;text-transform:uppercase;color:var(--amber);background:#e8b76529;border:1px solid rgba(232,183,101,.55);padding:2px 7px;border-radius:999px}.node-group-tag{font-size:10px;color:var(--text-faint)}.status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.status-dot.idle{background:#444}.status-dot.queued{background:var(--blue)}.status-dot.running{background:var(--green);animation:pulse 1.1s infinite}.status-dot.awaiting{background:var(--amber);animation:pulse 1.4s infinite}.status-dot.done{background:var(--green)}.status-dot.failed{background:var(--red)}@keyframes pulse{50%{opacity:.35}}.node-body{padding:10px 12px;display:flex;flex-direction:column;gap:9px}.node-prompt{width:100%;min-height:54px;resize:vertical;background:var(--panel-2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:8px 10px;font-size:12.5px;line-height:1.45;outline:none}.node-prompt:focus{border-color:var(--border-2)}.node-row{display:flex;gap:8px;align-items:center}.node-select{flex:1;background:var(--panel-2);border:1px solid var(--border);border-radius:8px;padding:6px 8px;font-size:11.5px;outline:none;color:var(--text-dim)}.node-cost{font-family:var(--mono);font-size:10.5px;color:var(--text-faint);white-space:nowrap}.node-run{background:var(--text);color:#111;font-weight:700;font-size:12px;border-radius:8px;padding:7px 14px;transition:all .12s}.node-run:hover{background:#fff}.node-run:disabled{opacity:.4;cursor:default}.node-output{border-radius:var(--radius-sm);overflow:hidden;background:var(--panel-2);border:1px solid var(--border)}.node-output img,.node-output video{width:100%;display:block}.node-output-text{padding:10px;font-size:12px;line-height:1.5;color:var(--text-dim);max-height:160px;overflow-y:auto;white-space:pre-wrap}.node-generating{height:120px;display:flex;flex-direction:column;gap:8px;align-items:center;justify-content:center;background:linear-gradient(110deg,transparent 30%,rgba(52,210,123,.07) 50%,transparent 70%) var(--panel-2);background-size:200% 100%;animation:shimmerbg 1.4s linear infinite;color:var(--text-dim);font-size:12px}@keyframes shimmerbg{to{background-position:-200% 0}}.spinner{width:18px;height:18px;border-radius:50%;border:2px solid var(--border-2);border-top-color:var(--green);animation:spin .8s linear infinite}.node-error{padding:9px 10px;font-size:11.5px;color:var(--red);background:#ff625912;border-radius:var(--radius-sm)}.node-actions{display:flex;gap:6px}.mini-btn{flex:1;padding:6px 0;font-size:11px;font-weight:600;border-radius:7px;background:var(--panel-2);border:1px solid var(--border);color:var(--text-dim);transition:all .12s}.mini-btn:hover{color:var(--text);border-color:var(--border-2)}.mini-btn.approve{color:var(--green);border-color:var(--green-deep)}.mini-btn.approve:hover{background:var(--green-bg)}.mini-btn.approved{background:var(--green-bg);color:var(--green);border-color:var(--green-deep);cursor:default}.node-recipe{font-family:var(--mono);font-size:10px;line-height:1.6;color:var(--text-faint);background:var(--panel-2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:9px 10px;white-space:pre-wrap;max-height:150px;overflow-y:auto}.upload-zone{border:1.5px dashed var(--border-2);border-radius:var(--radius-sm);padding:22px 10px;text-align:center;color:var(--text-faint);font-size:12px;cursor:pointer;transition:all .15s}.upload-zone:hover{border-color:var(--text-dim);color:var(--text-dim)}.edge-peek{position:absolute;transform:translate(-50%,-120%);z-index:50;background:var(--panel-2);border:1px solid var(--border-2);border-radius:10px;padding:8px 10px;font-size:11px;color:var(--text-dim);max-width:240px;box-shadow:var(--shadow);pointer-events:none}.edge-peek img{width:100%;border-radius:6px;margin-top:6px}.budget-chip{position:absolute;left:14px;bottom:14px;z-index:30;background:var(--panel);border:1px solid var(--border);border-radius:10px;padding:8px 12px;font-size:11.5px;color:var(--text-dim);display:flex;align-items:center;gap:9px;box-shadow:var(--shadow)}.budget-bar{width:70px;height:4px;border-radius:2px;background:var(--panel-3);overflow:hidden}.budget-bar i{display:block;height:100%;background:var(--green);transition:width .4s}.budget-bar i.warn{background:var(--amber)}.budget-bar i.over{background:var(--red)}.memory-chip{color:var(--text-faint);border-left:1px solid var(--border);padding-left:9px;cursor:pointer;background:none;border-top:none;border-bottom:none;border-right:none;font:inherit}.memory-chip:hover{color:var(--green)}.theme-toggle{background:none;border:none;font-size:14px;cursor:pointer;padding:0 9px 0 2px;line-height:1;color:var(--text-dim);border-right:1px solid var(--border);margin-right:2px}.theme-toggle:hover{color:var(--text)}.kb-panel{position:absolute;bottom:36px;left:0;width:340px;max-height:400px;background:var(--bg-card, var(--panel));border:1px solid var(--border);border-radius:10px;box-shadow:0 8px 32px #0006;z-index:100;display:flex;flex-direction:column;overflow:hidden}.kb-header{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;border-bottom:1px solid var(--border)}.kb-header b{font-size:13px}.kb-empty{padding:24px 16px;text-align:center;color:var(--text-faint);font-size:12px}.kb-list{overflow-y:auto;max-height:340px;padding:6px}.kb-entry{display:flex;gap:8px;align-items:center;padding:6px 8px;border-radius:6px}.kb-entry:hover{background:var(--bg-hover, rgba(255,255,255,.04))}.kb-entry.pinned{background:#34d27b0f}.kb-thumb{width:40px;height:40px;border-radius:4px;object-fit:cover;flex-shrink:0}.kb-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.kb-caption{font-size:11px;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.kb-meta{font-size:10px;color:var(--text-faint)}.kb-actions{display:flex;gap:2px;flex-shrink:0}.kb-actions button{background:none;border:none;cursor:pointer;font-size:12px;padding:2px 4px;border-radius:3px;color:var(--text-faint)}.kb-actions button:hover{background:var(--bg-hover, rgba(255,255,255,.04));color:var(--text)}.kb-warn{padding:6px 12px;font-size:10px;color:var(--amber);border-top:1px solid var(--border)}.queue-widget{position:absolute;right:14px;bottom:14px;z-index:30;background:var(--panel);border:1px solid var(--border);border-radius:12px;min-width:230px;box-shadow:var(--shadow);overflow:hidden}.queue-head{display:flex;align-items:center;gap:8px;padding:9px 13px;font-size:12.5px;cursor:pointer}.queue-head b{font-weight:600}.queue-head .q-count{color:var(--text-faint);font-size:11.5px;flex:1}.queue-head .q-failed{color:var(--red)}.queue-list{border-top:1px solid var(--border);max-height:180px;overflow-y:auto}.queue-item{display:flex;align-items:center;gap:8px;padding:8px 13px;font-size:11.5px;color:var(--text-dim)}.queue-item+.queue-item{border-top:1px solid var(--border)}.roots{position:absolute;right:14px;z-index:40;display:flex;flex-direction:column;background:#121212f7;border:1px solid var(--border-2);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);animation:pop .18s ease-out}.roots.floating{bottom:64px;width:400px;max-width:92vw;height:min(620px,calc(100vh - 140px));border-radius:18px}.roots.docked{top:0;bottom:0;width:420px;max-width:45vw;border-radius:0;border-top:none;border-bottom:none;border-right:none}.roots-head{display:flex;align-items:center;gap:8px;padding:12px 14px;border-bottom:1px solid var(--border)}.roots-title{font-size:13px;font-weight:600;display:flex;align-items:center;gap:6px;flex:1}.roots-title .chev{color:var(--text-faint);font-size:10px}.roots-icons{display:flex;gap:2px}.icon-btn{width:28px;height:28px;border-radius:8px;display:grid;place-items:center;color:var(--text-faint);font-size:13px;border:1px solid transparent;background:transparent}.icon-btn:hover{background:var(--panel-3);color:var(--text);border-color:var(--border)}.roots-scroll{flex:1;overflow-y:auto;padding:16px 16px 8px;display:flex;flex-direction:column;gap:14px}.roots-greeting{margin:auto 0}.roots-greeting h1{font-size:26px;font-weight:500;margin:0 0 22px;letter-spacing:-.01em}.starter{display:flex;align-items:center;gap:10px;padding:9px 4px;width:100%;text-align:left;color:var(--text-dim);font-size:13.5px;border-radius:8px;transition:all .12s}.starter:hover{color:var(--text);background:var(--panel-2)}.starter .s-icon{color:var(--text-faint);font-size:13px;width:18px}.msg-user{align-self:flex-end;max-width:85%;background:var(--panel-3);border:1px solid var(--border-2);border-radius:14px 14px 4px;padding:10px 13px;font-size:13px;line-height:1.5}.msg-roots{align-self:stretch;font-size:13px;line-height:1.55;color:var(--text-dim)}.msg-roots .f-summary{color:var(--text);margin-bottom:8px;white-space:pre-wrap}.roots-md{color:var(--text);line-height:1.58;margin-bottom:8px;overflow-wrap:anywhere}.roots-md>*{margin:0}.roots-md>*+*{margin-top:8px}.roots-md p{color:var(--text)}.roots-md h3,.roots-md h4,.roots-md h5{display:flex;align-items:center;gap:7px;color:var(--text);font-weight:600;letter-spacing:0;margin-top:12px}.roots-md h3{font-size:15px}.roots-md h4{font-size:13.5px}.roots-md h5{font-size:12.5px;color:var(--text-dim)}.roots-md-emoji{width:18px;height:18px;border-radius:6px;display:inline-grid;place-items:center;flex-shrink:0;background:var(--panel-2);border:1px solid var(--border);font-size:11px;line-height:1}.roots-md strong{color:var(--text);font-weight:600}.roots-md em{color:var(--text-dim);font-style:italic}.roots-md a{color:var(--green);text-decoration:none;border-bottom:1px solid var(--green-deep)}.roots-md a:hover{border-bottom-color:var(--green)}.roots-md ul,.roots-md ol{padding-left:18px;color:var(--text)}.roots-md li+li{margin-top:4px}.roots-md li::marker{color:var(--green)}.roots-md blockquote{padding:8px 10px;border-left:2px solid var(--green-deep);background:var(--panel-2);color:var(--text-dim);border-radius:0 9px 9px 0}.roots-md code{font-family:var(--mono);font-size:11.5px;padding:1px 5px;border-radius:6px;color:var(--text);background:var(--panel-2);border:1px solid var(--border)}.roots-md-code{position:relative;padding:28px 12px 12px;border-radius:12px;background:var(--panel-2);border:1px solid var(--border);overflow-x:auto}.roots-md-code code{display:block;padding:0;border:none;background:transparent;color:var(--text);white-space:pre;line-height:1.55}.roots-md-code-lang{position:absolute;top:8px;left:12px;font-family:var(--mono);font-size:10.5px;color:var(--text-faint);text-transform:uppercase;letter-spacing:.04em}.thought{border-left:2px solid var(--border-2);margin:4px 0 10px;padding-left:12px;display:flex;flex-direction:column;gap:5px}.thought-step{font-size:12px;color:var(--text-faint);display:flex;gap:7px;align-items:center;animation:fadein .3s}.thought-step:before{content:"✓";color:var(--green);font-size:10px}@keyframes fadein{0%{opacity:0;transform:translate(-4px)}}.shimmer-line{font-size:12.5px;padding:2px 0;background:linear-gradient(90deg,var(--text-faint) 30%,var(--text) 50%,var(--text-faint) 70%);background-size:200% 100%;-webkit-background-clip:text;background-clip:text;color:transparent;animation:shimmertext 1.3s linear infinite}@keyframes shimmertext{to{background-position:-200% 0}}.plan-doc{background:var(--panel-2);border:1px solid var(--border-2);border-radius:14px;overflow:hidden;margin-top:6px}.plan-head{padding:11px 13px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:8px}.plan-head b{font-size:12.5px;color:var(--text);flex:1}.plan-badge{font-size:10px;font-weight:700;padding:3px 8px;border-radius:999px;text-transform:uppercase;letter-spacing:.05em}.plan-badge.pending{color:var(--amber);background:#e8b7651a;border:1px solid rgba(232,183,101,.3)}.plan-badge.approved,.plan-badge.executing{color:var(--blue);background:#6aa7ff1a;border:1px solid rgba(106,167,255,.3)}.plan-badge.cancelled{color:var(--amber);background:#e8b7651a;border:1px solid rgba(232,183,101,.3)}.plan-badge.executed{color:var(--green);background:var(--green-bg);border:1px solid var(--green-deep)}.plan-badge.rejected,.plan-badge.blocked,.plan-badge.failed{color:var(--red);background:#ff625914;border:1px solid rgba(255,98,89,.3)}.plan-steps{padding:4px 0}.plan-step{display:flex;align-items:center;gap:9px;padding:7px 13px;font-size:12px}.plan-step+.plan-step{border-top:1px solid rgba(42,42,42,.6)}.plan-step .ps-icon{width:20px;height:20px;border-radius:5px;background:var(--panel-3);border:1px solid var(--border);display:grid;place-items:center;font-size:9.5px;color:var(--text-dim);flex-shrink:0}.plan-step .ps-title{flex:1;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.plan-step .ps-model{color:var(--text-faint);font-size:10.5px}.plan-step .ps-cost{font-family:var(--mono);font-size:10.5px;color:var(--text-dim)}.plan-total{display:flex;justify-content:space-between;padding:10px 13px;border-top:1px solid var(--border);font-size:12px;color:var(--text-dim)}.plan-total b{font-family:var(--mono);color:var(--text)}.plan-total b.over{color:var(--red)}.plan-actions{display:flex;gap:8px;padding:10px 13px;border-top:1px solid var(--border)}.plan-btn{flex:1;padding:8px 0;font-size:12px;font-weight:700;border-radius:9px;transition:all .12s}.plan-btn.go{background:var(--text);color:#111}.plan-btn.go:hover{background:#fff}.plan-btn.no{background:var(--panel-3);border:1px solid var(--border);color:var(--text-dim)}.plan-btn.no:hover{color:var(--text)}.plan-note{padding:8px 13px;font-size:11px;color:var(--text-faint);border-top:1px solid var(--border)}.plan-note.err{color:var(--red)}.roots-input-wrap{padding:10px 14px 14px}.roots-mode{display:flex;gap:4px;margin-bottom:8px}.mode-pill{font-size:10.5px;font-weight:600;padding:4px 10px;border-radius:999px;border:1px solid var(--border);color:var(--text-faint)}.mode-pill.on{background:var(--green-bg);border-color:var(--green-deep);color:var(--green)}.roots-input{display:flex;align-items:flex-end;gap:8px;background:var(--panel-2);border:1px solid var(--border-2);border-radius:14px;padding:10px 12px}.roots-input textarea{flex:1;background:none;border:none;outline:none;resize:none;font-size:13px;line-height:1.45;max-height:110px;color:var(--text)}.roots-input textarea::placeholder{color:var(--text-faint)}.roots-attachments{display:flex;gap:6px;padding:6px 8px 0;flex-wrap:wrap}.roots-attachment{position:relative;width:52px;height:52px;flex-shrink:0}.roots-attachment img{width:100%;height:100%;object-fit:cover;border-radius:6px;border:1px solid var(--border)}.roots-attachment button{position:absolute;top:-5px;right:-5px;width:16px;height:16px;border-radius:50%;background:#e5484d;border:none;color:#fff;font-size:9px;cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1}.roots-sessions-menu{position:absolute;top:100%;right:0;background:var(--panel-2);border:1px solid var(--border);border-radius:var(--radius-sm);max-height:240px;overflow-y:auto;box-shadow:0 4px 16px #0000004d;z-index:50;min-width:220px;max-width:90vw}.roots-session-item{display:flex;justify-content:space-between;width:100%;padding:8px 12px;background:none;border:none;border-bottom:1px solid var(--border);color:var(--text);cursor:pointer;font-size:12px;text-align:left}.roots-session-item:hover{background:#34d27b0f}.roots-session-name{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.roots-session-date{color:var(--text-faint);font-size:10px;flex-shrink:0;margin-left:8px}.roots-session-empty{padding:12px;color:var(--text-faint);font-size:12px;text-align:center}.roots-char-count{font-size:10px;color:var(--text-faint);padding:0 4px;align-self:center;flex-shrink:0}.roots-char-count.over{color:#e5484d}.send-btn{width:32px;height:32px;border-radius:50%;background:var(--text);color:#111;display:grid;place-items:center;font-size:14px;flex-shrink:0;transition:all .12s}.send-btn:hover{background:#fff}.send-btn:disabled{opacity:.35}.roots-fab{position:absolute;right:14px;bottom:64px;z-index:39;display:flex;align-items:center;gap:8px;background:var(--panel);border:1px solid var(--border-2);border-radius:999px;padding:10px 16px;font-size:13px;font-weight:600;box-shadow:var(--shadow);transition:all .15s}.roots-fab:hover{border-color:var(--green-deep);color:var(--green)}.roots-fab .dot{width:8px;height:8px;border-radius:50%;background:var(--green)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;z-index:100;display:grid;place-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal{width:460px;max-width:92vw;background:var(--panel);border:1px solid var(--border-2);border-radius:18px;box-shadow:var(--shadow);overflow:hidden;animation:pop .16s ease-out}.modal-head{padding:16px 18px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center}.modal-head b{font-size:15px}.modal-body{padding:16px 18px;display:flex;flex-direction:column;gap:13px;max-height:60vh;overflow-y:auto}.field label{display:block;font-size:11.5px;color:var(--text-dim);margin-bottom:5px;font-weight:600}.field input{width:100%;background:var(--panel-2);border:1px solid var(--border);border-radius:9px;padding:9px 11px;font-size:12.5px;outline:none;font-family:var(--mono)}.field input:focus{border-color:var(--border-2)}.field .hint{font-size:10.5px;color:var(--text-faint);margin-top:4px}.modal-foot{padding:13px 18px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:8px}.toast{position:absolute;top:64px;left:50%;transform:translate(-50%);z-index:80;background:var(--panel-2);border:1px solid rgba(232,183,101,.4);color:var(--amber);border-radius:10px;padding:9px 16px;font-size:12.5px;box-shadow:var(--shadow);animation:pop .2s}.node-hover-bar{position:absolute;top:-38px;left:0;right:0;display:flex;align-items:center;gap:5px;padding:5px 7px;background:var(--panel-2);border:1px solid var(--border-2);border-radius:10px;opacity:0;pointer-events:none;transition:opacity .12s;z-index:10;box-shadow:var(--shadow);width:max-content;max-width:480px}.gen-node:hover .node-hover-bar{opacity:1;pointer-events:auto}.tag-dot{width:13px;height:13px;border-radius:50%;flex-shrink:0;transition:transform .1s}.tag-dot:hover{transform:scale(1.25)}.tool-strip{display:flex;gap:3px;border-left:1px solid var(--border);padding-left:6px}.tool-chip{font-size:9.5px;font-weight:700;letter-spacing:.03em;text-transform:uppercase;color:var(--text-dim);background:var(--panel-3);border:1px solid var(--border);border-radius:6px;padding:3px 6px}.tool-chip:hover{color:var(--text);border-color:var(--border-2)}.tool-chip.danger:hover{color:var(--red);border-color:#5b2320}.search-bar{position:absolute;top:64px;left:50%;transform:translate(-50%);z-index:70;display:flex;align-items:center;gap:8px;background:var(--panel);border:1px solid var(--border-2);border-radius:12px;padding:8px 12px;box-shadow:var(--shadow);animation:pop .15s;width:360px}.search-bar input{flex:1;background:none;border:none;outline:none;font-size:13px;color:var(--text)}.gen-node.search-hit{border-color:var(--amber);box-shadow:0 0 0 2px #e8b7658c,var(--shadow)}.node-params .node-select{font-size:10.5px;padding:4px 6px}.node-params input.node-select{font-family:var(--font)}.batch-list{display:flex;flex-direction:column;gap:4px;max-height:180px;overflow-y:auto}.batch-item{display:flex;align-items:center;gap:8px;padding:5px 7px;background:var(--panel-2);border:1px solid var(--border);border-radius:8px;font-size:11.5px}.batch-item img{width:26px;height:26px;object-fit:cover;border-radius:5px}.batch-thumb{width:26px;height:26px;border-radius:5px;background:var(--panel-3);display:grid;place-items:center;font-size:11px;color:var(--text-faint)}.batch-label{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--text-dim)}.batch-item button{color:var(--text-faint);font-size:10px}.batch-item button:hover{color:var(--red)}.batch-more{font-size:10.5px;color:var(--text-faint);padding:2px 7px}.element-refs{display:flex;gap:5px}.element-refs img{width:56px;height:56px;object-fit:cover;border-radius:8px;border:1px solid var(--border)}.element-card{display:flex;align-items:center;gap:11px;padding:9px;background:var(--panel-2);border:1px solid var(--border);border-radius:12px}.element-card .element-refs img{width:36px;height:36px}.carousel-bar{display:flex;align-items:center;justify-content:space-between;padding:5px 9px;font-size:10.5px;color:var(--text-dim);border-bottom:1px solid var(--border);background:var(--panel-3)}.carousel-bar button{color:var(--text-dim);font-size:14px;padding:0 6px}.carousel-bar button:hover{color:var(--text)}.palette-list.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;padding:8px}.palette-grid-item{display:flex;flex-direction:column;align-items:center;gap:6px;padding:12px 4px;border-radius:10px;border:1px solid var(--border);background:var(--panel-2);font-size:11px}.palette-grid-item:hover{background:var(--panel-3);border-color:var(--border-2)}.palette-grid-item .palette-icon{width:26px;height:26px}.zoom-pill{font-weight:500;color:var(--text-dim)}.zoom-pill .chev{font-size:9px;color:var(--text-faint)}.zoom-menu{position:absolute;top:42px;right:0;z-index:80;min-width:130px;background:var(--panel-2);border:1px solid var(--border-2);border-radius:12px;box-shadow:var(--shadow);overflow:hidden;animation:pop .12s}.zoom-menu button{display:block;width:100%;padding:8px 14px;text-align:left;font-size:12.5px;color:var(--text-dim)}.zoom-menu button:hover{background:var(--panel-3);color:var(--text)}.help-menu{position:absolute;left:64px;bottom:80px;z-index:80;width:280px;background:var(--panel);border:1px solid var(--border-2);border-radius:14px;box-shadow:var(--shadow);overflow:hidden;animation:pop .14s}.help-menu>button{display:flex;align-items:center;gap:11px;width:100%;padding:11px 16px;font-size:13px;color:var(--text-dim)}.help-menu>button:hover{background:var(--panel-2);color:var(--text)}.help-menu .hm-icon{width:16px;color:var(--text-faint)}.help-menu .hm-key{margin-left:auto;font-size:11px;color:var(--text-faint);font-family:var(--mono)}.help-foot{border-top:1px solid var(--border);padding:10px 16px;display:flex;flex-direction:column;gap:2px;font-family:var(--mono);font-size:10px;color:var(--text-faint)}.toolbar-sep{width:24px;height:1px;background:var(--border);margin:3px 0}.canvas-search{position:absolute;top:230px;left:50%;transform:translate(-50%);z-index:70;display:flex;align-items:center;gap:11px;width:min(740px,60vw);background:var(--panel-2);border:1px solid var(--border-2);border-radius:14px;padding:14px 18px;box-shadow:var(--shadow);animation:pop .15s}.canvas-search input{flex:1;background:none;border:none;outline:none;font-size:15px;color:var(--text)}.search-count{font-size:11px;color:var(--text-faint);white-space:nowrap}.budget-chip{gap:0}.budget-detail{display:flex;align-items:center;gap:9px;max-width:0;overflow:hidden;transition:max-width .25s ease;white-space:nowrap}.budget-chip:hover .budget-detail{max-width:420px}.budget-detail>:first-child{margin-left:10px}.budget-detail button{color:inherit;font-size:inherit}.roots-corner{position:absolute;right:14px;bottom:14px;z-index:31;width:44px;height:44px;border-radius:12px;background:var(--panel);border:1px solid var(--border-2);display:grid;place-items:center;box-shadow:var(--shadow);transition:all .15s}.roots-corner:hover{border-color:var(--green-deep)}.roots-dots-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:3px}.roots-dots-grid i{width:4px;height:4px;border-radius:50%;background:var(--text-dim)}.roots-corner:hover .roots-dots-grid i{background:var(--green)}.queue-widget{right:68px!important}.technique-node{position:relative;width:380px;max-width:90vw}.technique-node.spawned{animation:spawn .4s cubic-bezier(.2,1.4,.4,1)}.technique-label{color:var(--green);font-size:12.5px;font-weight:600;margin-bottom:7px;display:flex;gap:6px}.technique-card{position:relative;background:#11301f40;border:1.5px solid var(--green-deep);border-radius:18px;padding:14px;display:flex;flex-direction:column;gap:10px;transition:border-color .15s}.technique-node.selected .technique-card,.technique-node.status-running .technique-card{border-color:var(--green);box-shadow:0 0 28px #34d27b1f}.technique-section{font-size:12px;color:var(--text-dim)}.technique-input{display:flex;align-items:center;gap:10px;border:1.5px dashed rgba(52,210,123,.35);border-radius:12px;padding:11px 13px;font-size:13.5px;color:var(--text)}.technique-input.filled{border-style:solid}.technique-input img{width:34px;height:34px;object-fit:cover;border-radius:7px}.technique-input .ti-icon{width:30px;height:30px;border-radius:8px;background:var(--panel-3);border:1px solid var(--border-2);display:grid;place-items:center;font-size:12px;color:var(--text-dim)}.technique-input .ti-hint{margin-left:auto;font-size:10.5px;color:var(--text-faint)}.technique-foot{display:flex;align-items:center;justify-content:space-between}.canopy-dots{color:#34d27b80;font-size:11px;letter-spacing:2px}.technique-run{width:42px;height:42px;border-radius:50%;background:var(--panel-3);border:1px solid var(--border-2);color:var(--text);font-size:17px;display:grid;place-items:center;transition:background-color .14s ease,border-color .14s ease,color .14s ease,transform .14s ease}.technique-run:hover{background:var(--green);color:#06170d;border-color:var(--green)}.technique-run:disabled{opacity:.5}.technique-progress{display:flex;flex-direction:column;gap:5px;font-size:11px;color:var(--text-dim)}.gen-progress{display:flex;flex-direction:column;gap:5px;width:100%;font-size:11px;color:var(--text-dim)}.gen-progress .tp-bar{width:100%}.tp-bar{height:4px;border-radius:2px;background:var(--panel-3);overflow:hidden}.tp-bar i{display:block;height:100%;background:var(--green);transition:width .4s}.technique-outputs{position:absolute;left:calc(100% + 26px);top:50%;transform:translateY(-30%);display:flex;flex-direction:column;gap:22px;pointer-events:none}.technique-stub{display:flex;align-items:center;gap:9px;font-size:13px;color:var(--text-dim);white-space:nowrap}.stub-circle{width:22px;height:22px;border-radius:50%;border:1.5px solid var(--text-faint)}.new-badge{color:var(--green);font-size:10px;font-weight:700;margin-left:4px}.palette-footer button.stub{opacity:.55}.assets-modal{width:min(1180px,86vw);height:min(760px,84vh);background:var(--panel);border:1px solid var(--border-2);border-radius:20px;box-shadow:var(--shadow);overflow:hidden;display:flex;flex-direction:column;animation:pop .16s ease-out}.assets-search{display:flex;align-items:center;gap:11px;margin:16px 18px 0;background:var(--panel-2);border:1px solid var(--border-2);border-radius:12px;padding:11px 15px;color:var(--text-faint)}.assets-search input{flex:1;background:none;border:none;outline:none;font-size:14px;color:var(--text)}.assets-tabs{display:flex;gap:4px;padding:12px 18px;border-bottom:1px solid var(--border)}.assets-tab{padding:7px 13px;border-radius:9px;font-size:13px;font-weight:600;color:var(--text-dim)}.assets-tab:hover{color:var(--text)}.assets-tab.on{background:var(--panel-3);color:var(--text)}.assets-body{flex:1;overflow-y:auto;padding:18px}.assets-section{font-size:13.5px;color:var(--text-dim);margin:8px 0 12px;display:flex;align-items:center;gap:8px}.count-badge{background:var(--panel-3);border-radius:6px;padding:1px 7px;font-size:11px;color:var(--text-faint)}.assets-grid{display:flex;gap:16px;margin-bottom:26px}.asset-card{width:240px;height:200px;border-radius:16px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;font-size:14px;color:var(--text-dim);background:var(--panel-2);transition:all .15s}.asset-card.dashed{background:none;border:1.5px dashed var(--border-2)}.asset-card:hover{color:var(--text);border-color:var(--text-faint)}.asset-card .ac-icon{font-size:26px}.unsplash-cats{display:flex;gap:18px;margin-bottom:16px}.unsplash-cats button{font-size:13.5px;color:var(--text-dim);padding:3px 0}.unsplash-cats button.on{color:var(--text);border-bottom:1.5px solid var(--text)}.unsplash-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.unsplash-item{display:flex;flex-direction:column;gap:6px;text-align:left}.unsplash-item img{width:100%;aspect-ratio:4/2.7;object-fit:cover;border-radius:10px;transition:transform .15s}.unsplash-item:hover img{transform:scale(1.02)}.unsplash-item span{font-size:11.5px;color:var(--text-dim);text-decoration:underline}.connect-pane{display:flex;flex-direction:column;align-items:center;padding-top:40px;gap:10px;text-align:center}.connect-logo{font-size:36px;color:var(--text-dim)}.connect-pane b{font-size:17px}.connect-pane p{font-size:13px;color:var(--text-dim);max-width:340px;margin:0;line-height:1.5}.connect-divider{width:100%;height:1px;background:var(--border);margin:26px 0 8px}.connect-empty{color:var(--text-faint)!important}.send-btn.stop{background:var(--text)}.stop-square{width:11px;height:11px;background:#111;border-radius:2px}.canopy-node{position:relative;width:360px;max-width:90vw;--tag: transparent}.canopy-node.spawned{animation:spawn .4s cubic-bezier(.2,1.4,.4,1)}.canopy-head{display:flex;align-items:center;gap:7px;padding:0 4px 8px}.canopy-head .fh-icon{color:var(--text-faint);font-size:13px}.fh-label{flex:1;min-width:0;background:none;border:none;outline:none;font-size:13.5px;font-weight:600;color:var(--text);font-family:var(--font)}.fh-model{font-size:12px;color:var(--text-faint);white-space:nowrap}.node-info-btn{width:18px;height:18px;border-radius:50%;font-size:11px;font-weight:700;font-style:italic;font-family:Georgia,serif;background:#ffffff0f;border:1px solid var(--border-2);color:var(--text-faint);cursor:pointer;display:grid;place-items:center;flex-shrink:0;transition:all .15s}.node-info-btn:hover{background:#ffffff1f;color:var(--text);border-color:var(--text-dim)}.node-info-popup{position:absolute;top:100%;left:0;right:0;z-index:50;background:#121212fa;border:1px solid var(--border-2);border-radius:12px;padding:14px;margin-top:4px;box-shadow:0 16px 48px #0009;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);animation:pop .14s ease-out}.nip-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.nip-title{font-size:13px;font-weight:600;color:var(--green)}.nip-close{background:none;border:none;color:var(--text-faint);font-size:13px;cursor:pointer;padding:0 4px}.nip-close:hover{color:var(--text)}.nip-desc{font-size:11.5px;color:var(--text-dim);line-height:1.5;margin-bottom:10px}.nip-mode{font-size:11px;color:var(--text-faint);margin-bottom:4px}.nip-mode b{color:var(--text)}.nip-section{font-size:10px;font-weight:600;color:var(--text-faint);text-transform:uppercase;letter-spacing:.05em;margin:8px 0 4px}.nip-list{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:4px}.nip-chip{font-size:10.5px;background:#34d27b1a;color:var(--green);border:1px solid rgba(52,210,123,.2);border-radius:6px;padding:2px 8px}.nip-tag{font-size:10.5px;background:#ffffff0d;color:var(--text-dim);border:1px solid var(--border);border-radius:6px;padding:2px 8px}.nip-tip{font-size:11px;color:var(--text-faint);font-style:italic;margin-top:8px;padding-top:8px;border-top:1px solid var(--border)}.canopy-card{background:#141414eb;border:1px solid var(--border-2);border-radius:22px;padding:14px;display:flex;flex-direction:column;gap:10px;box-shadow:0 0 0 2px var(--tag),0 10px 32px #00000073;transition:border-color .15s,box-shadow .15s}.canopy-node.selected .canopy-card{border-color:var(--text-dim)}.canopy-node.status-running .canopy-card{border-color:var(--green-deep);box-shadow:0 0 0 2px var(--tag),0 0 28px #34d27b24}.canopy-node.status-failed .canopy-card{border-color:#5b2320}.canopy-node.search-hit .canopy-card{border-color:var(--amber)}.canopy-prompt{width:100%;min-height:84px;resize:vertical;background:none;border:none;outline:none;font-size:14px;line-height:1.55;color:var(--text);font-family:var(--font)}.canopy-prompt::placeholder{color:var(--text-faint)}.canopy-foot{display:flex;align-items:center;gap:8px}.foot-icon{width:28px;height:28px;border-radius:8px;display:grid;place-items:center;color:var(--text-faint);font-size:13.5px}.foot-icon:hover{background:var(--panel-3);color:var(--text)}.canopy-run{width:38px;height:38px;border-radius:50%;background:var(--text);color:#111;font-size:16px;font-weight:700;display:grid;place-items:center;transition:all .12s}.canopy-run:hover{background:#fff;transform:scale(1.05)}.canopy-run:disabled{opacity:.5;transform:none}.canopy-run.canopy-stop{background:var(--red);color:#fff;font-size:12px}.canopy-run.canopy-stop:hover{background:#ff4a40;transform:scale(1.05)}.node-output.bare{border:none;background:var(--panel-2);border-radius:14px;overflow:hidden}.port-label{position:absolute;left:-128px;width:118px;text-align:right;font-size:12px;color:var(--text-dim);pointer-events:none;white-space:nowrap}.port-label .port-icon{font-size:10px;color:var(--text-faint);margin-right:2px}.port-label .port-count{color:var(--text-faint);font-size:10.5px}.node-float-bar{position:absolute;top:-54px;left:0;z-index:12;display:flex;align-items:center;gap:6px;padding:7px 10px;background:#161616f7;border:1px solid var(--border-2);border-radius:999px;box-shadow:var(--shadow);width:max-content;max-width:560px;animation:pop .12s}.float-model{background:none;border:none;outline:none;color:var(--text);font-size:13px;font-weight:600;font-family:var(--font);cursor:pointer;max-width:160px}.float-sep{width:1px;height:18px;background:var(--border-2)}.float-icon{width:26px;height:26px;border-radius:50%;display:grid;place-items:center;color:var(--text-dim);font-size:12px}.float-icon:hover{background:var(--panel-3);color:var(--text)}.float-icon.danger:hover{color:var(--red)}.input-chips{display:flex;gap:5px}.in-chip{position:relative;width:30px;height:30px;border-radius:8px;overflow:visible;background:var(--panel-3);border:1px solid var(--border-2);display:grid;place-items:center;font-size:11px;color:var(--text-dim);font-weight:700}.in-chip img{width:100%;height:100%;object-fit:cover;border-radius:7px}.in-chip-reorder{position:absolute;bottom:-16px;left:50%;transform:translate(-50%);display:none;gap:1px;background:var(--panel);border-radius:4px;border:1px solid var(--border);padding:0 2px}.in-chip:hover .in-chip-reorder{display:flex}.in-chip-reorder button{font-size:10px;padding:0 3px;color:var(--text-dim);background:none;border:none;cursor:pointer;line-height:14px}.in-chip-reorder button:hover{color:var(--text)}.in-chip-reorder button:disabled{opacity:.3;cursor:default}.quick-add{position:absolute;right:-44px;top:50%;transform:translateY(-50%);width:26px;height:26px;border-radius:50%;background:var(--panel-2);border:1px solid var(--border-2);color:var(--text-dim);font-size:14px;display:grid;place-items:center;opacity:0;transition:all .15s}.canopy-node:hover .quick-add{opacity:1}.quick-add:hover{color:var(--text);border-color:var(--text-faint)}.mention-menu.node-mention{position:absolute;bottom:34px;left:0;width:220px;z-index:20}.project-menu{position:absolute;top:52px;left:0;z-index:90;width:250px;background:#1c1c1cfa;border:1px solid var(--border-2);border-radius:14px;box-shadow:var(--shadow);overflow:hidden;animation:pop .13s;padding:6px 0}.project-menu button{display:flex;align-items:center;width:100%;padding:9px 18px;font-size:14px;color:var(--text);text-align:left}.project-menu button:hover:not(:disabled){background:var(--panel-3)}.project-menu button:disabled{color:var(--text-faint);cursor:default}.project-menu .hm-key{margin-left:auto;font-size:12px;color:var(--text-faint)}.pm-sep{height:1px;background:var(--border);margin:6px 0}.ws-selector{position:relative}.ws-trigger{display:flex;align-items:center;gap:8px;padding:4px 8px 4px 4px;border-radius:var(--radius-sm);cursor:pointer;transition:background .12s}.ws-trigger:hover{background:var(--panel-3)}.ws-logo{width:24px;height:24px;border-radius:6px;object-fit:cover}.ws-logo-fallback{display:flex;align-items:center;justify-content:center;background:var(--green-deep);color:var(--green);font-weight:600;font-size:12px}.ws-trigger-text{display:flex;flex-direction:column;gap:1px}.ws-name{font-size:11.5px;color:var(--text);font-weight:500;white-space:nowrap}.ws-member-count{font-size:10px;color:var(--text-faint)}.ws-dropdown{position:absolute;top:calc(100% + 6px);left:0;z-index:90;width:280px;background:#1c1c1cfa;border:1px solid var(--border-2);border-radius:14px;box-shadow:var(--shadow);overflow:hidden;animation:pop .13s;padding:6px 0}.ws-search-wrap{padding:6px 10px}.ws-search{width:100%;padding:7px 10px;border-radius:var(--radius-sm);background:var(--panel);border:1px solid var(--border);font-size:13px;outline:none}.ws-search:focus{border-color:var(--green)}.ws-list{max-height:260px;overflow-y:auto}.ws-empty{padding:14px 18px;font-size:13px;color:var(--text-faint)}.ws-item{display:flex;align-items:center;gap:10px;width:100%;padding:8px 14px;text-align:left;font-size:13px;color:var(--text);cursor:pointer;transition:background .1s}.ws-item:hover{background:var(--panel-3)}.ws-active{background:var(--panel-2)}.ws-item-logo{width:28px;height:28px;border-radius:7px;object-fit:cover;flex-shrink:0}.ws-item-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.ws-item-name{font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ws-item-meta{display:flex;align-items:center;gap:8px;font-size:11px;color:var(--text-faint)}.ws-plan-badge{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.ws-check{color:var(--green);font-size:14px;flex-shrink:0}.ws-sep{height:1px;background:var(--border);margin:4px 0}.ws-create{display:flex;width:100%;padding:10px 18px;font-size:13px;color:var(--text-dim);cursor:pointer}.ws-create:hover{background:var(--panel-3);color:var(--text)}.ws-create{gap:8px;align-items:center}.ws-user-row{display:flex;align-items:center;gap:10px;padding:8px 14px 10px}.ws-user-avatar{width:38px;height:38px;border-radius:50%;object-fit:cover;flex-shrink:0}.ws-user-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px}.ws-user-name{font-size:13.5px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ws-user-email{font-size:11.5px;color:var(--text-faint);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ws-user-actions{display:flex;gap:6px;flex-shrink:0}.ws-icon-btn{width:30px;height:30px;display:grid;place-items:center;border-radius:8px;border:1px solid var(--border);background:transparent;color:var(--text-dim);cursor:pointer;font-size:14px;transition:background .1s,color .1s}.ws-icon-btn:hover{background:var(--panel-3);color:var(--text)}.ws-label{padding:6px 14px 2px;font-size:11px;font-weight:600;color:var(--text-faint);text-transform:none}.ws-invite{padding:6px 14px 10px}.ws-invite-row{display:flex;gap:6px}.ws-invite-input{flex:1;min-width:0;padding:7px 10px;border-radius:var(--radius-sm);background:var(--panel);border:1px solid var(--border);font-size:13px;outline:none;color:var(--text)}.ws-invite-input:focus{border-color:var(--green)}.ws-invite-send{padding:7px 14px;border-radius:var(--radius-sm);border:none;background:var(--green);color:#07120c;font-size:12.5px;font-weight:600;cursor:pointer}.ws-invite-send:disabled{opacity:.5;cursor:default}.ws-invite-msg{margin-top:7px;font-size:11.5px}.ws-invite-msg.ok{color:var(--green)}.ws-invite-msg.err{color:#ff6b6b}.home{display:flex;height:100%;background:var(--bg)}.home-side{width:250px;flex-shrink:0;border-right:1px solid var(--border);background:#0e0e0e;padding:16px 12px;display:flex;flex-direction:column;gap:3px}.home-ws{display:flex;align-items:center;gap:10px;padding:6px 8px 18px}.ws-avatar{width:34px;height:34px;border-radius:9px;background:var(--green-deep);color:var(--green);display:grid;place-items:center;font-weight:700}.home-ws b{display:block;font-size:13px}.home-ws span{font-size:11px;color:var(--text-faint)}.home-nav{display:flex;align-items:center;gap:9px;padding:8px 10px;border-radius:9px;font-size:13.5px;color:var(--text-dim);text-align:left;border:1px solid transparent;background:transparent;transition:background-color .14s ease,border-color .14s ease,color .14s ease}.home-nav:hover,.home-nav.on{background:var(--panel-2);color:var(--text);border-color:var(--border)}.home-side-label{font-size:11.5px;color:var(--text-faint);padding:16px 10px 4px}.home-side-foot{margin-top:auto;padding:8px}.budget-pill{font-size:12px;color:var(--text-dim);background:var(--panel-2);border:1px solid var(--border);border-radius:9px;padding:7px 11px}.home-main{flex:1;overflow-y:auto;padding:60px 64px 80px}.home-hero{display:flex;flex-direction:column;align-items:center;gap:18px;margin-bottom:56px}.roots-dots-grid.big{grid-template-columns:repeat(4,1fr);gap:5px;padding:14px;background:var(--panel-2);border-radius:16px;border:1px solid var(--border)}.roots-dots-grid.big i{width:6px;height:6px}.home-hero h1{font-size:30px;font-weight:600;margin:0;letter-spacing:-.02em}.home-input{display:flex;align-items:center;gap:10px;width:min(720px,80%);background:var(--panel-2);border:1px solid var(--border-2);border-radius:16px;padding:12px 14px}.home-input input{flex:1;background:none;border:none;outline:none;font-size:14.5px;color:var(--text)}.home-section-head{display:flex;align-items:center;justify-content:space-between;margin:36px 0 16px}.home-section-head b{font-size:15px}.home-link{font-size:12.5px;color:var(--text-dim)}.home-link:hover{color:var(--text)}.explore-row{display:grid;grid-template-columns:repeat(5,1fr);gap:14px}.explore-card{position:relative;border-radius:14px;overflow:hidden;aspect-ratio:3/3.4;background:var(--panel-2);border:1px solid var(--border);text-align:left;display:flex;flex-direction:column;transition:all .15s}.explore-card:hover{border-color:var(--border-2);transform:translateY(-2px)}.explore-card.dashed{border:1.5px dashed var(--border-2);align-items:center;justify-content:center;gap:10px;color:var(--text-dim);font-size:13px;background:none}.explore-card img{width:100%;flex:1;object-fit:cover;min-height:0}.ec-thumb{width:100%;flex:1;min-height:0;display:grid;place-items:center;color:#ffffff40;border-bottom:1px solid var(--border)}.ec-thumb{position:relative}.ec-thumb-img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;z-index:1}.ec-thumb-icon{position:relative;z-index:2;filter:drop-shadow(0 2px 8px rgba(0,0,0,.5))}.ec-thumb:has(.ec-thumb-img) .ec-thumb-icon{color:#ffffffb3}.explore-card .ec-meta{padding:10px 12px}.explore-card .ec-meta b{display:block;font-size:13px}.explore-card .ec-meta span{font-size:11.5px;color:var(--text-dim);line-height:1.4}.fv{display:flex;height:100vh;width:100%;overflow:hidden;background:#fff;color:#1c1d22;font-family:Instrument Sans,system-ui,sans-serif}.fv button{cursor:pointer;font-family:inherit}.fv-embedded{flex:1;width:auto;height:100%;min-width:0}.fv-rail{width:232px;flex-shrink:0;border-right:1px solid #ececef;padding:16px 12px;display:flex;flex-direction:column;background:#fff}.fv-brand{display:flex;align-items:center;gap:9px;padding:2px 6px 18px}.fv-brand-mark{width:26px;height:26px;border-radius:8px;background:radial-gradient(circle at 30% 30%,#34d27b,#15803d 70%);flex-shrink:0}.fv-brand-name{font-size:18px;font-weight:700;letter-spacing:-.02em}.fv-rail-nav{display:flex;flex-direction:column;gap:1px}.fv-rail-item{display:flex;align-items:center;gap:11px;width:100%;padding:8px 9px;border:none;background:none;border-radius:9px;font-size:14px;color:#2b2c31;text-align:left;transition:background .1s}.fv-rail-item svg{color:#6b6d76;flex-shrink:0}.fv-rail-item:hover{background:#f4f4f6}.fv-rail-item.active{background:#e9f7ef;color:#1c1d22;font-weight:600}.fv-rail-item.active svg{color:#15803d}.fv-rail-item.dim{color:#4a4b52}.fv-rail-item.sm{font-size:13px;padding:6px 9px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.fv-rail-label{font-size:12px;font-weight:600;color:#9a9ba3;padding:14px 9px 5px}.fv-rail-empty{font-size:12.5px;color:#b5b6bd;padding:4px 9px}.fv-rail-foot{margin-top:auto;display:flex;flex-direction:column;gap:10px;padding-top:12px}.fv-invite-pill{display:flex;align-items:center;gap:8px;font-size:12.5px;color:#4a4b52;border:1px solid #e6e6ea;border-radius:11px;padding:9px 11px}.fv-invite-pill svg{color:#15803d}.fv-profile{display:flex;align-items:center;gap:10px;width:100%;padding:8px;border:none;background:none;border-radius:11px;text-align:left}.fv-profile:hover{background:#f4f4f6}.fv-profile-av{width:34px;height:34px;border-radius:50%;object-fit:cover;background:#15803d;color:#fff;display:grid;place-items:center;font-weight:700;font-size:14px;flex-shrink:0}.fv-profile-info{min-width:0;display:flex;flex-direction:column}.fv-profile-info b{font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.fv-profile-info span{font-size:11.5px;color:#9a9ba3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.fv-col{width:232px;flex-shrink:0;border-right:1px solid #ececef;padding:16px 10px;display:flex;flex-direction:column;gap:1px;background:#fff}.fv-col-item{display:flex;align-items:center;gap:10px;width:100%;padding:9px 12px;border:none;background:none;border-radius:9px;font-size:14px;color:#2b2c31;text-align:left}.fv-col-item svg{color:#6b6d76}.fv-col-item:hover{background:#f4f4f6}.fv-col-item.on{background:#f1f1f3;font-weight:600}.fv-col-count{margin-left:auto;font-size:12px;color:#9a9ba3}.fv-tree{margin-top:4px}.fv-tree-head,.fv-tree-item{display:flex;align-items:center;gap:7px;width:100%;padding:8px 10px;border:none;background:none;border-radius:9px;font-size:14px;color:#2b2c31;text-align:left}.fv-tree-head:hover,.fv-tree-item:hover{background:#f4f4f6}.fv-tree-item{padding-left:22px;font-size:13.5px}.fv-tree-head svg:first-child{color:#9a9ba3}.fv-main{flex:1;min-width:0;display:flex;flex-direction:column;background:#fff}.fv-topbar{display:flex;align-items:center;gap:14px;padding:14px 22px;border-bottom:1px solid #f0f0f2}.fv-search{flex:1;max-width:760px;display:flex;align-items:center;gap:9px;background:#f4f4f6;border-radius:11px;padding:9px 14px}.fv-search svg{color:#9a9ba3;flex-shrink:0}.fv-search input{flex:1;border:none;background:none;outline:none;font-size:14px;color:#1c1d22}.fv-credits{display:flex;align-items:center;gap:6px;font-size:14px;font-weight:600;color:#2b2c31}.fv-credits svg{color:#15803d}.fv-top-icon{position:relative;width:38px;height:38px;display:grid;place-items:center;border-radius:9px;border:1px solid transparent;background:none;color:#4a4b52;transition:background-color .14s ease,border-color .14s ease,color .14s ease}.fv-top-icon:hover{background:#f4f4f6;border-color:#e6e6ea}.fv-badge{position:absolute;top:3px;right:3px;min-width:16px;height:16px;padding:0 4px;border-radius:8px;background:#15803d;color:#fff;font-size:10px;font-weight:700;display:grid;place-items:center}.fv-notif{position:absolute;top:calc(100% + 8px);right:0;width:340px;background:#fff;border:1px solid #e6e6ea;border-radius:14px;box-shadow:0 12px 40px #00000024;z-index:100;overflow:hidden}.fv-notif-head{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid #f0f0f2}.fv-notif-head b{font-size:15px}.fv-notif-clear{border:none;background:none;color:#15803d;font-size:13px;font-weight:500}.fv-notif-empty{padding:22px 16px;color:#9a9ba3;font-size:13px}.fv-notif-item{display:flex;align-items:center;gap:11px;padding:13px 16px;border-bottom:1px solid #f4f4f6}.fv-notif-dot{width:30px;height:30px;border-radius:50%;background:radial-gradient(circle at 35% 30%,#34d27b,#15803d);flex-shrink:0}.fv-notif-text{flex:1;font-size:13.5px;color:#3a3b41}.fv-notif-when{font-size:12px;color:#9a9ba3;white-space:nowrap}.fv-notif-unread{width:8px;height:8px;border-radius:50%;background:#34d27b;flex-shrink:0}.fv-body{flex:1;overflow-y:auto;padding:26px 30px 60px}.fv-head-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}.fv-head-row h1{font-size:26px;font-weight:600;margin:0;letter-spacing:-.02em}.fv-head-actions{display:flex;align-items:center;gap:10px}.fv-viewtoggle{display:flex;border:1px solid #e6e6ea;border-radius:10px;overflow:hidden}.fv-viewtoggle button{width:38px;height:34px;display:grid;place-items:center;border:none;background:#fff;color:#9a9ba3}.fv-viewtoggle button.on{background:#e9f7ef;color:#15803d}.fv-btn{display:flex;align-items:center;gap:7px;min-height:36px;padding:8px 14px;border:1px solid #e6e6ea;border-radius:9px;background:#fff;font-size:13.5px;font-weight:500;color:#2b2c31;transition:background-color .14s ease,border-color .14s ease,color .14s ease,transform .14s ease}.fv-btn:hover{background:#f7f7f9;border-color:#d8dbe2}.fv-filters{display:flex;align-items:center;gap:9px;margin-bottom:22px}.fv-chip-wrap{position:relative}.fv-chip{padding:7px 13px;border:1px solid #e6e6ea;border-radius:999px;background:#fff;font-size:13px;color:#4a4b52}.fv-chip:hover{background:#f7f7f9}.fv-chip.active{border-color:#a7e0bf;background:#e9f7ef;color:#15803d}.fv-chip.right{margin-left:auto}.fv-chip-menu{position:absolute;top:calc(100% + 5px);left:0;background:#fff;border:1px solid #e6e6ea;border-radius:11px;box-shadow:0 10px 30px #0000001f;padding:5px;z-index:50;min-width:150px}.fv-chip-menu button{display:block;width:100%;text-align:left;padding:8px 11px;border:none;background:none;border-radius:8px;font-size:13px;color:#2b2c31}.fv-chip-menu button:hover{background:#f4f4f6}.fv-chip-menu button.on{background:#e9f7ef;color:#15803d;font-weight:600}.fv-btn-accent{border-color:#15803d38;background:#e9f7ef;color:#15803d}.fv-btn-accent:hover{background:#def3e6}.fv-brand-strip{display:grid;gap:14px;margin-bottom:22px;padding:16px;border:1px solid #e6e6ea;border-radius:14px;background:#fff}.fv-brand-summary{display:flex;align-items:center;gap:14px;min-width:0}.fv-brand-summary .fv-brand-mark{width:60px;height:60px;border-radius:12px;border:1px solid #e6e6ea;background:#f4f4f6;display:grid;place-items:center;overflow:hidden;flex-shrink:0;color:#15803d}.fv-brand-summary .fv-brand-mark img{width:100%;height:100%;object-fit:cover}.fv-brand-copy{display:grid;gap:4px;min-width:0}.fv-brand-copy span{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:#9a9ba3}.fv-brand-copy strong{font-size:15px;font-weight:650;color:#1c1d22}.fv-brand-copy p{margin:0;color:#4a4b52;font-size:13px;line-height:1.5;max-width:72ch}.fv-brand-metrics{display:flex;gap:12px;flex-wrap:wrap}.fv-brand-metrics div{min-width:88px;padding:10px 12px;border:1px solid #e6e6ea;border-radius:10px;background:#f7f7f9;display:grid;gap:2px}.fv-brand-metrics b{font-size:18px;line-height:1}.fv-brand-metrics span{font-size:11px;color:#9a9ba3;text-transform:uppercase;letter-spacing:.06em}.fv-brand-actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}.fv-tree-item.active{background:#e9f7ef;color:#15803d;font-weight:600}.fv-tree-item.active svg{color:#15803d}.fv-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:18px}.file-card{border:1px solid #ebebee;border-radius:14px;overflow:hidden;background:#fff;transition:box-shadow .15s,transform .15s}.file-card:hover{box-shadow:0 8px 24px #00000014;transform:translateY(-2px)}.fc-thumb{height:150px;display:grid;place-items:center;position:relative;overflow:hidden}.fc-thumb-img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover}.fc-thumb-icon{position:relative;z-index:1}.fc-thumb:has(.fc-thumb-img) .fc-thumb-icon{opacity:0}.fc-foot{display:flex;align-items:center;gap:10px;padding:12px 14px;border-top:1px solid #f1f1f3}.fc-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px}.fc-title{font-size:14px;font-weight:600;color:#1c1d22;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.fc-sub{font-size:12px;color:#9a9ba3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.fc-del{border:none;background:none;color:#b5b6bd;font-size:13px;padding:3px 7px;border-radius:7px;opacity:0;transition:opacity .12s}.file-card:hover .fc-del{opacity:1}.fc-del:hover{background:#f4f4f6;color:#ef4444}.fv-listview{display:flex;flex-direction:column}.file-row{display:flex;align-items:center;gap:14px;padding:11px 12px;border-bottom:1px solid #f1f1f3;border-radius:8px}.file-row:hover{background:#f7f7f9}.fr-icon{width:34px;height:34px;border-radius:8px;display:grid;place-items:center;flex-shrink:0}.fr-name{font-size:14px;font-weight:500;color:#1c1d22}.fr-sub{margin-left:auto;font-size:12.5px;color:#9a9ba3}.fv-empty{padding:40px 4px;color:#9a9ba3;font-size:14px}.cs{height:100%;flex:1;min-width:0;overflow-y:auto;background:var(--bg)}.cs-body{max-width:980px;margin:0 auto;padding:48px 32px 80px}.cs-head h1{font-size:30px;font-weight:600;letter-spacing:-.02em;margin:0 0 6px}.cs-head p{color:var(--text-dim);font-size:14px;margin:0 0 26px}.cs-urlbar{display:flex;gap:10px}.cs-urlbar input{flex:1;background:var(--panel-2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:11px 14px;font-size:14px;color:var(--text);outline:none}.cs-urlbar input:focus{border-color:var(--green)}.cs-btn{padding:10px 16px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--panel-2);color:var(--text);font-size:13.5px;font-weight:500}.cs-btn:hover{background:var(--panel-3)}.cs-btn.primary{background:var(--green-bg);border-color:var(--green-deep);color:var(--green)}.cs-btn.primary:hover{filter:brightness(1.15)}.cs-btn:disabled{opacity:.5;cursor:default}.cs-placeholder{margin:0 0 24px;border-radius:14px;overflow:hidden;border:1px solid var(--border);max-height:280px}.cs-placeholder img{width:100%;display:block;object-fit:cover;max-height:280px}.cs-err{margin-top:12px;color:var(--red);font-size:13px}.cs-section-label{font-size:12px;font-weight:600;color:var(--text-faint);text-transform:uppercase;letter-spacing:.04em;margin:30px 0 12px}.cs-dna{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);padding:18px}.cs-dna-head{display:flex;align-items:baseline;gap:10px}.cs-dna-head b{font-size:17px}.cs-dna-head span{color:var(--text-faint);font-size:12.5px}.cs-dna-summary{color:var(--text-dim);font-size:13px;line-height:1.55;margin:8px 0 12px}.cs-swatches{display:flex;gap:6px;margin-bottom:12px}.cs-swatch{width:28px;height:28px;border-radius:7px;border:1px solid var(--border-2)}.cs-chips{display:flex;flex-wrap:wrap;gap:6px}.cs-chip{font-size:11.5px;color:var(--text-dim);background:var(--panel-2);border:1px solid var(--border);border-radius:999px;padding:3px 10px}.cs-goals{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.cs-goal{text-align:left;background:var(--panel);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px 14px;display:flex;flex-direction:column;gap:2px}.cs-goal:hover{border-color:var(--border-2)}.cs-goal.on{border-color:var(--green-deep);background:var(--green-bg)}.cs-goal b{font-size:13.5px}.cs-goal span{font-size:11.5px;color:var(--text-dim)}.cs-goal.on span{color:var(--green)}.cs-direction{width:100%;margin:12px 0;background:var(--panel-2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 13px;font-size:13.5px;color:var(--text);outline:none}.cs-direction:focus{border-color:var(--green)}.cs-concepts{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}.cs-concept{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);padding:16px;display:flex;flex-direction:column;gap:12px}.cs-concept-top b{font-size:15px}.cs-angle{display:block;color:var(--text-dim);font-size:12.5px;margin-top:3px}.cs-hook{display:block;color:var(--green);font-size:13px;margin-top:6px;font-style:italic}.cs-caption{color:var(--text-dim);font-size:12.5px;line-height:1.5;margin:6px 0 0}.cs-assets{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.cs-asset{display:flex;flex-direction:column;gap:4px}.cs-asset-thumb{aspect-ratio:1/1;background:var(--panel-2);border:1px solid var(--border);border-radius:8px;overflow:hidden;display:grid;place-items:center}.cs-asset-thumb img{width:100%;height:100%;object-fit:cover}.cs-asset-spin{width:16px;height:16px;border:2px solid var(--border-2);border-top-color:var(--green);border-radius:50%;animation:cs-spin .8s linear infinite}@keyframes cs-spin{to{transform:rotate(360deg)}}.cs-asset-err{color:var(--red);font-size:11px}.cs-asset-label{font-size:10.5px;color:var(--text-faint);text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.projects-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}.project-card{display:flex;flex-direction:column;border-radius:14px;overflow:hidden}.project-card-new{aspect-ratio:16/8.2}.pc-canvas{width:100%;aspect-ratio:16/8.2;border:1.5px dashed var(--border-2);border-radius:14px;background:var(--panel-2);color:var(--text-faint);font-size:12px;display:flex;align-items:center;justify-content:center;transition:all .15s}.pc-canvas:hover{border-color:var(--text-faint);transform:translateY(-2px)}.pc-meta{display:flex;align-items:flex-start;justify-content:space-between;padding:9px 4px 0}.pc-meta b{display:block;font-size:13px}.pc-meta span{font-size:11.5px;color:var(--text-dim)}.pc-del{color:var(--text-faint);font-size:12px;padding:2px 7px;border-radius:7px;opacity:0;transition:opacity .15s}.project-card:hover .pc-del{opacity:1}.pc-del:hover{color:var(--text);background:var(--panel-3)}.proj-action{background:none;border:none;color:var(--text-dim);cursor:pointer;font-size:14px;padding:2px 6px;opacity:0;transition:opacity .15s;border-radius:7px}.project-card:hover .proj-action{opacity:1}.proj-action:hover{color:var(--green);background:var(--panel-3)}.pc-thumb{width:100%;height:100%;position:relative;overflow:hidden;background:radial-gradient(circle at 30% 40%,rgba(34,197,94,.04) 0%,transparent 60%),radial-gradient(circle at 70% 60%,rgba(59,130,246,.04) 0%,transparent 60%)}.pc-mini-node{position:absolute;width:20px;height:14px;border-radius:3px;border:1px solid;display:grid;place-items:center;transform:translate(-50%,-50%)}.pc-node-count{position:absolute;bottom:6px;right:8px;font-size:10px;color:var(--text-faint);background:#00000080;padding:1px 6px;border-radius:4px}.pc-empty-thumb{width:100%;height:100%;display:grid;place-items:center;color:var(--text-faint);font-size:11.5px;position:relative;overflow:hidden}.pc-empty-img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;opacity:.5}.pc-empty-thumb span{position:relative;z-index:1}.home-side-empty{font-size:12px;color:var(--text-faint);padding:4px 10px}.docs-list{display:flex;flex-direction:column;gap:8px;max-width:860px}.doc-item{border:1px solid var(--border);border-radius:13px;overflow:hidden;background:var(--panel-2)}.doc-item.open{border-color:var(--border-2)}.doc-head{display:flex;align-items:center;justify-content:space-between;width:100%;padding:13px 17px;font-size:13.5px;font-weight:600;color:var(--text);text-align:left}.doc-head:hover{background:var(--panel-3)}.doc-head .chev{color:var(--text-faint);font-size:10px}.doc-body{padding:12px 17px 16px;font-size:13px;line-height:1.65;color:var(--text-dim);white-space:pre-wrap;border-top:1px solid var(--border)}.usage-panel{display:flex;flex-direction:column;gap:10px}.usage-balance{display:flex;flex-direction:column;gap:4px;padding:12px 14px;background:var(--green-bg);border:1px solid var(--green-deep);border-radius:12px;font-size:12.5px}.usage-balance b{color:var(--green);font-size:11.5px}.ub-num{font-size:18px;font-weight:700;color:var(--text);margin-right:4px}.ub-dim{color:var(--text-faint)}.usage-row{display:flex;justify-content:space-between;padding:7px 4px;border-bottom:1px solid var(--border);font-size:12.5px;color:var(--text-dim)}.usage-row.head{color:var(--text);font-weight:600;border-bottom-color:var(--border-2);margin-top:4px}.usage-row span:last-child{font-family:var(--mono);font-size:11.5px}.usage-links{display:flex;gap:6px;margin-top:6px}.provider-status{display:flex;flex-direction:column;gap:2px}.provider-status-row{display:grid;grid-template-columns:22px 22px 1fr auto auto;gap:8px;align-items:center;padding:7px 4px;border-bottom:1px solid var(--border);font-size:12.5px}.ps-icon{font-size:11px;text-align:center}.ps-label{display:flex;flex-direction:column;gap:2px;color:var(--text);font-weight:600;font-size:12px}.ps-msg{font-weight:400;font-size:10.5px;color:var(--text-faint);line-height:1.35}.ps-ts{font-family:var(--mono);font-size:10px;color:var(--text-faint);white-space:nowrap}.node-output.bare{position:relative}.sim-badge{position:absolute;top:8px;left:8px;z-index:2;font-size:9px;font-weight:800;letter-spacing:.04em;text-transform:uppercase;padding:2px 6px;border-radius:6px;color:#1a1400;background:var(--amber);border:1px solid #c9922e;pointer-events:none}.plan-selfheal{display:flex;align-items:center;gap:7px;font-size:11.5px;color:var(--text-dim);cursor:pointer;padding:7px 2px 2px;-webkit-user-select:none;user-select:none}.plan-selfheal input{accent-color:var(--green)}.plan-selfheal b{color:var(--text);font-weight:700}.plan-selfheal span{color:var(--text-faint);font-size:10.5px}.skill-chips{display:flex;gap:6px;margin-bottom:7px;flex-wrap:wrap}.skill-chip{font-size:10.5px;font-weight:700;padding:3px 9px;border-radius:999px;color:var(--green);background:var(--green-bg);border:1px solid var(--green-deep)}.mention-menu{background:var(--panel-2);border:1px solid var(--border-2);border-radius:10px;margin-bottom:6px;overflow:hidden;animation:pop .12s}.mention-menu button{display:flex;align-items:center;gap:8px;width:100%;padding:7px 11px;font-size:12px;color:var(--text-dim);text-align:left}.mention-menu button>span:last-child{margin-left:auto;font-size:10px;color:var(--text-faint)}.mention-menu button:hover{background:var(--panel-3);color:var(--text)}.mention-node-row{min-height:44px}.mention-node-row .ctx-chip-icon,.mention-node-row .ctx-chip-thumb{margin-right:2px}.mention-node-main{min-width:0;flex:1;display:flex;flex-direction:column;gap:1px}.mention-node-main b{color:var(--text);font-size:12px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mention-node-main small{color:var(--text-faint);font-size:10.5px;font-weight:400;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mention-node-id{font-family:var(--mono);letter-spacing:.02em}.node-float-bar{display:none}.canopy-node:hover .node-float-bar,.node-float-bar.pinned,.batch-node-v2:hover .node-float-bar,.action-node-v2:hover .node-float-bar,.router-node:hover .node-float-bar,.technique-node:hover .node-float-bar{display:flex}.node-ctx-menu{position:fixed;z-index:1000;background:var(--panel-2);border:1px solid var(--border);border-radius:var(--radius-sm);min-width:200px;box-shadow:0 8px 32px #00000080;padding:4px 0;animation:pop .12s ease-out}.node-ctx-menu button{display:flex;align-items:center;gap:8px;width:100%;padding:7px 14px;background:none;border:none;color:var(--text);cursor:pointer;font-size:12px;text-align:left;white-space:nowrap}.node-ctx-menu button:hover{background:#34d27b14}.node-ctx-menu button.danger{color:#e5484d}.node-ctx-menu button.danger:hover{background:#e5484d14}.node-ctx-menu hr{border:none;border-top:1px solid var(--border);margin:4px 0}.ctx-icon{width:16px;text-align:center;font-size:13px}.mode-badge{font-size:10px;font-weight:700;letter-spacing:.04em;white-space:nowrap;padding:2px 8px;border-radius:999px;background:var(--panel-3);color:var(--text-dim);border:1px solid var(--border)}.kind-image .mode-badge{color:var(--blue)}.kind-video .mode-badge{color:var(--amber)}.kind-audio .mode-badge{color:#b78aff}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#050505b8;z-index:300;display:grid;place-items:center;animation:fade .12s}@keyframes fade{0%{opacity:0}}.mini-btn.gold{color:var(--amber);border-color:#6b5526}.mini-btn.gold:hover{background:#2a2113}.audio-controls{display:flex;gap:6px;padding:0 2px}.voice-row{display:flex;gap:4px;align-items:center;flex:1}.voice-select{flex:1}.char-counter{font-size:10.5px;color:var(--text-faint);padding:1px 6px;font-family:var(--mono)}.char-counter.over{color:var(--amber)}.audio-output{display:flex;align-items:center;gap:8px;padding:10px}.audio-play{padding:6px 13px;border-radius:999px;background:var(--green-bg);color:var(--green);border:1px solid var(--green-deep);font-size:12px;font-weight:700}.audio-play:hover{filter:brightness(1.2)}.audio-wave{display:flex;align-items:center;gap:2px;flex:1}.audio-wave i{width:3px;border-radius:2px;background:var(--green-deep)}.audio-fmt{font-size:10px;color:var(--text-faint);font-family:var(--mono)}.frames-strip{padding:2px}.frames-head{font-size:10.5px;color:var(--text-faint);padding:2px 4px}.frames-row{display:flex;gap:5px;flex-wrap:wrap}.frame-chip{position:relative;width:52px;height:38px;border-radius:7px;overflow:hidden;border:1px solid var(--border-2)}.frame-chip img{width:100%;height:100%;object-fit:cover}.frame-ops{position:absolute;top:0;right:0;bottom:0;left:0;display:none;align-items:center;justify-content:space-between;background:#0000008c}.frame-chip:hover .frame-ops{display:flex}.frame-ops button{color:#fff;font-size:11px;padding:2px 4px}.frame-ops button:disabled{opacity:.3}.frame-add{width:52px;height:38px;border-radius:7px;border:1.5px dashed var(--border-2);color:var(--text-dim);font-size:16px}.frame-add:hover{border-color:var(--green);color:var(--green)}.a2v-hint{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--amber);padding:4px 6px;flex-wrap:wrap}.a2v-hint.ok{color:var(--green)}.paircontrols{display:flex;align-items:center;gap:8px;padding:4px 6px}.pair-label{font-size:10.5px;color:var(--text-faint);font-weight:700;letter-spacing:.05em}.pair-toggle{display:flex;border:1px solid var(--border-2);border-radius:999px;overflow:hidden}.pair-toggle button{padding:3px 12px;font-size:11.5px;color:var(--text-dim)}.pair-toggle button.on{background:var(--green-bg);color:var(--green)}.pair-toggle button:disabled{opacity:.35;cursor:not-allowed}.pair-count{font-size:11px;color:var(--text-dim);font-family:var(--mono)}.seed-ctl{display:flex;align-items:center;gap:4px;font-size:11px;color:var(--text-faint);font-family:var(--mono)}.seed-input{width:64px;background:var(--panel-3);border:1px solid var(--border);border-radius:6px;color:var(--text);font-size:11px;padding:3px 6px;font-family:var(--mono)}.strength-row{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--text-dim)}.strength-row input[type=range]{width:80px;accent-color:var(--green)}.strength-row em{font-style:normal;font-family:var(--mono);font-size:10.5px}.run-wrap{position:relative}.cost-tip{position:absolute;bottom:40px;right:0;z-index:40;width:max-content;max-width:240px;background:var(--panel);border:1px solid var(--border-2);border-radius:10px;padding:9px 12px;font-size:11.5px;line-height:1.5;box-shadow:var(--shadow);animation:pop .1s}.cost-tip span{color:var(--text-faint);font-size:10.5px}.foot-icon.busy{animation:spin-icon .9s linear infinite}@keyframes spin-icon{to{transform:rotate(360deg)}}.action-node-v2{width:330px;background:var(--panel);border:1px solid #4c3a78;border-radius:var(--radius);box-shadow:0 0 0 1px #7c5cc41f,var(--shadow)}.action-node-v2.selected{border-color:#8a6ae0}.action-node-v2.status-failed{border-color:var(--red)}.an-head{display:flex;align-items:center;gap:7px;padding:10px 12px;border-bottom:1px solid var(--border)}.an-icon{color:#b78aff;font-size:14px}.an-title{font-weight:700;font-size:13px;flex:1}.an-io{display:flex;align-items:center;gap:3px;font-size:10px;color:var(--text-faint)}.slot-badges{display:inline-flex;gap:2px}.slot-badge{width:16px;height:16px;border-radius:4px;display:inline-grid;place-items:center;font-size:9px;background:var(--panel-3);border:1px solid var(--border)}.slot-badge.image{color:var(--blue)}.slot-badge.video{color:var(--amber)}.slot-badge.text{color:var(--green)}.slot-badge.audio{color:#b78aff}.action-picker{border-bottom:1px solid var(--border)}.ap-search{width:100%;background:var(--panel-2);border:none;border-bottom:1px solid var(--border);padding:9px 12px;color:var(--text);font-size:12.5px;font-family:var(--font);outline:none}.ap-list{max-height:300px;overflow-y:auto}.ap-group{font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-faint);padding:9px 12px 3px}.ap-item{display:flex;align-items:center;gap:8px;width:100%;padding:7px 12px;text-align:left}.ap-item:hover,.ap-item.on{background:var(--panel-2)}.ap-label{flex:1;min-width:0}.ap-label b{display:block;font-size:12.5px}.ap-label span{display:block;font-size:10.5px;color:var(--text-dim);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ap-empty{padding:14px;font-size:12px;color:var(--text-faint)}.an-body{padding:10px 12px;display:flex;flex-direction:column;gap:7px}.an-noparams{font-size:11.5px;color:var(--text-dim)}.ap-row{display:flex;align-items:center;gap:8px;font-size:11.5px;color:var(--text-dim)}.ap-row span{width:108px;flex-shrink:0}.ap-row input[type=range]{flex:1;accent-color:#b78aff}.ap-row input[type=color]{width:30px;height:22px;border:none;background:none;padding:0;cursor:pointer}.ap-row input[type=text],.ap-row input[type=number],.ap-row select{flex:1;min-width:0;background:var(--panel-3);border:1px solid var(--border);border-radius:6px;color:var(--text);font-size:11.5px;padding:4px 7px;font-family:var(--font)}.ap-row em{font-style:normal;font-family:var(--mono);font-size:10.5px;width:44px;text-align:right}.ap-row.toggle input{accent-color:#b78aff}.an-foot{display:flex;align-items:center;justify-content:space-between;padding-top:3px}.batch-node-v2{width:330px;max-width:90vw;background:var(--panel);border:1px solid var(--border-2);border-radius:var(--radius);box-shadow:var(--shadow);position:relative}.batch-node-v2.selected{border-color:var(--green)}.batch-split-bar{position:absolute;top:-42px;left:0;display:flex;align-items:center;gap:7px;background:#161616f7;border:1px solid var(--border-2);border-radius:999px;padding:6px 12px;font-size:11px;color:var(--text-dim);box-shadow:var(--shadow);z-index:11}.batch-split-bar select,.split-custom{background:var(--panel-3);border:1px solid var(--border);border-radius:6px;color:var(--text);font-size:11px;padding:3px 6px;font-family:var(--font)}.split-custom{width:56px;font-family:var(--mono)}.bn-head{display:flex;align-items:center;gap:7px;padding:10px 12px;border-bottom:1px solid var(--border)}.bn-icon{color:var(--green)}.bn-title{font-weight:700;font-size:13px;flex:1}.bn-meta{font-size:10.5px;color:var(--text-faint);font-family:var(--mono)}.bn-body{padding:8px 10px;display:flex;flex-direction:column;gap:6px}.bn-empty{font-size:11.5px;color:var(--text-dim);line-height:1.5;display:flex;flex-direction:column;gap:7px;align-items:flex-start}.bn-list{display:flex;flex-direction:column;gap:3px;max-height:210px;overflow-y:auto}.bn-item{display:flex;align-items:center;gap:7px;padding:4px 6px;border-radius:7px;cursor:pointer}.bn-item:hover{background:var(--panel-2)}.bn-item.hl{background:var(--green-bg);outline:1px solid var(--green-deep)}.bn-item img,.bn-thumb{width:30px;height:22px;border-radius:4px;object-fit:cover;flex-shrink:0}.bn-thumb{display:grid;place-items:center;background:var(--panel-3);font-size:10px;color:var(--text-dim)}.bn-label{flex:1;font-size:11px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.bn-src{font-size:9.5px;color:var(--text-faint)}.bn-del{color:var(--text-faint);font-size:10px}.bn-del:hover{color:var(--red)}.bn-foot{display:flex;align-items:center;gap:6px;padding:0 10px 8px}.bn-quick{position:absolute;bottom:36px;right:0;background:var(--panel);border:1px solid var(--border-2);border-radius:10px;padding:4px;display:flex;flex-direction:column;z-index:30;box-shadow:var(--shadow)}.bn-quick button{padding:6px 16px;font-size:12px;color:var(--text-dim);text-align:left;border-radius:6px}.bn-quick button:hover{background:var(--panel-3);color:var(--text)}.doc-node{width:320px;background:var(--panel);border:1px solid var(--border-2);border-radius:var(--radius);box-shadow:var(--shadow)}.doc-node.selected{border-color:var(--blue)}.doc-head{display:flex;align-items:center;gap:7px;padding:10px 12px;border-bottom:1px solid var(--border)}.doc-icon{color:var(--blue)}.doc-title{font-weight:700;font-size:12.5px;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.doc-pages{font-size:10.5px;color:var(--text-faint);font-family:var(--mono)}.doc-card{padding:8px;display:flex;flex-direction:column;gap:7px}.doc-preview{position:relative;border-radius:9px;overflow:hidden;border:1px solid var(--border);cursor:zoom-in}.doc-preview img{width:100%;display:block}.doc-loading{position:absolute;bottom:6px;left:6px;font-size:10px;background:#000000a6;color:var(--text-dim);padding:2px 8px;border-radius:999px}.doc-carousel{display:flex;gap:5px;overflow-x:auto;padding-bottom:2px}.doc-thumb{flex-shrink:0;width:42px;height:56px;border-radius:5px;overflow:hidden;border:1.5px solid var(--border);cursor:grab}.doc-thumb img{width:100%;height:100%;object-fit:cover}.doc-thumb.on{border-color:var(--blue)}.doc-foot{font-size:10px;color:var(--text-faint);line-height:1.4}.doc-reader{width:min(1060px,94vw);height:min(760px,90vh);background:var(--panel);border:1px solid var(--border-2);border-radius:16px;display:flex;flex-direction:column;overflow:hidden}.dr-head{display:flex;align-items:center;gap:12px;padding:12px 16px;border-bottom:1px solid var(--border);font-size:13px}.dr-head span{color:var(--text-dim);font-size:11.5px}.dr-head .foot-icon{margin-left:auto}.dr-hint{color:var(--text-faint)!important}.dr-body{flex:1;display:grid;grid-template-columns:1.2fr 1fr;gap:12px;padding:12px 16px;min-height:0}.dr-page{overflow:auto;border-radius:10px;border:1px solid var(--border);background:#0f0f0f}.dr-page img{width:100%;display:block}.dr-text{overflow:auto;font-size:12.5px;line-height:1.7;color:var(--text-dim);-webkit-user-select:text;user-select:text;cursor:text;padding-right:6px;white-space:pre-wrap}.dr-nav{display:flex;gap:8px;justify-content:center;padding:10px;border-top:1px solid var(--border)}.dr-menu{position:fixed;z-index:400;background:var(--panel);border:1px solid var(--border-2);border-radius:10px;padding:4px;box-shadow:var(--shadow);display:flex;flex-direction:column}.dr-menu button{padding:7px 16px;font-size:12px;color:var(--text);text-align:left;border-radius:6px;display:flex;gap:10px;justify-content:space-between}.dr-menu button:hover{background:var(--panel-3)}.dr-menu kbd{color:var(--text-faint);font-size:10px;font-family:var(--mono)}.layer-node{width:300px;background:var(--panel);border:1px solid var(--border-2);border-radius:var(--radius);box-shadow:var(--shadow)}.layer-node.selected{border-color:#b78aff}.ln-head{display:flex;align-items:center;gap:7px;padding:10px 12px;border-bottom:1px solid var(--border)}.ln-icon{color:#b78aff}.ln-title{font-weight:700;font-size:13px;flex:1}.ln-body{padding:8px 10px;display:flex;flex-direction:column;gap:7px}.layer-editor{width:min(1100px,96vw);height:min(720px,92vh);background:var(--panel);border:1px solid var(--border-2);border-radius:16px;display:flex;flex-direction:column;overflow:hidden}.le-top{display:flex;align-items:center;gap:12px;padding:10px 14px;border-bottom:1px solid var(--border);font-size:13px;flex-wrap:wrap}.le-align{display:flex;gap:2px;border:1px solid var(--border);border-radius:8px;padding:2px}.le-align button{width:26px;height:24px;border-radius:5px;color:var(--text-dim);font-size:12px;display:grid;place-items:center}.le-align button:hover{background:var(--panel-3);color:var(--text)}.le-frame{display:flex;align-items:center;gap:5px;font-size:11.5px;color:var(--text-dim)}.le-frame input{width:58px;background:var(--panel-3);border:1px solid var(--border);border-radius:6px;color:var(--text);font-size:11px;padding:3px 6px;font-family:var(--mono)}.le-snap{display:flex;align-items:center;gap:5px;font-size:11.5px;color:var(--text-dim)}.le-snap input{accent-color:var(--green)}.le-main{flex:1;display:grid;grid-template-columns:250px 1fr;min-height:0}.le-panel{border-right:1px solid var(--border);overflow-y:auto;padding:10px;display:flex;flex-direction:column;gap:4px}.le-panel-title{font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-faint);padding:6px 2px 2px}.le-layer{display:flex;align-items:center;gap:4px;padding:4px;border-radius:8px;cursor:pointer;border:1px solid transparent}.le-layer:hover{background:var(--panel-2)}.le-layer.on{background:var(--panel-2);border-color:#6a4fae}.le-layer button{font-size:11px;width:22px}.le-name{flex:1;min-width:0;background:none;border:none;color:var(--text);font-size:11.5px;font-family:var(--font);outline:none}.le-layer img{width:30px;height:24px;object-fit:cover;border-radius:4px}.le-empty{font-size:11.5px;color:var(--text-dim);padding:8px 4px;line-height:1.5}.le-stage-wrap{display:grid;place-items:center;position:relative;background:#0e0e0e;overflow:auto}.le-stage{position:relative;background:#181818;background-image:repeating-conic-gradient(#1f1f1f,#1f1f1f 25%,#181818 0%,#181818 50%);background-size:22px 22px;outline:1px solid var(--border-2)}.le-obj{position:absolute;cursor:move}.le-obj img{width:100%;height:100%;object-fit:fill;display:block;pointer-events:none}.le-obj.sel{outline:1.5px solid #b78aff}.le-obj.locked{cursor:not-allowed}.le-handle{position:absolute;width:9px;height:9px;background:#fff;border:1.5px solid #8a6ae0;border-radius:2px;z-index:5}.le-handle.nw{left:-5px;top:-5px;cursor:nwse-resize}.le-handle.ne{right:-5px;top:-5px;cursor:nesw-resize}.le-handle.sw{left:-5px;bottom:-5px;cursor:nesw-resize}.le-handle.se{right:-5px;bottom:-5px;cursor:nwse-resize}.le-handle.n{left:calc(50% - 4px);top:-5px;cursor:ns-resize}.le-handle.s{left:calc(50% - 4px);bottom:-5px;cursor:ns-resize}.le-handle.w{left:-5px;top:calc(50% - 4px);cursor:ew-resize}.le-handle.e{right:-5px;top:calc(50% - 4px);cursor:ew-resize}.le-rotzone{position:absolute;width:16px;height:16px;z-index:4;cursor:crosshair}.le-rotzone.nw{left:-18px;top:-18px}.le-rotzone.ne{right:-18px;top:-18px}.le-rotzone.sw{left:-18px;bottom:-18px}.le-rotzone.se{right:-18px;bottom:-18px}.le-stagemeta{position:absolute;bottom:8px;left:0;right:0;text-align:center;font-size:10.5px;color:var(--text-faint);font-family:var(--mono);pointer-events:none}.router-node{width:190px;background:var(--panel);border:1px solid var(--border-2);border-radius:12px;box-shadow:var(--shadow);padding:10px 12px;position:relative}.router-node.selected{border-color:var(--green)}.router-head{display:flex;align-items:center;gap:7px}.router-icon{color:var(--green)}.router-label{font-weight:700;font-size:13px;cursor:text}.router-label-input{background:var(--panel-3);border:1px solid var(--border);border-radius:6px;color:var(--text);font-size:12.5px;padding:2px 6px;width:110px;font-family:var(--font);outline:none}.router-modality{font-size:11px;color:var(--text-dim);margin-top:3px;font-family:var(--mono)}.router-count{color:var(--text-faint)}.router-thumb{margin-top:7px;border-radius:7px;overflow:hidden;border:1px solid var(--border)}.router-thumb img{width:100%;height:64px;object-fit:cover;display:block}.router-hint{font-size:10.5px;color:var(--text-faint);margin-top:6px;line-height:1.45}.router-out-state{position:absolute;right:-7px;top:calc(50% - 8px);width:16px;height:16px;border-radius:50%;display:grid;place-items:center;font-size:11px;pointer-events:none;z-index:5}.router-out-state.empty{border:1.5px solid var(--border-2);background:var(--panel)}.router-out-state.ready{border:1.5px solid var(--green);background:var(--panel);color:var(--green)}.router-out-state.filled{border:1.5px solid var(--green);background:var(--green)}.export-node{width:290px;background:var(--panel);border:1.5px solid #8a6f2e;border-radius:var(--radius);box-shadow:0 0 0 1px #e8b7651a,var(--shadow)}.export-node.selected{border-color:var(--amber)}.export-head{display:flex;align-items:center;gap:7px;padding:10px 12px;border-bottom:1px solid var(--border)}.export-icon{color:var(--amber);font-size:14px}.export-empty{padding:18px 14px;font-size:12px;color:var(--text-dim);text-align:center;line-height:1.5}.export-body{padding:10px 12px;display:flex;flex-direction:column;gap:7px;align-items:flex-start}.export-count{font-size:11px;color:var(--text-dim);font-family:var(--mono)}.fmt-menu{position:absolute;top:30px;left:0;z-index:40;width:260px;background:var(--panel);border:1px solid var(--border-2);border-radius:10px;padding:4px;box-shadow:var(--shadow)}.fmt-menu button{display:flex;align-items:baseline;gap:7px;width:100%;padding:7px 9px;border-radius:6px;text-align:left}.fmt-menu button:hover{background:var(--panel-3)}.fmt-menu kbd{font-size:9.5px;color:var(--text-faint);border:1px solid var(--border);border-radius:4px;padding:0 4px;font-family:var(--mono)}.fmt-menu b{font-size:12px}.fmt-menu span{font-size:10px;color:var(--text-dim)}.drive-connect{margin:4px 12px 12px;padding:8px 12px;border-radius:9px;background:#2a2113;border:1px solid #6b5526;color:var(--amber);font-size:12px;font-weight:700;width:calc(100% - 24px)}.drive-connect:hover{filter:brightness(1.2)}.export-drive{display:flex;align-items:center;gap:8px;padding:4px 12px 12px}.drive-badge{font-size:11px;color:var(--amber);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:130px}.export-menu-wrap{position:relative;margin-left:auto}.export-menu{position:absolute;right:0;top:26px;z-index:40;width:190px;background:var(--panel);border:1px solid var(--border-2);border-radius:10px;padding:4px;box-shadow:var(--shadow)}.export-menu button{width:100%;padding:7px 10px;font-size:12px;color:var(--text);text-align:left;border-radius:6px}.export-menu button:hover{background:var(--panel-3)}.em-acct{font-size:10px;color:var(--text-faint);padding:5px 10px;border-bottom:1px solid var(--border);margin-bottom:3px}.export-progress{margin:0 12px 12px}.drive-picker{width:min(440px,92vw);background:var(--panel);border:1px solid var(--border-2);border-radius:14px;overflow:hidden}.drive-head{display:flex;justify-content:space-between;align-items:center;padding:13px 16px;border-bottom:1px solid var(--border);font-size:13.5px}.drive-acct{font-size:11px;color:var(--text-faint)}.drive-tabs{display:flex;gap:4px;padding:9px 14px 0}.drive-tabs button{padding:6px 14px;border-radius:8px 8px 0 0;font-size:12px;color:var(--text-dim);border-bottom:2px solid transparent}.drive-tabs button.on{color:var(--text);border-bottom-color:var(--amber)}.drive-crumbs{display:flex;align-items:center;gap:5px;padding:9px 16px 2px;font-size:11.5px;color:var(--text-faint)}.drive-crumbs button{color:var(--text-dim)}.drive-crumbs button:hover{color:var(--text)}.drive-list{padding:8px 12px;min-height:160px;max-height:240px;overflow-y:auto;display:flex;flex-direction:column;gap:2px}.drive-folder{padding:8px 10px;border-radius:8px;font-size:12.5px;color:var(--text);text-align:left}.drive-folder:hover{background:var(--panel-3)}.drive-empty{padding:14px;font-size:12px;color:var(--text-faint)}.drive-foot{display:flex;justify-content:flex-end;gap:8px;padding:11px 16px;border-top:1px solid var(--border)}.fs-view{width:min(1240px,97vw);height:min(800px,94vh);background:var(--panel);border:1px solid var(--border-2);border-radius:16px;display:flex;flex-direction:column;overflow:hidden}.fs-top{display:flex;align-items:center;gap:14px;padding:12px 16px;border-bottom:1px solid var(--border)}.fs-layouts{display:flex;border:1px solid var(--border-2);border-radius:999px;overflow:hidden}.fs-layouts button{padding:4px 16px;font-size:12px;color:var(--text-dim)}.fs-layouts button.on{background:var(--green-bg);color:var(--green)}.fs-count{font-size:11.5px;color:var(--text-faint);font-family:var(--mono)}.fs-top .foot-icon{margin-left:auto}.fs-single{flex:1;display:grid;grid-template-columns:1fr 280px;min-height:0}.fs-stage{display:grid;place-items:center;background:#0e0e0e;overflow:hidden}.fs-stage img,.fs-stage video{max-width:100%;max-height:100%}.fs-meta{border-left:1px solid var(--border);padding:14px;display:flex;flex-direction:column;gap:10px;overflow-y:auto;font-size:12px}.fs-meta-title{font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-faint)}.fs-pair{font-size:11.5px;color:var(--text-dim)}.fs-pair em{font-style:normal;color:var(--text)}.fs-prompt{color:var(--text-dim);line-height:1.5}.fs-recipe{font-family:var(--mono);font-size:10.5px;color:var(--text-faint)}.fs-nav{display:flex;align-items:center;gap:10px;margin-top:auto}.fs-masonry{flex:1;overflow-y:auto;padding:14px;display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:10px;align-content:start}.fs-cell{border-radius:10px;overflow:hidden;border:1px solid var(--border);aspect-ratio:16/10;background:#0e0e0e}.fs-cell:hover{border-color:var(--green)}.fs-cell img,.fs-cell video{width:100%;height:100%;object-fit:cover}.fs-text{font-size:11px;color:var(--text-dim);padding:10px;text-align:left;overflow:hidden}.fs-matrix-wrap{flex:1;overflow:auto;padding:12px}.fs-matrix{border-collapse:separate;border-spacing:6px}.fs-matrix th{position:sticky;background:var(--panel);z-index:3}.fs-matrix thead th{top:0}.fs-matrix tbody th{left:0}.fs-corner{z-index:4!important;font-size:10px;color:var(--text-faint)}.fs-colhead img,.fs-rowhead img{width:72px;height:48px;object-fit:cover;border-radius:7px;border:1px solid var(--border-2)}.fs-htext{display:inline-block;max-width:90px;font-size:10px;color:var(--text-dim);font-weight:400}.fs-mcell{padding:0}.fs-mcell-in{position:relative;width:168px;height:104px;border-radius:8px;overflow:hidden;border:1px solid var(--border);cursor:pointer;background:#0e0e0e}.fs-mcell-in:hover{border-color:var(--green)}.fs-mcell-in img,.fs-mcell-in video{width:100%;height:100%;object-fit:cover}.fs-hover{position:absolute;inset:auto 0 0 0;display:none;align-items:center;justify-content:space-between;padding:4px 6px;background:#0009}.fs-mcell-in:hover .fs-hover{display:flex}.fs-srcs img{width:26px;height:20px;border-radius:3px;margin-right:3px}.fs-pending{display:grid;place-items:center;width:100%;height:100%}.global-toast{z-index:500}.landing{height:100%;display:flex;flex-direction:column;overflow:hidden auto;background:radial-gradient(900px 500px at 80% -10%,rgba(52,210,123,.1),transparent 60%),radial-gradient(700px 420px at 8% 110%,rgba(106,167,255,.07),transparent 60%),var(--bg)}.landing-nav{display:flex;align-items:center;justify-content:space-between;padding:22px 44px}.landing-logo{font-weight:700;font-size:17px;letter-spacing:.2px}.landing-logo:first-letter{color:var(--green)}.landing-nav nav{display:flex;gap:10px;align-items:center}.landing-nav nav button{color:var(--text-dim);font-size:14px;padding:9px 16px;border-radius:99px}.landing-nav nav button:hover{color:var(--text)}.landing-cta{background:var(--green)!important;color:#06180e!important;font-weight:600;border-radius:99px;padding:9px 18px!important}.landing-cta:hover{filter:brightness(1.08)}.landing-cta.big{font-size:16px;padding:14px 30px!important}.landing-hero{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:24px;gap:22px}.landing-badge{font-family:var(--mono);font-size:11px;color:var(--green);border:1px solid var(--green-deep);background:var(--green-bg);padding:6px 14px;border-radius:99px;letter-spacing:.4px}.landing-hero h1{font-size:clamp(38px,5.5vw,64px);line-height:1.06;margin:0;letter-spacing:-1.5px}.landing-hero>p{max-width:560px;color:var(--text-dim);font-size:16px;line-height:1.6;margin:0}.landing-hero-img{width:100%;max-width:960px;margin:32px auto 0;border-radius:16px;overflow:hidden;border:1px solid var(--border);box-shadow:0 24px 80px #00000073,0 0 0 1px #ffffff0a inset}.landing-hero-img img{width:100%;display:block}.landing-preview{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;margin-top:14px}.landing-chip{font-size:12.5px;color:var(--text-dim);border:1px solid var(--border);background:var(--panel);padding:8px 14px;border-radius:99px}.landing-foot{text-align:center;color:var(--text-faint);font-size:12px;padding:26px}.login-split{display:flex;height:100%}.login-art{flex:1;position:relative;display:flex;align-items:flex-end;padding:48px;background:url(/thumbnails/login-art.webp) center / cover no-repeat,radial-gradient(800px 600px at 20% 20%,rgba(52,210,123,.22),transparent 55%),radial-gradient(700px 700px at 85% 75%,rgba(106,167,255,.16),transparent 55%),radial-gradient(500px 400px at 60% 40%,rgba(232,183,101,.1),transparent 60%),linear-gradient(160deg,#0d1410,#0a0a0a 70%)}.login-art:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background:linear-gradient(to top,rgba(10,10,10,.82),transparent 55%)}.login-back{position:absolute;top:26px;left:28px;z-index:2;color:var(--text-dim);font-size:13px;padding:8px 14px;border-radius:99px;border:1px solid rgba(255,255,255,.14);background:#0a0a0a73;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.login-back:hover{color:var(--text)}.login-art-copy{position:relative;z-index:1;max-width:460px;display:grid;gap:14px}.login-art-copy h2{font-size:34px;margin:0;letter-spacing:-.8px;line-height:1.1}.login-art-copy p{color:var(--text-dim);line-height:1.6;margin:0}.login-form{flex:1;display:flex;align-items:center;justify-content:center;background:var(--bg);border-left:1px solid var(--border);overflow-y:auto;padding:32px}@media (max-width: 900px){.login-split{flex-direction:column}.login-art{min-height:38vh;flex:none}}.auth{min-height:100vh;display:flex;flex-direction:column;background:#212126;color:#fff}.auth-bar{display:flex;align-items:center;justify-content:space-between;padding:20px 32px;flex-shrink:0}.auth-brand{display:flex;align-items:center;gap:8px;color:#fff;text-decoration:none;font-weight:600;font-size:15px}.auth-mark{flex-shrink:0}.auth-nav-link{color:#71717a;font-size:14px;font-weight:500;text-decoration:none;transition:color .15s}.auth-nav-link:hover{color:#fff}.auth-grid{flex:1;display:flex;min-height:0}.auth-pane{display:flex;align-items:center;justify-content:center}.auth-pane--form{flex:1;padding:40px}.auth-pane--showcase{flex:none;width:45%;padding:16px}.auth-panel-img{width:100%;height:100%;border-radius:25px;overflow:hidden;background:url(/thumbnails/login-art.webp) center / cover no-repeat;background-color:#18191c}.auth-form-wrap{width:100%;max-width:380px;margin:0 auto}.auth-title{font-size:32px;font-weight:300;letter-spacing:-.02em;line-height:1.15;margin:0 0 8px;color:#fff}.auth-sub{color:#9b9b9b;font-size:14px;line-height:1.5;margin:0 0 24px}@media (max-width: 768px){.auth-pane--showcase{display:none}.auth-pane--form{padding:32px 24px}}@media (max-width: 600px){.auth-bar{padding:14px 16px}.auth-pane--form{padding:24px 16px}}.tin-row{display:flex;align-items:center;gap:6px;padding:4px 8px;border-radius:6px;position:relative;font-size:11px}.tin-row.filled{background:#34d27b14}.tin-icon{font-size:13px;opacity:.7;width:16px;text-align:center}.tin-name{flex:1}.tin-thumb{width:28px;height:28px;object-fit:cover;border-radius:4px}.tin-preset{filter:grayscale(1)}.technique-cost-chip{font-size:10px;background:#34d27b26;color:var(--accent,#34D27B);padding:1px 6px;border-radius:8px;margin-left:auto}.technique-edit-btn{background:none;border:none;color:var(--text-faint);cursor:pointer;font-size:14px;padding:0 4px;opacity:0;transition:opacity .15s}.technique-label:hover .technique-edit-btn{opacity:.8}.technique-edit-btn:hover{color:var(--green);opacity:1!important}.technique-detach{background:none;border:none;color:var(--text-dim);cursor:pointer;font-size:14px;padding:0 4px;opacity:.6}.technique-detach:hover{opacity:1}.technique-menu-btn{background:none;border:none;color:var(--text-dim);cursor:pointer;font-size:16px;padding:0 4px;line-height:1}.technique-menu-btn:hover{color:var(--text)}.technique-context-menu{position:absolute;top:100%;right:0;z-index:100;background:var(--panel-2);border:1px solid var(--border);border-radius:var(--radius-sm);min-width:180px;box-shadow:0 8px 24px #0006;padding:4px 0}.technique-context-menu button{display:block;width:100%;text-align:left;padding:6px 12px;background:none;border:none;color:var(--text);cursor:pointer;font-size:12px;white-space:nowrap}.technique-context-menu button:hover{background:#34d27b14}.technique-context-menu hr{border:none;border-top:1px solid var(--border);margin:4px 0}.technique-outputs .tin-icon{font-size:11px}.tout-row{display:flex;align-items:center;gap:6px;padding:2px 8px;font-size:11px;position:relative}.tin-actions{display:flex;gap:4px;margin-left:auto;align-items:center}.tin-action{background:none;border:1px solid var(--border);border-radius:4px;padding:1px 5px;font-size:11px;color:var(--text-dim);cursor:pointer;line-height:1.2}.tin-action:hover{border-color:var(--green);color:var(--green)}.tin-thumb.tin-preset:hover{opacity:.65!important}.technique-preset-all{background:#34d27b1a;border:1px solid rgba(52,210,123,.3);border-radius:var(--radius-sm);padding:3px 10px;font-size:11px;color:var(--green);cursor:pointer;margin-top:4px;width:100%}.technique-preset-all:hover{background:#34d27b33}.tin-batch-badge{font-size:10px;padding:1px 6px;border-radius:4px;background:#6aa7ff1f;color:#6aa7ff;margin-left:auto;font-weight:500}.technique-batch-mult{font-size:9px;opacity:.7}.build-tech-btn{position:fixed;bottom:16px;left:50%;transform:translate(-50%);background:var(--panel);border:1px solid var(--border);color:var(--text);padding:8px 20px;border-radius:10px;cursor:pointer;font-size:12px;z-index:50;transition:background .15s}.build-tech-btn:hover{background:var(--panel-2)}.tech-builder{position:fixed;top:56px;right:12px;bottom:12px;width:320px;max-width:92vw;background:var(--panel);border:1px solid var(--border);border-radius:12px;z-index:120;display:flex;flex-direction:column;overflow-y:auto;padding:16px;gap:12px;font-size:12px}.tb-header{display:flex;justify-content:space-between;align-items:center;font-weight:600;font-size:14px}.tb-step{display:flex;flex-direction:column;gap:10px}.tb-step-title{font-weight:600;font-size:13px;color:var(--accent,#34D27B)}.tb-hint{color:var(--text-dim);font-size:11px;margin:0}.tb-card{background:var(--panel-2);border:1px solid var(--border);border-radius:8px;padding:10px;display:flex;flex-direction:column;gap:6px}.tb-card-head{display:flex;align-items:center;gap:6px}.tb-card-kind{font-size:10px;text-transform:uppercase;color:var(--text-dim);flex:1}.tb-input{background:#ffffff0f;border:1px solid var(--border);border-radius:6px;padding:6px 8px;font-size:11px;color:var(--text);resize:none}.tb-input:focus{outline:none;border-color:var(--accent,#34D27B)}.tb-thumb{width:100%;max-height:80px;object-fit:cover;border-radius:6px}.tb-primary{background:var(--accent,#34D27B);color:#0a0a0a;border:none;padding:8px 16px;border-radius:8px;cursor:pointer;font-weight:600;font-size:12px}.tb-primary:hover{filter:brightness(1.1)}.tb-secondary{background:none;border:1px solid var(--border);color:var(--text-dim);padding:6px 12px;border-radius:8px;cursor:pointer;font-size:11px}.tb-empty{color:var(--text-dim);font-style:italic;text-align:center;padding:16px}.tb-errors{display:flex;flex-direction:column;gap:4px}.tb-error{color:#e5484d;font-size:11px;background:#e5484d14;padding:4px 8px;border-radius:6px}.tb-meta-row{display:flex;gap:12px;font-size:11px;color:var(--text-dim);padding:4px 0}.tb-tags{display:flex;flex-wrap:wrap;gap:4px;align-items:center}.tb-tag{background:#ffffff14;padding:2px 8px;border-radius:10px;font-size:11px;display:flex;align-items:center;gap:4px}.tb-tag button{background:none;border:none;color:var(--text-dim);cursor:pointer;font-size:10px;padding:0}.tb-tag-input{background:none;border:none;color:var(--text);font-size:11px;width:80px;outline:none}.tb-step-workflow{background:#34d27b0f;border:1px dashed var(--green-deep);border-radius:8px;padding:10px 12px;display:flex;flex-direction:column;gap:6px}@keyframes eligible-pulse{0%,to{outline-color:#ffffff26}50%{outline-color:#ffffff73}}.tb-pick-input{outline:2px solid var(--accent,#34D27B)!important;outline-offset:2px;box-shadow:0 0 0 4px #34d27b2e!important}.tb-pick-output{outline:2px solid var(--amber,#e8b765)!important;outline-offset:2px;box-shadow:0 0 0 4px #e8b7652e!important}.tb-eligible{outline:1px dashed rgba(255,255,255,.2)!important;outline-offset:2px;animation:eligible-pulse 1.6s ease-in-out infinite}.tech-lib{display:flex;flex-direction:column;gap:12px}.tech-lib-toolbar{display:flex;gap:8px;margin-bottom:12px}.tech-lib-search{background:#ffffff0f;border:1px solid var(--border);border-radius:8px;padding:8px 12px;font-size:12px;color:var(--text);width:100%}.tech-lib-search:focus{outline:none;border-color:var(--accent,#34D27B)}.tech-lib-cats{display:flex;flex-wrap:wrap;gap:6px}.tech-lib-cat{background:#ffffff0f;border:1px solid var(--border);padding:3px 10px;border-radius:12px;font-size:11px;cursor:pointer;color:var(--text-dim)}.tech-lib-cat.active{background:var(--accent,#34D27B);color:#0a0a0a;border-color:var(--accent,#34D27B)}.tech-lib-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px}.tech-card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px}.tech-card{background:var(--panel-2);border:1px solid var(--border);border-radius:10px;padding:12px;cursor:pointer;display:flex;flex-direction:column;gap:8px;transition:border-color .15s}.tech-card:hover{border-color:var(--accent,#34D27B)}.tech-card-thumb{width:100%;aspect-ratio:16 / 9;object-fit:cover;border-radius:6px;background:linear-gradient(135deg,var(--panel-3) 0%,var(--panel-2) 100%)}.tech-card-name{font-weight:600;font-size:13px}.tech-card-desc{font-size:11px;color:var(--text-dim)}.tech-card-meta{display:flex;gap:8px;font-size:10px;color:var(--text-dim)}.tech-card-actions{display:flex;gap:6px;margin-top:auto}.tech-picker{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:#161616e0;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--border);border-radius:14px;z-index:200;width:440px;max-width:92vw;max-height:60vh;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:12px;box-shadow:var(--shadow)}.tech-picker-header{display:flex;justify-content:space-between;align-items:center;font-weight:600}.tech-picker .tech-lib-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}.tech-detail{padding:0}.tech-detail-back{background:none;border:none;color:var(--text-dim);cursor:pointer;font-size:13px;padding:0 0 16px;display:flex;align-items:center;gap:4px}.tech-detail-back:hover{color:var(--text)}.tech-detail-header{display:flex;gap:24px;margin-bottom:28px;align-items:flex-start}.tech-detail-hero{width:260px;min-height:170px;border-radius:var(--radius);object-fit:cover;flex-shrink:0;background:var(--panel-2)}.tech-detail-info{flex:1;min-width:0}.tech-detail-title{font-size:20px;font-weight:600;color:var(--text);margin:0 0 6px}.tech-detail-cat{display:inline-block;font-size:11px;padding:2px 8px;background:#34d27b1a;color:var(--green);border-radius:4px;margin-bottom:8px}.tech-detail-desc{font-size:13px;color:var(--text-dim);margin:0 0 12px;line-height:1.55}.tech-detail-stats{display:flex;gap:16px;font-size:12px;color:var(--text-dim);margin-bottom:8px;flex-wrap:wrap}.tech-detail-cost{color:var(--green);font-weight:600}.tech-detail-tags{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:12px}.tech-detail-tag{font-size:10px;padding:2px 8px;border-radius:4px;background:var(--panel-3);color:var(--text-dim)}.tech-detail-actions{display:flex;gap:8px;margin-top:12px;flex-wrap:wrap}.tech-detail-sections{border-top:1px solid var(--border);padding-top:20px}.tech-detail-section{margin-bottom:24px}.tech-detail-section h3{font-size:13px;font-weight:600;color:var(--text);margin:0 0 10px;text-transform:uppercase;letter-spacing:.04em}.tech-detail-io-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px}.tech-detail-io-card{background:var(--panel-2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px;text-align:center}.tech-detail-io-icon{font-size:20px;margin-bottom:4px}.tech-detail-io-name{font-size:12px;font-weight:500;color:var(--text);margin-bottom:2px}.tech-detail-io-desc{font-size:10px;color:var(--text-dim);margin-bottom:4px}.tech-detail-io-kind{font-size:10px;color:var(--text-faint);text-transform:uppercase;letter-spacing:.04em}.tech-detail-io-editable{font-size:9px;color:var(--green);margin-top:4px}.tech-detail-io-thumb{width:100%;max-height:80px;object-fit:cover;border-radius:4px;margin-top:6px}.tech-detail-workflow-summary{display:flex;gap:16px;align-items:center;font-size:12px;color:var(--text-dim);flex-wrap:wrap}.tech-featured{margin-bottom:20px}.tech-featured-title{font-size:13px;font-weight:600;color:var(--text);margin:0 0 10px}.tech-featured-scroll{display:flex;gap:12px;overflow-x:auto;padding-bottom:8px;scrollbar-width:thin;scrollbar-color:var(--border) transparent}.tech-featured-card{flex:0 0 170px;cursor:pointer;border-radius:var(--radius-sm);overflow:hidden;background:var(--panel-2);border:1px solid var(--border);transition:border-color .15s}.tech-featured-card:hover{border-color:var(--green)}.tech-featured-thumb{width:100%;height:96px;object-fit:cover;display:block}.tech-featured-name{font-size:12px;font-weight:500;padding:6px 8px 2px;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tech-featured-meta{font-size:10px;padding:0 8px 6px;color:var(--text-dim)}.btn-secondary{background:var(--panel-3);border:1px solid var(--border);color:var(--text-dim);border-radius:var(--radius-sm);padding:4px 12px;font-size:11px;cursor:pointer}.btn-sm.btn-secondary{background:var(--panel-3);border-color:var(--border);color:var(--text-dim)}.btn-sm.btn-secondary:hover{border-color:var(--text-dim);color:var(--text)}.wf-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:#000000d9;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center}.wf-overlay-panel{width:min(1100px,92vw);height:min(720px,88vh);background:var(--panel);border:1px solid var(--border-2);border-radius:18px;box-shadow:var(--shadow);display:flex;flex-direction:column;overflow:hidden;animation:pop .16s ease-out}.wf-overlay-header{padding:14px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:10px;flex-shrink:0}.wf-overlay-canvas{flex:1;min-height:0;background:#0e0e0e}.wf-overlay-footer{padding:10px 20px;border-top:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;flex-shrink:0}.wf-category-badge{font-size:10px;padding:2px 8px;border-radius:10px;background:#ffffff12;border:1px solid var(--border);color:var(--text-dim)}.wf-node{background:var(--panel-2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:8px 12px;display:flex;gap:8px;align-items:flex-start;min-width:160px;max-width:220px;font-size:12px}.wf-action{background:#8b5cf626;border-color:#8b5cf666}.wf-input{border-left:3px solid var(--green)}.wf-output{border-right:3px solid #f59e0b}.wf-node-icon{font-size:18px;flex-shrink:0;line-height:1.2}.wf-node-body{display:flex;flex-direction:column;gap:2px;min-width:0}.wf-node-label{font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:140px}.wf-node-kind{font-size:10px;color:var(--text-faint);text-transform:uppercase;letter-spacing:.04em}.wf-badge{font-size:9px;padding:1px 6px;border-radius:4px;font-weight:600;margin-top:4px;display:inline-block}.wf-badge-input{background:#34d27b26;color:var(--green)}.wf-badge-output{background:#f59e0b26;color:#f59e0b}.technique-view-btn{background:none;border:none;color:var(--text-dim);cursor:pointer;font-size:14px;padding:0 4px;opacity:.6}.technique-view-btn:hover{opacity:1;color:var(--green)}.technique-override-gear{background:none;border:none;color:var(--text-faint);cursor:pointer;font-size:13px;padding:0 3px;line-height:1;flex-shrink:0}.technique-override-gear:hover{color:var(--text)}.technique-override-gear.active{color:var(--green)}.technique-override-panel{position:absolute;right:calc(100% + 8px);top:0;background:var(--panel-2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px;min-width:190px;z-index:50;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:6px}.technique-override-row{display:flex;align-items:center;justify-content:space-between;gap:8px;font-size:11px;color:var(--text-dim)}.technique-override-row .node-select{flex:1;max-width:120px;font-size:11px;padding:3px 6px}.tb-toggle-row{display:flex;align-items:center;gap:7px;font-size:11px;color:var(--text-dim);cursor:pointer;padding:2px 0}.tb-toggle-row input[type=checkbox]{accent-color:var(--green);cursor:pointer}.tb-visibility{display:flex;flex-direction:column;gap:4px}.tb-vis-label{font-size:11px;font-weight:600;color:var(--text-dim)}.tb-vis-option{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--text);cursor:pointer;padding:2px 0}.tb-vis-option input[type=radio]{accent-color:var(--accent,#34D27B);cursor:pointer}.tb-vis-note{font-size:10px;color:var(--accent,#34D27B);background:#34d27b14;padding:4px 8px;border-radius:6px;margin-top:2px}.publish-success{background:var(--panel);border:1px solid var(--border-2);border-radius:18px;box-shadow:var(--shadow);max-width:400px;width:90%;padding:24px;display:flex;flex-direction:column;align-items:center;gap:14px;animation:pop .16s ease-out;text-align:center}.publish-success-thumb{width:100%;max-height:160px;object-fit:cover;border-radius:10px}.publish-success-name{font-size:16px;font-weight:700;color:var(--text)}.publish-success-msg{font-size:13px;color:var(--accent,#34D27B);font-weight:500}.publish-success-link{display:flex;align-items:center;gap:8px;background:#ffffff0f;border:1px solid var(--border);border-radius:8px;padding:8px 12px;font-size:12px;color:var(--text-dim);width:100%;justify-content:space-between}.publish-success-link span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.publish-success-copy{background:var(--accent,#34D27B);color:#0a0a0a;border:none;padding:4px 10px;border-radius:6px;cursor:pointer;font-size:11px;font-weight:600;white-space:nowrap}.publish-success-copy:hover{filter:brightness(1.1)}.publish-success-actions{display:flex;gap:10px;width:100%;justify-content:center;margin-top:4px}.technique-feedback{display:flex;align-items:center;gap:8px;padding:6px 8px;border-top:1px solid var(--border);margin-top:4px}.technique-feedback.rated{justify-content:center}.technique-feedback-label{font-size:11px;color:var(--text-dim);flex:1}.technique-feedback-btn{background:none;border:1px solid var(--border);border-radius:4px;padding:2px 8px;cursor:pointer;font-size:14px;transition:background .15s,border-color .15s}.technique-feedback-btn:hover{border-color:var(--green);background:#34d27b14}.node-feedback{display:flex;gap:4px;padding:2px 0;justify-content:flex-end}.node-feedback.rated{font-size:12px;opacity:.5;justify-content:flex-end}.node-feedback.rated.up{color:var(--green)}.node-feedback.rated.down{color:#e5484d}.node-feedback-btn{background:none;border:none;cursor:pointer;font-size:13px;opacity:.4;padding:2px;transition:opacity .15s}.node-feedback-btn:hover{opacity:1}.tech-card-rating{font-size:11px;color:var(--text-dim)}.app-mode{position:fixed;top:0;right:0;bottom:0;left:0;z-index:800;background:var(--bg);display:flex;flex-direction:column;overflow-y:auto}.app-mode-header{display:flex;align-items:center;padding:16px 24px;gap:16px;border-bottom:1px solid var(--border);flex-shrink:0;background:var(--panel)}.app-mode-back{background:none;border:none;color:var(--text-dim);cursor:pointer;font-size:14px;padding:4px 8px;border-radius:6px}.app-mode-back:hover{color:var(--text);background:var(--panel-2)}.app-mode-title{font-size:18px;font-weight:600;color:var(--text);flex:1}.app-mode-cost{font-size:14px;color:var(--green);font-weight:500;background:#34d27b1a;border:1px solid rgba(52,210,123,.25);border-radius:8px;padding:2px 10px}.app-mode-body{flex:1;max-width:800px;margin:0 auto;padding:32px 24px;width:100%}.app-mode-inputs{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px;margin-bottom:28px}.app-input-card{border:2px dashed var(--border);border-radius:var(--radius);padding:20px 16px;text-align:center;cursor:pointer;transition:border-color .2s,background .2s;min-height:160px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px}.app-input-card:hover{border-color:var(--green);background:#34d27b0a}.app-input-card.filled{border-style:solid;border-color:var(--green);cursor:default}.app-input-card.dragging{border-color:var(--green);background:#34d27b14}.app-input-card-name{font-size:13px;font-weight:500;color:var(--text)}.app-input-card-desc{font-size:11px;color:var(--text-dim)}.app-input-card-icon{font-size:28px;color:var(--text-faint)}.app-input-thumb{max-width:100%;max-height:120px;border-radius:var(--radius-sm);object-fit:cover}.app-input-preset{font-size:11px;color:var(--green);cursor:pointer;background:#34d27b1a;border:1px solid rgba(52,210,123,.3);border-radius:4px;padding:2px 8px;margin-top:4px}.app-input-preset:hover{background:#34d27b33}.app-run-btn{display:block;margin:0 auto 28px;padding:12px 40px;background:var(--green);color:#000;border:none;border-radius:var(--radius);font-size:15px;font-weight:600;cursor:pointer;transition:opacity .2s}.app-run-btn:disabled{opacity:.4;cursor:not-allowed}.app-run-btn:hover:not(:disabled){opacity:.88}.app-progress{text-align:center;margin-bottom:24px}.app-progress-bar{height:6px;background:var(--panel-3);border-radius:3px;overflow:hidden;margin:8px 0}.app-progress-fill{height:100%;background:var(--green);border-radius:3px;transition:width .4s ease}.app-progress-label{font-size:12px;color:var(--text-dim)}.app-results{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}.app-result-card{background:var(--panel-2);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.app-result-header{padding:10px 14px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--border)}.app-result-name{font-size:13px;font-weight:500;color:var(--text)}.app-result-download{font-size:11px;color:var(--green);cursor:pointer;background:none;border:none;text-decoration:none}.app-result-download:hover{text-decoration:underline}.app-result-body{padding:12px}.app-result-body img{width:100%;border-radius:var(--radius-sm);display:block}.app-result-body video{width:100%;border-radius:var(--radius-sm);display:block}.app-result-body pre{white-space:pre-wrap;font-size:12px;color:var(--text);font-family:var(--mono);max-height:300px;overflow-y:auto;margin:0;line-height:1.5}.app-error{text-align:center;color:#e5484d;padding:20px;background:#e5484d14;border:1px solid rgba(229,72,77,.2);border-radius:var(--radius);margin-bottom:24px}.error-boundary{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:var(--bg, #0d0d0d);z-index:9999}.error-boundary-card{background:var(--panel, #1a1a1a);border:1px solid var(--border, #333);border-radius:14px;padding:32px 40px;max-width:440px;text-align:center;box-shadow:0 16px 48px #00000080}.error-boundary-card h2{font-size:18px;color:#e5e5e5;margin:0 0 8px}.error-boundary-msg{font-size:13px;color:#999;margin:0 0 20px;line-height:1.5}.error-boundary-actions{display:flex;gap:8px;justify-content:center;flex-wrap:wrap}.error-boundary-actions button{padding:8px 18px;border-radius:8px;border:1px solid #333;background:#1a1a1a;color:#e5e5e5;cursor:pointer;font-size:13px}.error-boundary-actions button:hover{border-color:#555}.error-boundary-actions button.danger{color:#e5484d;border-color:#e5484d4d}.error-boundary-actions button.danger:hover{background:#e5484d14}.error-boundary-details{margin-top:16px;text-align:left}.error-boundary-details summary{font-size:11px;color:#666;cursor:pointer}.error-boundary-details pre{font-size:10px;color:#777;overflow-x:auto;max-height:200px;margin-top:8px;white-space:pre-wrap}.shortcuts-panel{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);max-width:480px;width:90vw;max-height:70vh;overflow-y:auto;padding:20px 24px;box-shadow:0 16px 48px #00000080}.shortcuts-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.shortcuts-header h2{font-size:16px;color:var(--text);margin:0}.shortcuts-category{margin-bottom:16px}.shortcuts-category h3{font-size:12px;color:var(--text-faint);text-transform:uppercase;margin:0 0 8px;letter-spacing:.5px}.shortcut-row{display:flex;justify-content:space-between;align-items:center;padding:4px 0}.shortcut-keys{display:flex;gap:4px}.shortcut-keys kbd{background:var(--panel-3);border:1px solid var(--border);border-radius:4px;padding:2px 7px;font-size:11px;color:var(--text-dim);font-family:inherit;min-width:22px;text-align:center}.shortcut-desc{font-size:12px;color:var(--text-dim)}.onboarding-hint{position:fixed;bottom:80px;left:50%;transform:translate(-50%);z-index:500;background:var(--panel);border:1px solid var(--green);border-radius:var(--radius);padding:16px 24px;box-shadow:0 8px 32px #0006;max-width:360px;text-align:center}.onboarding-content h3{font-size:15px;color:var(--text);margin:0 0 6px}.onboarding-content p{font-size:12px;color:var(--text-dim);margin:0 0 10px;line-height:1.5}.onboarding-shortcuts{display:flex;gap:16px;justify-content:center;margin-bottom:12px;font-size:11px;color:var(--text-dim)}.onboarding-shortcuts kbd{background:var(--panel-3);border:1px solid var(--border);border-radius:3px;padding:1px 5px;font-size:10px}.btn-sm.btn-green{background:var(--green);color:#000;border:none;border-radius:var(--radius-sm);padding:6px 18px;font-size:12px;font-weight:600;cursor:pointer}.btn-sm.btn-green:hover{filter:brightness(1.1)}.tool-btn.active{background:var(--panel-3);color:var(--green)}.share-modal{background:var(--panel);border:1px solid var(--border);border-radius:16px;width:440px;max-width:92vw;padding:0;box-shadow:var(--shadow);animation:fade .12s}.share-header{display:flex;align-items:center;justify-content:space-between;padding:18px 20px 12px}.share-header h3{font-size:15px;font-weight:700;margin:0;color:var(--text)}.share-invite{padding:0 20px 14px}.share-inputs{display:flex;gap:8px;margin-bottom:10px}.share-name-input,.share-email-input{flex:1;padding:8px 10px;border-radius:8px;font-size:12.5px;background:var(--panel-2);border:1px solid var(--border);color:var(--text)}.share-name-input{max-width:110px}.share-role-select{padding:6px 8px;border-radius:8px;font-size:12px;background:var(--panel-2);border:1px solid var(--border);color:var(--text)}.share-role-select.small{padding:3px 6px;font-size:11px}.share-divider{height:1px;background:var(--border);margin:0 20px}.share-people{padding:14px 20px;max-height:260px;overflow-y:auto}.share-section-label{font-size:11px;color:var(--text-faint);text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px}.share-person{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid rgba(255,255,255,.04)}.share-person:last-child{border-bottom:none}.share-avatar{width:32px;height:32px;border-radius:50%;display:grid;place-items:center;font-weight:700;font-size:13px;color:#fff;background:#555;flex-shrink:0}.share-avatar.owner-avatar{background:#7a4a2c}.share-person-info{flex:1;min-width:0}.share-person-name{display:block;font-size:13px;font-weight:600;color:var(--text)}.share-person-email{display:block;font-size:11px;color:var(--text-faint);overflow:hidden;text-overflow:ellipsis}.share-role-badge{font-size:11px;padding:2px 8px;border-radius:6px;background:var(--panel-3);color:var(--text-dim)}.share-role-badge.owner{color:var(--green);background:var(--green-bg)}.share-remove{font-size:13px;color:var(--text-faint);opacity:.5}.share-remove:hover{opacity:1;color:#e06060}.share-empty{font-size:12px;color:var(--text-faint);padding:12px 0}.share-footer{display:flex;justify-content:space-between;padding:14px 20px}.comments-panel{position:absolute;left:62px;top:80px;bottom:80px;width:320px;z-index:35;background:var(--panel);border:1px solid var(--border);border-radius:14px;display:flex;flex-direction:column;box-shadow:var(--shadow);animation:slideInLeft .15s ease-out}@keyframes slideInLeft{0%{opacity:0;transform:translate(-12px)}}.comments-header{display:flex;align-items:center;gap:10px;padding:14px 16px 10px;border-bottom:1px solid var(--border)}.comments-header h3{font-size:14px;font-weight:700;margin:0;color:var(--text);flex:1}.comments-counts{display:flex;gap:8px;font-size:11px}.comment-count-open{color:var(--green)}.comment-count-resolved{color:var(--text-faint)}.comments-filter{display:flex;gap:2px;padding:8px 12px;border-bottom:1px solid var(--border)}.filter-btn{padding:4px 10px;border-radius:6px;font-size:11.5px;font-weight:600;color:var(--text-dim);background:none;border:none;cursor:pointer}.filter-btn:hover{background:var(--panel-3)}.filter-btn.active{background:var(--panel-3);color:var(--text)}.comments-list{flex:1;overflow-y:auto;padding:8px 12px}.comments-empty{color:var(--text-faint);font-size:12px;text-align:center;padding:32px 0}.comment-thread{padding:10px;margin-bottom:8px;border-radius:10px;background:var(--panel-2);border:1px solid var(--border)}.comment-thread.resolved{opacity:.55}.comment-node-tag{font-size:10px;color:var(--green);background:var(--green-bg);padding:1px 7px;border-radius:4px;display:inline-block;margin-bottom:6px;font-weight:600}.comment-header{display:flex;align-items:center;gap:8px;margin-bottom:4px}.comment-author{font-size:12px;font-weight:700;color:var(--text)}.comment-time{font-size:10.5px;color:var(--text-faint)}.comment-text{font-size:12.5px;color:var(--text-dim);line-height:1.45}.comment-actions{display:flex;gap:8px;margin-top:6px}.comment-actions button{font-size:10.5px;color:var(--text-faint);background:none;border:none;cursor:pointer;padding:0}.comment-actions button:hover{color:var(--text)}.comment-replies{margin-top:8px;padding-left:12px;border-left:2px solid var(--border)}.comment-reply{padding:6px 0}.comment-reply-box{display:flex;gap:6px;margin-top:8px;align-items:center}.comment-reply-box input{flex:1;padding:6px 10px;border-radius:6px;font-size:12px;background:var(--panel-3);border:1px solid var(--border);color:var(--text)}.comments-compose{border-top:1px solid var(--border);padding:10px 12px}.compose-row{margin-bottom:6px}.compose-node-select{width:100%;padding:5px 8px;border-radius:6px;font-size:11.5px;background:var(--panel-2);border:1px solid var(--border);color:var(--text)}.compose-input-row{display:flex;gap:6px}.compose-input-row input{flex:1;padding:8px 10px;border-radius:8px;font-size:12.5px;background:var(--panel-2);border:1px solid var(--border);color:var(--text)}.compose-input-row input::placeholder{color:var(--text-faint)}.tool-btn.disabled{opacity:.35;cursor:not-allowed}.tool-btn.disabled:hover{background:none;color:var(--text-dim)}.flows-dropdown{position:absolute;left:48px;top:-4px;z-index:40;background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:8px 0;min-width:220px;box-shadow:var(--shadow);animation:fade .1s}.flows-section-label{font-size:10px;color:var(--text-faint);text-transform:uppercase;letter-spacing:.5px;padding:4px 14px 6px}.flows-empty{font-size:12px;color:var(--text-faint);padding:8px 14px}.flows-item{display:flex;align-items:center;justify-content:space-between;width:100%;padding:7px 14px;font-size:12.5px;color:var(--text);background:none;border:none;cursor:pointer;text-align:left}.flows-item:hover{background:var(--panel-3)}.flows-item-name{font-weight:600}.flows-item-meta{font-size:10.5px;color:var(--text-faint)}.flows-sep{height:1px;background:var(--border);margin:4px 10px}.flows-browse{width:100%;padding:8px 14px;font-size:12px;font-weight:600;color:var(--green);background:none;border:none;cursor:pointer;text-align:left}.flows-browse:hover{background:var(--panel-3)}.gen-history-panel{position:absolute;left:62px;top:80px;bottom:80px;width:340px;z-index:35;background:var(--panel);border:1px solid var(--border);border-radius:14px;display:flex;flex-direction:column;box-shadow:var(--shadow);animation:slideInLeft .15s ease-out}.gen-history-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px 10px;border-bottom:1px solid var(--border)}.gen-history-header h3{font-size:14px;font-weight:700;margin:0;color:var(--text)}.gen-history-filters{display:flex;gap:2px;padding:8px 12px;border-bottom:1px solid var(--border)}.gen-history-grid{flex:1;overflow-y:auto;padding:10px;display:grid;grid-template-columns:1fr 1fr;gap:10px;align-content:start}.gen-history-empty{grid-column:1 / -1;text-align:center;color:var(--text-faint);font-size:12px;padding:32px 12px}.gen-history-item{background:var(--panel-2);border:1px solid var(--border);border-radius:10px;overflow:hidden;position:relative}.gen-history-thumb{aspect-ratio:1;overflow:hidden}.gen-history-thumb img,.gen-history-thumb video{width:100%;height:100%;object-fit:cover;display:block}.gen-history-text-preview{padding:10px;font-size:11px;color:var(--text-dim);line-height:1.4;min-height:80px}.gen-history-meta{padding:6px 8px;display:flex;flex-direction:column;gap:2px}.gen-history-label{font-size:11.5px;font-weight:600;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.gen-history-time{font-size:10px;color:var(--text-faint)}.gen-history-type-badge{position:absolute;top:6px;right:6px;font-size:9px;font-weight:700;text-transform:uppercase;padding:2px 6px;border-radius:4px;background:#0009;color:var(--text-dim)}.gen-history-type-badge.image{color:var(--green)}.gen-history-type-badge.video{color:var(--amber)}.gen-history-type-badge.text{color:#8bb8f0}.gen-history-type-badge.audio{color:#c490e4}.split-layers-modal{background:var(--panel);border:1px solid var(--border);border-radius:16px;width:400px;max-width:92vw;padding:24px;box-shadow:var(--shadow);animation:fade .12s}.split-layers-modal h3{font-size:16px;font-weight:700;margin:0 0 8px;color:var(--text)}.split-layers-desc{font-size:12.5px;color:var(--text-dim);margin:0 0 16px;line-height:1.45}.split-layers-preview{margin-bottom:16px;border-radius:10px;overflow:hidden;border:1px solid var(--border);max-height:160px}.split-layers-thumb{width:100%;height:100%;object-fit:cover;display:block}.split-layers-picker{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.split-layers-label{font-size:12.5px;font-weight:600;color:var(--text)}.split-layers-options{display:flex;gap:6px}.split-layer-btn{width:36px;height:36px;border-radius:10px;font-size:14px;font-weight:700;background:var(--panel-2);border:1px solid var(--border);color:var(--text-dim);cursor:pointer;transition:all .12s}.split-layer-btn:hover{background:var(--panel-3);color:var(--text)}.split-layer-btn.active{background:var(--green-bg);border-color:var(--green-deep);color:var(--green)}.split-layers-cascade{display:flex;flex-direction:column;gap:4px;margin-bottom:18px}.cascade-layer{padding:8px 14px;border-radius:8px;font-size:12px;font-weight:600;background:var(--panel-2);border:1px solid var(--border);color:var(--text-dim)}.split-layers-actions{display:flex;justify-content:flex-end;gap:8px}.app.comment-cursor-active .react-flow__pane{cursor:crosshair}.comment-cursor-banner{position:absolute;top:56px;left:50%;transform:translate(-50%);z-index:40;background:var(--panel);border:1px solid var(--green-deep);border-radius:10px;padding:8px 18px;font-size:12.5px;font-weight:600;color:var(--green);display:flex;align-items:center;box-shadow:var(--shadow);animation:fade .12s}.canvas-comment-bubble{display:flex;align-items:flex-start;gap:6px;background:var(--panel);border:1px solid var(--border);border-radius:10px;padding:6px 10px;box-shadow:var(--shadow);cursor:pointer;max-width:200px;animation:fade .12s}.canvas-comment-bubble:hover{border-color:var(--green-deep)}.comment-bubble-avatar{width:22px;height:22px;border-radius:50%;background:#7a4a2c;color:#fff;display:grid;place-items:center;font-size:10px;font-weight:700;flex-shrink:0}.comment-bubble-text{font-size:11px;color:var(--text-dim);line-height:1.35}.comment-input-popup{display:flex;gap:6px;align-items:center;background:var(--panel);border:1px solid var(--border);border-radius:10px;padding:6px 8px;box-shadow:var(--shadow);animation:fade .1s}.comment-input-popup input{width:200px;padding:6px 10px;border-radius:6px;font-size:12px;background:var(--panel-2);border:1px solid var(--border);color:var(--text)}.comment-input-popup input::placeholder{color:var(--text-faint)}.selection-toolbar{position:fixed;bottom:24px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:8px;background:var(--panel);border:1px solid var(--border-2);border-radius:14px;padding:8px 14px;box-shadow:var(--shadow);z-index:55;animation:sel-tb-in .18s ease-out}@keyframes sel-tb-in{0%{opacity:0;transform:translate(-50%) translateY(10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.sel-count{font-size:12px;font-weight:600;color:var(--text-dim);white-space:nowrap}.sel-sep{width:1px;height:18px;background:var(--border-2);flex-shrink:0}.sel-tags{display:flex;gap:5px;align-items:center}.sel-btn{font-size:12px;padding:5px 10px;border-radius:8px;background:var(--panel-3);border:1px solid var(--border);color:var(--text);cursor:pointer;white-space:nowrap;transition:background .12s}.sel-btn:hover{background:var(--border)}.sel-btn:disabled{opacity:.4;cursor:default}.sel-btn-danger:hover{background:#5b2320;color:var(--red)}.bulk-params-panel{position:fixed;top:60px;right:16px;width:260px;background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);padding:14px;box-shadow:var(--shadow);z-index:40;display:flex;flex-direction:column;gap:10px;max-height:calc(100vh - 100px);overflow-y:auto;animation:fade .15s}.bulk-header{border-bottom:1px solid var(--border);padding-bottom:8px}.bulk-title{font-size:12px;font-weight:600;color:var(--text-dim)}.bulk-field{display:flex;flex-direction:column;gap:4px}.bulk-field label{font-size:11px;color:var(--text-faint)}.bulk-field .node-select{width:100%;padding:5px 8px;border-radius:6px;font-size:12px;background:var(--panel-2);border:1px solid var(--border);color:var(--text)}.bulk-field .node-select.mixed{color:var(--text-faint);font-style:italic}.bulk-field .seed-input{width:100%;padding:5px 8px;border-radius:6px;font-size:12px;background:var(--panel-2);border:1px solid var(--border);color:var(--text)}.bulk-field .seed-input.mixed::placeholder{color:var(--text-faint);font-style:italic}.bulk-field input[type=range]{width:100%;accent-color:var(--green)}.mixed-tag{font-size:10px;color:var(--text-faint);font-style:italic;margin-left:4px}@media (max-width: 1440px){.projects-grid{grid-template-columns:repeat(3,1fr)}.explore-row{grid-template-columns:repeat(4,1fr)}}@media (max-width: 1024px){.projects-grid{grid-template-columns:repeat(2,1fr)}.explore-row{grid-template-columns:repeat(3,1fr)}.home-main{padding:48px 40px 60px}.home-hero h1{font-size:26px}.home-hero{margin-bottom:40px}.roots.docked{max-width:50vw}.docs-list{max-width:100%}.tech-builder{width:280px}}@media (max-width: 768px){.home{flex-direction:column}.home-side{width:100%;max-height:none;flex:none;flex-direction:row;flex-wrap:wrap;align-items:center;padding:12px 16px;gap:8px;border-right:none;border-bottom:1px solid var(--border)}.home-side-label,.home-side-foot{display:none}.home-side .home-nav{padding:6px 12px;font-size:12px}.home-main{padding:32px 24px 48px;overflow-y:auto}.home-hero{margin-bottom:28px;gap:14px}.home-hero h1{font-size:22px}.home-input{max-width:100%}.projects-grid,.explore-row{grid-template-columns:repeat(2,1fr);gap:12px}.toolbar{padding:6px 4px;gap:3px}.tool-btn{width:34px;height:34px;border-radius:10px}.tool-btn .tip{display:none}.tool-avatar{width:28px;height:28px;font-size:11px}.topbar{padding:10px 12px}.topbar-right{gap:6px}.topbar-right .btn{padding:6px 10px;font-size:12px;gap:5px}.proj-name{font-size:12px}.proj-ws{font-size:10px}.comments-panel{position:fixed;left:0;top:0;bottom:0;width:100%;max-width:340px;border-radius:0 14px 14px 0;z-index:200}.gen-history-panel{position:fixed;left:0;top:0;bottom:0;width:100%;max-width:360px;border-radius:0 14px 14px 0;z-index:200}.roots.docked{width:100%;max-width:380px}.roots.floating{width:92vw;max-width:400px}.tech-builder{width:92vw;max-width:320px;right:0}.tech-picker{width:92vw}.canvas-search{width:80vw;max-width:400px}.queue-widget{max-width:200px}.palette{width:92vw;max-width:300px}.palette-list.grid{grid-template-columns:repeat(2,1fr)}.share-modal{width:92vw}.split-layers-modal{width:92vw;padding:18px}.node-float-bar{max-width:90vw}.comment-cursor-banner{font-size:11px;padding:6px 14px}.flows-dropdown{min-width:180px;max-width:80vw}.budget-chip:hover .budget-detail{max-width:280px}}@media (max-width: 640px){.projects-grid{grid-template-columns:1fr}.explore-row{grid-template-columns:1fr 1fr}.home-main{padding:24px 16px 40px}.home-hero h1{font-size:20px}.home-section-head{flex-direction:column;align-items:flex-start;gap:6px}.toolbar{position:fixed;left:8px;right:8px;bottom:8px;top:auto;transform:none;flex-direction:row;justify-content:center;border-radius:16px;padding:6px 10px;gap:4px;z-index:40}.toolbar-sep{width:1px;height:24px;margin:0 3px}.tool-btn{width:36px;height:36px}.topbar{padding:8px 10px}.topbar-right .btn{padding:5px 8px;font-size:11px}.proj-meta{display:none}.comments-panel,.gen-history-panel{max-width:100%;border-radius:0}.roots.floating{bottom:64px;width:94vw;max-width:none;left:3vw}.roots.docked{max-width:100%;width:100%}.tech-builder{width:100%;max-width:100%;right:0;left:0;top:48px;border-radius:0}.share-inputs{flex-direction:column}.share-name-input{max-width:100%}.react-flow__minimap{display:none}.budget-chip,.queue-widget{bottom:60px;right:10px}.roots-corner{bottom:64px}.comment-input-popup input{width:min(200px,50vw)}}@media (max-width: 480px){.explore-row{grid-template-columns:1fr}.home-main{padding:20px 12px 36px}.home-hero h1{font-size:18px}.home-input input{font-size:14px;padding:10px 14px}.tool-btn{width:32px;height:32px;font-size:14px}.toolbar{gap:2px;padding:5px 8px}.topbar-right .btn{font-size:10px;padding:4px 7px;gap:4px}.topbar-right .btn svg{display:none}.logo-mark{width:18px;height:18px}.share-header{padding:14px 16px 10px}.share-invite{padding:0 16px 12px}.share-people,.share-footer{padding:10px 16px}.split-layers-modal{padding:14px}.split-layers-preview{max-height:120px}.canopy-node{width:300px}.technique-node{width:320px}.batch-node-v2{width:290px}.roots.floating{height:60vh;bottom:56px}.roots-head{padding:10px 12px}.comments-compose{padding:8px 10px}.compose-input-row input{font-size:13px;padding:7px 9px}.gen-history-grid{grid-template-columns:1fr}.build-tech-btn{font-size:11px;padding:6px 12px;bottom:62px}}@media (pointer: coarse){.tool-btn{min-width:36px;min-height:36px}.btn-sm{min-height:32px;padding:6px 14px}.palette-item{padding:11px 10px}.palette-footer button{padding:8px 0}.filter-btn{padding:6px 12px}.comment-actions button{padding:4px 6px;font-size:11px}.share-role-select{padding:8px 10px}.pc-del,.proj-action{opacity:1;padding:6px 10px}}.ctx-chips-bar{display:flex;flex-wrap:wrap;gap:6px;padding:8px 10px 6px;border-bottom:1px solid var(--border)}.msg-ctx-chips{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:8px}.ctx-chip{display:inline-flex;align-items:center;gap:6px;min-width:0;max-width:min(230px,100%);padding:4px 7px 4px 4px;border-radius:9px;font-size:11px;background:var(--panel-2);border:1px solid var(--border);color:var(--text-dim);white-space:nowrap}.ctx-chip.has-output{border-color:var(--green-deep);background:var(--green-bg)}.ctx-chip.status-running{border-color:#6aa7ff73}.ctx-chip.status-failed{border-color:#ff625973;background:#ff625914}.ctx-chip-icon,.ctx-chip-thumb{width:24px;height:24px;border-radius:7px;flex-shrink:0;display:grid;place-items:center;background:var(--panel-3);border:1px solid var(--border);color:var(--text-dim);overflow:hidden}.ctx-chip-icon{font-size:12px}.ctx-chip-thumb img,.ctx-chip-thumb video{width:100%;height:100%;object-fit:cover;display:block}.ctx-chip-body{min-width:0;display:flex;flex-direction:column;gap:1px}.ctx-chip-label{overflow:hidden;text-overflow:ellipsis;color:var(--text);font-size:11.5px;line-height:1.1}.ctx-chip-meta{overflow:hidden;text-overflow:ellipsis;color:var(--text-faint);font-size:10.5px;line-height:1.1}.ctx-chip-x{background:none;border:none;color:var(--text-faint);cursor:pointer;font-size:12px;padding:0 1px;line-height:1;flex-shrink:0}.ctx-chip-x:hover{color:var(--text)}.ctx-chip-overflow{font-size:10.5px;color:var(--text-faint);padding:5px 4px;font-style:italic}.studio-tab{padding:32px 0}.studio-tabs{display:flex;gap:4px;margin-bottom:24px;border-bottom:1px solid var(--border);padding-bottom:0}.studio-tab-btn{padding:10px 18px;font-size:13px;color:var(--text-dim);background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;display:flex;align-items:center;gap:6px;transition:all .15s}.studio-tab-btn:hover{color:var(--text)}.studio-tab-btn.active{color:var(--text);border-bottom-color:var(--green)}.studio-tab-icon{font-size:15px}.studio-body{display:flex;gap:32px;min-height:500px}.studio-controls{width:340px;flex-shrink:0;display:flex;flex-direction:column;gap:12px}.studio-results{flex:1;min-width:0}.studio-label{font-size:11.5px;color:var(--text-faint);text-transform:uppercase;letter-spacing:.04em;margin-top:4px}.studio-select{width:100%;padding:8px 10px;font-size:13px;border-radius:8px;border:1px solid var(--border);background:var(--panel-2);color:var(--text);outline:none;cursor:pointer}.studio-select:focus{border-color:var(--border-2)}.studio-model-tags{display:flex;flex-wrap:wrap;gap:4px}.studio-tag{font-size:10px;padding:2px 7px;border-radius:4px;background:#ffffff0f;color:var(--text-dim);border:1px solid var(--border)}.studio-textarea{width:100%;padding:10px 12px;font-size:13px;border-radius:8px;resize:vertical;border:1px solid var(--border);background:var(--panel-2);color:var(--text);font-family:inherit;outline:none;min-height:80px}.studio-textarea:focus{border-color:var(--border-2)}.studio-textarea::placeholder{color:var(--text-faint)}.studio-upload-section{display:flex;flex-direction:column;gap:8px}.studio-upload-row{display:flex;gap:8px;align-items:center}.studio-ref-preview{width:100%;max-height:160px;object-fit:contain;border-radius:8px;border:1px solid var(--border);margin-top:4px}.studio-generate-row{margin-top:8px}.studio-generate-btn{width:100%;padding:10px 16px!important;font-size:13px!important;font-weight:500}.studio-generate-btn:disabled{opacity:.4;cursor:not-allowed}.studio-loading{display:flex;align-items:center;gap:10px;font-size:12px;color:var(--text-dim);padding:8px 0}.studio-spinner{width:16px;height:16px;border:2px solid var(--border-2);border-top-color:var(--green);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.studio-error{font-size:12px;color:#e06060;background:#dc32321a;border:1px solid rgba(220,50,50,.25);border-radius:8px;padding:8px 12px}.studio-hint{font-size:12px;color:var(--text-faint);background:var(--panel-2);border:1px solid var(--border);border-radius:8px;padding:10px 12px;line-height:1.5}.studio-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:300px;color:var(--text-faint);gap:8px}.studio-empty-icon{font-size:40px;opacity:.3}.studio-empty-hint{font-size:11px}.studio-results-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}.studio-result-card{border:1px solid var(--border);border-radius:10px;overflow:hidden;background:var(--panel-2);transition:border-color .15s}.studio-result-card:hover{border-color:var(--border-2)}.studio-result-card img{width:100%;display:block}.studio-video-result video{width:100%;display:block;background:#050807;aspect-ratio:16 / 9;object-fit:cover}.studio-result-actions{padding:8px 10px;display:flex;gap:6px}.studio-result-actions span{font-size:11px;color:var(--text-faint)}.studio-result-note{margin-left:auto;max-width:58%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:right}.studio-text-result{padding:14px 16px}.studio-text-result pre{font-size:12.5px;white-space:pre-wrap;word-break:break-word;color:var(--text);margin:0;font-family:inherit;line-height:1.6}.cinema-studio{display:grid;gap:16px;align-items:start}.cinema-panel{border:1px solid var(--border);background:color-mix(in srgb,var(--panel-2) 86%,#111 14%);border-radius:8px;padding:14px;min-width:0}.cinema-panel-head{display:flex;justify-content:space-between;gap:12px;align-items:center;margin-bottom:12px;color:var(--text-dim);font-size:12px}.cinema-panel-head span:first-child{color:var(--text);font-weight:600}.cinema-preset-grid{display:grid;gap:8px;margin-bottom:14px}.cinema-preset{display:grid;gap:3px;padding:10px 11px;text-align:left;border-radius:8px;border:1px solid var(--border);background:#ffffff08;color:var(--text-dim);cursor:pointer}.cinema-preset:hover,.cinema-preset.active{border-color:color-mix(in srgb,var(--green) 46%,var(--border-2));background:#4dc49a14}.cinema-preset strong{color:var(--text);font-size:12px;font-weight:600}.cinema-preset span{font-size:11px;line-height:1.35}.cinema-brief{min-height:110px;margin-bottom:12px}.cinema-control-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:9px;margin-bottom:12px}.cinema-control-grid label{display:grid;gap:5px;min-width:0}.cinema-control-grid span{color:var(--text-faint);font-size:10.5px;text-transform:uppercase;letter-spacing:.04em}.cinema-control-grid select{min-width:0;width:100%;padding:7px 8px;border-radius:7px;border:1px solid var(--border);background:var(--panel);color:var(--text);font:inherit;font-size:12px;outline:none}.cinema-stage{display:grid;gap:14px}.cinema-stage-top{display:grid;gap:10px}.cinema-stage-top h2{margin:4px 0 0;font-size:20px;line-height:1.15;letter-spacing:0}.cinema-model-select{max-width:100%}.cinema-frame{position:relative;width:min(100%,520px);margin:0 auto;overflow:hidden;border:1px solid var(--border-2);border-radius:8px;background:linear-gradient(135deg,#12181deb,#07090af5),repeating-linear-gradient(90deg,rgba(255,255,255,.04) 0 1px,transparent 1px 34px);box-shadow:inset 0 0 0 1px #ffffff08}.cinema-frame-9-16{aspect-ratio:9 / 16;max-height:560px}.cinema-frame-16-9{aspect-ratio:16 / 9}.cinema-frame-1-1{aspect-ratio:1 / 1;max-height:520px}.cinema-frame img{width:100%;height:100%;object-fit:cover;display:block}.cinema-placeholder{height:100%;display:grid;place-content:center;gap:10px;text-align:center;padding:28px}.cinema-placeholder span,.cinema-placeholder small{color:var(--text-faint);font-size:12px}.cinema-placeholder strong{color:var(--text);font-size:clamp(24px,5vw,44px);font-weight:650;letter-spacing:0}.cinema-overlay{position:absolute;left:10px;right:10px;bottom:10px;display:flex;gap:6px;flex-wrap:wrap}.cinema-overlay span{padding:4px 7px;border-radius:5px;background:#00000094;border:1px solid rgba(255,255,255,.12);color:#ffffffd1;font-size:11px}.cinema-motion-path{position:absolute;width:34%;height:2px;left:33%;top:50%;background:linear-gradient(90deg,transparent,rgba(77,196,154,.9),transparent);transform-origin:center;animation:cinemaPath 2.8s ease-in-out infinite}@keyframes cinemaPath{0%,to{transform:translate(-18%) scaleX(.55);opacity:.35}50%{transform:translate(18%) scaleX(1.15);opacity:1}}.cinema-actions{display:flex;flex-wrap:wrap;gap:8px}.cinema-prompt-preview{max-height:260px;overflow:auto;white-space:pre-wrap;word-break:break-word;margin:0 0 12px;padding:11px;border-radius:8px;border:1px solid var(--border);background:#0000002e;color:var(--text-dim);font:12px/1.55 inherit}.cinema-shot-cards{display:grid;gap:8px}.cinema-shot-card{display:flex;justify-content:space-between;gap:10px;align-items:center;border:1px solid var(--border);border-radius:8px;padding:10px;background:#ffffff08}.cinema-shot-card div{display:grid;gap:3px;min-width:0}.cinema-shot-card strong{color:var(--text);font-size:12px}.cinema-shot-card span{color:var(--text-faint);font-size:11px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cinema-results{display:grid;gap:10px;margin-top:12px}@media (max-width: 900px){.studio-body{flex-direction:column}.studio-controls{width:100%}}@media (max-width: 600px){.studio-tabs{overflow-x:auto}.studio-tab-btn{padding:8px 12px;font-size:12px}.studio-results-grid{grid-template-columns:1fr}}@media (min-width: 980px){.cinema-studio{grid-template-columns:minmax(260px,340px) minmax(340px,1fr)}.cinema-shotlist{grid-column:1 / -1}}@media (min-width: 1280px){.cinema-studio{grid-template-columns:minmax(280px,340px) minmax(440px,1fr) minmax(280px,340px)}.cinema-shotlist{grid-column:auto}}@media (max-width: 560px){.cinema-panel{padding:12px}.cinema-control-grid{grid-template-columns:1fr}.cinema-actions .btn-sm{flex:1 1 140px}}.kb-page{width:100vw;height:100vh;background:var(--bg);color:var(--text);display:flex;flex-direction:column;overflow:hidden}.kb-header{display:flex;justify-content:space-between;align-items:center;padding:20px 32px;border-bottom:1px solid var(--border)}.kb-header-left{display:flex;align-items:center;gap:12px}.kb-header-left h2{margin:0;font-size:18px;font-weight:600}.kb-header-right{display:flex;gap:8px}.kb-back{background:none;border:1px solid var(--border);border-radius:9px;color:var(--text);cursor:pointer;padding:6px 10px;font-size:14px}.kb-back:hover{background:var(--bg-hover)}.kb-count{font-size:12px;color:var(--text-faint)}.kb-filters{display:flex;gap:12px;align-items:center;padding:12px 32px;border-bottom:1px solid var(--border)}.kb-search{flex:1;max-width:320px;padding:6px 12px;border-radius:6px;border:1px solid var(--border);background:var(--bg-elevated);color:var(--text);font-size:13px;outline:none}.kb-search:focus{border-color:var(--accent)}.kb-type-filters{display:flex;gap:4px}.kb-filter-btn{padding:4px 12px;border-radius:12px;border:1px solid var(--border);background:none;color:var(--text-faint);cursor:pointer;font-size:12px}.kb-filter-btn:hover{background:var(--bg-hover)}.kb-filter-btn.active{background:var(--accent-faint, #34d27b18);color:var(--accent, #34d27b);border-color:var(--accent, #34d27b)}.kb-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px;padding:20px 32px;overflow-y:auto;flex:1}.kb-card{background:var(--bg-elevated);border:1px solid var(--border);border-radius:10px;padding:14px;display:flex;flex-direction:column;gap:8px;transition:border-color .15s}.kb-card:hover{border-color:var(--text-faint)}.kb-card.pinned{border-color:var(--accent, #34d27b)}.kb-card-head{display:flex;justify-content:space-between;align-items:center}.kb-type-badge{font-size:11px;font-weight:600;padding:2px 8px;border-radius:8px;text-transform:uppercase;letter-spacing:.5px}.kb-card-actions{display:flex;gap:2px}.kb-card-actions button{background:none;border:none;cursor:pointer;padding:2px 6px;color:var(--text-faint);font-size:14px;border-radius:4px}.kb-card-actions button:hover{background:var(--bg-hover);color:var(--text)}.kb-pin-btn.active{color:var(--accent, #34d27b)!important}.kb-card-thumb{width:100%;height:120px;object-fit:cover;border-radius:6px}.kb-card-content{font-size:13px;line-height:1.5;color:var(--text);overflow:hidden;display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical}.kb-card-foot{display:flex;justify-content:space-between;align-items:center}.kb-source{font-size:11px;color:var(--text-faint)}.kb-embedded{font-size:11px;color:var(--accent, #34d27b)}.kb-empty{text-align:center;padding:60px 20px;color:var(--text-faint);font-size:14px}.kb-modal{background:var(--bg-elevated);border:1px solid var(--border);border-radius:12px;width:min(480px,90vw);max-height:80vh;overflow-y:auto}.kb-modal-body{padding:16px 20px;display:flex;flex-direction:column;gap:10px}.kb-modal-body label{font-size:12px;font-weight:500;color:var(--text-faint)}.kb-type-select{display:flex;gap:6px}.kb-type-opt{padding:5px 14px;border-radius:8px;border:1px solid var(--border);background:none;color:var(--text);cursor:pointer;font-size:12px}.kb-type-opt:hover{background:var(--bg-hover)}.kb-type-opt.active{background:var(--tc, #34d27b)22;color:var(--tc, #34d27b);border-color:var(--tc, #34d27b)}.kb-textarea{width:100%;padding:8px 12px;border-radius:6px;border:1px solid var(--border);background:var(--bg);color:var(--text);font-size:13px;resize:vertical;font-family:inherit;outline:none}.kb-textarea:focus{border-color:var(--accent)}.kb-input{width:100%;padding:6px 12px;border-radius:6px;border:1px solid var(--border);background:var(--bg);color:var(--text);font-size:13px;outline:none}.kb-input:focus{border-color:var(--accent)}.kb-pin-label{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--text);cursor:pointer}.kb-modal-foot{display:flex;justify-content:flex-end;gap:8px;padding:12px 20px;border-top:1px solid var(--border)}.kb-badge{position:absolute;top:2px;right:2px;background:var(--accent, #34d27b);color:#000;font-size:9px;font-weight:700;min-width:14px;height:14px;border-radius:7px;display:flex;align-items:center;justify-content:center;padding:0 3px}.brand-kb-page{background:linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px),var(--bg);background-size:96px 96px}.brand-kb-header{background:#0a0c0cdb;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.brand-kb-header .kb-header-left>div{display:grid;gap:2px}.brand-kb-main{display:grid;gap:18px;padding:20px 18px 36px;overflow:auto}.brand-kit-strip{display:grid;grid-template-columns:1fr;gap:12px}.brand-scope-toggle,.brand-elements-summary{border:1px solid var(--border);border-radius:8px;background:var(--panel);padding:14px 16px;display:flex;justify-content:space-between;gap:16px;align-items:center}.brand-scope-toggle strong,.brand-elements-summary h3{display:block;color:var(--text);font-size:14px;margin:0 0 4px}.brand-scope-toggle span,.brand-elements-summary p,.brand-elements-summary span:first-child{color:var(--text-dim);font-size:12px;line-height:1.4}.brand-scope-toggle>div:last-child{display:inline-flex;border:1px solid var(--border);border-radius:7px;padding:3px;background:#ffffff08}.brand-scope-toggle button{border:0;border-radius:5px;padding:7px 10px;background:transparent;color:var(--text-dim);cursor:pointer}.brand-scope-toggle button.active{background:var(--green);color:#06100c}.brand-scope-toggle button:disabled{opacity:.45;cursor:not-allowed}.brand-elements-summary{align-items:flex-start}.brand-elements-summary>div:first-child{max-width:520px}.brand-kit-create,.brand-kit-card{position:relative;min-height:172px;padding:16px;border-radius:8px;border:1px solid var(--border);background:var(--panel-2);color:var(--text);text-align:left;cursor:pointer}.brand-kit-create{display:grid;place-items:center;align-content:center;gap:6px;border-style:dashed;color:var(--text-dim)}.brand-kit-create span{width:44px;height:44px;display:grid;place-items:center;border-radius:8px;border:1px solid var(--border);color:var(--green);font-size:24px}.brand-kit-create strong,.brand-kit-card strong{color:var(--text);font-size:15px}.brand-kit-create small,.brand-kit-card small{color:var(--text-faint);font-size:11px}.brand-kit-card{display:grid;gap:14px;transition:border-color .16s ease,background .16s ease}.brand-kit-card:hover,.brand-kit-card.active{border-color:var(--green-deep);background:color-mix(in srgb,var(--panel-2) 86%,var(--green) 14%)}.brand-kit-main{display:grid;grid-template-columns:58px 1fr;gap:12px;align-items:start;min-width:0}.brand-kit-main div:last-child{display:grid;gap:5px;min-width:0}.brand-kit-main span{color:var(--text-dim);font-size:12px;line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.brand-logo-box{width:58px;height:58px;border-radius:8px;border:1px solid var(--border);background:#ffffff0a;display:grid;place-items:center;overflow:hidden}.brand-logo-box img{max-width:100%;max-height:100%;object-fit:contain}.brand-logo-box span{color:var(--green);font-weight:700;font-size:16px;-webkit-line-clamp:1}.brand-card-swatches{display:flex;gap:7px;min-height:28px;align-items:center}.brand-card-swatches i,.brand-color-list i{width:26px;height:26px;border-radius:999px;border:1px solid rgba(255,255,255,.18);box-shadow:inset 0 0 0 1px #0000002e;flex:0 0 auto}.brand-card-foot{display:flex;justify-content:space-between;gap:8px;align-items:center;color:var(--text-faint);font-size:11px}.brand-confidence{padding:3px 7px;border-radius:5px;background:#34d27b1a;color:var(--green);border:1px solid rgba(52,210,123,.2)}.brand-confidence.draft{background:#e8b7651f;color:var(--amber);border-color:#e8b7653d}.brand-delete-hit{position:absolute;right:8px;top:8px;width:24px;height:24px;display:grid;place-items:center;border-radius:5px;border:0;background:#00000038;color:var(--text-faint);cursor:pointer}.brand-delete-hit:hover{color:#e06060}.brand-detail{border:1px solid var(--border);border-radius:8px;background:var(--panel);padding:18px;display:grid;gap:18px}.brand-detail.empty{min-height:220px;align-items:center}.brand-detail-copy{display:grid;gap:7px}.brand-detail-copy span,.brand-detail-grid small{color:var(--text-faint);font-size:11px;text-transform:uppercase;letter-spacing:.05em}.brand-detail-copy h2{margin:0;font-size:clamp(28px,4vw,44px);font-weight:620;letter-spacing:0}.brand-detail-copy p,.brand-detail-grid p{margin:0;color:var(--text-dim);line-height:1.55;max-width:76ch}.brand-detail-copy b{color:var(--text);font-size:14px}.brand-detail-grid{display:grid;gap:14px}.brand-detail-grid>div{display:grid;gap:10px;padding:13px;border-radius:8px;border:1px solid var(--border);background:#ffffff06}.brand-color-list,.brand-chip-list{display:flex;gap:8px;flex-wrap:wrap}.brand-color-list span,.brand-chip-list span{min-height:36px;display:inline-flex;align-items:center;gap:8px;padding:5px 9px;border-radius:7px;border:1px solid var(--border);background:#ffffff09;color:var(--text);font-size:12px}.brand-color-list em,.brand-chip-list em{color:var(--text-faint);font-style:normal}.brand-entry-section{border:1px solid var(--border);border-radius:8px;background:color-mix(in srgb,var(--panel) 84%,#000 16%);overflow:hidden}.brand-scan-modal{width:min(560px,calc(100vw - 28px));border-radius:10px;border:1px solid var(--border);background:var(--panel);box-shadow:0 30px 80px #00000073}.brand-scan-body{display:grid;gap:10px;padding:16px 20px 20px}.brand-scan-body label{color:var(--text-faint);font-size:12px}.brand-scan-body p{margin:0;color:var(--text-faint);font-size:12px;line-height:1.5}.brand-url-row{display:grid;gap:8px}@media (min-width: 760px){.brand-kb-main{padding:24px 32px 40px}.brand-kit-strip{grid-template-columns:repeat(2,minmax(0,1fr))}.brand-url-row{grid-template-columns:1fr auto}}@media (max-width: 759px){.brand-scope-toggle,.brand-elements-summary{display:grid}}@media (min-width: 1180px){.brand-kit-strip{grid-template-columns:220px repeat(3,minmax(0,1fr))}.brand-detail{grid-template-columns:minmax(280px,.9fr) minmax(520px,1.5fr)}.brand-detail-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}.brand-agent{--ba-ink: #141413;--ba-ink-soft: #6e6b64;--ba-ink-faint: #a8a49a;--ba-accent: #D97757;--ba-accent-deep: #A8552F;--ba-accent-wash: #F7ECE5;--ba-line: #e8e3d9;--ba-card: #fff;--ba-bg: #FAF9F5;--ba-rail: #F4F1EA;--ba-ok: #1a9e6c;--ba-bad: #d23f3f;--ba-radius: 16px;--ba-shadow: 0 1px 2px rgba(22,18,31,.04), 0 8px 28px rgba(76,29,149,.07);--ba-font-display: "Fraunces", Georgia, serif;--ba-font-body: "Instrument Sans", -apple-system, sans-serif;flex:1;min-width:0;height:100%;position:relative;overflow:hidden;background:var(--ba-bg);color:var(--ba-ink);font-family:var(--ba-font-body);-webkit-font-smoothing:antialiased}.brand-agent *,.brand-agent *:before,.brand-agent *:after{box-sizing:border-box}.brand-agent button{font:inherit;cursor:pointer}.brand-agent h1,.brand-agent h2,.brand-agent h3{font-family:var(--ba-font-display);font-weight:500;letter-spacing:-.02em;margin:0}.brand-agent input,.brand-agent textarea,.brand-agent select{font-family:inherit}.ba-onboard{position:absolute;top:0;right:0;bottom:0;left:0;z-index:30;background:var(--ba-bg);display:none;flex-direction:column;overflow-y:auto}.ba-onboard.active{display:flex}.ba-onboard:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background-image:radial-gradient(rgba(217,119,87,.18) 1.2px,transparent 1.2px);background-size:14px 14px;-webkit-mask-image:linear-gradient(to top,rgba(0,0,0,.9),transparent 55%);mask-image:linear-gradient(to top,rgba(0,0,0,.9),transparent 55%)}.ba-ob-head{display:flex;align-items:center;justify-content:space-between;padding:18px 28px;position:relative;z-index:1}.ba-wordmark{font-family:var(--ba-font-display);font-weight:600;font-size:21px}.ba-ob-body{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 24px;position:relative;z-index:1}.ba-hero{font-size:clamp(36px,5vw,52px);text-align:center}.ba-hero-sub{margin-top:12px;color:var(--ba-ink-soft);text-align:center;line-height:1.55;font-size:15.5px}.ba-url-bar{margin-top:30px;width:min(560px,92vw);display:flex;align-items:center;gap:8px;background:var(--ba-card);border:1px solid var(--ba-line);border-radius:16px;padding:8px 8px 8px 18px;box-shadow:var(--ba-shadow);transition:all .2s}.ba-url-bar:focus-within{border-color:#e3b8a3;box-shadow:0 0 0 4px #d977571a,var(--ba-shadow)}.ba-url-bar input{flex:1;border:0;outline:0;font:inherit;font-size:16px;background:transparent;color:var(--ba-ink)}.ba-url-bar input::placeholder{color:var(--ba-ink-faint)}.ba-go-btn{width:44px;height:40px;border:0;border-radius:12px;background:var(--ba-accent);color:#fff;font-size:18px;display:grid;place-items:center;transition:background .15s}.ba-go-btn:hover{background:var(--ba-accent-deep)}.ba-go-btn[disabled]{background:#ecc4b1}.ba-add-error{margin-top:14px;color:var(--ba-bad);font-size:14px;min-height:18px;text-align:center}.ba-extract-grid{display:grid;gap:16px;width:min(1080px,96vw);grid-template-columns:340px 1fr}@media (max-width: 860px){.ba-extract-grid{grid-template-columns:1fr}}.ba-card{background:var(--ba-card);border:1px solid var(--ba-line);border-radius:var(--ba-radius);box-shadow:var(--ba-shadow);padding:24px}.ba-steps-card h2{font-size:29px;line-height:1.15}.ba-steps-card .ba-sub{color:var(--ba-ink-soft);font-size:14px;margin:10px 0 24px}.ba-step{display:flex;align-items:center;gap:13px;padding:9px 0;position:relative}.ba-step+.ba-step:before{content:"";position:absolute;left:11px;top:-8px;height:14px;width:1.5px;background:var(--ba-line)}.ba-bullet{width:23px;height:23px;border-radius:50%;border:1.5px solid var(--ba-line);display:grid;place-items:center;font-size:11px;color:#fff;flex:none;transition:all .25s}.ba-step.doing .ba-bullet{border-color:var(--ba-accent)}.ba-step.doing .ba-bullet:after{content:"";width:11px;height:11px;border-radius:50%;border:2px solid var(--ba-accent);border-top-color:transparent;animation:ba-spin .8s linear infinite}.ba-step.done .ba-bullet{background:var(--ba-accent);border-color:var(--ba-accent)}.ba-step.done .ba-bullet:after{content:"✓"}.ba-step span{font-size:14.5px;color:var(--ba-ink-soft)}.ba-step.doing span,.ba-step.done span{color:var(--ba-ink)}.ba-eta{margin-top:20px;color:var(--ba-ink-faint);font-size:13.5px}.ba-facts{display:grid;gap:16px;grid-template-columns:1fr 1fr;align-content:start}@media (max-width: 640px){.ba-facts{grid-template-columns:1fr}}.ba-fact{opacity:0;transform:translateY(10px);transition:all .5s}.ba-fact.show{opacity:1;transform:none}.ba-fact h4{font-family:var(--ba-font-display);font-weight:500;font-size:19px;color:var(--ba-ink-faint);margin:0 0 12px}.ba-fact-body{font-size:14.5px;line-height:1.6}.ba-tagline-text{font-style:italic}.ba-fact.ba-span2{grid-column:span 2}@media (max-width: 640px){.ba-fact.ba-span2{grid-column:span 1}}.ba-logo-tile{height:150px;border-radius:14px;display:grid;place-items:center;font-family:var(--ba-font-display);font-size:54px;font-weight:600;color:#fff;overflow:hidden}.ba-logo-tile img{width:100%;height:100%;object-fit:contain;padding:18px}.ba-palette{display:flex;gap:10px;flex-wrap:wrap}.ba-chip{display:flex;flex-direction:column;gap:6px;align-items:center}.ba-chip i{width:42px;height:42px;border-radius:12px;border:1px solid rgba(0,0,0,.07)}.ba-chip small{font-size:11px;color:var(--ba-ink-faint)}.ba-tags{display:flex;gap:7px;flex-wrap:wrap}.ba-tag{background:var(--ba-accent-wash);color:var(--ba-accent-deep);border-radius:999px;padding:5px 12px;font-size:12.5px;font-weight:500}.ba-begin-btn{margin-top:24px;width:100%;padding:13px;border:0;border-radius:12px;background:var(--ba-accent);color:#fff;font-weight:600;font-size:15px;transition:background .15s}.ba-begin-btn:hover{background:var(--ba-accent-deep)}.ba-shell{display:flex;height:100%}.ba-aside{width:218px;flex:none;background:var(--ba-rail);border-right:1px solid var(--ba-line);display:flex;flex-direction:column;padding:16px 12px}.ba-aside .ba-wordmark{padding:4px 10px 16px}.ba-nav-item{display:flex;align-items:center;gap:11px;width:100%;border:0;background:none;border-radius:10px;padding:9px 11px;font-size:14px;font-weight:500;color:var(--ba-ink-soft);text-align:left;transition:all .12s}.ba-nav-item svg{width:17px;height:17px;flex:none}.ba-nav-item:hover{background:#ece7dd;color:var(--ba-ink)}.ba-nav-item.on{background:var(--ba-accent-wash);color:var(--ba-accent-deep)}.ba-foot{margin-top:auto;padding:10px;font-size:12.5px;color:var(--ba-ink-faint);line-height:1.7}.ba-foot b{color:var(--ba-ink-soft)}.ba-main{flex:1;overflow-y:auto;position:relative;min-width:0}.ba-topbar{position:sticky;top:0;z-index:5;background:#fdfcfbd9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;gap:12px;padding:13px 30px;border-bottom:1px solid var(--ba-line)}.ba-brand-select{display:flex;align-items:center;gap:9px;background:var(--ba-card);border:1px solid var(--ba-line);border-radius:11px;padding:7px 12px;font-size:14px;font-weight:500;max-width:280px}.ba-brand-select:hover{border-color:#e3b8a3}.ba-mono{width:22px;height:22px;border-radius:7px;display:grid;place-items:center;color:#fff;font-family:var(--ba-font-display);font-weight:600;font-size:12px;overflow:hidden;flex:none}.ba-mono img{width:100%;height:100%;object-fit:cover}.ba-car{color:var(--ba-ink-faint);font-size:11px}.ba-brand-menu{position:absolute;top:54px;left:30px;z-index:20;min-width:260px;background:var(--ba-card);border:1px solid var(--ba-line);border-radius:14px;box-shadow:0 16px 48px #00000024;padding:6px}.ba-brand-menu button{display:flex;align-items:center;gap:10px;width:100%;border:0;background:none;border-radius:9px;padding:9px 10px;font-size:14px;text-align:left;color:var(--ba-ink)}.ba-brand-menu button:hover{background:var(--ba-accent-wash)}.ba-credits-pill{margin-left:auto;font-size:13px;color:var(--ba-ink-soft);background:var(--ba-card);border:1px solid var(--ba-line);border-radius:999px;padding:6px 13px}.ba-credits-pill b{color:var(--ba-ink)}.ba-page{display:block;padding:30px 30px 170px;max-width:1240px}.ba-page>h1{font-size:36px}.ba-page>.ba-lede{color:var(--ba-ink-soft);font-size:15px;margin:8px 0 28px}.ba-ov-grid{display:grid;gap:18px;grid-template-columns:1.2fr 1fr}@media (max-width: 980px){.ba-ov-grid{grid-template-columns:1fr}}.ba-ov-brand{display:flex;flex-direction:column}.ba-ov-logo{height:190px;border-radius:13px;display:grid;place-items:center;overflow:hidden;font-family:var(--ba-font-display);font-size:60px;color:#fff}.ba-ov-logo img{width:100%;height:100%;object-fit:contain;padding:22px}.ba-ov-row{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:16px}.ba-kicker{font-size:11.5px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--ba-ink-faint);display:flex;align-items:center;gap:7px}.ba-ov-brand h3{font-size:24px;margin-top:5px}.ba-linklike{background:none;border:0;color:var(--ba-accent);font-size:13.5px;text-decoration:underline;text-underline-offset:3px}.ba-ov-create{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:8px;min-height:240px}.ba-ov-swatch-row{display:flex;gap:8px;margin-bottom:10px}.ba-ov-swatch-row i{width:52px;height:64px;border-radius:10px;border:1px solid rgba(0,0,0,.06)}.ba-ov-create h3{font-size:24px}.ba-ov-recent{grid-column:1 / -1}.ba-ov-recent h3{font-size:20px;margin-bottom:14px}.ba-thumb-strip{display:flex;gap:10px;overflow-x:auto;padding-bottom:4px}.ba-thumb-strip img{width:130px;height:96px;object-fit:cover;border-radius:11px;border:1px solid var(--ba-line);cursor:zoom-in;flex:none}.ba-grid{display:grid;gap:14px;grid-template-columns:repeat(auto-fill,minmax(228px,1fr))}.ba-tile{background:var(--ba-card);border:1px solid var(--ba-line);border-radius:14px;overflow:hidden;box-shadow:var(--ba-shadow);animation:ba-rise .35s ease both}.ba-ph{aspect-ratio:4/3;display:grid;place-items:center;background:linear-gradient(110deg,#f4f0e8 30%,#ede5d8,#f4f0e8 60%);background-size:220% 100%;animation:ba-shimmer 1.4s linear infinite;color:var(--ba-ink-faint);font-size:13px}.ba-tile img{width:100%;aspect-ratio:4/3;object-fit:cover;display:block;cursor:zoom-in;background:#f4f1fa}.ba-tile-meta{padding:10px 12px 4px}.ba-tile-kind{font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--ba-ink-faint)}.ba-tile-prompt{font-size:13px;margin-top:3px;line-height:1.45;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.ba-tile-acts{display:flex;gap:6px;padding:9px 12px 12px}.ba-act{flex:1;border:1px solid var(--ba-line);background:var(--ba-bg);border-radius:8px;font-size:12.5px;padding:6px 0;color:var(--ba-ink-soft);transition:all .15s;text-align:center;text-decoration:none}.ba-act:hover{border-color:var(--ba-accent);color:var(--ba-accent-deep)}.ba-tile-failed{color:var(--ba-bad);font-size:12.5px;padding:6px 12px 12px}.ba-empty{color:var(--ba-ink-faint);font-size:14px;padding:40px 0;text-align:center;border:1.5px dashed var(--ba-line);border-radius:14px}.ba-filter-row{display:flex;gap:8px;margin-bottom:18px;flex-wrap:wrap}.ba-fbtn{border:1px solid var(--ba-line);background:var(--ba-card);border-radius:999px;padding:6px 14px;font-size:13px;color:var(--ba-ink-soft)}.ba-fbtn.sel{border-color:var(--ba-accent);background:var(--ba-accent-wash);color:var(--ba-accent-deep);font-weight:600}.ba-idea-section{margin-bottom:30px}.ba-idea-section h3{font-size:19px;display:flex;align-items:center;gap:9px;margin-bottom:13px}.ba-idea-grid{display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(215px,1fr))}.ba-idea{background:var(--ba-card);border:1px solid var(--ba-line);border-radius:13px;padding:16px;text-align:left;transition:all .14s}.ba-idea:hover{border-color:#e3b8a3;transform:translateY(-2px);box-shadow:var(--ba-shadow)}.ba-idea-ic{width:34px;height:34px;border-radius:9px;background:var(--ba-accent-wash);display:grid;place-items:center;font-size:16px;margin-bottom:11px}.ba-idea b{font-size:14.5px;display:block}.ba-idea p{font-size:12.5px;color:var(--ba-ink-soft);margin-top:4px;line-height:1.5}.ba-brand-cards{display:grid;gap:18px;max-width:860px;margin:0 auto}.ba-brand-cards h3{font-size:22px;color:var(--ba-ink-faint);margin-bottom:18px}.ba-ident{display:grid;gap:22px;grid-template-columns:240px 1fr;align-items:start}@media (max-width: 700px){.ba-ident{grid-template-columns:1fr}}.ba-host{font-weight:600;font-size:16px}.ba-desc{color:var(--ba-ink-soft);font-size:14.5px;line-height:1.65;margin-top:8px}.ba-tg-label{font-weight:600;font-size:14px;margin-top:16px}.ba-tg{color:var(--ba-ink-soft);font-size:14.5px;margin-top:5px;font-style:italic}.ba-dl-grid{display:grid;gap:26px;grid-template-columns:1fr 1fr}@media (max-width: 700px){.ba-dl-grid{grid-template-columns:1fr}}.ba-dl-grid h5{font-size:13.5px;font-weight:600;margin:0 0 10px}.ba-swatches{display:flex;gap:9px;flex-wrap:wrap}.ba-swatches i{width:36px;height:36px;border-radius:9px;border:1px solid rgba(0,0,0,.07)}.ba-font-tiles{display:flex;gap:10px;flex-wrap:wrap}.ba-font-tile{border:1px solid var(--ba-line);border-radius:11px;padding:14px 18px;min-width:130px}.ba-aa{font-size:21px}.ba-font-tile small{color:var(--ba-ink-faint);font-size:12px;display:block;margin-top:5px}.ba-aesthetic{color:var(--ba-ink-soft);font-size:14px;line-height:1.65}.ba-upload-bar{display:flex;gap:8px;margin-bottom:20px;max-width:620px}.ba-upload-bar input{flex:1;border:1px solid var(--ba-line);border-radius:11px;padding:11px 14px;font:inherit;font-size:14.5px;outline:0;background:var(--ba-card);color:var(--ba-ink)}.ba-upload-bar input:focus{border-color:#e3b8a3}.ba-btn-solid{border:0;background:var(--ba-accent);color:#fff;border-radius:11px;padding:10px 18px;font-weight:600;font-size:14px;transition:background .15s}.ba-btn-solid:hover{background:var(--ba-accent-deep)}.ba-btn-solid[disabled]{background:#ecc4b1}.ba-btn-ghost{border:1px solid var(--ba-line);background:var(--ba-card);border-radius:11px;padding:9px 16px;font-size:14px;color:var(--ba-ink)}.ba-dock-wrap{position:absolute;bottom:22px;left:calc(50% + 109px);transform:translate(-50%);width:min(620px,calc(100% - 280px));z-index:15}.ba-dock-chips{display:flex;gap:7px;margin-bottom:8px;justify-content:center;flex-wrap:wrap}.ba-dchip{background:var(--ba-card);border:1px solid var(--ba-line);border-radius:999px;padding:7px 14px;font-size:13px;font-weight:500;box-shadow:var(--ba-shadow);transition:all .14s}.ba-dchip:hover{border-color:var(--ba-accent);color:var(--ba-accent-deep)}.ba-dock{background:var(--ba-card);border:1px solid var(--ba-line);border-radius:18px;box-shadow:0 18px 50px #16121f29;padding:13px 14px 11px}.ba-dock textarea{width:100%;border:0;outline:0;resize:none;font:inherit;font-size:14.5px;min-height:44px;background:transparent;color:var(--ba-ink)}.ba-dock-row{display:flex;align-items:center;gap:8px;margin-top:6px}.ba-dock select{border:1px solid var(--ba-line);border-radius:9px;padding:6px 8px;font:inherit;font-size:13px;color:var(--ba-ink-soft);background:var(--ba-bg);outline:0}.ba-dock-row .ba-btn-solid{margin-left:auto;padding:9px 22px;border-radius:10px}.ba-dock-note{text-align:center;font-size:12.5px;color:var(--ba-ink-faint);margin-top:7px;min-height:16px}.ba-veil{position:fixed;top:0;right:0;bottom:0;left:0;background:#16121f73;z-index:1200;display:flex;align-items:center;justify-content:center;padding:24px}.ba-modal{background:var(--ba-card);border-radius:var(--ba-radius);box-shadow:0 24px 80px #00000040;padding:24px;width:min(460px,94vw);animation:ba-pop .35s cubic-bezier(.2,1.3,.4,1)}.ba-modal h3{font-size:22px;margin-bottom:14px}.ba-modal textarea{width:100%;min-height:76px;border:1px solid var(--ba-line);border-radius:10px;padding:11px 13px;font:inherit;font-size:14.5px;outline:0;color:var(--ba-ink)}.ba-mrow{display:flex;gap:8px;margin-top:16px;justify-content:flex-end}.ba-ratio-row{display:flex;gap:8px;flex-wrap:wrap}.ba-ratio{border:1px solid var(--ba-line);background:var(--ba-card);border-radius:10px;padding:7px 13px;font-size:13.5px;color:var(--ba-ink-soft);transition:all .15s}.ba-ratio.sel{border-color:var(--ba-accent);color:var(--ba-accent-deep);background:var(--ba-accent-wash);font-weight:600}.ba-lightbox img{max-width:90vw;max-height:84vh;border-radius:14px;box-shadow:0 24px 80px #0006}@keyframes ba-spin{to{transform:rotate(360deg)}}@keyframes ba-shimmer{to{background-position:-220% 0}}@keyframes ba-pop{0%{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}@keyframes ba-rise{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}@media (max-width: 760px){.ba-aside{display:none}.ba-dock-wrap{left:50%;width:min(620px,calc(100% - 32px))}}
