*{box-sizing:border-box}.loading-screen{display:flex;align-items:center;justify-content:center;min-height:100vh;background:#0a0a0a}.loading-spinner{width:40px;height:40px;border:2px solid rgba(255,255,255,.1);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#0a0a0a;color:#fff;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.app{display:flex;flex-direction:column;height:100vh;overflow:hidden}.toolbar{display:flex;align-items:center;gap:8px;padding:8px 12px;background:#171717cc;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid rgba(255,255,255,.06);flex-shrink:0;position:relative;z-index:100}.toolbar-logo{display:flex;align-items:center;padding-right:4px}.toolbar-logo .logo-text{font-size:20px;font-weight:700;color:#fff;letter-spacing:-.5px}.toolbar-group{display:flex;gap:4px}.toolbar button{padding:6px 12px;background:#ffffff14;border:none;color:#ffffffb3;border-radius:8px;cursor:pointer;font-size:13px;transition:all .15s ease}.toolbar button:hover:not(:disabled){background:#ffffff24;color:#fff}.toolbar button:disabled{opacity:.35;cursor:not-allowed}.toolbar .separator{color:#ffffff26;padding:0 4px;-webkit-user-select:none;user-select:none}.toolbar .selection-info{margin-left:auto;font-size:12px;color:#ffffff80;padding:6px 12px;background:#ffffff0d;border-radius:8px}.toolbar .user-profile{display:flex;align-items:center;gap:8px;margin-left:auto;padding-left:12px;border-left:1px solid rgba(255,255,255,.08);position:relative}.user-profile-popover{position:absolute;top:calc(100% + 8px);right:0;min-width:280px;background:#171717fa;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:none;border-radius:14px;box-shadow:0 8px 32px #00000080;z-index:1000;overflow:visible}.user-profile-popover:before{content:"";position:absolute;top:-12px;left:0;right:0;height:12px;background:transparent}.user-popover-header{padding:12px 14px;font-size:11px;font-weight:600;color:#fff6;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid rgba(255,255,255,.08)}.user-popover-content{padding:14px;display:flex;flex-direction:column;gap:10px}.user-id-row{display:flex;flex-direction:column;gap:6px}.user-id-label{font-size:11px;color:#fff6;font-weight:500}.user-id-value-row{display:flex;align-items:center;gap:8px;background:#ffffff0d;border-radius:8px;padding:8px 10px}.user-id-value{font-size:11px;font-family:ui-monospace,SF Mono,monospace;color:#ffffffb3;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;-webkit-user-select:all;user-select:all}.user-id-copy-btn{padding:4px 10px!important;background:#4285f433!important;border:none!important;border-radius:6px!important;color:#4285f4!important;font-size:11px!important;font-weight:600;cursor:pointer;transition:all .15s ease;white-space:nowrap;flex-shrink:0}.user-id-copy-btn:hover{background:#4285f459!important;color:#fff!important}.user-popover-row{display:flex;justify-content:space-between;font-size:12px;color:#fff9}.user-popover-row span:last-child{color:#fffc;max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.toolbar .selection-info+.user-profile{margin-left:12px}.toolbar .user-name{font-size:12px;color:#ffffff80;max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.toolbar .sign-out-btn{padding:6px;background:#ffffff0f;border:none;color:#ffffff80;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s ease}.toolbar .sign-out-btn:hover{background:#ffffff1f;color:#fff}.toolbar .sign-in-btn{margin-left:auto;padding:6px 16px;background:#ffffff1a;border:1px solid rgba(255,255,255,.15);color:#ffffffd9;border-radius:8px;cursor:pointer;font-size:12px;font-weight:500;transition:all .15s ease;white-space:nowrap}.toolbar .sign-in-btn:hover{background:#ffffff2e;color:#fff;border-color:#ffffff40}.sync-status{display:flex;align-items:center;gap:6px;padding:5px 10px;border-radius:8px;font-size:11px;margin-left:auto;transition:all .2s ease}.toolbar .selection-info+.sync-status{margin-left:12px}.sync-status+.user-profile{margin-left:12px}.sync-status-synced{color:#4cd964;background:#4cd9641a}.sync-status-synced svg{stroke:#4cd964}.sync-status-syncing{color:#4285f4;background:#4285f41a}.sync-status-syncing svg{stroke:#4285f4}.sync-status-pending{color:#f4b400;background:#f4b4001a}.sync-status-pending svg{stroke:#f4b400}.sync-status-error{color:#ea4335;background:#ea43351a}.sync-status-error svg{stroke:#ea4335}.sync-status-text{max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@keyframes sync-spin{to{transform:rotate(360deg)}}.sync-spinning{animation:sync-spin 1s linear infinite}.token-usage-display{display:flex;align-items:center;gap:6px;padding:5px 10px;border-radius:8px;font-size:11px;margin-left:auto;transition:all .2s ease;color:#fff9;background:#ffffff0d;cursor:pointer;position:relative}.token-usage-display:hover{background:#ffffff14;color:#fffc}.token-usage-display.near-limit{color:#f4b400;background:#f4b4001a}.token-usage-display.near-limit svg{stroke:#f4b400}.token-usage-display.at-limit{color:#ea4335;background:#ea43351a}.token-usage-display.at-limit svg{stroke:#ea4335}.token-usage-display .token-count{font-variant-numeric:tabular-nums}.token-usage-display+.sync-status{margin-left:12px}.token-usage-popover{position:absolute;top:calc(100% + 8px);right:0;min-width:240px;background:#171717fa;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:none;border-radius:14px;box-shadow:0 8px 32px #00000080;z-index:1000;overflow:visible}.token-usage-popover:before{content:"";position:absolute;top:-12px;left:0;right:0;height:12px;background:transparent}.token-popover-header{padding:12px 14px;font-size:11px;font-weight:600;color:#fff6;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid rgba(255,255,255,.08)}.token-popover-content{padding:14px}.token-progress-bar{height:6px;background:#ffffff1a;border-radius:3px;overflow:hidden;margin-bottom:14px}.token-progress-fill{height:100%;background:#4cd964;border-radius:3px;transition:width .3s ease}.token-progress-fill.near-limit{background:#f4b400}.token-progress-fill.at-limit{background:#ea4335}.token-breakdown{display:flex;flex-direction:column;gap:8px;margin-bottom:14px}.token-row{display:flex;justify-content:space-between;font-size:12px;color:#fff9}.token-row span:last-child{font-variant-numeric:tabular-nums;color:#fffc}.token-row.limit{padding-top:8px;border-top:1px solid rgba(255,255,255,.08)}.token-row.remaining span:last-child{color:#4cd964}.token-contact-message{font-size:11px;color:#fff6;line-height:1.5;padding:10px;background:#ffffff08;border-radius:8px;border:1px solid rgba(255,255,255,.06)}.token-usage-badge{display:flex;align-items:center;gap:5px;padding:6px 10px;border-radius:8px;font-size:11px;color:#ffffff80;background:#ffffff0f;cursor:pointer;position:relative;transition:all .15s ease}.token-usage-badge:after{content:"";position:absolute;top:100%;left:0;right:0;height:12px;background:transparent}.token-usage-badge:hover{background:#ffffff1a;color:#ffffffb3}.token-usage-badge.near-limit{color:#f4b400;background:#f4b4001a}.token-usage-badge.near-limit svg{stroke:#f4b400}.token-usage-badge.at-limit{color:#ea4335;background:#ea43351a}.token-usage-badge.at-limit svg{stroke:#ea4335}.token-usage-badge .token-usage-popover{bottom:auto;top:calc(100% + 8px);left:0;right:auto}.token-popover-bottom{bottom:auto!important;top:calc(100% + 8px)!important}.canvas-selector{position:relative}.canvas-selector-btn{display:flex;align-items:center;gap:8px;padding:6px 10px!important;background:#ffffff14!important;border:none!important;min-width:140px;border-radius:10px!important}.canvas-selector-btn:hover{background:#ffffff24!important}.canvas-selector-btn .canvas-name{flex:1;text-align:left;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.canvas-dropdown{position:absolute;top:calc(100% + 6px);left:0;min-width:240px;background:#171717f2;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:none;border-radius:14px;box-shadow:0 8px 32px #00000080;z-index:1000;overflow:hidden}.canvas-dropdown-header{padding:12px 14px;font-size:11px;font-weight:600;color:#fff6;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid rgba(255,255,255,.06)}.canvas-dropdown-list{max-height:260px;overflow-y:auto;padding:4px}.canvas-dropdown-item{display:flex;align-items:center;justify-content:space-between;padding:2px;border-radius:10px;transition:background .1s ease}.canvas-dropdown-item:hover{background:#ffffff0f}.canvas-dropdown-item.active{background:#4285f426}.canvas-dropdown-item-content{flex:1;display:flex;align-items:center;gap:10px;padding:10px;cursor:pointer;color:#fffc;font-size:13px}.canvas-dropdown-item.active .canvas-dropdown-item-content{color:#fff}.canvas-dropdown-item.active .canvas-dropdown-item-content svg{stroke:#4285f4}.canvas-dropdown-item-actions{display:flex;gap:2px;opacity:0;transition:opacity .15s ease;padding-right:4px}.canvas-action-btn{padding:6px;background:transparent;border:none;color:#ffffff80;cursor:pointer;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:all .15s ease}.canvas-action-btn:hover{background:#ffffff1a;color:#fff}.canvas-action-btn.delete:hover{background:#ea433533;color:#ea4335}.canvas-dropdown-add{display:flex;align-items:center;gap:8px;width:100%;padding:12px 14px;background:transparent;border:none;border-top:none;color:#4285f4;font-size:13px;cursor:pointer;transition:background .15s ease}.canvas-dropdown-add:hover{background:#4285f41a}.canvas-dropdown-list::-webkit-scrollbar{width:6px}.canvas-dropdown-list::-webkit-scrollbar-track{background:transparent}.canvas-dropdown-list::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:3px}.canvas-dropdown-list::-webkit-scrollbar-thumb:hover{background:#ffffff40}.artboards-popover-container{position:relative}.artboards-btn{display:flex;align-items:center;gap:8px;padding:6px 10px!important;background:#ffffff14!important;border:none!important;border-radius:10px!important}.artboards-btn:hover,.artboards-btn.active{background:#ffffff24!important}.artboards-popover{position:absolute;top:calc(100% + 6px);left:0;min-width:280px;background:#171717f2;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:none;border-radius:14px;box-shadow:0 8px 32px #00000080;z-index:1000;overflow:hidden}.artboards-popover-header{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;font-size:11px;font-weight:600;color:#fff6;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid rgba(255,255,255,.06)}.artboards-popover-header .import-btn{padding:4px 10px!important;font-size:11px;text-transform:none;color:#fff;background:#4285f4!important;border:none!important;border-radius:6px!important}.artboards-popover-header .import-btn:hover:not(:disabled){background:#5a9bf4!important}.artboards-popover-list{max-height:320px;overflow-y:auto;padding:4px}.artboards-popover-empty{padding:32px 14px;text-align:center;color:#fff6;font-size:13px}.artboards-popover-item{display:flex;align-items:center;gap:12px;padding:10px 12px;cursor:pointer;border-radius:10px;transition:background .1s ease}.artboards-popover-item:hover{background:#ffffff0f}.artboards-popover-item.selected{background:#4285f426}.artboards-popover-item .artboard-icon{color:#fff6;display:flex;align-items:center}.artboards-popover-item.selected .artboard-icon{color:#4285f4}.artboards-popover-item .artboard-info{display:flex;flex-direction:column;gap:2px}.artboards-popover-item .artboard-name{font-size:13px;color:#fffc}.artboards-popover-item.selected .artboard-name{color:#fff}.artboard-name-input{font-size:13px;color:#fff;background:#ffffff1a;border:1px solid rgba(255,255,255,.3);border-radius:3px;padding:1px 4px;outline:none;font-family:inherit;width:100%}.artboards-popover-item .artboard-size{font-size:11px;color:#ffffff59}.artboards-popover-list::-webkit-scrollbar{width:6px}.artboards-popover-list::-webkit-scrollbar-track{background:transparent}.artboards-popover-list::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:3px}.zoom-controls{display:flex;align-items:center;gap:1px;background:#ffffff14;padding:3px;border-radius:10px;border:none}.zoom-controls button{min-width:28px;padding:5px 8px;background:transparent;border:none;border-radius:7px}.zoom-controls button:hover:not(:disabled){background:#ffffff1f}.zoom-controls .zoom-percent{min-width:48px;font-variant-numeric:tabular-nums;text-align:center;font-size:12px;color:#fff9;padding:0 4px}.toolbar .clear-btn{color:#ea4335;background:#ea43351a}.toolbar .clear-btn:hover:not(:disabled){background:#ea433533;color:#ea4335}.editing{outline:2px solid #22c55e!important;outline-offset:2px!important}.editing:after{content:"EDITING";position:absolute;top:-24px;left:50%;transform:translate(-50%);background:#22c55e;color:#000;font-size:10px;font-weight:700;padding:2px 8px;border-radius:4px}.main{display:flex;flex:1;overflow:hidden}.canvas-container{flex:1;position:relative;background:#0f0f0f}.chat-panel{width:340px;display:flex;flex-direction:column;background:#111111f2;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-left:1px solid rgba(255,255,255,.06);flex-shrink:0}.chat-header{padding:14px 16px;border-bottom:1px solid rgba(255,255,255,.06);display:flex;flex-direction:column;gap:6px}.chat-title{font-weight:600;font-size:14px;color:#ffffffe6}.selected-badge{font-size:11px;color:#ffffff80;background:#ffffff0f;padding:4px 10px;border-radius:6px;display:inline-block;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.selected-badge.edit-mode{background:#4cd9641a;color:#4cd964;border:none}.selected-artboard-indicator{padding:8px 14px;border-top:1px solid rgba(255,255,255,.06)}.chat-messages{flex:1;overflow-y:auto;padding:14px;display:flex;flex-direction:column;gap:12px}.message{padding:12px 14px;border-radius:14px;font-size:13px;line-height:1.5;max-width:92%;word-wrap:break-word}.message.user{background:#4285f4;margin-left:auto;border-bottom-right-radius:6px}.message.assistant{background:#ffffff14;margin-right:auto;border-bottom-left-radius:6px}.message.assistant.error{background:#ea433526;border:none}.message.system{background:#4285f414;border:none;font-size:12px;color:#ffffffb3}.message.system strong{color:#fff}.message.system ul{margin:8px 0;padding-left:20px}.message.system li{margin:4px 0}.message.system code{background:#0000004d;padding:2px 6px;border-radius:4px;font-size:11px}.message.system em{color:#ffffff80}.chat-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;flex:1;min-height:200px}.chat-empty-ghost{width:180px;height:auto;animation:float 4.5s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.chat-empty-greeting{margin-top:16px;font-size:15px;color:#ffffffe6;font-weight:500}.chat-empty-prompt{margin-top:8px;padding:0;background:none;border:none;color:#ffffff73;font-size:13px;cursor:pointer;transition:color .2s ease}.chat-empty-prompt:hover{color:#fffc}.message.streaming{background:linear-gradient(135deg,#4285f41a,#4285f40d);border:none}.token-info{margin-top:10px;padding-top:8px;border-top:1px solid rgba(255,255,255,.08);font-size:10px;color:#ffffff59;display:flex;justify-content:space-between;gap:8px}.token-info .session-total{color:#ffffff80;font-weight:500}.streaming-indicator{display:flex;align-items:center;gap:10px;font-size:12px;color:#fff9}.streaming-indicator .pulse{width:8px;height:8px;background:#4285f4;border-radius:50%;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.2)}}.streaming-text{font-size:12px;line-height:1.5;color:#ffffffb3;white-space:pre-wrap;word-break:break-word;font-family:SF Mono,Fira Code,Fira Mono,Menlo,monospace;max-height:200px;overflow-y:auto}.streaming-text.done{color:#ffffffd9}.streaming-cursor{display:inline-block;width:2px;height:1em;background:#4285f4;margin-left:1px;vertical-align:text-bottom;animation:pulse 1s ease-in-out infinite}.reasoning-block{border-left:2px solid rgba(168,85,247,.5);background:#a855f70f;border-radius:4px;margin:6px 0;overflow:hidden}.reasoning-header{display:flex;align-items:center;gap:6px;padding:6px 10px;cursor:pointer;font-size:11px;color:#a855f7cc;-webkit-user-select:none;user-select:none}.reasoning-header:hover{background:#a855f714}.reasoning-chevron{transition:transform .15s ease;font-size:10px}.reasoning-block.collapsed .reasoning-chevron{transform:rotate(-90deg)}.reasoning-content{padding:4px 10px 8px;font-size:11px;line-height:1.5;color:#ffffff8c;white-space:pre-wrap;word-break:break-word;max-height:150px;overflow-y:auto}.reasoning-block.collapsed .reasoning-content{display:none}.refero-tool-block{display:flex;align-items:center;gap:6px;padding:4px 8px;font-size:11px;color:#fff9;background:#6366f114;border-radius:4px;border-left:2px solid rgba(99,102,241,.3)}.refero-tool-block.done{color:#fff6;background:#6366f10a}.refero-tool-block.error{color:#ef4444b3;border-left-color:#ef44444d;background:#ef44440f}.refero-tool-icon{font-size:10px;min-width:12px}.refero-tool-spinner{width:10px;height:10px;border:1.5px solid rgba(99,102,241,.2);border-top-color:#6366f1b3;border-radius:50%;animation:spin .8s linear infinite}.refero-tool-label{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1}.refero-tool-block.clickable{cursor:pointer}.refero-tool-block.clickable:hover{background:#6366f11f}.refero-tool-chevron{font-size:8px;opacity:.5;transition:transform .2s;margin-left:auto}.refero-tool-chevron.expanded{transform:rotate(180deg)}.refero-tool-wrapper{display:flex;flex-direction:column;gap:2px}.refero-research-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:6px;padding:6px 0;max-height:300px;overflow-y:auto}.refero-research-item{display:flex;flex-direction:column;gap:3px;background:#ffffff08;border-radius:4px;overflow:hidden;border:1px solid rgba(255,255,255,.06)}.refero-research-thumb{width:100%;aspect-ratio:9 / 16;object-fit:cover;background:#0003}.refero-research-info{padding:3px 5px 4px;display:flex;flex-direction:column;gap:1px}.refero-research-app{font-size:10px;font-weight:500;color:#818cf8cc;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.refero-research-screen{font-size:9px;color:#fff6;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.refero-research-desc{font-size:9px;color:#ffffff4d;font-style:italic;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.refero-research-panel{margin-top:6px;border-radius:4px;border-left:2px solid rgba(99,102,241,.2);background:#6366f10a;overflow:hidden}.refero-research-header{display:flex;align-items:center;gap:6px;padding:5px 8px;cursor:pointer;font-size:10px;color:#ffffff80;text-transform:uppercase;letter-spacing:.5px}.refero-research-header:hover{background:#6366f10f}.refero-research-title{font-weight:500}.refero-research-panel .refero-research-grid{padding:4px 8px 8px}.refero-references{margin-top:6px;padding:6px 8px;background:#6366f10f;border-radius:4px;border-left:2px solid rgba(99,102,241,.2);font-size:11px}.refero-references-label{color:#fff6;margin-bottom:3px;font-size:10px;text-transform:uppercase;letter-spacing:.5px}.refero-reference-item{color:#ffffff8c;line-height:1.4}.refero-ref-app{color:#818cf8cc;font-weight:500}.refero-ref-screen{color:#ffffff73}.refero-ref-desc{color:#ffffff59;font-style:italic}.streaming-parts{display:flex;flex-direction:column;gap:4px}.streaming-parts-header{display:flex;align-items:center;gap:8px;font-size:11px;color:#fff6;margin-bottom:4px}.chat-input-container{padding:14px;border-top:1px solid rgba(255,255,255,.06)}.chat-input-container textarea{width:100%;padding:14px 16px 50px;background:#ffffff0f;border:none;border-radius:16px;color:#fff;font-size:14px;font-family:inherit;outline:none;transition:all .15s ease;resize:none;box-sizing:border-box}.chat-input-container textarea:focus{background:#ffffff14;box-shadow:0 0 0 2px #4285f44d}.chat-input-container textarea::placeholder{color:#ffffff59}.chat-input-container textarea:disabled{opacity:.5}.chat-input-toolbar{display:flex;justify-content:space-between;align-items:center;margin-top:-44px;padding:0 10px 10px;position:relative}.toolbar-left,.toolbar-right{display:flex;align-items:center;gap:8px}.toolbar-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:#ffffff14;border:none;border-radius:10px;color:#fff9;cursor:pointer;transition:all .15s ease}.toolbar-btn:hover:not(:disabled){background:#ffffff1f;color:#fff}.toolbar-btn:disabled{opacity:.4;cursor:not-allowed}.model-dropdown-wrapper{position:relative}.model-dropdown-btn{display:flex;align-items:center;gap:6px;padding:8px 12px;background:#ffffff14;border:none;border-radius:20px;color:#ffffffe6;font-size:13px;font-weight:500;cursor:pointer;transition:all .15s ease}.model-dropdown-btn:hover:not(:disabled){background:#ffffff1f}.model-dropdown-btn:disabled{opacity:.6;cursor:not-allowed}.model-dropdown-menu{position:absolute;bottom:100%;right:0;margin-bottom:8px;min-width:160px;background:#1e1e23fa;border:none;border-radius:12px;padding:6px;box-shadow:0 8px 32px #0006;z-index:100}.model-dropdown-item{display:flex;align-items:center;justify-content:space-between;width:100%;padding:10px 12px;background:transparent;border:none;border-radius:8px;color:#ffffffb3;font-size:13px;cursor:pointer;transition:all .1s ease;text-align:left}.model-dropdown-item:hover:not(:disabled){background:#ffffff14;color:#fff}.model-dropdown-item.selected{color:#fff}.model-dropdown-item.disabled{opacity:.4;cursor:not-allowed}.send-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:#ffffff1f;border:none;border-radius:50%;color:#ffffffe6;cursor:pointer;transition:all .15s ease}.send-btn:hover:not(:disabled){background:#fff3}.send-btn:disabled{opacity:.4;cursor:not-allowed}.chat-messages::-webkit-scrollbar{width:6px}.chat-messages::-webkit-scrollbar-track{background:transparent}.chat-messages::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:3px}.chat-messages::-webkit-scrollbar-thumb:hover{background:#ffffff40}.message-images{display:flex;gap:6px;margin-bottom:10px;flex-wrap:wrap}.message-image{max-width:120px;max-height:80px;border-radius:8px;object-fit:cover}.image-previews{display:flex;gap:8px;padding:10px 14px;border-top:1px solid rgba(255,255,255,.06);flex-wrap:wrap}.image-preview{position:relative;width:60px;height:60px}.image-preview img{width:100%;height:100%;object-fit:cover;border-radius:8px;border:1px solid rgba(255,255,255,.1)}.image-preview .remove-image{position:absolute;top:-6px;right:-6px;width:18px;height:18px;background:#ea4335;border:none;border-radius:50%;color:#fff;font-size:12px;cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1;padding:0;transition:background .15s ease}.image-preview .remove-image:hover{background:#d33a2e}.token-info .model-badge{background:#ffffff1a;padding:2px 6px;border-radius:4px;margin-right:6px;font-size:9px;font-weight:500;color:#fff9}.bottom-toolbar{position:absolute;bottom:20px;left:50%;transform:translate(-50%);display:flex;gap:2px;padding:4px;background:#171717d9;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:none;border-radius:14px;box-shadow:0 4px 24px #0006;z-index:100}.bottom-toolbar .tool-btn{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:10px;color:#ffffff80;cursor:pointer;transition:all .15s ease}.bottom-toolbar .tool-btn:hover{background:#ffffff1a;color:#fff}.bottom-toolbar .tool-btn.active{background:#ffffff1f;color:#fff}.bottom-toolbar .tool-btn svg{width:18px;height:18px}.bottom-toolbar .tool-separator{width:1px;height:24px;background:#ffffff26;margin:0 4px}.selection-marquee{position:absolute;border:1px solid rgba(66,133,244,.8);background:#4285f426;pointer-events:none;z-index:1000}.selected-badge.multi-edit{background:#ea8c5526;color:#ea8c55;border:none}.pinned-context-section{padding:10px 14px;border-top:none;background:#ea8c550d}.pinned-context-header{display:flex;align-items:center;gap:6px;font-size:11px;font-weight:600;color:#ea8c55;text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.pinned-token-estimate{margin-left:auto;font-size:10px;font-weight:500;color:#ffffff80;text-transform:none;letter-spacing:0}.pinned-token-estimate.warning{color:#f87171}.pinned-warning{font-size:11px;color:#ea4335;background:#ea43351a;border:none;border-radius:6px;padding:6px 10px;margin-bottom:8px}.pinned-item-tokens{font-size:10px;color:#fff6;flex-shrink:0}.pinned-item-tokens.truncated{color:#ea8c55}.pinned-context-list{display:flex;flex-direction:column;gap:6px}.pinned-context-item{display:flex;align-items:center;justify-content:space-between;padding:6px 10px;background:#ffffff0d;border:none;border-radius:8px;gap:8px}.pinned-item-info{display:flex;align-items:center;gap:8px;flex:1;min-width:0}.pinned-item-type{font-size:9px;font-weight:700;color:#ea8c55;background:#ea8c5533;padding:2px 5px;border-radius:4px;flex-shrink:0}.pinned-item-desc{font-size:12px;color:#ffffffb3;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pinned-item-remove{display:flex;align-items:center;justify-content:center;width:20px;height:20px;background:transparent;border:none;border-radius:4px;color:#fff6;cursor:pointer;transition:all .15s ease;flex-shrink:0}.pinned-item-remove:hover{background:#ea433533;color:#ea4335}.toast-container{position:fixed;bottom:80px;left:50%;transform:translate(-50%);display:flex;flex-direction:column;gap:8px;z-index:10000;pointer-events:none}.toast{display:flex;align-items:center;gap:12px;padding:12px 16px;background:#1e1e23f2;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:none;border-radius:12px;box-shadow:0 8px 32px #0006;animation:toast-in .25s ease-out;pointer-events:auto}@keyframes toast-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.toast-message{font-size:13px;color:#ffffffe6;max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.toast-actions{display:flex;align-items:center;gap:6px;flex-shrink:0}.toast-action-btn{padding:6px 14px;background:#4285f4;border:none;border-radius:6px;color:#fff;font-size:12px;font-weight:600;cursor:pointer;transition:background .15s ease}.toast-action-btn:hover{background:#5a9bf4}.toast-dismiss-btn{display:flex;align-items:center;justify-content:center;width:24px;height:24px;background:transparent;border:none;border-radius:4px;color:#fff6;cursor:pointer;transition:all .15s ease}.toast-dismiss-btn:hover{background:#ffffff1a;color:#fffc}.debug-info{margin-top:10px;padding:8px 10px;background:#f4b4001a;border:none;border-radius:8px;font-size:10px;font-family:ui-monospace,monospace}.debug-header{font-weight:700;color:#f4b400;margin-bottom:6px;letter-spacing:.5px}.debug-row{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:4px}.debug-row:last-child{margin-bottom:0}.debug-detail{color:#ffffff80}.go-to-screen-btn{margin-top:8px;padding:5px 10px;background:#6366f126;border:1px solid rgba(99,102,241,.25);border-radius:6px;color:#a5b4fc;font-size:12px;cursor:pointer;transition:all .15s ease;display:inline-flex;align-items:center;gap:6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.go-to-screen-btn:hover{background:#6366f140;border-color:#6366f166;color:#c7d2fe}.go-to-screen-btn svg{flex-shrink:0}.debug-btn{margin-top:8px;padding:4px 10px;background:#f4b40026;border:none;border-radius:4px;color:#f4b400;font-size:11px;font-family:ui-monospace,monospace;cursor:pointer;transition:all .15s ease}.debug-btn:hover{background:#f4b40040}.debug-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:10000;padding:20px}.debug-modal{background:#1a1a1a;border:none;border-radius:12px;width:100%;max-width:900px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #00000080}.debug-modal-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid #333}.debug-modal-header h3{margin:0;font-size:16px;color:#f4b400}.debug-modal-close{background:none;border:none;color:#666;font-size:24px;cursor:pointer;padding:0;line-height:1}.debug-modal-close:hover{color:#fff}.debug-modal-content{padding:20px;overflow-y:auto;flex:1}.debug-section{margin-bottom:24px}.debug-section:last-child{margin-bottom:0}.debug-section h4{margin:0 0 12px;font-size:13px;color:#888;text-transform:uppercase;letter-spacing:.5px}.debug-meta{display:flex;flex-wrap:wrap;gap:16px;font-size:13px;color:#ccc}.debug-meta span{background:#252525;padding:6px 12px;border-radius:6px}.debug-meta strong{color:#888;margin-right:6px}.debug-pre{background:#0d0d0d;border:1px solid #333;border-radius:8px;padding:16px;margin:0;font-size:12px;font-family:ui-monospace,SF Mono,monospace;color:#a0a0a0;overflow-x:auto;white-space:pre-wrap;word-break:break-word;max-height:400px;overflow-y:auto}.auth-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:10000;padding:20px}.auth-modal{background:#171717f2;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:none;border-radius:20px;padding:40px;text-align:center;max-width:420px;width:100%;box-shadow:0 20px 60px #00000080}.auth-modal h2{color:#fff;font-size:24px;font-weight:600;margin:0 0 12px}.auth-modal .auth-subtitle{color:#fff9;font-size:15px;margin:0 0 8px}.auth-modal .auth-tokens{color:#4cd964;font-size:14px;font-weight:500;margin:0 0 28px}.auth-modal .auth-buttons{display:flex;flex-direction:column;gap:12px;margin-bottom:20px}.auth-modal .google-sign-in-button,.auth-modal .apple-sign-in-button{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:14px 24px;background:#fff;color:#000;border:none;border-radius:12px;font-size:15px;font-weight:500;cursor:pointer;transition:all .2s ease}.auth-modal .google-sign-in-button:hover,.auth-modal .apple-sign-in-button:hover{background:#f0f0f0;transform:translateY(-1px)}.auth-modal .auth-dismiss{background:none;border:none;color:#fff6;font-size:14px;cursor:pointer;padding:8px 16px;transition:color .2s ease}.auth-modal .auth-dismiss:hover{color:#ffffffb3}.pricing-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:10000;padding:20px;overflow-y:auto}.pricing-modal{background:#171717f2;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:none;border-radius:24px;padding:40px;max-width:420px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #00000080;position:relative;margin:auto}.pricing-modal-close{position:absolute;top:16px;right:16px;background:none;border:none;color:#fff6;cursor:pointer;padding:8px;border-radius:8px;transition:all .2s ease}.pricing-modal-close:hover{background:#ffffff1a;color:#fff}.pricing-content{text-align:center}.pricing-badge{display:inline-block;padding:6px 14px;border-radius:20px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin-bottom:16px}.pricing-badge.free{background:#ffffff1a;color:#fff9}.pricing-badge.pro{background:#4285f4;color:#fff}.pricing-content h2{color:#fff;font-size:28px;font-weight:700;margin:0 0 8px}.pricing-subtitle{color:#fff9;font-size:15px;margin:0 0 28px;line-height:1.5}.billing-toggle{display:flex;background:#ffffff0d;border-radius:12px;padding:4px;margin-bottom:24px}.billing-option{flex:1;padding:12px 16px;background:transparent;border:none;border-radius:10px;color:#fff9;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;position:relative}.billing-option:hover{color:#fffc}.billing-option.active{background:#ffffff1a;color:#fff}.billing-savings{display:block;font-size:11px;color:#4cd964;margin-top:2px}.pricing-display{margin-bottom:24px}.price-amount{font-size:48px;font-weight:700;color:#fff}.price-period{font-size:18px;color:#ffffff80}.price-billed{font-size:13px;color:#fff6;margin-top:4px}.pricing-features{list-style:none;padding:0;margin:0 0 28px;text-align:left}.pricing-features li{display:flex;align-items:center;gap:10px;padding:10px 0;color:#fffc;font-size:14px;border-bottom:1px solid rgba(255,255,255,.06)}.pricing-features li:last-child{border-bottom:none}.pricing-features svg{color:#4cd964;flex-shrink:0}.pricing-cta{width:100%;padding:16px 24px;background:#4285f4;border:none;border-radius:14px;color:#fff;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease}.pricing-cta:hover{transform:translateY(-2px);box-shadow:0 8px 20px #4285f466}.pricing-disclaimer{font-size:12px;color:#fff6;margin:16px 0 0}.extra-tokens-card{background:#ffffff0d;border:none;border-radius:16px;padding:24px;margin-top:24px}.extra-tokens-amount{font-size:24px;font-weight:700;color:#fff;margin-bottom:4px}.extra-tokens-price{font-size:36px;font-weight:700;color:#4cd964;margin-bottom:4px}.extra-tokens-note{font-size:13px;color:#ffffff80;margin-bottom:20px}.token-usage-badge.pro{background:#4285f426;border:none}.token-usage-badge .tier-badge{background:#4285f4;color:#fff;font-size:9px;font-weight:700;padding:2px 6px;border-radius:4px;text-transform:uppercase}.token-popover-header .tier-label{background:#4285f4;color:#fff;font-size:9px;font-weight:700;padding:3px 8px;border-radius:4px;margin-left:auto;text-transform:uppercase}.token-row.extra span:last-child{color:#4cd964}.token-row.period{font-size:11px;color:#fff6}.token-upgrade-btn{width:100%;margin-top:12px;padding:10px 16px;background:#4285f4;border:none;border-radius:8px;color:#fff;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s ease}.token-upgrade-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #4285f466}.payment-waiting,.payment-success,.payment-timeout{text-align:center;padding:20px 0}.payment-waiting-spinner{width:48px;height:48px;border:3px solid rgba(255,255,255,.1);border-top-color:#4285f4;border-radius:50%;margin:0 auto 24px;animation:spin 1s linear infinite}.payment-success-icon{width:72px;height:72px;background:#4cd964;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 24px}.payment-success-icon svg{stroke:#fff}.payment-timeout-actions{display:flex;flex-direction:column;gap:12px;margin-top:24px}.pricing-cta.secondary{background:#ffffff1a;color:#fffc}.pricing-cta.secondary:hover{background:#ffffff26;transform:none;box-shadow:none}.mobile-chat-toggle{display:none;align-items:center;justify-content:center;width:36px;height:36px;padding:0!important;background:#4285f426!important;border:none;border-radius:10px!important;color:#4285f4;cursor:pointer;transition:all .15s ease;flex-shrink:0;margin-left:auto}.mobile-chat-toggle:hover{background:#4285f440!important;color:#fff}.mobile-chat-toggle.active{background:#4285f4!important;color:#fff}.chat-panel-wrapper{display:flex}@media (max-width: 768px){.toolbar{padding:6px 8px}.toolbar .separator,.toolbar .toolbar-group.zoom-controls,.toolbar .toolbar-group:has(button[title="Undo (Cmd+Z)"]),.toolbar .artboards-popover-container,.toolbar .sync-status,.toolbar .token-usage-badge,.toolbar .user-profile,.toolbar .sign-in-btn,.toolbar .canvas-selector{display:none}.canvas-container{flex:1}.mobile-chat-toggle{display:flex}.chat-panel-wrapper{display:none}.chat-panel-wrapper.open{display:flex;position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:#00000080;animation:fade-in .2s ease}.chat-panel-wrapper.open .chat-panel{width:100%;max-width:380px;margin-left:auto;height:100%;border-left:none;animation:slide-in-right .25s ease}.bottom-toolbar{bottom:12px}}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes slide-in-right{0%{transform:translate(100%)}to{transform:translate(0)}}.shared-view-app{display:flex;flex-direction:column;height:100vh}.shared-view-canvas-only{position:relative;width:100vw;height:100vh;overflow:hidden;background:#0f0f0f}.shared-view-mascot{position:fixed;bottom:20px;right:20px;z-index:200;display:flex;flex-direction:column;align-items:flex-end;gap:8px}.shared-view-mascot-btn{width:44px;height:44px;border-radius:50%;background:#171717e6;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.12);cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;box-shadow:0 4px 20px #0006;transition:transform .15s ease,box-shadow .15s ease}.shared-view-mascot-btn:hover{transform:scale(1.08);box-shadow:0 6px 24px #00000080}.shared-view-mascot-btn img{border-radius:50%}.shared-view-mascot-popup{background:#171717f2;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:14px 16px;min-width:200px;box-shadow:0 8px 32px #00000080;animation:mascotPopupIn .15s ease}@keyframes mascotPopupIn{0%{opacity:0;transform:scale(.95) translateY(4px)}to{opacity:1;transform:scale(1) translateY(0)}}.shared-view-mascot-popup-title{color:#ffffffe6;font-size:13px;font-weight:600;margin-bottom:4px}.shared-view-mascot-popup-desc{color:#ffffff73;font-size:11px;line-height:1.4;margin-bottom:12px}.shared-view-mascot-cta{display:block;padding:7px 12px;background:#6366f133;color:#8c8ffff2;border:1px solid rgba(99,102,241,.3);border-radius:7px;text-decoration:none;font-size:12px;font-weight:500;text-align:center;transition:all .15s ease}.shared-view-mascot-cta:hover{background:#6366f14d}.shared-view-nav-minimal{position:fixed;bottom:20px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:6px;padding:8px 12px;background:#171717d9;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.08);border-radius:100px;z-index:100}.shared-view-nav-dot{width:6px;height:6px;border-radius:50%;background:#ffffff40;border:none;padding:0;cursor:pointer;transition:background .15s ease,transform .15s ease}.shared-view-nav-dot:hover{background:#ffffff80;transform:scale(1.3)}.shared-view-nav-dot.active{background:#8184ffe6;transform:scale(1.2)}.shared-view-toolbar{display:flex;align-items:center;gap:12px;padding:0 16px;height:48px;background:#171717e6;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid rgba(255,255,255,.06);flex-shrink:0}.shared-view-toolbar .toolbar-logo{text-decoration:none}.shared-view-canvas-name{color:#ffffffe6;font-size:13px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:300px}.shared-view-artboard-indicator{color:#fff6;display:flex;align-items:center}.shared-view-badge{display:inline-flex;align-items:center;padding:2px 10px;background:#6366f126;color:#8184ffe6;border:1px solid rgba(99,102,241,.25);border-radius:100px;font-size:11px;font-weight:500;letter-spacing:.3px;white-space:nowrap}.shared-view-owner{color:#fff6;font-size:12px;white-space:nowrap}.shared-view-error{display:flex;align-items:center;justify-content:center;height:100vh;background:#0a0a0a}.shared-view-error-content{text-align:center;color:#ffffffb3}.shared-view-error-content svg{color:#ffffff4d;margin-bottom:16px}.shared-view-error-content h2{color:#ffffffe6;font-size:20px;margin:0 0 8px}.shared-view-error-content p{font-size:14px;margin:0 0 24px;color:#ffffff80}.shared-view-home-link{display:inline-block;padding:8px 20px;background:#6366f126;color:#8184ffe6;border:1px solid rgba(99,102,241,.3);border-radius:8px;text-decoration:none;font-size:13px;font-weight:500;transition:all .15s ease}.shared-view-home-link:hover{background:#6366f140}.shared-view-nav{position:fixed;bottom:16px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:4px;padding:4px;background:#171717eb;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.08);border-radius:10px;z-index:100;max-width:calc(100vw - 32px);overflow-x:auto;scrollbar-width:none}.shared-view-nav::-webkit-scrollbar{display:none}.shared-view-nav-item{display:flex;align-items:center;gap:6px;padding:6px 12px;background:transparent;border:1px solid transparent;border-radius:7px;color:#ffffff80;font-size:12px;font-weight:500;cursor:pointer;white-space:nowrap;transition:all .15s ease}.shared-view-nav-item:hover{color:#fffc;background:#ffffff0f}.shared-view-nav-item.active{color:#fffffff2;background:#6366f126;border-color:#6366f14d}.shared-view-nav-label{max-width:120px;overflow:hidden;text-overflow:ellipsis}.share-popover-container{position:relative}.share-btn{display:flex;align-items:center;gap:6px;padding:4px 10px;background:#6366f11f;border:1px solid rgba(99,102,241,.25);border-radius:6px;color:#8184ffe6;font-size:12px;font-weight:500;cursor:pointer;transition:all .15s ease;white-space:nowrap}.share-btn:hover,.share-btn.active{background:#6366f133;border-color:#6366f166}.share-popover{position:absolute;top:calc(100% + 8px);right:0;width:340px;background:#1e1e23fa;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.08);border-radius:12px;box-shadow:0 12px 40px #00000080;z-index:1000;overflow:hidden}.share-popover-header{padding:12px 16px;font-size:12px;font-weight:600;color:#ffffff80;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid rgba(255,255,255,.06)}.share-popover-content{padding:16px}.share-description{font-size:12px;color:#ffffff80;margin:0 0 12px;line-height:1.4}.share-link-row{display:flex;gap:8px;margin-bottom:8px}.share-link-input{flex:1;padding:6px 10px;background:#ffffff0f;border:1px solid rgba(255,255,255,.1);border-radius:6px;color:#fffc;font-size:12px;font-family:monospace;outline:none;min-width:0}.share-link-input:focus{border-color:#6366f166}.share-copy-btn{padding:6px 12px;background:#6366f133;border:1px solid rgba(99,102,241,.3);border-radius:6px;color:#8184ffe6;font-size:12px;font-weight:500;cursor:pointer;white-space:nowrap;transition:all .15s ease}.share-copy-btn:hover{background:#6366f14d}.share-generate-btn{width:100%;padding:8px 16px;background:#6366f133;border:1px solid rgba(99,102,241,.3);border-radius:8px;color:#8184ffe6;font-size:13px;font-weight:500;cursor:pointer;transition:all .15s ease}.share-generate-btn:hover:not(:disabled){background:#6366f14d}.share-generate-btn:disabled{opacity:.5;cursor:not-allowed}.share-revoke-btn{width:100%;padding:6px 12px;background:transparent;border:1px solid rgba(234,67,53,.2);border-radius:6px;color:#ea4335b3;font-size:12px;cursor:pointer;transition:all .15s ease;margin-top:8px}.share-revoke-btn:hover:not(:disabled){background:#ea43351a;border-color:#ea43354d}.share-revoke-btn:disabled{opacity:.5;cursor:not-allowed}.artboard-share-btn{display:flex;align-items:center;justify-content:center;width:24px;height:24px;background:transparent;border:none;border-radius:4px;color:#ffffff4d;cursor:pointer;transition:all .15s ease;flex-shrink:0;margin-left:auto}.artboard-share-btn:hover{background:#6366f126;color:#8184ffe6}.react-flow{direction:ltr;--xy-edge-stroke-default: #b1b1b7;--xy-edge-stroke-width-default: 1;--xy-edge-stroke-selected-default: #555;--xy-connectionline-stroke-default: #b1b1b7;--xy-connectionline-stroke-width-default: 1;--xy-attribution-background-color-default: rgba(255, 255, 255, .5);--xy-minimap-background-color-default: #fff;--xy-minimap-mask-background-color-default: rgba(240, 240, 240, .6);--xy-minimap-mask-stroke-color-default: transparent;--xy-minimap-mask-stroke-width-default: 1;--xy-minimap-node-background-color-default: #e2e2e2;--xy-minimap-node-stroke-color-default: transparent;--xy-minimap-node-stroke-width-default: 2;--xy-background-color-default: transparent;--xy-background-pattern-dots-color-default: #91919a;--xy-background-pattern-lines-color-default: #eee;--xy-background-pattern-cross-color-default: #e2e2e2;background-color:var(--xy-background-color, var(--xy-background-color-default));--xy-node-color-default: inherit;--xy-node-border-default: 1px solid #1a192b;--xy-node-background-color-default: #fff;--xy-node-group-background-color-default: rgba(240, 240, 240, .25);--xy-node-boxshadow-hover-default: 0 1px 4px 1px rgba(0, 0, 0, .08);--xy-node-boxshadow-selected-default: 0 0 0 .5px #1a192b;--xy-node-border-radius-default: 3px;--xy-handle-background-color-default: #1a192b;--xy-handle-border-color-default: #fff;--xy-selection-background-color-default: rgba(0, 89, 220, .08);--xy-selection-border-default: 1px dotted rgba(0, 89, 220, .8);--xy-controls-button-background-color-default: #fefefe;--xy-controls-button-background-color-hover-default: #f4f4f4;--xy-controls-button-color-default: inherit;--xy-controls-button-color-hover-default: inherit;--xy-controls-button-border-color-default: #eee;--xy-controls-box-shadow-default: 0 0 2px 1px rgba(0, 0, 0, .08);--xy-edge-label-background-color-default: #ffffff;--xy-edge-label-color-default: inherit;--xy-resize-background-color-default: #3367d9}.react-flow.dark{--xy-edge-stroke-default: #3e3e3e;--xy-edge-stroke-width-default: 1;--xy-edge-stroke-selected-default: #727272;--xy-connectionline-stroke-default: #b1b1b7;--xy-connectionline-stroke-width-default: 1;--xy-attribution-background-color-default: rgba(150, 150, 150, .25);--xy-minimap-background-color-default: #141414;--xy-minimap-mask-background-color-default: rgba(60, 60, 60, .6);--xy-minimap-mask-stroke-color-default: transparent;--xy-minimap-mask-stroke-width-default: 1;--xy-minimap-node-background-color-default: #2b2b2b;--xy-minimap-node-stroke-color-default: transparent;--xy-minimap-node-stroke-width-default: 2;--xy-background-color-default: #141414;--xy-background-pattern-dots-color-default: #777;--xy-background-pattern-lines-color-default: #777;--xy-background-pattern-cross-color-default: #777;--xy-node-color-default: #f8f8f8;--xy-node-border-default: 1px solid #3c3c3c;--xy-node-background-color-default: #1e1e1e;--xy-node-group-background-color-default: rgba(240, 240, 240, .25);--xy-node-boxshadow-hover-default: 0 1px 4px 1px rgba(255, 255, 255, .08);--xy-node-boxshadow-selected-default: 0 0 0 .5px #999;--xy-handle-background-color-default: #bebebe;--xy-handle-border-color-default: #1e1e1e;--xy-selection-background-color-default: rgba(200, 200, 220, .08);--xy-selection-border-default: 1px dotted rgba(200, 200, 220, .8);--xy-controls-button-background-color-default: #2b2b2b;--xy-controls-button-background-color-hover-default: #3e3e3e;--xy-controls-button-color-default: #f8f8f8;--xy-controls-button-color-hover-default: #fff;--xy-controls-button-border-color-default: #5b5b5b;--xy-controls-box-shadow-default: 0 0 2px 1px rgba(0, 0, 0, .08);--xy-edge-label-background-color-default: #141414;--xy-edge-label-color-default: #f8f8f8}.react-flow__background{background-color:var(--xy-background-color-props, var(--xy-background-color, var(--xy-background-color-default)));pointer-events:none;z-index:-1}.react-flow__container{position:absolute;width:100%;height:100%;top:0;left:0}.react-flow__pane{z-index:1}.react-flow__pane.draggable{cursor:grab}.react-flow__pane.dragging{cursor:grabbing}.react-flow__pane.selection{cursor:pointer}.react-flow__viewport{transform-origin:0 0;z-index:2;pointer-events:none}.react-flow__renderer{z-index:4}.react-flow__selection{z-index:6}.react-flow__nodesselection-rect:focus,.react-flow__nodesselection-rect:focus-visible{outline:none}.react-flow__edge-path{stroke:var(--xy-edge-stroke, var(--xy-edge-stroke-default));stroke-width:var(--xy-edge-stroke-width, var(--xy-edge-stroke-width-default));fill:none}.react-flow__connection-path{stroke:var(--xy-connectionline-stroke, var(--xy-connectionline-stroke-default));stroke-width:var(--xy-connectionline-stroke-width, var(--xy-connectionline-stroke-width-default));fill:none}.react-flow .react-flow__edges{position:absolute}.react-flow .react-flow__edges svg{overflow:visible;position:absolute;pointer-events:none}.react-flow__edge{pointer-events:visibleStroke}.react-flow__edge.selectable{cursor:pointer}.react-flow__edge.animated path{stroke-dasharray:5;animation:dashdraw .5s linear infinite}.react-flow__edge.animated path.react-flow__edge-interaction{stroke-dasharray:none;animation:none}.react-flow__edge.inactive{pointer-events:none}.react-flow__edge.selected,.react-flow__edge:focus,.react-flow__edge:focus-visible{outline:none}.react-flow__edge.selected .react-flow__edge-path,.react-flow__edge.selectable:focus .react-flow__edge-path,.react-flow__edge.selectable:focus-visible .react-flow__edge-path{stroke:var(--xy-edge-stroke-selected, var(--xy-edge-stroke-selected-default))}.react-flow__edge-textwrapper{pointer-events:all}.react-flow__edge .react-flow__edge-text{pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-flow__arrowhead polyline{stroke:var(--xy-edge-stroke, var(--xy-edge-stroke-default))}.react-flow__arrowhead polyline.arrowclosed{fill:var(--xy-edge-stroke, var(--xy-edge-stroke-default))}.react-flow__connection{pointer-events:none}.react-flow__connection .animated{stroke-dasharray:5;animation:dashdraw .5s linear infinite}svg.react-flow__connectionline{z-index:1001;overflow:visible;position:absolute}.react-flow__nodes{pointer-events:none;transform-origin:0 0}.react-flow__node{position:absolute;-webkit-user-select:none;-moz-user-select:none;user-select:none;pointer-events:all;transform-origin:0 0;box-sizing:border-box;cursor:default}.react-flow__node.selectable{cursor:pointer}.react-flow__node.draggable{cursor:grab;pointer-events:all}.react-flow__node.draggable.dragging{cursor:grabbing}.react-flow__nodesselection{z-index:3;transform-origin:left top;pointer-events:none}.react-flow__nodesselection-rect{position:absolute;pointer-events:all;cursor:grab}.react-flow__handle{position:absolute;pointer-events:none;min-width:5px;min-height:5px;width:6px;height:6px;background-color:var(--xy-handle-background-color, var(--xy-handle-background-color-default));border:1px solid var(--xy-handle-border-color, var(--xy-handle-border-color-default));border-radius:100%}.react-flow__handle.connectingfrom{pointer-events:all}.react-flow__handle.connectionindicator{pointer-events:all;cursor:crosshair}.react-flow__handle-bottom{top:auto;left:50%;bottom:0;transform:translate(-50%,50%)}.react-flow__handle-top{top:0;left:50%;transform:translate(-50%,-50%)}.react-flow__handle-left{top:50%;left:0;transform:translate(-50%,-50%)}.react-flow__handle-right{top:50%;right:0;transform:translate(50%,-50%)}.react-flow__edgeupdater{cursor:move;pointer-events:all}.react-flow__pane.selection .react-flow__panel{pointer-events:none}.react-flow__panel{position:absolute;z-index:5;margin:15px}.react-flow__panel.top{top:0}.react-flow__panel.bottom{bottom:0}.react-flow__panel.top.center,.react-flow__panel.bottom.center{left:50%;transform:translate(-15px) translate(-50%)}.react-flow__panel.left{left:0}.react-flow__panel.right{right:0}.react-flow__panel.left.center,.react-flow__panel.right.center{top:50%;transform:translateY(-15px) translateY(-50%)}.react-flow__attribution{font-size:10px;background:var(--xy-attribution-background-color, var(--xy-attribution-background-color-default));padding:2px 3px;margin:0}.react-flow__attribution a{text-decoration:none;color:#999}@keyframes dashdraw{0%{stroke-dashoffset:10}}.react-flow__edgelabel-renderer{position:absolute;width:100%;height:100%;pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none;left:0;top:0}.react-flow__viewport-portal{position:absolute;width:100%;height:100%;left:0;top:0;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-flow__minimap{background:var( --xy-minimap-background-color-props, var(--xy-minimap-background-color, var(--xy-minimap-background-color-default)) )}.react-flow__minimap-svg{display:block}.react-flow__minimap-mask{fill:var( --xy-minimap-mask-background-color-props, var(--xy-minimap-mask-background-color, var(--xy-minimap-mask-background-color-default)) );stroke:var( --xy-minimap-mask-stroke-color-props, var(--xy-minimap-mask-stroke-color, var(--xy-minimap-mask-stroke-color-default)) );stroke-width:var( --xy-minimap-mask-stroke-width-props, var(--xy-minimap-mask-stroke-width, var(--xy-minimap-mask-stroke-width-default)) )}.react-flow__minimap-node{fill:var( --xy-minimap-node-background-color-props, var(--xy-minimap-node-background-color, var(--xy-minimap-node-background-color-default)) );stroke:var( --xy-minimap-node-stroke-color-props, var(--xy-minimap-node-stroke-color, var(--xy-minimap-node-stroke-color-default)) );stroke-width:var( --xy-minimap-node-stroke-width-props, var(--xy-minimap-node-stroke-width, var(--xy-minimap-node-stroke-width-default)) )}.react-flow__background-pattern.dots{fill:var( --xy-background-pattern-color-props, var(--xy-background-pattern-color, var(--xy-background-pattern-dots-color-default)) )}.react-flow__background-pattern.lines{stroke:var( --xy-background-pattern-color-props, var(--xy-background-pattern-color, var(--xy-background-pattern-lines-color-default)) )}.react-flow__background-pattern.cross{stroke:var( --xy-background-pattern-color-props, var(--xy-background-pattern-color, var(--xy-background-pattern-cross-color-default)) )}.react-flow__controls{display:flex;flex-direction:column;box-shadow:var(--xy-controls-box-shadow, var(--xy-controls-box-shadow-default))}.react-flow__controls.horizontal{flex-direction:row}.react-flow__controls-button{display:flex;justify-content:center;align-items:center;height:26px;width:26px;padding:4px;border:none;background:var(--xy-controls-button-background-color, var(--xy-controls-button-background-color-default));border-bottom:1px solid var( --xy-controls-button-border-color-props, var(--xy-controls-button-border-color, var(--xy-controls-button-border-color-default)) );color:var( --xy-controls-button-color-props, var(--xy-controls-button-color, var(--xy-controls-button-color-default)) );cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-flow__controls-button svg{width:100%;max-width:12px;max-height:12px;fill:currentColor}.react-flow__edge.updating .react-flow__edge-path{stroke:#777}.react-flow__edge-text{font-size:10px}.react-flow__node.selectable:focus,.react-flow__node.selectable:focus-visible{outline:none}.react-flow__node-input,.react-flow__node-default,.react-flow__node-output,.react-flow__node-group{padding:10px;border-radius:var(--xy-node-border-radius, var(--xy-node-border-radius-default));width:150px;font-size:12px;color:var(--xy-node-color, var(--xy-node-color-default));text-align:center;border:var(--xy-node-border, var(--xy-node-border-default));background-color:var(--xy-node-background-color, var(--xy-node-background-color-default))}.react-flow__node-input.selectable:hover,.react-flow__node-default.selectable:hover,.react-flow__node-output.selectable:hover,.react-flow__node-group.selectable:hover{box-shadow:var(--xy-node-boxshadow-hover, var(--xy-node-boxshadow-hover-default))}.react-flow__node-input.selectable.selected,.react-flow__node-input.selectable:focus,.react-flow__node-input.selectable:focus-visible,.react-flow__node-default.selectable.selected,.react-flow__node-default.selectable:focus,.react-flow__node-default.selectable:focus-visible,.react-flow__node-output.selectable.selected,.react-flow__node-output.selectable:focus,.react-flow__node-output.selectable:focus-visible,.react-flow__node-group.selectable.selected,.react-flow__node-group.selectable:focus,.react-flow__node-group.selectable:focus-visible{box-shadow:var(--xy-node-boxshadow-selected, var(--xy-node-boxshadow-selected-default))}.react-flow__node-group{background-color:var(--xy-node-group-background-color, var(--xy-node-group-background-color-default))}.react-flow__nodesselection-rect,.react-flow__selection{background:var(--xy-selection-background-color, var(--xy-selection-background-color-default));border:var(--xy-selection-border, var(--xy-selection-border-default))}.react-flow__nodesselection-rect:focus,.react-flow__nodesselection-rect:focus-visible,.react-flow__selection:focus,.react-flow__selection:focus-visible{outline:none}.react-flow__controls-button:hover{background:var( --xy-controls-button-background-color-hover-props, var(--xy-controls-button-background-color-hover, var(--xy-controls-button-background-color-hover-default)) );color:var( --xy-controls-button-color-hover-props, var(--xy-controls-button-color-hover, var(--xy-controls-button-color-hover-default)) )}.react-flow__controls-button:disabled{pointer-events:none}.react-flow__controls-button:disabled svg{fill-opacity:.4}.react-flow__controls-button:last-child{border-bottom:none}.react-flow__controls.horizontal .react-flow__controls-button{border-bottom:none;border-right:1px solid var( --xy-controls-button-border-color-props, var(--xy-controls-button-border-color, var(--xy-controls-button-border-color-default)) )}.react-flow__controls.horizontal .react-flow__controls-button:last-child{border-right:none}.react-flow__resize-control{position:absolute}.react-flow__resize-control.left,.react-flow__resize-control.right{cursor:ew-resize}.react-flow__resize-control.top,.react-flow__resize-control.bottom{cursor:ns-resize}.react-flow__resize-control.top.left,.react-flow__resize-control.bottom.right{cursor:nwse-resize}.react-flow__resize-control.bottom.left,.react-flow__resize-control.top.right{cursor:nesw-resize}.react-flow__resize-control.handle{width:5px;height:5px;border:1px solid #fff;border-radius:1px;background-color:var(--xy-resize-background-color, var(--xy-resize-background-color-default));translate:-50% -50%}.react-flow__resize-control.handle.left{left:0;top:50%}.react-flow__resize-control.handle.right{left:100%;top:50%}.react-flow__resize-control.handle.top{left:50%;top:0}.react-flow__resize-control.handle.bottom{left:50%;top:100%}.react-flow__resize-control.handle.top.left,.react-flow__resize-control.handle.bottom.left{left:0}.react-flow__resize-control.handle.top.right,.react-flow__resize-control.handle.bottom.right{left:100%}.react-flow__resize-control.line{border-color:var(--xy-resize-background-color, var(--xy-resize-background-color-default));border-width:0;border-style:solid}.react-flow__resize-control.line.left,.react-flow__resize-control.line.right{width:1px;transform:translate(-50%);top:0;height:100%}.react-flow__resize-control.line.left{left:0;border-left-width:1px}.react-flow__resize-control.line.right{left:100%;border-right-width:1px}.react-flow__resize-control.line.top,.react-flow__resize-control.line.bottom{height:1px;transform:translateY(-50%);left:0;width:100%}.react-flow__resize-control.line.top{top:0;border-top-width:1px}.react-flow__resize-control.line.bottom{border-bottom-width:1px;top:100%}.react-flow__edge-textbg{fill:var(--xy-edge-label-background-color, var(--xy-edge-label-background-color-default))}.react-flow__edge-text{fill:var(--xy-edge-label-color, var(--xy-edge-label-color-default))}.aigma-nodes-root .react-flow__node{padding:0;border-radius:10px;border:none;background:transparent;box-shadow:none;font-size:13px}.aigma-nodes-root .react-flow__node.selected,.aigma-nodes-root .react-flow__node:focus,.aigma-nodes-root .react-flow__node:focus-visible{outline:none}.aigma-node{background:#242424;border:1px solid #363636;border-radius:10px;min-width:260px;color:#e5e5e5;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;box-shadow:0 4px 24px #0009;transition:border-color .15s;overflow:visible}.aigma-node.selected{border-color:#444;box-shadow:0 0 0 4px #1e1e1e,0 4px 24px #0009}.aigma-node.published{border-color:#10b981;box-shadow:0 0 8px 1px #10b98155,0 0 20px 4px #10b98122;animation:published-pulse 3s ease-in-out infinite}.aigma-node.published.selected{border-color:#10b981;box-shadow:0 0 0 4px #1e1e1e,0 0 12px 2px #10b98166,0 0 28px 6px #10b98128}@keyframes published-pulse{0%,to{box-shadow:0 0 8px 1px #10b98155,0 0 20px 4px #10b98122}50%{box-shadow:0 0 12px 2px #10b98177,0 0 28px 6px #10b98133}}.node-header{display:flex;align-items:center;gap:7px;padding:9px 12px 8px;border-bottom:1px solid #333}.node-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.dot-green{background:#10b981;box-shadow:0 0 6px #10b98155}.dot-pink{background:#ec4899;box-shadow:0 0 6px #ec489955}.dot-blue{background:#3b82f6;box-shadow:0 0 6px #3b82f655}.dot-purple{background:#8b5cf6;box-shadow:0 0 6px #8b5cf655}.dot-amber{background:#f59e0b;box-shadow:0 0 6px #f59e0b55}.node-label{font-size:11px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:#666}.status-badge{font-size:10px;font-weight:500;padding:2px 7px;border-radius:999px;letter-spacing:.02em}.badge-done{background:#10b98118;color:#10b981}.badge-error{background:#ef444418;color:#ef4444}.badge-running{background:#8b5cf618;color:#8b5cf6}.badge-published{background:#10b98118;color:#10b981;text-decoration:none;cursor:pointer}.badge-published:hover{background:#10b98130}.node-body{padding:10px 12px 12px;display:flex;flex-direction:column;gap:8px}.prompt-textarea{width:100%;background:#111;border:1px solid #2a2a2a;border-radius:6px;color:#e5e5e5;font-size:12.5px;line-height:1.6;padding:8px 10px;resize:vertical;outline:none;font-family:inherit;min-height:96px;box-sizing:border-box;transition:border-color .15s}.prompt-textarea:focus{border-color:#10b981}.prompt-textarea::placeholder{color:#3a3a3a}.model-select{width:100%;background:#111;border:1px solid #2a2a2a;border-radius:6px;color:#aaa;font-size:12px;padding:7px 28px 7px 10px;outline:none;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%23555' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center}.model-select option{background:#1a1a1a}.model-select:disabled{opacity:.5}.image-dropzone{display:flex;flex-direction:column;align-items:center;gap:8px;padding:24px 16px;border:1px dashed #2d2d2d;border-radius:7px;color:#444;cursor:pointer;font-size:12px;transition:all .15s;text-align:center}.image-dropzone:hover{border-color:#ec4899;color:#ec4899;background:#ec489908}.image-preview-wrap{position:relative;cursor:pointer;border-radius:7px;overflow:hidden}.image-preview{max-height:180px;max-width:100%;width:auto;height:auto;display:block;border-radius:7px;margin:0 auto}.image-replace-hint{position:absolute;top:0;right:0;bottom:0;left:0;background:#0000008c;display:flex;align-items:center;justify-content:center;font-size:12px;color:#ccc;opacity:0;transition:opacity .15s;border-radius:7px}.image-preview-wrap:hover .image-replace-hint{opacity:1}.image-bucket-node{min-width:200px;width:220px}.bucket-dropzone{display:flex;flex-direction:column;align-items:center;gap:8px;padding:24px 16px;border:1px dashed #2d2d2d;border-radius:7px;color:#444;cursor:pointer;font-size:12px;transition:all .15s;text-align:center}.bucket-dropzone:hover{border-color:#06b6d4;color:#06b6d4;background:#06b6d408}.bucket-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:5px}.bucket-thumb{position:relative;aspect-ratio:1;border-radius:5px;overflow:hidden;background:#111}.bucket-thumb-img{width:100%;height:100%;object-fit:cover;display:block}.bucket-thumb-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#0009;opacity:0;transition:opacity .15s;display:flex;align-items:center;justify-content:center;gap:5px}.bucket-thumb:hover .bucket-thumb-overlay{opacity:1}.bucket-thumb-btn{width:24px;height:24px;border-radius:4px;background:#ffffff1a;border:none;color:#ccc;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .12s}.bucket-thumb-btn:hover{background:#fff3;color:#fff}.bucket-thumb-remove:hover{background:#ef44444d;color:#f87171}.bucket-add-btn{aspect-ratio:1;border-radius:5px;background:#111;border:1px dashed #2d2d2d;color:#444;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.bucket-add-btn:hover{border-color:#06b6d4;color:#06b6d4;background:#06b6d408}.bucket-count{font-size:11px;color:#555;text-align:center}.html-output-node{min-width:440px;min-height:360px;width:100%;height:100%;display:flex;flex-direction:column}.input-handle-slot{position:absolute;left:0;transform:translateY(-50%);display:flex;align-items:center;pointer-events:none;z-index:10}.input-handle-label{position:absolute;right:18px;white-space:nowrap;font-size:10.5px;font-weight:500;letter-spacing:.03em;opacity:0;transition:opacity .2s;text-align:right;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.aigma-node:hover .input-handle-label,.aigma-node.selected .input-handle-label{opacity:1}.output-handle-slot{position:absolute;right:0;transform:translateY(-50%);display:flex;align-items:center;pointer-events:none;z-index:10}.output-handle-label{position:absolute;left:18px;white-space:nowrap;font-size:10.5px;font-weight:500;letter-spacing:.03em;color:#8b5cf6;opacity:0;transition:opacity .2s;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.aigma-node:hover .output-handle-label,.aigma-node.selected .output-handle-label{opacity:1}.ai-edit-bar{border-bottom:1px solid #262626;background:#0f0f17;padding:8px 10px;display:flex;flex-direction:column;gap:6px}.ai-edit-bar-inner{display:flex;align-items:center;gap:7px}.ai-edit-icon{flex-shrink:0;opacity:.7}.ai-edit-input{flex:1;background:#1a1a2e;border:1px solid #2d2d4a;border-radius:6px;color:#e5e5e5;font-size:12px;padding:6px 10px;outline:none;font-family:inherit;min-width:0;transition:border-color .15s}.ai-edit-input:focus{border-color:#8b5cf6}.ai-edit-input::placeholder{color:#3a3a5a}.ai-edit-input:disabled{opacity:.5}.ai-edit-apply{padding:5px 12px;background:linear-gradient(135deg,#7c3aed,#6d28d9);border:none;border-radius:5px;color:#fff;font-size:11.5px;font-weight:600;cursor:pointer;font-family:inherit;white-space:nowrap;transition:opacity .15s;display:flex;align-items:center;gap:5px;flex-shrink:0}.ai-edit-apply:hover:not(:disabled){opacity:.88}.ai-edit-apply:disabled{opacity:.4;cursor:not-allowed}.ai-edit-close{background:none;border:none;color:#444;font-size:12px;cursor:pointer;padding:2px 4px;border-radius:4px;transition:color .15s;flex-shrink:0;font-family:inherit}.ai-edit-close:hover{color:#888}.ai-edit-error{font-size:11px;color:#ef4444;padding:0 2px}.html-menu-wrap{position:relative}.html-menu-trigger{display:flex;align-items:center;justify-content:center;width:26px;height:26px;background:transparent;border:1px solid transparent;border-radius:5px;color:#555;font-size:14px;font-weight:700;letter-spacing:1px;cursor:pointer;font-family:inherit;transition:all .15s;line-height:1;padding:0}.html-menu-trigger:hover:not(:disabled){color:#aaa;border-color:#2d2d2d;background:#1e1e1e}.html-menu-trigger:disabled{opacity:.25;cursor:not-allowed}.html-menu-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:99}.html-menu-dropdown{position:absolute;top:calc(100% + 6px);right:0;background:#1a1a1a;border:1px solid #2d2d2d;border-radius:8px;padding:4px;min-width:160px;box-shadow:0 8px 24px #00000080;z-index:100;display:flex;flex-direction:column;gap:1px}.html-menu-item{display:flex;align-items:center;gap:8px;padding:7px 10px;background:transparent;border:none;border-radius:5px;color:#aaa;font-size:12px;cursor:pointer;font-family:inherit;text-align:left;transition:all .1s;width:100%}.html-menu-item:hover{background:#242424;color:#e5e5e5}.html-menu-item-ai{color:#8b5cf6}.html-menu-item-ai:hover{background:#1e1530;color:#a78bfa}.html-menu-item-publish{color:#10b981}.html-menu-item-publish:hover{background:#10b98110;color:#34d399}.html-menu-item-danger{color:#ef4444}.html-menu-item-danger:hover{background:#ef444410;color:#f87171}.html-menu-divider{height:1px;background:#222;margin:3px 4px}.run-button-inline{display:flex;align-items:center;gap:5px;padding:4px 10px;background:linear-gradient(135deg,#7c3aed,#6d28d9);border:none;border-radius:5px;color:#fff;font-size:12px;font-weight:600;cursor:pointer;transition:opacity .15s;font-family:inherit;white-space:nowrap}.run-button-inline:hover:not(:disabled){opacity:.88}.run-button-inline.running{background:linear-gradient(135deg,#4c1d95,#3b0764)}.run-button-inline:disabled{opacity:.5;cursor:not-allowed}.run-spinner{width:10px;height:10px;border:1.5px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.output-error{padding:6px 12px;font-size:11.5px;color:#ef4444;background:#ef444410;border-bottom:1px solid #262626}.html-output-body{flex:1;display:flex;flex-direction:column;min-height:300px}.html-iframe{width:100%;flex:1;border:none;border-radius:0 0 10px 10px;background:#fff;display:block}.html-empty-state{flex:1;display:flex;align-items:center;justify-content:center;color:#333;font-size:12px;padding:40px 24px;text-align:center;min-height:280px}.aurora-loader{display:flex;flex-direction:column;align-items:center;gap:12px;color:#8b5cf6}.aurora-ring{width:32px;height:32px;border-radius:50%;border:2px solid #2a2a2a;border-top-color:#8b5cf6;animation:spin .8s linear infinite}.handle-out,.handle-in{width:10px!important;height:10px!important;border-radius:50%!important;border:2px solid #1a1a1a!important}.handle-out{background:#10b981!important}.handle-out-pink{background:#ec4899!important}.react-flow__handle{width:10px!important;height:10px!important;border-radius:50%!important;border:2px solid #1a1a1a!important}.aigma-nodes-root .react-flow__edge-path{stroke:#333;stroke-width:1.5}.aigma-nodes-root .react-flow__edge.selected .react-flow__edge-path{stroke:#7c3aed}.aigma-nodes-root .react-flow__edge:hover .react-flow__edge-path{stroke:#555}.aigma-nodes-root .react-flow__connection-line{stroke:#7c3aed;stroke-width:1.5}.aigma-nodes-root .react-flow__controls{background:#1a1a1a;border:1px solid #2d2d2d;border-radius:8px;box-shadow:0 4px 16px #0006}.aigma-nodes-root .react-flow__controls-button{background:#1a1a1a;border-bottom:1px solid #222;color:#666;fill:#666}.aigma-nodes-root .react-flow__controls-button:hover{background:#222;fill:#ccc}.aigma-nodes-root .react-flow__controls-button:last-child{border-bottom:none}.resizer-line{border-color:#7c3aed55!important}.resizer-handle{background:#7c3aed!important;border:none!important;width:7px!important;height:7px!important}.nodes-graph-loading{position:absolute;top:0;right:0;bottom:0;left:0;background:#0a0a0a;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px;z-index:50;color:#444;font-size:12px;letter-spacing:.04em}.nodes-graph-loading-bar{width:180px;height:2px;background:#1e1e1e;border-radius:2px;overflow:hidden}.nodes-graph-loading-fill{height:100%;background:linear-gradient(90deg,#7c3aed,#8b5cf6,#7c3aed);background-size:200% 100%;animation:nodes-loading-slide 1.4s ease-in-out infinite;border-radius:2px}@keyframes nodes-loading-slide{0%{background-position:200% 0;width:40%}50%{background-position:0% 0;width:80%}to{background-position:-200% 0;width:40%}}.nodes-floating-dock{position:absolute;bottom:24px;left:50%;transform:translate(-50%);z-index:20;display:flex;align-items:center;gap:3px;background:#141414;border:1px solid #222;border-radius:14px;padding:6px 8px;box-shadow:0 8px 32px #0009,0 2px 8px #0006;-webkit-user-select:none;user-select:none}.nodes-float-btn{display:flex;align-items:center;gap:6px;padding:7px 13px;background:transparent;border:1px solid transparent;border-radius:9px;color:#666;font-size:12px;cursor:pointer;font-family:inherit;transition:all .15s;white-space:nowrap}.nodes-float-btn:hover{background:#1e1e1e;color:#e5e5e5;border-color:#2d2d2d}.nodes-float-icon{padding:7px 10px;min-width:34px;justify-content:center}.nodes-dock-divider{width:1px;height:20px;background:#222;margin:0 3px;flex-shrink:0}.nodes-toolbar{position:fixed;top:0;left:0;right:0;height:48px;background:#111;border-bottom:1px solid #1e1e1e;display:flex;align-items:center;padding:0 16px;gap:10px;z-index:100;-webkit-user-select:none;user-select:none}.nodes-toolbar-logo{font-size:14px;font-weight:700;color:#e5e5e5;letter-spacing:-.01em}.nodes-toolbar-logo span{color:#8b5cf6}.nodes-toolbar-divider{width:1px;height:18px;background:#242424}.nodes-toolbar-label{font-size:11px;color:#444;text-transform:uppercase;letter-spacing:.06em;font-weight:600}.nodes-add-btn{display:flex;align-items:center;gap:6px;padding:5px 11px;background:#171717;border:1px solid #252525;border-radius:6px;color:#888;font-size:12px;cursor:pointer;font-family:inherit;transition:all .15s}.nodes-add-btn:hover{background:#1e1e1e;color:#e5e5e5;border-color:#333}.add-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.dot-green-sm{background:#10b981}.dot-pink-sm{background:#ec4899}.dot-blue-sm{background:#3b82f6}.dot-amber-sm{background:#f59e0b}.dot-cyan-sm{background:#06b6d4}.nodes-toolbar-spacer{flex:1}.nodes-back-btn{display:flex;align-items:center;gap:4px;padding:5px 12px;background:transparent;border:1px solid #252525;border-radius:6px;color:#555;font-size:12px;cursor:pointer;font-family:inherit;text-decoration:none;transition:all .15s}.nodes-back-btn:hover{color:#aaa;border-color:#333}.nodes-save-status{font-size:11px;color:#444;letter-spacing:.03em}.nodes-save-status.saved{color:#10b981}.nodes-user-chip{display:flex;align-items:center;gap:7px;padding:3px 8px 3px 4px;background:#171717;border:1px solid #252525;border-radius:20px}.nodes-user-avatar{width:22px;height:22px;border-radius:50%;object-fit:cover}.nodes-user-initials{width:22px;height:22px;border-radius:50%;background:#8b5cf6;color:#fff;font-size:9px;font-weight:700;display:flex;align-items:center;justify-content:center}.nodes-user-name{font-size:12px;color:#888;max-width:80px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.nodes-signout-btn{background:none;border:none;color:#444;font-size:13px;cursor:pointer;padding:0;line-height:1;transition:color .15s}.nodes-signout-btn:hover{color:#888}.nodes-login-gate{width:100vw;height:100vh;background:#0d0d0d;display:flex;align-items:center;justify-content:center}.nodes-login-card{background:#141414;border:1px solid #222;border-radius:14px;padding:40px 36px;display:flex;flex-direction:column;align-items:center;gap:16px;width:320px;box-shadow:0 8px 40px #0009}.nodes-login-logo{font-size:20px;font-weight:700;color:#e5e5e5;letter-spacing:-.01em;margin-bottom:4px}.nodes-login-logo span{color:#8b5cf6}.nodes-login-sub{font-size:13px;color:#555;text-align:center;margin:0;line-height:1.5}.nodes-login-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:10px;padding:11px 16px;border-radius:8px;font-size:13px;font-weight:500;cursor:pointer;font-family:inherit;transition:opacity .15s;border:none}.nodes-login-btn:hover{opacity:.88}.nodes-login-google{background:#fff;color:#1a1a1a}.nodes-login-apple{background:#1c1c1c;color:#e5e5e5;border:1px solid #2d2d2d}.published-html-loading{width:100vw;height:100vh;background:#0a0a0a;display:flex;align-items:center;justify-content:center}.published-html-error{width:100vw;height:100vh;background:#0a0a0a;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:#555;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:14px;text-align:center;padding:24px}.published-html-error h2{color:#888;font-size:18px;font-weight:600;margin:0}.published-html-error p{margin:0}.published-html-error a,.published-html-error button{color:#8b5cf6;text-decoration:none;background:none;border:none;cursor:pointer;font-size:13px;font-family:inherit;padding:0}.published-html-error a:hover,.published-html-error button:hover{color:#a78bfa}.nodes-sidebar{width:172px;flex-shrink:0;background:#0e0e0e;border-right:1px solid #1a1a1a;display:flex;flex-direction:column;overflow:hidden}.nodes-sidebar-list{flex:1;overflow-y:auto;padding:6px 0}.nodes-sidebar-list::-webkit-scrollbar{width:3px}.nodes-sidebar-list::-webkit-scrollbar-thumb{background:#222;border-radius:3px}.nodes-sidebar-item{display:flex;align-items:center;gap:4px;padding:7px 8px 7px 10px;margin:1px 6px;border-radius:6px;cursor:pointer;border:1px solid transparent;transition:all .12s;min-height:34px;position:relative;box-sizing:border-box}.nodes-sidebar-item:hover{background:#161616;border-color:#222}.nodes-sidebar-item.active{background:#181828;border-color:#2d2050}.nodes-sidebar-name{flex:1;font-size:11.5px;color:#666;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0;line-height:1.4;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.nodes-sidebar-item.active .nodes-sidebar-name{color:#a78bfa}.nodes-sidebar-actions{display:flex;align-items:center;gap:1px;opacity:0;transition:opacity .12s;flex-shrink:0}.nodes-sidebar-item:hover .nodes-sidebar-actions{opacity:1}.nodes-sidebar-act{display:flex;align-items:center;justify-content:center;width:19px;height:19px;background:transparent;border:none;border-radius:4px;color:#444;cursor:pointer;padding:0;transition:all .12s}.nodes-sidebar-act:hover{background:#222;color:#999}.nodes-sidebar-act.danger:hover{background:#2a1010;color:#ef4444}.nodes-sidebar-act:disabled{opacity:.2;cursor:not-allowed}.nodes-sidebar-rename{flex:1;background:#1a1a2e;border:1px solid #3d2e8a;border-radius:4px;color:#e5e5e5;font-size:11.5px;padding:3px 6px;outline:none;font-family:inherit;min-width:0;width:100%;box-sizing:border-box}.nodes-sidebar-new{display:flex;align-items:center;justify-content:center;gap:6px;padding:8px 10px;margin:4px 6px 8px;background:transparent;border:1px dashed #1e1e1e;border-radius:7px;color:#3a3a3a;font-size:11.5px;cursor:pointer;font-family:inherit;transition:all .15s;box-sizing:border-box}.nodes-sidebar-new:hover{border-color:#2d2d2d;color:#777;background:#0a0a0a}.nodes-token-badge{display:flex;align-items:center;gap:5px;padding:3px 9px 3px 7px;background:#141414;border:1px solid #222;border-radius:20px;cursor:pointer;font-family:inherit;transition:all .15s}.nodes-token-badge:hover{background:#1a1a1a;border-color:#333}.nodes-migrate-banner{background:#120f1e;border-bottom:1px solid #2d2050;padding:7px 16px;display:flex;align-items:center;gap:10px;font-size:12px;color:#777;flex-shrink:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.nodes-migrate-btn{padding:4px 11px;background:linear-gradient(135deg,#7c3aed,#6d28d9);border:none;border-radius:5px;color:#fff;font-size:11.5px;font-weight:600;cursor:pointer;font-family:inherit;transition:opacity .15s;white-space:nowrap}.nodes-migrate-btn:hover:not(:disabled){opacity:.85}.nodes-migrate-btn:disabled{opacity:.5;cursor:not-allowed}.nodes-migrate-dismiss{background:none;border:none;color:#444;cursor:pointer;padding:2px 4px;font-size:14px;font-family:inherit;margin-left:auto;transition:color .15s;line-height:1}.nodes-migrate-dismiss:hover{color:#888}.canvas-dropdown-trigger{display:flex;align-items:center;gap:6px;padding:4px 9px 4px 8px;background:transparent;border:1px solid transparent;border-radius:6px;color:#999;font-size:12.5px;cursor:pointer;font-family:inherit;transition:all .12s;max-width:200px}.canvas-dropdown-trigger:hover{background:#161616;border-color:#222;color:#e5e5e5}.canvas-dropdown-name{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-align:left;min-width:0}.canvas-dropdown-menu{position:absolute;top:calc(100% + 6px);left:0;background:#161616;border:1px solid #252525;border-radius:9px;padding:5px;min-width:220px;max-width:280px;box-shadow:0 8px 32px #0009;z-index:200}.canvas-dropdown-list{max-height:280px;overflow-y:auto;display:flex;flex-direction:column;gap:1px}.canvas-dropdown-list::-webkit-scrollbar{width:3px}.canvas-dropdown-list::-webkit-scrollbar-thumb{background:#2a2a2a;border-radius:3px}.canvas-dropdown-item{display:flex;align-items:center;gap:6px;padding:7px 8px;border-radius:6px;cursor:pointer;transition:background .1s;min-height:34px;position:relative}.canvas-dropdown-item:hover{background:#1e1e1e}.canvas-dropdown-item.active{background:#181828}.canvas-dropdown-item-name{flex:1;font-size:12px;color:#888;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.canvas-dropdown-item.active .canvas-dropdown-item-name{color:#a78bfa}.canvas-dropdown-item-actions{display:flex;align-items:center;gap:1px;opacity:0;transition:opacity .1s;flex-shrink:0}.canvas-dropdown-item:hover .canvas-dropdown-item-actions{opacity:1}.canvas-dropdown-act{display:flex;align-items:center;justify-content:center;width:20px;height:20px;background:transparent;border:none;border-radius:4px;color:#444;cursor:pointer;padding:0;transition:all .1s}.canvas-dropdown-act:hover{background:#252525;color:#aaa}.canvas-dropdown-act.danger:hover{background:#2a1010;color:#ef4444}.canvas-dropdown-act:disabled{opacity:.2;cursor:not-allowed}.canvas-dropdown-rename{flex:1;background:#1a1a2e;border:1px solid #3d2e8a;border-radius:4px;color:#e5e5e5;font-size:12px;padding:3px 7px;outline:none;font-family:inherit;min-width:0;width:100%;box-sizing:border-box}.canvas-dropdown-divider{height:1px;background:#1e1e1e;margin:4px 0}.canvas-dropdown-new{display:flex;align-items:center;gap:7px;width:100%;padding:7px 8px;background:transparent;border:none;border-radius:6px;color:#555;font-size:12px;cursor:pointer;font-family:inherit;transition:all .1s;text-align:left}.canvas-dropdown-new:hover{background:#1e1e1e;color:#aaa}.token-popover{position:absolute;top:calc(100% + 8px);right:0;background:#161616;border:1px solid #252525;border-radius:10px;padding:12px 14px;min-width:200px;box-shadow:0 8px 32px #0009;z-index:200;display:flex;flex-direction:column;gap:8px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.token-popover-header{display:flex;align-items:center;justify-content:space-between}.token-popover-tier{font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:2px 8px;border-radius:20px}.token-popover-tier.free{background:#1e1e1e;color:#666}.token-popover-tier.pro{background:#1e1030;color:#8b5cf6}.token-popover-upgrade{padding:3px 10px;background:linear-gradient(135deg,#7c3aed,#6d28d9);border:none;border-radius:5px;color:#fff;font-size:11px;font-weight:600;cursor:pointer;font-family:inherit;transition:opacity .15s}.token-popover-upgrade:hover{opacity:.85}.token-popover-progress-row{display:flex;align-items:center;gap:4px;font-size:12px}.token-popover-bar-track{height:4px;background:#1e1e1e;border-radius:4px;overflow:hidden}.token-popover-bar-fill{height:100%;border-radius:4px;transition:width .3s ease}.token-popover-divider{height:1px;background:#1e1e1e}.token-popover-model-row{display:flex;align-items:center;justify-content:space-between;gap:8px}.token-popover-model-label{font-size:11.5px;color:#555}.token-popover-model-value{font-size:11.5px;color:#888;font-weight:500}.token-popover-provider-group{display:flex;flex-direction:column;gap:2px}.token-popover-model-sub{font-size:10.5px;color:#333;padding-left:8px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}
