.spinner-overlay{align-items:center;background-color:var(--color-bg-canvas);display:flex;height:100%;justify-content:center;left:0;position:fixed;top:0;width:100%;z-index:100}.spinner-logo{animation:spin 1.5s linear infinite;height:60px;width:60px}.image-picker-modal-overlay{align-items:center;background-color:#000000b3;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:10000}.image-picker-modal{background:var(--color-bg-ui);border:1px solid var(--border-color);border-radius:12px;box-shadow:0 20px 40px #0000004d;display:flex;flex-direction:column;max-height:80vh;max-width:800px;position:relative;width:90%;z-index:10001}.image-picker-modal-header{align-items:center;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;padding:12px 16px}.image-picker-modal-header h2{color:var(--text-primary);font-size:1rem;font-weight:600;margin:0}.close-button{background:none;border:none;border-radius:6px;color:var(--text-secondary);cursor:pointer;padding:8px;transition:all .2s ease}.close-button:hover{background-color:var(--bg-hover);color:var(--text-primary)}.image-picker-modal-body{display:flex;flex:1 1;flex-direction:column;min-height:0;overflow:hidden;padding:24px}.category-tabs{border-bottom:1px solid var(--border-color);display:flex;flex-shrink:0;gap:8px;margin-bottom:16px}.category-tab{align-items:center;background:none;border:none;border-bottom:2px solid #0000;color:var(--text-secondary);cursor:pointer;display:flex;font-size:.9rem;font-weight:500;gap:8px;padding:12px 16px;transition:all .2s ease}.category-tab:hover{background-color:var(--bg-hover);color:var(--text-primary)}.category-tab.active{border-bottom-color:var(--accent-color);color:var(--accent-color)}.category-icon{font-size:1rem}.images-grid{grid-gap:16px;display:grid;flex:1 1;gap:16px;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));min-height:0;overflow-y:auto}.image-item{background:var(--bg-secondary);border:2px solid #0000;border-radius:8px;cursor:pointer;overflow:hidden;transition:all .2s ease}.image-item:hover{border-color:var(--accent-color);box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.image-item.selected{border-color:var(--accent-color);box-shadow:0 0 0 3px #3b82f64d}.image-item img{display:block;height:120px;object-fit:cover;width:100%}.image-name{background:var(--bg-primary);border-top:1px solid var(--border-color);color:var(--text-primary);font-size:.8rem;padding:8px 12px;text-align:center}.no-images{color:var(--text-secondary);font-style:italic;grid-column:1/-1;padding:40px;text-align:center}.modal-footer{border-top:1px solid var(--border-color);display:flex;flex-shrink:0;gap:12px;justify-content:flex-end;padding:20px 24px;width:100%}.cancel-button,.confirm-button{border-radius:6px;cursor:pointer;flex:1 1;font-size:.9rem;font-weight:500;padding:10px 20px;transition:all .2s ease}.cancel-button{background:none;border:1px solid var(--border-color);color:var(--text-secondary)}.cancel-button:hover{background-color:var(--bg-hover);color:var(--text-primary)}.confirm-button{background:var(--accent-color);background-color:var(--color-button-default-highlight);border:1px solid var(--accent-color);color:#fff}.confirm-button:hover:not(:disabled){background:var(--color-accent-primary-hover);border-color:var(--accent-hover)}.confirm-button:disabled{cursor:not-allowed;opacity:.5}[data-theme=dark] .image-picker-modal{background:var(--bg-primary)}[data-theme=dark] .image-item{background:var(--bg-secondary)}[data-theme=dark] .image-name{background:var(--bg-primary)}.image-gen-node{background-color:var(--node-bg-shell);border:1px solid var(--node-border-color);border-radius:var(--node-border-radius);box-shadow:var(--node-box-shadow);display:flex;flex-direction:column;font-family:inherit;height:400px!important;min-height:400px;transition:height .3s ease-in-out;width:600px!important}.node-header{align-items:center;background-color:var(--node-header-bg-color);border-top-left-radius:var(--node-border-radius);border-top-right-radius:var(--node-border-radius);display:flex;padding:var(--node-header-padding)}.node-icon{font-size:var(--node-header-icon-size);margin-right:var(--node-header-icon-margin-right)}.node-icon,.node-title{color:var(--node-header-text-color)}.node-title{flex-grow:1;font-size:var(--node-header-font-size);font-weight:var(--node-header-font-weight);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.node-id-input{background-color:var(--color-bg-canvas);border:1px solid var(--color-border-default);border-radius:4px;font-size:.8rem;margin-left:8px;padding:4px 6px;text-align:center;width:100px}.node-body{flex-direction:column;flex-grow:1;padding:var(--node-content-padding)}.imageFrame,.node-body{display:flex;justify-content:center;overflow:hidden}.imageFrame{align-items:center;background-color:initial;border-radius:4px;color:var(--color-text-tertiary);height:100%;width:100%}.imageFrame img{height:100%;object-fit:scale-down;width:100%}.image-placeholder{font-style:italic}.image-placeholder-button{align-items:center;background-color:var(--color-border-strong);border:1px solid var(--color-border-strong);border-radius:6px;color:var(--color-text-tertiary);cursor:pointer;display:flex;font-size:1.2rem;font-style:italic;font-weight:400;justify-content:center;min-height:50px;outline:none;padding:12px 16px;text-align:center;transition:all .2s ease-in-out;-webkit-user-select:none;user-select:none}.image-placeholder-button:hover{background-color:var(--flow-selection-outline);border-color:var(--flow-selection-outline);box-shadow:0 2px 4px #0000001a;color:#fff;transform:translateY(-1px)}.image-placeholder-button:active{box-shadow:0 1px 2px #0000001a;transform:translateY(0)}.image-placeholder-button:focus{outline:2px solid var(--flow-selection-outline);outline-offset:2px}.placeholder-icon{font-size:1.5rem;margin-right:8px;opacity:.7}.image-placeholder-button:hover .placeholder-icon{opacity:1}.prompt-area{display:flex;flex-direction:column;flex-grow:1;margin-top:12px}.description-area,.style-area{display:flex;flex-direction:column;margin-bottom:8px}.prompt-area label{color:var(--color-text-secondary);font-size:.8rem;font-weight:600;margin-bottom:4px}.prompt-area textarea{border:1px solid var(--color-border-default);border-radius:4px;font-size:.9rem;line-height:1.4;padding:8px;resize:none;width:100%}.style-area textarea{min-height:40px}.description-area textarea{flex-grow:1;min-height:100px}.generate-button{align-self:flex-end;background-color:var(--color-bg-ui);border:none;border:1px solid var(--color-border-strong);border-radius:4px;color:var(--color-text-primary);cursor:pointer;font-weight:400;margin-top:4px;padding:3px 7px}.generate-button:disabled{background-color:var(--color-border-strong);cursor:not-allowed}.node-footer{align-items:center;border-top:1px solid var(--color-border-subtle);display:flex;justify-content:space-between;padding:0 5px}.error-text{color:#d9534f;font-size:.8rem}.collapse-toggle{background:none;border:none;color:var(--color-text-secondary);cursor:pointer;font-size:1.5rem;padding:0}.loader{animation:spin 1s linear infinite;border-top:4px solid var(--color-button-default-bg);border:4px solid var(--color-button-default-bg);border-radius:50%;border-top-color:var(--flow-selection-outline);height:40px;width:40px}.planner-roadmap-card{background-color:var(--color-bg-tertiary);border:1px solid var(--color-border-subtle);border-radius:8px;font-family:var(--font-primary);margin:12px 0;max-width:500px;padding:16px}.roadmap-header{margin-bottom:20px}.roadmap-title-area{align-items:center;display:flex;justify-content:space-between;margin-bottom:4px}.build-all-container{display:flex;justify-content:flex-start;margin-bottom:20px}.build-all-btn{align-items:center;background:linear-gradient(135deg,#6c5ce7,#a29bfe);border:none;border-radius:6px;box-shadow:0 4px 12px #6c5ce74d;color:#fff;cursor:pointer;display:flex;font-size:13px;font-weight:700;gap:8px;padding:8px 16px;transition:all .3s cubic-bezier(.175,.885,.32,1.275)}.build-all-btn:hover:not(:disabled){box-shadow:0 6px 16px #6c5ce766;filter:brightness(1.1);transform:translateY(-2px) scale(1.05)}.build-all-btn:active:not(:disabled){transform:translateY(0) scale(.98)}.build-all-btn:disabled{background:#ccc;box-shadow:none;cursor:default;opacity:.7}.roadmap-title-area h4{color:var(--color-text-primary);font-size:16px;margin:0}.completed-badge{background-color:#27ae6026;border-radius:4px;color:#2ecc71;font-size:11px;font-weight:600;padding:2px 6px}.roadmap-explanation{color:var(--color-text-secondary);font-size:13px;line-height:1.4;margin:0 0 12px}.roadmap-meta{color:var(--color-text-tertiary);font-size:11px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.roadmap-steps-container{display:flex;flex-direction:column;gap:0}.roadmap-step-item{display:flex;gap:16px;padding-bottom:24px;position:relative}.roadmap-step-item:last-child{padding-bottom:0}.step-timeline-indicator{align-items:center;display:flex;flex-direction:column;position:relative;width:24px}.timeline-connector{background-color:var(--color-border-subtle);bottom:-8px;position:absolute;top:24px;width:2px;z-index:1}.roadmap-step-item.status-COMPLETED .timeline-connector{background-color:#2ecc71}.icon-completed{background-color:var(--color-bg-tertiary);color:#2ecc71;font-size:20px;z-index:2}.icon-progress{animation:spin 2s linear infinite;color:var(--color-brand-primary);font-size:20px;z-index:2}.icon-pending{color:var(--color-border-subtle)}.icon-error,.icon-pending{background-color:var(--color-bg-tertiary);font-size:20px;z-index:2}.icon-error{color:#e74c3c}.icon-reviewing{background-color:var(--color-bg-tertiary);color:#f1c40f;font-size:20px;z-index:2}.step-content{align-items:flex-start;display:flex;flex:1 1;flex-direction:column}.step-content h5{color:var(--color-text-primary);font-size:14px;margin:0 0 4px}.status-PENDING .step-content h5{color:var(--color-text-secondary)}.step-type-badge{background:#ffffff0d;border:1px solid var(--color-border-subtle);border-radius:4px;color:var(--color-text-tertiary);font-size:10px;margin-bottom:12px;padding:2px 6px}.execute-step-btn{background-color:var(--color-brand-primary);border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:12px;font-weight:600;padding:6px 12px;transition:background-color .2s ease,opacity .2s ease}.execute-step-btn:hover:not(:disabled){background-color:var(--color-brand-hover)}.execute-step-btn:disabled{cursor:not-allowed;opacity:.5}.execute-step-btn.status-review{background-color:#f1c40f33;border:1px solid #f1c40f;color:#f1c40f;opacity:1}.step-actions-unified{display:flex;gap:8px;margin-top:8px}.accept-step-btn{align-items:center;background-color:var(--color-brand-primary);border:none;border-radius:4px;color:#fff;cursor:pointer;display:flex;font-size:12px;font-weight:600;gap:6px;justify-content:center;padding:6px 12px;transition:background-color .2s ease}.accept-step-btn:hover:not(:disabled){background-color:var(--color-brand-hover)}.reject-step-btn{align-items:center;background-color:#e74c3c1a;border:1px solid #e74c3c4d;border-radius:4px;color:#e74c3c;cursor:pointer;display:flex;font-size:12px;font-weight:600;gap:6px;justify-content:center;padding:6px 12px;transition:all .2s ease}.reject-step-btn:hover:not(:disabled){background-color:#e74c3c33;border-color:#e74c3c}.status-REVIEWING .step-content h5{color:#f1c40f}@keyframes spin{to{transform:rotate(1turn)}}@property --angle{syntax:"<angle>";inherits:false;initial-value:0deg}.ask-alex-page-container-with-sidebar{background-color:var(--node-bg-shell);display:flex;height:100vh;height:calc(100vh - 60px);margin-top:60px;overflow:hidden;position:relative;width:100%}.ask-alex-sidebar{background-color:var(--color-accent-secondary);border-right:1px solid var(--color-border-default);display:flex;flex-direction:column;flex-shrink:0;overflow:hidden;padding:10px;transition:width .3s ease,padding .3s ease,border .3s ease,opacity .3s ease;width:250px}.ask-alex-page-container-with-sidebar.sidebar-collapsed .ask-alex-sidebar *{opacity:0;pointer-events:none;transition:opacity .1s ease;visibility:hidden}.ask-alex-page-container-with-sidebar.sidebar-collapsed .ask-alex-sidebar{border-right:none;opacity:0;padding-left:0;padding-right:0;width:0}.ask-alex-sidebar-toggle-button{align-items:center;background-color:var(--node-bg-shell);border:1px solid var(--color-border-default);border-bottom-right-radius:5px;border-left:none;border-top-right-radius:5px;box-shadow:1px 0 3px #0000001a;color:var(--color-text-primary);cursor:pointer;display:flex;justify-content:center;left:250px;padding:10px 5px;position:absolute;top:50%;transform:translateY(-50%);transition:left .3s ease;z-index:100}.ask-alex-sidebar-toggle-button:hover{background-color:var(--color-button-default-hover-bg)}.ask-alex-page-container-with-sidebar.sidebar-collapsed .ask-alex-sidebar-toggle-button{border-left:1px solid var(--color-border-default);border-radius:0 5px 5px 0;left:0}.new-chat-button{align-items:center;background-color:var(--color-accent-primary);border:none;border-radius:5px;color:var(--color-text-inverted);cursor:pointer;display:flex;flex-shrink:0;font-weight:500;gap:8px;justify-content:center;margin:0 0 15px;padding:5px 10px;transition:background-color .2s ease;white-space:nowrap}.new-chat-button:hover{background-color:var(--color-accent-primary-hover)}.conversation-list{flex-grow:1;overflow-y:auto}.conversation-item{align-items:center;border-bottom:1px solid var(--color-border-default);color:var(--color-text-primary);cursor:pointer;display:flex;font-size:.9em;justify-content:space-between;overflow:hidden;padding:10px 15px;transition:background-color .2s ease;white-space:nowrap}.conversation-item:hover{background-color:var(--color-button-default-bg)}.conversation-item.active{background-color:var(--color-accent-secondary);color:var(--color-accent-secondary-active-text);font-weight:600}.conversation-title{flex-grow:1;margin-right:10px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.delete-chat-button{background:none;border:none;border-radius:3px;color:var(--color-text-tertiary);cursor:pointer;flex-shrink:0;line-height:1;opacity:0;padding:2px 5px;transition:opacity .2s ease,color .2s ease}.conversation-item:hover .delete-chat-button{opacity:1}.delete-chat-button:hover{background-color:var(--color-button-default-bg);color:var(--color-accent-primary)}.no-chat-selected-message,.no-conversations-message{color:var(--color-text-secondary);font-style:italic;padding:20px;text-align:center}.ask-alex-chat-window{height:100%;overflow:hidden;position:relative}.ask-alex-chat-window,.ask-alex-messages-area{background-color:var(--color-bg-ui);display:flex;flex-direction:column;flex-grow:1}.ask-alex-messages-area{gap:15px;overflow-y:auto;padding:20px}.ask-alex-message{display:flex;margin-bottom:10px}.ask-alex-message.user{justify-content:flex-end}.ask-alex-bubble-container{display:flex;flex-direction:column;max-width:75%}.ask-alex-message.user .ask-alex-bubble-container{align-items:flex-end}.ask-alex-message.alex{align-items:flex-end;gap:10px;justify-content:flex-start}.ask-alex-avatar{background-color:var(--color-bg-ui);border:none;border-radius:7px;flex-shrink:0;height:60px;margin-bottom:2px;width:60px}.ask-alex-bubble{word-wrap:break-word;border-radius:18px;max-width:100%;overflow-wrap:break-word;padding:10px 15px;position:relative;width:fit-content;z-index:0}.ask-alex-message.user .ask-alex-bubble{background-color:var(--color-border-strong)!important}.ask-alex-message.alex .ask-alex-bubble{background-color:var(--color-accent-secondary);border-bottom-left-radius:4px;color:var(--color-text-primary)}.ask-alex-message.alex.loading .ask-alex-bubble{align-items:center;display:flex;gap:10px}.ask-alex-message.error.system-error .ask-alex-bubble{background-color:var(--color-button-default-bg);border:1px solid var(--color-button-default-bg);color:var(--color-accent-primary)}.thinking-mode-container{border-top:1px solid var(--color-border-default);display:flex;flex-shrink:0;justify-content:flex-start;padding:5px 10px}.thinking-mode-container,.thinking-mode-toggle{align-items:center;background-color:var(--node-bg-shell)}.thinking-mode-toggle{border:none;border-radius:15px;color:var(--color-text-secondary);cursor:pointer;display:inline-flex;font-size:.85em;gap:6px;outline:none;padding:4px 10px;transition:background-color .2s ease,color .2s ease;-webkit-user-select:none;user-select:none;white-space:nowrap}.thinking-mode-toggle:hover:not(:disabled){background-color:var(--color-button-default-hover-bg)}.thinking-mode-toggle .toggle-icon{color:var(--color-border-default);font-size:1.8em;line-height:1;transform:rotate(180deg);transition:color .2s ease;vertical-align:middle}.thinking-mode-toggle.active .toggle-icon{color:var(--color-accent-primary);transform:rotate(0deg)}.thinking-mode-toggle span{transition:color .2s ease}.thinking-mode-toggle.active span{color:var(--color-accent-primary-hover)}.thinking-mode-toggle:disabled{cursor:not-allowed;opacity:.6}.ask-alex-input-area{align-items:flex-end;background-color:var(--node-bg-shell);border-top:1px solid var(--color-border-default);display:flex;flex-shrink:0;gap:10px;padding:15px 20px}.ask-alex-input-area textarea{background-color:var(--node-bg-shell);border:1px solid var(--color-border-default);border-radius:7px;color:var(--color-text-primary);flex-grow:1;font-family:inherit;font-size:1em;line-height:1.4;max-height:150px;min-height:44px;overflow-y:auto;padding:10px 15px;resize:none}.ask-alex-input-area textarea:focus{border:1px solid var(--flow-selection-outline)!important;box-shadow:0 0 0 .05rem #007bff40;outline:none}.ask-alex-input-area button.send-button{align-items:center;background-color:var(--color-accent-primary);border:none;border-radius:12px;color:var(--color-text-inverted);cursor:pointer;display:flex;flex-shrink:0;height:44px;justify-content:center;transition:background-color .2s ease;width:44px}.ask-alex-input-area button.send-button:hover:not(:disabled){background-color:var(--color-accent-primary-hover)}.ask-alex-input-area button.send-button:disabled{background-color:var(--color-accent-secondary);cursor:not-allowed}.ask-alex-input-area button.stop-button{align-items:center;background-color:#ff8c00;border:none;border-radius:12px;color:var(--color-text-inverted);cursor:pointer;display:flex;flex-shrink:0;height:44px;justify-content:center;transition:background-color .2s ease,transform .1s ease;width:44px}.ask-alex-input-area button.stop-button:hover{background-color:#e67e00}.ask-alex-input-area button.stop-button:active{transform:scale(.95)}.stop-icon{background-color:currentColor;border-radius:2px;height:16px;width:16px}.ask-alex-message.alex.loading .spinner-container{display:inline-block;margin-right:8px;vertical-align:middle}@media (max-width:768px){.ask-alex-page-container-with-sidebar.sidebar-collapsed .ask-alex-sidebar{border-bottom:none;opacity:0;padding-bottom:0}.ask-alex-sidebar-toggle-button{border:1px solid var(--color-border-default);border-radius:5px;left:250px;top:580px;transform:none}.ask-alex-page-container-with-sidebar.sidebar-collapsed .ask-alex-sidebar-toggle-button{border-left:1px solid var(--color-border-default);border-radius:0 5px 5px 0;left:0;right:auto}.thinking-mode-container{justify-content:center}.ask-alex-input-area{padding:10px}}.ask-alex-bubble p{line-height:1.4;margin:0 0 5px}.ask-alex-bubble p:last-child{margin-bottom:0}.ask-alex-message.user .ask-alex-bubble{background-color:var(--color-accent-primary);border-bottom-right-radius:4px;color:var(--color-text-inverted)}@keyframes marching-ants-color-cycle{to{--angle:360deg}}.ask-alex-message.alex.loading .ask-alex-bubble{--border-thickness:3px;--text-padding-vertical:10px;--text-padding-horizontal:15px;animation:marching-ants-color-cycle 4s linear infinite;background:conic-gradient(from var(--angle),#0060c7,#9be8fd 25%,#ff6ec7 50%,#ba68c8 75%,#0060c7 100%);border-radius:18px;border-bottom-left-radius:4px;color:var(--color-text-primary);overflow:hidden;padding:var(--border-thickness);position:relative;z-index:0}.ask-alex-message.alex.loading .ask-alex-bubble span{animation:none;background-color:var(--color-bg-ui);border-bottom-left-radius:calc(4px - var(--border-thickness));border-bottom-right-radius:calc(18px - var(--border-thickness));border-top-left-radius:calc(18px - var(--border-thickness));border-top-right-radius:calc(18px - var(--border-thickness));color:var(--color-text-secondary);display:block;font-weight:400;padding:var(--text-padding-vertical) var(--text-padding-horizontal)}.ask-alex-message.alex:not(.loading) .ask-alex-bubble{animation:none;background-color:var(--color-accent-secondary);background-color:var(--alex-bubble-bg,var(--color-accent-secondary));border-radius:18px;border-bottom-left-radius:4px;color:var(--color-text-primary);color:var(--alex-bubble-text,var(--color-text-primary));overflow:visible;padding:10px 15px}.ask-alex-message.alex:not(.loading) .ask-alex-bubble:before{display:none}.ask-alex-message.alex:not(.loading) .ask-alex-bubble span{background-color:initial;border-radius:0;padding:0}.ask-alex-intake-form{background-color:var(--color-bg-ui);border-top:1px solid var(--color-border-strong);display:flex;flex-direction:column;gap:15px;padding:15px}.intake-metadata{align-items:center;display:flex;gap:20px}.intake-field{display:flex;flex-direction:column;flex-grow:1;gap:5px}.intake-field label{color:var(--color-text-tertiary);font-size:.8rem;font-weight:500}.intake-field select{background-color:var(--color-button-default-bg);border:1px solid var(--color-border-default);border-radius:5px;color:var(--color-text-primary);cursor:pointer;font-size:.9rem;padding:8px 12px}.intake-field select:focus{border-color:var(--color-accent-primary);box-shadow:0 0 0 2px #049dc880;outline:none}.intake-goal-form{display:flex;flex-direction:column;gap:10px}.intake-goal-form textarea{background-color:var(--color-bg-ui);border:1px solid var(--color-border-strong);border-radius:5px;color:var(--color-text-primary);font-family:inherit;font-size:.95rem;min-height:70px;padding:10px;resize:vertical}.intake-goal-form button{background-color:var(--color-accent-primary);border:none;border-radius:5px;color:var(--color-text-inverted);cursor:pointer;font-weight:600;padding:10px 15px;transition:background-color .2s}.intake-goal-form button:hover:not(:disabled){background-color:var(--color-accent-primary-hover)}.intake-goal-form button:disabled{background-color:var(--color-text-tertiary);cursor:not-allowed}.ask-alex-input-area.chat-mode{display:flex;flex-direction:column}.finalized-goal-display{align-items:center;background-color:var(--color-bg-ui);border-bottom:1px solid var(--color-border-strong);color:var(--color-text-tertiary);display:flex;font-size:.85rem;justify-content:space-between;padding:8px 15px}.finalized-goal-display span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.finalized-goal-display button{align-items:center;background:none;border:none;color:var(--color-text-tertiary);cursor:pointer;display:flex;margin-left:10px;padding:2px}.finalized-goal-display button:hover{color:var(--color-text-primary)}.inline-roadmap-container{margin-top:10px;width:100%}.inline-roadmap-container .planner-roadmap-card{border-color:var(--color-border-subtle);box-shadow:none;margin:0;max-width:100%}.build-draft-btn{align-items:center;background-color:var(--color-brand-primary);border:none;border-radius:4px;color:#fff;cursor:pointer;display:inline-flex;font-size:12px;font-weight:600;gap:6px;margin-top:10px;padding:6px 12px;transition:background-color .2s ease,opacity .2s ease}.build-draft-btn:hover:not(:disabled){background-color:var(--color-brand-hover)}.build-draft-btn:disabled{cursor:not-allowed;opacity:.5}.react-flow{direction:ltr}.react-flow__container{height:100%;left:0;position:absolute;top:0;width:100%}.react-flow__pane{cursor:grab;z-index:1}.react-flow__pane.selection{cursor:pointer}.react-flow__pane.dragging{cursor:grabbing}.react-flow__viewport{pointer-events:none;transform-origin:0 0;z-index:2}.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 .react-flow__edges{overflow:visible;pointer-events:none}.react-flow__connection-path,.react-flow__edge-path{stroke:#b1b1b7;stroke-width:1;fill:none}.react-flow__edge{cursor:pointer;pointer-events:visibleStroke}.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:focus .react-flow__edge-path,.react-flow__edge:focus-visible .react-flow__edge-path{stroke:#555}.react-flow__edge-textwrapper{pointer-events:all}.react-flow__edge-textbg{fill:#fff}.react-flow__edge .react-flow__edge-text{pointer-events:none;-webkit-user-select:none;user-select:none}.react-flow__connection{pointer-events:none}.react-flow__connection .animated{stroke-dasharray:5;animation:dashdraw .5s linear infinite}.react-flow__connectionline{z-index:1001}.react-flow__nodes{pointer-events:none;transform-origin:0 0}.react-flow__node{box-sizing:border-box;cursor:grab;pointer-events:all;position:absolute;transform-origin:0 0;-webkit-user-select:none;user-select:none}.react-flow__node.dragging{cursor:grabbing}.react-flow__nodesselection{pointer-events:none;transform-origin:left top;z-index:3}.react-flow__nodesselection-rect{cursor:grab;pointer-events:all;position:absolute}.react-flow__handle{background:#1a192b;border:1px solid #fff;border-radius:100%;height:6px;min-height:5px;min-width:5px;pointer-events:none;position:absolute;width:6px}.react-flow__handle.connectionindicator{cursor:crosshair;pointer-events:all}.react-flow__handle-bottom{bottom:-4px;left:50%;top:auto;transform:translate(-50%)}.react-flow__handle-top{left:50%;top:-4px;transform:translate(-50%)}.react-flow__handle-left{left:-4px;top:50%;transform:translateY(-50%)}.react-flow__handle-right{right:-4px;top:50%;transform:translateY(-50%)}.react-flow__edgeupdater{cursor:move;pointer-events:all}.react-flow__panel{margin:15px;position:absolute;z-index:5}.react-flow__panel.top{top:0}.react-flow__panel.bottom{bottom:0}.react-flow__panel.left{left:0}.react-flow__panel.right{right:0}.react-flow__panel.center{left:50%;transform:translateX(-50%)}.react-flow__attribution{background:#ffffff80;font-size:10px;margin:0;padding:2px 3px}.react-flow__attribution a{color:#999;text-decoration:none}@keyframes dashdraw{0%{stroke-dashoffset:10}}.react-flow__edgelabel-renderer{height:100%;pointer-events:none;position:absolute;-webkit-user-select:none;user-select:none;width:100%}.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-default,.react-flow__node-group,.react-flow__node-input,.react-flow__node-output{background-color:#fff;border:1px solid #1a192b;border-radius:3px;color:#222;font-size:12px;padding:10px;text-align:center;width:150px}.react-flow__node-default.selectable:hover,.react-flow__node-group.selectable:hover,.react-flow__node-input.selectable:hover,.react-flow__node-output.selectable:hover{box-shadow:0 1px 4px 1px #00000014}.react-flow__node-default.selectable.selected,.react-flow__node-default.selectable:focus,.react-flow__node-default.selectable:focus-visible,.react-flow__node-group.selectable.selected,.react-flow__node-group.selectable:focus,.react-flow__node-group.selectable:focus-visible,.react-flow__node-input.selectable.selected,.react-flow__node-input.selectable:focus,.react-flow__node-input.selectable:focus-visible,.react-flow__node-output.selectable.selected,.react-flow__node-output.selectable:focus,.react-flow__node-output.selectable:focus-visible{box-shadow:0 0 0 .5px #1a192b}.react-flow__node-group{background-color:#f0f0f040}.react-flow__nodesselection-rect,.react-flow__selection{background:#0059dc14;border:1px dotted #0059dccc}.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{box-shadow:0 0 2px 1px #00000014}.react-flow__controls-button{align-items:center;background:#fefefe;border:none;border-bottom:1px solid #eee;box-sizing:initial;cursor:pointer;display:flex;height:16px;justify-content:center;padding:5px;-webkit-user-select:none;user-select:none;width:16px}.react-flow__controls-button:hover{background:#f4f4f4}.react-flow__controls-button svg{max-height:12px;max-width:12px;width:100%}.react-flow__controls-button:disabled{pointer-events:none}.react-flow__controls-button:disabled svg{fill-opacity:.4}.react-flow__minimap{background-color:#fff}.react-flow__minimap svg{display:block}.react-flow__resize-control{position:absolute}.react-flow__resize-control.left,.react-flow__resize-control.right{cursor:ew-resize}.react-flow__resize-control.bottom,.react-flow__resize-control.top{cursor:ns-resize}.react-flow__resize-control.bottom.right,.react-flow__resize-control.top.left{cursor:nwse-resize}.react-flow__resize-control.bottom.left,.react-flow__resize-control.top.right{cursor:nesw-resize}.react-flow__resize-control.handle{background-color:#3367d9;border:1px solid #fff;border-radius:1px;height:4px;transform:translate(-50%,-50%);width:4px}.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.bottom.left,.react-flow__resize-control.handle.top.left{left:0}.react-flow__resize-control.handle.bottom.right,.react-flow__resize-control.handle.top.right{left:100%}.react-flow__resize-control.line{border:0 solid #3367d9}.react-flow__resize-control.line.left,.react-flow__resize-control.line.right{height:100%;top:0;transform:translate(-50%);width:1px}.react-flow__resize-control.line.left{border-left-width:1px;left:0}.react-flow__resize-control.line.right{border-right-width:1px;left:100%}.react-flow__resize-control.line.bottom,.react-flow__resize-control.line.top{height:1px;left:0;transform:translateY(-50%);width:100%}.react-flow__resize-control.line.top{border-top-width:1px;top:0}.react-flow__resize-control.line.bottom{border-bottom-width:1px;top:100%}.main{display:flex;flex:1 1;height:calc(100vh - 60px);margin-top:60px;overflow:hidden;position:relative}.main.is-dashboard{height:100vh;margin-top:0}.react-flow-container{flex-grow:1;height:100%;min-width:0;position:relative;width:100%}.main .character-sidebar{flex-shrink:0;height:100%;width:200px}.react-flow{height:100%;width:100%}.app-container{display:flex;flex-direction:column;height:100vh;width:100%}.flow{background-color:#1e1e1e;background-image:radial-gradient(circle,#444 1px,#0000 0);background-image:radial-gradient(circle,#444 var(--dot-size,1px),#0000 var(--dot-size,1px));background-size:5px 5px;background-size:var(--grid-size,5px) var(--grid-size,5px);position:relative}.react-flow-wrapper{border:2px dashed red;height:100%;position:relative;width:100%}.rnd-resizable{background-color:#00ff001a;border:2px solid green}.react-rnd{position:relative;-webkit-user-select:none;user-select:none}.react-flow__edges{overflow:visible}.sidebar{background-color:#fff;border-right:1px solid #dfdede;box-sizing:border-box;height:100%;padding-left:15px;padding-right:15px;padding-top:0;width:220px}.dndcontainer{margin-top:80px}.dndnode{background-color:#fff;border:1px solid #ddd;border-radius:3px;font-size:14px;justify-content:space-between;padding:3px 3px 3px 10px;text-align:left}.dndnode:hover{background-color:#f0f0f0}.file-icon,.heartbeat-icon,.movie-icon,.segment-icon{color:#000;font-size:20px;margin-right:10px}.drag-icon{color:grey;font-size:20px}.BiCustomize-icon,.BsPersonVcard-icon,.structure-icon{color:#000;font-size:20px;margin-right:10px}.text-left{font-size:14px;margin-right:auto;padding-left:0}.dropdown-label,.text-left{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif}.dropdown-label{align-items:center;cursor:pointer;display:flex;font-size:22px;font-weight:700;height:30px;justify-content:space-between;margin-top:10px}.dropdown-content{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-size:14px;margin-top:5px;padding-left:10px}.icon,.icon-rotated{transition:transform .3s ease}.icon-rotated{transform:rotate(90deg)}:root{--node-font-family:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;--node-monospace-font-family:"Courier New",Courier,monospace;--node-bg-color:var(--node-bg-shell);--node-border-color:var(--color-border-default);--node-border-radius:4px;--node-box-shadow:var(--node-shadow);--node-header-bg-color:var(--node-header-bg);--node-header-border-color:#0000;--node-header-text-color:var(--color-text-primary);--node-header-height:40px;--node-header-padding:6px 10px;--node-header-font-size:16px;--node-header-font-weight:600;--node-header-icon-size:18px;--node-header-icon-margin-right:5px;--node-id-container-border:1px solid var(--color-border-light);--node-id-container-radius:3px;--node-id-container-padding:2px;--node-id-bg-color:#0000;--node-id-text-color:var(--color-text-secondary);--node-id-font-size:10px;--node-id-copy-icon-color:var(--color-text-secondary);--node-id-copy-icon-hover-color:var(--flow-selection-outline);--node-id-copy-icon-copied-color:var(--color-accent-secondary-active-text);--node-id-display-padding:3px 5px;--node-id-display-min-width:40px;--node-id-display-max-width:70px;--node-id-copy-icon-font-size:20px;--node-id-copy-icon-internal-padding:2px;--node-input-bg-color:var(--node-input-bg-color);--node-input-border-color:var(--color-border-default);--node-input-border-radius:4px;--node-input-padding:5px 10px;--node-input-font-size:16px;--node-input-text-color:var(--color-accent-secondary-active-text);--node-input-placeholder-color:var(--color-text-tertiary);--node-input-focus-border-color:var(--flow-selection-outline);--node-input-focus-box-shadow:none;--node-input-focus-border-width:2px;--node-input-font-family-override:"Courier New",Courier,monospace;--node-textarea-bg-color:var(--node-input-bg-color);--node-textarea-border-color:var(--color-border-default);--node-textarea-border-radius:4px;--node-textarea-padding:8px;--node-textarea-font-size:12px;--node-textarea-line-height:1.5;--node-textarea-min-height:350px;--node-textarea-text-color:var(--color-accent-secondary-active-text);--node-textarea-placeholder-color:var(--color-text-tertiary);--node-dropdown-bg-color:var(--node-input-bg-color);--node-dropdown-text-color:var(--node-input-text-color);--node-dropdown-border-color:var(--node-input-border-color);--node-dropdown-border-radius:var(--node-input-border-radius);--node-dropdown-padding:var(--node-input-padding);--node-dropdown-font-size:12px;--node-dropdown-font-family:var(--node-font-family);--node-color-1:#e3e3e3;--node-color-2:#b3ecff;--node-color-3:#ffb3d9;--node-color-4:#b3ffe2;--node-color-5:#fff4b3;--node-color-6:#e1c1f0;--node-color-7:#ffbeb3;--node-label-font-size:0.8em;--node-label-font-weight:700;--node-label-margin-bottom:4px;--node-label-text-color:var(--node-header-text-color);--node-button-bg-color:var(--color-button-default-hover-bg);--node-button-text-color:var(--node-header-text-color);--node-button-border-color:var(--color-border-default);--node-button-border-radius:var(--node-input-border-radius);--node-button-padding:6px 10px;--node-button-font-size:12px;--node-button-hover-bg-color:var(--color-bg-ui)}.react-flow__node{background-color:initial!important}.react-flow__node.react-flow__node-beat.nopan.selectable{width:500px!important}.character-node,.image-frame-node,.image-gen-node,.react-flow__node-character,.react-flow__node-imageframe,.react-flow__node-imagegenerationnode,.react-flow__node-visualStyle,.react-flow__node-world,.visual-style-node,.world-node{height:400px!important;overflow:visible!important;width:600px!important}.guide-node,.react-flow__node-guide{height:400px!important;overflow:visible!important;width:620px!important}.react-flow__node-Scene,.react-flow__node-SceneNode,.scene-node{height:470px!important;overflow:visible!important;width:620px!important}.react-flow__node-Sticky,.sticky-node{height:270px!important;overflow:visible!important;width:370px!important}.guide-node .Title-button-container{justify-content:flex-start;padding-right:10px}.react-flow__node-arc,.react-flow__node-backstory,.scene-node{width:600px!important}.arc-node,.backstory-node,.character-node,.guide-node,.image-frame-node,.image-gen-node,.plot-node,.structure-node,.theme-node,.visual-style-node,.world-node{align-items:stretch;background-color:var(--node-bg-shell);background-color:var(--node-bg-color);border:1px solid var(--node-border-color);border-radius:4px;border-radius:var(--node-border-radius);box-shadow:var(--node-shadow);box-shadow:var(--node-box-shadow);display:flex;flex-direction:column;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-family:var(--node-font-family);height:400px!important;min-height:400px;overflow:visible;width:600px!important}.Main.selectable.draggable{display:flex;flex-direction:column;height:100%;overflow:visible;width:100%}.header-bar-container{align-items:center;background-color:var(--node-header-bg);background-color:var(--node-header-bg-color);border-bottom:1px solid #0000;border-bottom:1px solid var(--node-header-border-color);box-sizing:border-box;cursor:grab;display:flex;flex-shrink:0;height:40px;height:var(--node-header-height);padding:6px 10px;padding:var(--node-header-padding);position:relative;width:100%}.beat-header-bar[style*="--color-brand-primary"],.header-bar-container[style*="--color-brand-primary"]{--node-header-text-color:var(--color-text-inverted)!important}.beat-header-bar[style*="--color-brand-primary"] .header-title,.beat-header-bar[style*="--color-brand-primary"] .heart-icon,.header-bar-container[style*="--color-brand-primary"] .arc-icon,.header-bar-container[style*="--color-brand-primary"] .backstory-icon,.header-bar-container[style*="--color-brand-primary"] .beat-icon,.header-bar-container[style*="--color-brand-primary"] .character-icon,.header-bar-container[style*="--color-brand-primary"] .guide-icon,.header-bar-container[style*="--color-brand-primary"] .header-title,.header-bar-container[style*="--color-brand-primary"] .plot-icon,.header-bar-container[style*="--color-brand-primary"] .scene-icon,.header-bar-container[style*="--color-brand-primary"] .structure-icon,.header-bar-container[style*="--color-brand-primary"] .theme-icon,.header-bar-container[style*="--color-brand-primary"] .world-icon{color:var(--color-text-inverted)!important}.beat-header-bar[style*="--color-brand-primary"] .id-container,.header-bar-container[style*="--color-brand-primary"] .id-container{border-color:#ffffff80!important}.beat-header-bar[style*="--color-brand-primary"] .copy-id-icon,.beat-header-bar[style*="--color-brand-primary"] .node-id-display,.header-bar-container[style*="--color-brand-primary"] .copy-id-icon,.header-bar-container[style*="--color-brand-primary"] .node-id-display{color:var(--color-text-inverted)!important}.beat-header-bar[style*="--color-brand-primary"] .id-container:hover,.header-bar-container[style*="--color-brand-primary"] .id-container:hover{background-color:#ffffff1a!important;border-color:var(--color-text-inverted)!important}.beat-header-bar[style*="--color-brand-primary"] .node-delete-button,.header-bar-container[style*="--color-brand-primary"] .node-delete-button{border-color:#ffffff80!important;color:var(--color-text-inverted)!important}.beat-header-bar[style*="--color-brand-primary"] .node-delete-button:hover,.header-bar-container[style*="--color-brand-primary"] .node-delete-button:hover{background-color:#ef4444!important;border-color:#ef4444!important}.Title-button-container{align-items:center;display:flex;height:100%;overflow:visible!important;padding-right:0}.beat-header-bar,.guide-header-bar{overflow:hidden}.header-title{color:var(--color-text-primary);color:var(--node-header-text-color);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-family:var(--node-font-family);font-size:16px;font-size:var(--node-header-font-size);font-weight:600;font-weight:var(--node-header-font-weight);margin-left:5px;margin-left:var(--node-header-icon-margin-right);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.arc-icon,.backstory-icon,.beat-icon,.character-icon,.character-select-icon,.guide-icon,.plot-icon,.scene-icon,.structure-icon,.theme-icon,.visual-style-icon,.world-icon{color:var(--color-text-primary);color:var(--node-header-text-color);flex-shrink:0;font-size:18px;font-size:var(--node-header-icon-size)}.id-container{align-items:center;background-color:initial;border:var(--node-id-container-border);border-radius:3px;border-radius:var(--node-id-container-radius);cursor:pointer;display:flex;flex-shrink:0;gap:0;padding:2px;padding:var(--node-id-container-padding);transition:background-color .2s ease-in-out,border-color .2s ease-in-out}.id-container:hover{background-color:var(--color-bg-ui);background-color:var(--node-button-hover-bg-color);border-color:var(--color-border-strong)}.copy-id-icon{align-items:center;color:var(--color-border-light);cursor:pointer;display:flex;font-size:20px;font-size:var(--node-id-copy-icon-font-size);justify-content:center;padding:2px;padding:var(--node-id-copy-icon-internal-padding);transition:color .2s ease-in-out,transform .1s ease-in-out}.copy-id-icon:hover{color:var(--flow-selection-outline);color:var(--node-id-copy-icon-hover-color)}.copy-id-icon:active{transform:scale(.9)}.copy-id-icon.copied{animation:pulseBlackCharacterStyle 1.5s ease-in-out;color:var(--color-accent-secondary-active-text);color:var(--node-id-copy-icon-copied-color)}.node-delete-button{background-color:initial;border:1px solid var(--color-border-light);border-radius:3px;box-sizing:border-box;color:var(--color-text-secondary);cursor:pointer;font-size:10px;font-weight:700;height:24px;justify-content:center;line-height:1;padding:0;transition:all .2s ease-in-out;width:24px}.header-buttons,.node-delete-button{align-items:center;display:flex;flex-shrink:0}.header-buttons{gap:10px;margin-left:auto;padding-left:10px}.header-buttons .id-container{display:flex!important;margin:0}.header-buttons .node-color-picker-trigger{border-radius:3px!important;margin:0}.header-buttons .id-container:hover{background-color:var(--color-bg-ui)!important;background-color:var(--node-button-hover-bg-color,var(--color-bg-ui))!important}.header-bar-container>.node-delete-button{position:absolute;right:8px;top:8px;z-index:10}.node-delete-button:hover{background-color:#ef4444;border-color:#ef4444;color:var(--color-text-inverted);transform:scale(1.1)}.node-delete-button:active{transform:scale(.95)}.beat-header-bar,.header-bar-container{position:relative}@keyframes pulseBlackCharacterStyle{0%{color:var(--color-text-secondary);color:var(--node-id-copy-icon-color);transform:scale(1)}20%{color:var(--color-accent-secondary-active-text);color:var(--node-id-copy-icon-copied-color);transform:scale(1.1)}80%{color:var(--color-accent-secondary-active-text);color:var(--node-id-copy-icon-copied-color);transform:scale(1.1)}to{color:var(--color-text-secondary);color:var(--node-id-copy-icon-color);transform:scale(1)}}.node-id-display{background-color:initial;background-color:var(--node-id-bg-color);border-radius:3px;border-radius:var(--node-id-container-radius);box-sizing:border-box;color:var(--color-text-secondary);color:var(--node-id-text-color);cursor:default;font-size:10px;font-size:var(--node-id-font-size);font-weight:400;max-width:70px;max-width:var(--node-id-display-max-width);min-width:40px;min-width:var(--node-id-display-min-width);overflow:hidden;padding:3px 5px;padding:var(--node-id-display-padding);text-align:left;text-overflow:ellipsis;-webkit-user-select:text;user-select:text;white-space:nowrap}.node-header__editable-label{background-color:var(--color-bg-ui);border:1px solid #0000;border-radius:4px;border-radius:var(--node-input-border-radius);box-sizing:border-box;color:var(--color-text-primary);color:var(--node-header-text-color);flex:1 1;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-family:var(--node-font-family);font-size:16px;font-size:var(--node-header-font-size);font-weight:600;font-weight:var(--node-header-font-weight);line-height:normal;margin-left:5px;margin-left:var(--node-header-icon-margin-right);margin-right:10px;outline:none;padding:2px 4px;width:auto!important}.node-header__editable-label:focus{background-color:var(--node-input-bg-color);border:var(--node-input-focus-border-width) solid var(--node-input-focus-border-color)!important;box-shadow:none;box-shadow:var(--node-input-focus-box-shadow);color:var(--color-accent-secondary-active-text);color:var(--node-input-text-color);font-family:Courier New,Courier,monospace;font-family:var(--node-input-font-family-override)}.nowheel.nodrag.w-full.min-width{box-sizing:border-box;display:flex;flex-direction:column;flex-grow:1;gap:var(--node-content-gap);max-height:350px;min-height:0;overflow-y:hidden;padding:var(--node-content-padding);width:100%}.node-label{color:var(--color-text-primary);color:var(--node-label-text-color);display:block;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-family:var(--node-font-family);font-size:.8em;font-size:var(--node-label-font-size);font-weight:700;font-weight:var(--node-label-font-weight);margin-bottom:4px;margin-bottom:var(--node-label-margin-bottom)}.arc-name-input,.character-name-input,.plot-name-input,.structure-name-input,.theme-name-input,.world-name-input{background-color:var(--node-input-bg-color);border:1px solid var(--color-border-strong);border-radius:4px;border-radius:var(--node-input-border-radius);box-sizing:border-box;color:var(--color-accent-secondary-active-text);color:var(--node-input-text-color);font-family:Courier New,Courier,monospace!important;font-family:var(--node-input-font-family-override)!important;font-size:16px!important;font-size:var(--node-input-font-size)!important;font-weight:400;height:30px;margin-bottom:0;outline:none;width:100%}.arc-name-input::placeholder,.character-name-input::placeholder,.plot-name-input::placeholder,.structure-name-input::placeholder,.theme-name-input::placeholder,.world-name-input::placeholder{color:var(--color-text-tertiary);color:var(--node-input-placeholder-color);opacity:1}.arc-name-input:focus,.character-name-input:focus,.plot-name-input:focus,.structure-name-input:focus,.theme-name-input:focus,.world-name-input:focus{border:var(--node-input-focus-border-width) solid var(--node-input-focus-border-color)!important;box-shadow:none;box-shadow:var(--node-input-focus-box-shadow);outline:none}.Arc-Text-Container,.Backstory-Text-Container,.Character-Text-Container,.Guide-Text-Container,.Plot-Text-Container,.Structure-Text-Container,.Theme-Text-Container,.World-Text-Container{border-radius:4px;box-sizing:border-box;display:flex;flex-direction:column;flex-grow:1;overflow-y:hidden;padding:0;width:100%}.Arc-textarea,.Backstory-textarea,.Guide-textarea,.backstory-description-input,.edit-textarea,.instructions-textarea,.plot-description-input,.structure-description-input,.textarea,.theme-description-input,.visual-style-textarea,.world-description-input{background-color:var(--color-bg-ui);border:none;border-radius:4px;border-radius:var(--node-textarea-border-radius);box-sizing:border-box;color:var(--color-accent-secondary-active-text);color:var(--node-textarea-text-color);flex-grow:1;font-family:Courier New,Courier,monospace!important;font-family:var(--node-monospace-font-family)!important;font-size:12px!important;font-size:var(--node-textarea-font-size)!important;line-height:1.5;line-height:var(--node-textarea-line-height);min-height:350px;min-height:var(--node-textarea-min-height);outline:none;overflow-y:auto;padding:8px;padding:var(--node-textarea-padding);resize:vertical;width:100%}.guide-node .group.width.resizable{display:flex;flex-direction:column;flex-grow:1;min-height:0;width:100%}.Arc-textarea::placeholder,.Guide-textarea::placeholder,.backstory-description-input::placeholder,.instructions-textarea::placeholder,.plot-description-input::placeholder,.structure-description-input::placeholder,.textarea::placeholder,.theme-description-input::placeholder,.world-description-input::placeholder{color:var(--color-text-tertiary);color:var(--node-textarea-placeholder-color);opacity:.8}.Arc-textarea:focus,.Backstory-textarea:focus,.Guide-textarea:focus,.backstory-description-input:focus,.edit-textarea:focus,.instructions-textarea:focus,.plot-description-input:focus,.structure-description-input:focus,.textarea:focus,.theme-description-input:focus,.world-description-input:focus{border:none!important;box-shadow:none!important;outline:none}.scene-node .Scene-Text-Container .textarea:focus{border:none!important;box-shadow:none!important}.character-selection,.node-dropdown-container{padding:10px;width:100%}.character-dropdown,.dropdown,.node-dropdown{background-color:var(--node-input-bg-color);background-color:var(--node-dropdown-bg-color);border:1px solid var(--node-dropdown-border-color);border-radius:4px;border-radius:var(--node-dropdown-border-radius);box-sizing:border-box;color:var(--color-accent-secondary-active-text);color:var(--node-dropdown-text-color);cursor:pointer;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-family:var(--node-dropdown-font-family);font-size:12px;font-size:var(--node-dropdown-font-size);outline:none;padding:5px 10px;padding:var(--node-dropdown-padding);transition:background-color .3s,border-color .3s;width:100%}.character-dropdown:focus,.dropdown:focus,.node-dropdown:focus{border:var(--node-input-focus-border-width) solid var(--node-input-focus-border-color)!important;box-shadow:none;box-shadow:var(--node-input-focus-box-shadow);outline:none}.ai-write-button,.node-button{background-color:var(--color-button-default-hover-bg);background-color:var(--node-button-bg-color);border:1px solid var(--node-button-border-color);border-radius:4px;border-radius:var(--node-button-border-radius);box-sizing:border-box;color:var(--color-text-primary);color:var(--node-button-text-color);cursor:pointer;display:block;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-family:var(--node-font-family);font-size:12px;font-size:var(--node-button-font-size);font-weight:500;padding:6px 10px;padding:var(--node-button-padding);text-align:center;transition:background-color .2s ease-in-out,border-color .2s ease-in-out;width:100%}.ai-write-button:hover:not(:disabled),.node-button:hover:not(:disabled){background-color:var(--color-bg-ui);background-color:var(--node-button-hover-bg-color);border-color:var(--color-border-strong)}.ai-write-button:disabled,.node-button:disabled{background-color:var(--color-bg-topbar-nav);border-color:var(--color-border-default);color:var(--color-text-tertiary);cursor:not-allowed}.character-add-section button,.context-nodeid-input button{background-color:var(--color-button-default-hover-bg);background-color:var(--node-button-bg-color);border:1px solid var(--node-button-border-color);border-radius:var(--node-button-border-radius)}.character-add-section button:hover:not(:disabled),.context-nodeid-input button:hover:not(:disabled){background-color:var(--color-bg-ui);background-color:var(--node-button-hover-bg-color)}.ai-write-button{background-color:var(--color-button-default-hover-bg);background-color:var(--node-button-bg-color,#e9e9e9);border:1px solid var(--node-button-border-color,#ccc);border-radius:4px;border-radius:var(--node-button-border-radius,6px);color:var(--node-button-text-color,#333);font-family:var(--node-font-family,"Inter",sans-serif);font-size:12px;font-size:var(--node-button-font-size,12px);font-weight:500;overflow:hidden;transition:background-color .2s ease-in-out}.ai-write-button .button-text{background-color:initial;border-radius:3px;border-radius:calc(var(--node-button-border-radius, 6px) - 1px);padding:6px 10px;padding:var(--node-button-padding,6px 10px)}.ai-write-button:hover:not(:disabled):not(.loading){background-color:#dcdcdc;background-color:var(--color-accent-primary-hover,#dcdcdc);border:1px solid var(--node-button-border-color,#ccc)}.ai-write-button:disabled:not(.loading){background-color:var(--color-bg-topbar-nav);border:1px solid var(--color-border-default);color:var(--color-text-tertiary)}.ai-write-button.loading{animation:marching-ants-gradient-master 2s linear infinite;background-image:linear-gradient(90deg,var(--flow-selection-outline),var(--flow-selection-outline),var(--color-accent-primary-hover),var(--flow-selection-outline),var(--flow-selection-outline));border:1px solid #0000}.ai-write-button.loading .button-text{background-color:var(--color-button-default-hover-bg);background-color:var(--node-button-bg-color,#e9e9e9);border-radius:3px;border-radius:calc(var(--node-button-border-radius, 6px) - 1px);padding:6px 10px;padding:var(--node-button-padding,6px 10px)}@keyframes marching-ants-gradient-master{0%{background-position:0 50%}to{background-position:200% 50%}}.node-id-section{border:1px solid var(--node-input-border-color);border-radius:var(--node-input-border-radius);box-sizing:border-box;margin-top:8px;padding:8px}.node-id-section>label{color:var(--color-text-primary);color:var(--node-label-text-color);display:block;font-size:.8em;font-size:var(--node-label-font-size);font-weight:700;font-weight:var(--node-label-font-weight);margin-bottom:6px}.context-nodeid-input{margin-bottom:8px}.context-nodeid-input input{background-color:var(--node-input-bg-color);border:1px solid var(--node-input-border-color);border-radius:var(--node-input-border-radius);color:var(--color-accent-secondary-active-text);color:var(--node-input-text-color);font-family:Courier New,Courier,monospace;font-family:var(--node-monospace-font-family);font-size:var(--node-textarea-font-size);padding:6px 8px}.context-nodeid-input input:focus{border-color:var(--node-input-focus-border-color)!important;border-width:2px!important;border-width:var(--node-input-focus-border-width)!important;box-shadow:none;box-shadow:var(--node-input-focus-box-shadow)}.context-nodeid-input button{flex-shrink:0;font-size:1.1em;line-height:1;padding:6px 10px;width:auto}.manual-node-list{font-size:.8em;font-size:var(--node-label-font-size)}.manual-node-item{background-color:var(--node-bg-shell);border-radius:var(--node-input-border-radius);margin-bottom:4px;padding:4px 8px}.manual-node-item .node-type-icon{color:var(--color-text-primary);color:var(--node-header-text-color);flex-shrink:0;font-size:1em;margin-right:6px}.manual-node-item .node-name{color:var(--color-text-secondary);font-size:.85em;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.manual-node-item .delete-context-button{background-color:initial;border:1px solid var(--node-input-border-color);border-radius:4px;color:var(--color-text-secondary);cursor:pointer;font-size:.9em;line-height:1;margin-left:5px;padding:1px 4px}.manual-node-item .delete-context-button:hover{background-color:#ef4444;border-color:#ef4444;color:var(--color-text-inverted)}.beat-preview{color:var(--color-text-secondary);font-size:.8em;margin-left:20px}.arc-item .node-name{font-style:normal}.beat-error-message{background-color:#fee2e2;border:1px solid #fca5a5;border-radius:4px;border-radius:var(--node-input-border-radius);color:#ef4444;font-size:.85em;margin-top:8px;padding:4px}.character-display{margin-bottom:var(--node-content-gap)}.character-names{display:flex;flex-wrap:wrap;gap:6px}.character-entry{background-color:var(--color-button-default-bg);border-radius:5px;color:var(--color-text-primary);font-size:1em;font-weight:500;padding:3px 8px}.no-characters{color:var(--color-text-secondary);font-size:.85em;font-style:italic}.node-content-group{align-items:stretch;display:inline-flex;flex-direction:column;gap:4px}.arc-node,.backstory-node,.beat-node,.character-node,.guide-node,.image-frame-node,.image-gen-node,.plot-node,.scene-node,.structure-node,.theme-node,.visual-style-node,.world-node{overflow:visible!important}.header-left-group{align-items:center;display:flex;gap:8px}.guide-header-bar{align-items:center;display:flex;flex-grow:1;gap:10px}.node-color-picker-trigger{background-color:var(--color-button-default-highlight)!important;border:1px solid var(--color-border-light);border-radius:3px;cursor:pointer;flex-shrink:0;height:25px;margin-left:10px;position:relative;transition:transform .2s;width:25px}.node-color-picker-trigger:hover{transform:scale(1.15)}.color-picker-popup{background:var(--color-bg-ui);border:1px solid var(--color-border-default);border-radius:5px;box-shadow:2px 2px 5px #0003;display:flex;gap:5px;left:100%;margin-left:8px;padding:5px;position:absolute;top:50%;transform:translateY(-50%);z-index:20}.color-picker-option{border:1px solid #0000001a;border-radius:3px;cursor:pointer;height:20px;transition:transform .2s;width:20px}.custom-handle{transition:all .2s ease-in-out}.scene-node .target-handle{margin-left:-15px}.target-handle{margin-left:-10px}.source-handle{margin-right:-10px}.custom-handle:not(.connectable){cursor:not-allowed;opacity:.5}.arc-node.selected,.backstory-node.selected,.beat-node-container.selected,.character-node.selected,.dark-mode .arc-node.selected,.dark-mode .backstory-node.selected,.dark-mode .beat-node-container.selected,.dark-mode .character-node.selected,.dark-mode .guide-node.selected,.dark-mode .image-frame-node.selected,.dark-mode .image-gen-node.selected,.dark-mode .plot-node.selected,.dark-mode .scene-node.selected,.dark-mode .structure-node.selected,.dark-mode .theme-node.selected,.dark-mode .visual-style-node.selected,.dark-mode .world-node.selected,.guide-node.selected,.image-frame-node.selected,.image-gen-node.selected,.plot-node.selected,.scene-node.selected,.structure-node.selected,.theme-node.selected,.visual-style-node.selected,.world-node.selected{background-color:var(--node-bg-shell)!important;background-color:var(--node-bg-color)!important;box-shadow:0 0 0 2px #60a5fa!important;outline:none!important}.dark-mode .react-flow__node-ImageFrameNode.selected{background-color:var(--node-bg-shell)!important;background-color:var(--node-bg-color)!important}.delete-confirmation-overlay{align-items:center;background-color:initial;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.delete-confirmation-dialog{background-color:var(--color-bg-ui);border:1px solid var(--color-border-default);border-radius:4px;border-radius:var(--node-border-radius);box-shadow:0 4px 12px #0000004d;max-width:400px;padding:20px;position:relative;width:90%}.delete-confirmation-dialog h3{color:var(--color-text-primary);font-size:18px;font-weight:600;margin:0 0 10px}.delete-confirmation-dialog p{color:var(--color-text-secondary);font-size:14px;line-height:1.5;margin:0 0 20px}.delete-confirmation-actions{display:flex;gap:10px;justify-content:flex-end}.delete-confirmation-actions button{border:1px solid var(--color-border-default);border-radius:4px;border-radius:var(--node-border-radius);cursor:pointer;font-size:14px;padding:8px 16px;transition:all .2s ease}.confirm-delete{background-color:#ef4444;border-color:#ef4444;color:#fff}.confirm-delete:hover{background-color:#dc2626;border-color:#dc2626}.cancel-delete{background-color:var(--color-button-default-bg);border-color:var(--color-border-default);color:var(--color-text-primary)}.cancel-delete:hover{background-color:var(--color-button-default-hover-bg)}.sticky-note-container{background-color:#b3ecff;border-radius:5px;box-shadow:3px 3px 5px #0000001a;height:250px;padding:10px;position:relative;width:350px;z-index:10}.sticky-note-container:hover{box-shadow:5px 5px 12px #0000004d}.color-picker-trigger{border:1px solid #333;border-radius:2px;cursor:pointer;height:20px;left:10px;position:absolute;top:10px;width:20px}.color-picker{background:#fff;border:1px solid #ccc;border-radius:5px;box-shadow:0 2px 5px #0003;display:flex;gap:5px;left:30px;padding:5px;position:absolute;top:0}.color-option{border-radius:3px;cursor:pointer;height:20px;transition:transform .2s;width:20px}.color-option:hover{transform:scale(1.1)}.sticky-note-container .sticky-note-textarea{word-wrap:break-word;background:#0000;border:none;color:#333;font-family:Arial,sans-serif;font-size:14px;height:200px;margin-top:30px;outline:none;overflow-x:hidden;overflow-y:auto;padding:5px;resize:none;scrollbar-color:#0000004d #0000;scrollbar-width:thin;white-space:pre-wrap;width:100%}.sticky-note-container .sticky-note-textarea::-webkit-scrollbar{width:6px}.sticky-note-container .sticky-note-textarea::-webkit-scrollbar-track{background:#0000}.sticky-note-container .sticky-note-textarea::-webkit-scrollbar-thumb{background:#0000004d;border-radius:3px}.sticky-note-container .sticky-note-textarea::-webkit-scrollbar-thumb:hover{background:#00000080}.sticky-note-container .sticky-note-textarea::placeholder{color:#333;opacity:.8}.sticky-note-container .sticky-note-textarea:focus{background-color:#ffffff4d;border:none!important}.sticky-note-container .node-delete-button{align-items:center;background-color:initial;border:1px solid #ccc;border-radius:3px;color:#666;cursor:pointer;display:flex;font-size:14px;font-weight:700;height:24px;justify-content:center;line-height:1;position:absolute;right:8px;top:8px;transition:all .2s ease-in-out;width:24px;z-index:10}.sticky-note-container .node-delete-button:hover{background-color:#ef4444;border-color:#ef4444;color:#fff;transform:scale(1.1)}.sticky-note-container .node-delete-button:active{transform:scale(.95)}.rich-text-editor{background-color:#fff;background-color:var(--rich-editor-bg,#fff);border:1px solid #e0e0e0;border:1px solid var(--rich-editor-border,#e0e0e0);border-radius:6px;display:flex;flex-direction:column;height:100%;overflow:hidden;width:100%}.rich-text-toolbar{align-items:center;background-color:#f8f9fa;background-color:var(--rich-toolbar-bg,#f8f9fa);border-bottom:1px solid #e0e0e0;border-bottom:1px solid var(--rich-toolbar-border,#e0e0e0);display:flex;flex-wrap:wrap;gap:2px;padding:8px 12px}.toolbar-button{background:none;border:none;border-radius:4px;color:#333;color:var(--rich-toolbar-color,#333);cursor:pointer;font-size:13px;font-weight:500;min-width:28px;padding:6px 8px;text-align:center;transition:all .2s ease;white-space:nowrap}.toolbar-button:hover{background-color:#e9ecef;background-color:var(--rich-toolbar-hover-bg,#e9ecef);color:#000;color:var(--rich-toolbar-hover-color,#000)}.toolbar-button:active{background-color:#dee2e6;background-color:var(--rich-toolbar-active-bg,#dee2e6)}.toolbar-divider{background-color:#ccc;background-color:var(--rich-toolbar-divider,#ccc);height:20px;margin:0 4px;width:1px}.toolbar-spacer{flex:1 1}.rich-text-editor-container{flex:1 1;overflow:hidden;position:relative}.rich-text-editor-content,.rich-text-editor-content *,.rich-text-editor-content div,.rich-text-editor-content p{font-family:Courier New,monospace!important;font-family:var(--node-monospace-font-family,"Courier New",monospace)!important;font-size:12px!important;font-size:var(--node-textarea-font-size,12px)!important;line-height:1.5!important;line-height:var(--node-textarea-line-height,1.5)!important;white-space:pre-wrap!important}.rich-text-editor-content{background-color:initial;background-color:var(--rich-editor-content-bg,#0000);border:none;color:#333;color:var(--rich-editor-text-color,#333);height:100%;outline:none;padding:16px;resize:none;width:100%}.rich-text-editor-content:empty:before{color:#999;color:var(--rich-editor-placeholder-color,#999);content:attr(placeholder);pointer-events:none}.rich-text-editor-content h1,.rich-text-editor-content h2,.rich-text-editor-content h3{font-weight:600;line-height:1.3;margin:16px 0 8px}.rich-text-editor-content h1{color:#2c3e50;color:var(--rich-editor-heading-color,#2c3e50);font-size:24px}.rich-text-editor-content h2{color:#34495e;color:var(--rich-editor-heading-color,#34495e);font-size:20px}.rich-text-editor-content h3{color:#7f8c8d;color:var(--rich-editor-heading-color,#7f8c8d);font-size:16px}.rich-text-editor-content p{margin:8px 0}.rich-text-editor-content ol,.rich-text-editor-content ul{margin:8px 0;padding-left:24px}.rich-text-editor-content li{margin:4px 0}.rich-text-editor-actions{align-items:center;display:flex;gap:8px;margin-left:auto}.rich-text-toolbar .rich-text-editor-actions{background:#0000;border:none;justify-content:flex-end;padding:0}.editor-status{align-items:center;color:#666;color:var(--rich-status-color,#666);display:flex;font-size:12px;gap:16px}.unsaved-indicator{color:#d35400;color:var(--rich-unsaved-color,#d35400);font-weight:500}.word-count{color:#7f8c8d;color:var(--rich-wordcount-color,#7f8c8d)}.editor-buttons{align-items:center;display:flex;gap:8px}.cancel-button{background-color:#fff;background-color:var(--rich-cancel-bg,#fff);border:1px solid #bdc3c7;border:1px solid var(--rich-cancel-border,#bdc3c7);border-radius:6px;color:#7f8c8d;color:var(--rich-cancel-color,#7f8c8d);font-size:14px;font-weight:500;min-width:80px;padding:10px 20px;transition:all .2s ease}.cancel-button:hover{background-color:#ecf0f1;background-color:var(--rich-cancel-hover-bg,#ecf0f1);border-color:#95a5a6;border-color:var(--rich-cancel-hover-border,#95a5a6);box-shadow:0 2px 4px #0000001a;transform:translateY(-1px)}.scene-save-button{background-color:#697486;background-color:var(--rich-scene-save-bg,var(--color-accent-primary,#697486));border:1px solid #697486;border:1px solid var(--rich-scene-save-border,var(--color-accent-primary,#697486));border-radius:6px;box-shadow:0 2px 4px #6974864d;color:#fff;color:var(--rich-scene-save-color,#fff);cursor:pointer;font-size:14px;font-weight:500;min-width:120px;padding:6px 20px;transition:all .2s ease}.scene-save-button:hover:not(:disabled){background-color:var(--color-accent-primary-hover);border-color:#306b87;border-color:var(--rich-scene-save-hover-border,var(--color-accent-primary-hover,#306b87));box-shadow:0 4px 8px #69748666;transform:translateY(-1px)}.scene-save-button:disabled{background-color:#bdc3c7;background-color:var(--rich-save-disabled-bg,#bdc3c7);border-color:#bdc3c7;border-color:var(--rich-save-disabled-border,#bdc3c7);box-shadow:none;color:#7f8c8d;color:var(--rich-save-disabled-color,#7f8c8d);cursor:not-allowed;opacity:.6;transform:none}CK .scene-editor-modal{display:flex;flex-direction:column;height:100%;min-height:500px}.combined-view-content{flex:1 1;overflow-y:auto;padding:0}.scene-editor-content .rich-text-editor{border:none;display:flex;flex-direction:column;height:100%}.scene-editor-content .rich-text-editor-container{flex:1 1;min-height:300px}@media (max-width:768px){.combined-view-header{padding:16px}}.modal-overlay{align-items:center;background-color:#000000b3;bottom:0;box-sizing:border-box;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.modal-container{background-color:#fff;background-color:var(--modal-bg,#fff);border-radius:8px;box-shadow:0 10px 30px #0000004d;display:flex;flex-direction:column;max-height:90vh;max-width:90%;overflow:hidden;width:90%}.modal-header{align-items:center;background-color:#f8f9fa;background-color:var(--modal-header-bg,#f8f9fa);border-bottom:1px solid #e5e5e5;border-bottom:1px solid var(--modal-border,#e5e5e5);display:flex;justify-content:space-between;padding:10px}.modal-title{color:#333;color:var(--modal-title-color,#333);font-size:18px;font-weight:600;margin:0}.modal-navigation-toggle{background:var(--rich-toolbar-bg);border:1px solid #e5e5e5;border:1px solid var(--modal-border,#e5e5e5);border-radius:8px;display:flex;margin-left:auto;padding:3px}.modal-toggle-option{background:#0000;border:none;border-radius:6px;color:#64748b;color:var(--color-text-secondary,#64748b);cursor:pointer;font-size:11px;font-weight:600;padding:4px 12px;transition:all .2s cubic-bezier(.4,0,.2,1);white-space:nowrap}.modal-toggle-option:hover{color:#1e293b;color:var(--color-text-primary,#1e293b)}.modal-toggle-option.active{background:#fff;color:#007bff;color:var(--color-primary,#007bff)}.dark-mode .modal-navigation-toggle{background:var(--rich-toolbar-bg);border-color:var(--rich-toolbar-border)}.dark-mode .modal-toggle-option.active{background:var(--modal-header-bg);color:var(--color-text-primary)}.modal-close-button{align-items:center;background:none;border:none;border-radius:4px;color:#666;color:var(--modal-close-color,#666);cursor:pointer;display:flex;justify-content:center;padding:5px;transition:all .2s ease}.modal-close-button:hover{background-color:#f0f0f0;background-color:var(--modal-close-hover-bg,#f0f0f0);color:#333;color:var(--modal-close-hover-color,#333)}.modal-content{background-color:var(--color-bg-ui);flex:1 1;max-height:100%;overflow-y:auto;padding:20px}.dark-mode .modal-content::-webkit-scrollbar{width:10px}.dark-mode .modal-content::-webkit-scrollbar-track{background:#0f172a;background:var(--dark-mode-bg-canvas,#0f172a)}.dark-mode .modal-content::-webkit-scrollbar-thumb{background-color:#4b5563;background-color:var(--dark-mode-border-strong,#4b5563);border-radius:5px}.dark-mode .modal-content::-webkit-scrollbar-thumb:hover{background-color:#6b7280;background-color:var(--dark-mode-border-light,#6b7280)}.dark-mode .modal-content{scrollbar-color:#4b5563 #0f172a;scrollbar-color:var(--dark-mode-border-strong,#4b5563) var(--dark-mode-bg-canvas,#0f172a);scrollbar-width:thin}.modal-nav-button{align-items:center;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);background:#ffffff1a;border:1px solid #fff3;border-radius:12px;box-shadow:0 4px 15px #0000004d;color:#fff;cursor:pointer;display:flex;height:120px;justify-content:center;position:absolute;top:50%;transform:translateY(-50%);transition:all .3s cubic-bezier(.4,0,.2,1);width:60px;z-index:10001}.modal-nav-button:hover{background:#fff3;box-shadow:0 6px 20px #0000004d;transform:translateY(-50%) scale(1.1)}.modal-nav-button:active{transform:translateY(-50%) scale(.95)}.modal-nav-button.prev{left:30px}.modal-nav-button.next{right:30px}.dark-mode .modal-nav-button{background:#0f172a66;border-color:#ffffff1a}.dark-mode .modal-nav-button:hover{background:#0f172a99}@media (max-width:1100px){.modal-nav-button.prev{left:10px}.modal-nav-button.next{right:10px}}@media (max-width:768px){.modal-nav-button{height:40px;width:40px}}.standard-modal-size{height:90vh;max-width:95%;width:800px}@media (max-width:768px){.modal-overlay{padding:10px}.modal-header{padding:15px}.modal-title{font-size:16px}.modal-content{padding:15px}}.beat-node-container{cursor:grab}.beat-node-container:active{cursor:grabbing}.beat-node-container{background-color:var(--node-bg-shell);border:1px solid var(--color-border-subtle);border-radius:4px;box-shadow:var(--node-shadow);box-sizing:border-box;cursor:pointer;font-size:16px;overflow:visible!important;transition:background-color .3s;width:480px!important}.beat-header-bar{align-items:center;background-color:var(--node-header-bg);border:none;border-bottom:1px solid var(--color-border-default);border-radius:4px 4px 0 0;box-sizing:border-box;display:flex;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-size:12px;font-weight:600;height:40px!important;justify-content:space-between;margin-bottom:5px;outline:none;overflow:visible;padding:6px 10px;text-align:left;width:100%}.beat-node-container .header-buttons{align-items:center;display:flex;flex-shrink:0}.beat-node-container .header-buttons .node-color-picker-trigger{border-radius:3px!important;cursor:pointer;flex-shrink:0;transition:transform .2s}.beat-node-container .header-buttons .id-container:hover{background-color:var(--color-bg-ui)!important;background-color:var(--node-button-hover-bg-color,var(--color-bg-ui))!important;border-color:var(--color-strong,var(--flow-selection-outline))!important}.beat-header-bar .header-title{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-size:16px;font-weight:600}.beat-header-bar .header-title,.beat-header-bar .heart-icon{align-items:center;color:var(--color-text-primary);display:flex}.beat-header-bar .heart-icon{font-size:18px;margin-right:0;vertical-align:middle}.beat-node-container .node-id-display{background-color:initial;border-radius:3px;box-sizing:border-box;color:var(--color-text-secondary);cursor:default;font-size:10px;font-weight:400;max-width:70px;min-width:40px;padding:3px 5px;text-align:left;-webkit-user-select:none;user-select:none;width:auto}.beat-node-container .copy-id-icon{align-items:center;border-radius:2px;color:var(--color-text-secondary);cursor:pointer;display:flex;font-size:20px;justify-content:center;padding:3px;transition:color .2s ease-in-out,transform .1s ease-in-out}.beat-node-container .copy-id-icon:hover{background-color:var(--color-flow-dots);color:var(--color-accent-selection)}.beat-node-container .copy-id-icon:active{transform:scale(.9)}.beat-node-container .copy-id-icon.copied{animation:pulseBlackBeatNode 1.5s ease-in-out;color:var(--color-text-primary)}.beat-node-container .header-bar-container[style*="--color-brand-primary"] .id-container,.beat-node-container .header-bar-container[style*="--color-brand-primary"] .node-color-picker-trigger{border-color:#ffffff80!important}.beat-node-container .header-bar-container[style*="--color-brand-primary"] .copy-id-icon,.beat-node-container .header-bar-container[style*="--color-brand-primary"] .node-id-display{color:var(--color-text-inverted)!important}.beat-node-container .header-bar-container[style*="--color-brand-primary"] .id-container:hover{background-color:#ffffff1a!important;border-color:var(--color-text-inverted)!important}@keyframes pulseBlackBeatNode{0%{color:var(--color-text-secondary);transform:scale(1)}20%{color:var(--color-text-primary);transform:scale(1.1)}80%{color:var(--color-text-primary);transform:scale(1.1)}to{color:var(--color-text-secondary);transform:scale(1)}}.all-elements{background-color:var(--node-bg-shell);box-sizing:border-box;overflow:visible;padding:10px;width:100%}.instructions-label{margin-top:10px;padding-top:20px}.edit-label,.instructions-label{font-size:12px;font-weight:600!important;padding-bottom:5px}.instructions-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:5px}.collapse-toggle-button{align-items:center;background:none;border:none;color:var(--color-text-secondary);cursor:pointer;display:flex;font-size:12px;justify-content:center;padding:2px;transition:color .2s ease-in-out}.collapse-toggle-button:hover{color:var(--color-text-primary)}.structure-name-input:focus{border:2px solid var(--color-accent-selection)!important}.ai-button-container{margin-bottom:0;margin-top:10px;text-align:center}@keyframes marching-ants-gradient{0%{background-position:0 50%}to{background-position:200% 50%}}.ai-write-button{background-color:var(--color-button-default-highlight);border:1px solid var(--color-border-default);border-radius:6px;color:var(--color-text-primary);cursor:pointer;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-size:14px;margin-bottom:0;padding:0;text-align:center;transition:background-color .2s ease-in-out,border-color .2s ease-in-out}.ai-write-button,.ai-write-button .button-text{box-sizing:border-box;display:block;position:relative;width:100%}.ai-write-button .button-text{background-color:inherit;border-radius:inherit;color:inherit;height:100%;padding:6px 12px;transition:background-color .2s ease-in-out,color .2s ease-in-out;z-index:2}.ai-write-button:hover:not(:disabled):not(.loading){border-color:var(--color-border-default)}.ai-write-button:hover:not(:disabled):not(.loading) .button-text{background-color:var(--color-bg-secondary)}.ai-write-button:disabled:not(.loading){animation:none;background-image:none;border-color:var(--color-border-default);cursor:not-allowed}.ai-write-button:disabled:not(.loading),.ai-write-button:disabled:not(.loading) .button-text{background-color:var(--color-bg-tertiary);color:var(--color-text-secondary)}.ai-write-button.loading{animation:marching-ants-gradient 2s linear infinite;background-image:linear-gradient(90deg,var(--color-accent-selection),#66bfff,#0056b3,#66bfff,var(--color-accent-selection));background-size:200% 100%;border-color:#0000;border-radius:6px;color:#0000;cursor:progress;padding:1px;text-shadow:none}.ai-write-button.loading .button-text{background-color:var(--color-bg-tertiary);border-radius:4px;box-shadow:none;color:var(--color-text-secondary);padding:2px}.chat-section{border:1px solid var(--color-border-default);border-radius:4px;margin-bottom:10px;padding:10px}.chat-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:10px}.chat-messages{background-color:var(--color-bg-primary);border:1px solid var(--color-border-subtle);border-radius:4px;margin-bottom:10px;max-height:200px;overflow-y:auto;padding:5px}.chat-message{border-radius:4px;font-size:12px;line-height:1.4;margin-bottom:8px;padding:6px}.chat-message.user{background-color:var(--color-accent-selection);color:#fff;margin-left:20px}.chat-message.assistant{background-color:var(--color-bg-secondary);color:var(--color-text-primary);margin-right:20px}.message-content{word-wrap:break-word;white-space:pre-wrap}.chat-input{align-items:flex-end;display:flex;gap:8px}.chat-input textarea{border:1px solid var(--color-border-default);border-radius:4px;flex:1 1;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-size:12px;line-height:1.4;max-height:120px;min-height:60px;outline:none;padding:8px;resize:vertical}.chat-input textarea:focus{border:2px solid var(--color-accent-selection)}.send-button{align-items:center;background-color:var(--color-accent-selection);border:none;border-radius:4px;color:#fff;cursor:pointer;display:flex;height:36px;justify-content:center;transition:background-color .2s ease;width:36px}.send-button:hover:not(:disabled){background-color:#0056b3;background-color:var(--color-accent-selection-hover,#0056b3)}.send-button:disabled{background-color:var(--color-bg-tertiary);color:var(--color-text-secondary);cursor:not-allowed}.content-section{border:1px solid var(--color-border-default);border-radius:4px;margin-bottom:10px;padding:10px}.edit-window{margin-top:5px}.edit-textarea{border:none;border-radius:4px;font-family:Courier New,Courier,monospace;font-size:12px;line-height:1.5;outline:none;padding:8px;resize:vertical;width:100%}.edit-textarea:focus{border:none;box-shadow:none;outline:none}.context-section,.context-sections{margin-bottom:10px}.context-section{font-size:12px;font-weight:600;padding-bottom:0;padding-top:5px}.context-content{background-color:var(--color-bg-primary);border:none;border-radius:4px;color:var(--color-text-secondary);font-size:12px;font-weight:400;padding:3px}.manual-node-ids{font-size:12px;font-weight:600;margin-bottom:10px;width:60%}.manual-node-input{align-items:center;display:flex;font-size:12px;font-weight:600;padding-top:0;width:150px}.manual-node-input input{border:1px solid var(--color-border-default);border-radius:4px;flex:1 1;font-size:12px;outline:none;padding:3px}.manual-node-input :focus{border:2px solid var(--color-accent-selection)!important}.manual-node-input button{font-size:10px;margin-left:5px;padding:3px}.delete-node-button{background-color:none;border:1px solid var(--color-border-default);border-radius:4px;cursor:pointer;font-size:10px;margin-left:5px;margin-right:-5px;padding:2px 5px}.node-id{margin-right:5px}.node-id,.node-type-icon{color:var(--color-text-primary)}.node-type-icon{flex-shrink:0;font-size:14px;margin-right:8px}.manual-node-item .node-name{color:var(--color-text-primary);font-size:12px;margin-right:auto}.beat-preview{color:var(--color-text-primary);flex-grow:1;font-style:italic;text-align:left}.delete-node-button:hover{background-color:var(--color-border-default)}.manual-node-list{font-size:12px;margin-top:5px}.manual-node-item{margin-bottom:5px}.manual-node-item,.node-type-badge{align-items:center;background-color:var(--color-bg-primary);border:1px solid var(--color-border-default);border-radius:4px;cursor:default;display:flex;justify-content:space-between;margin-left:0;padding:3px 10px}.node-type-badge{margin-bottom:10px}.manual-node-item:hover{cursor:default}.manual-node-input input::placeholder{font-size:12px;opacity:1}.character-display{border:1px solid var(--color-border-default);border-radius:4px;margin-bottom:10px;padding:10px}.character-add-section{align-items:center;display:flex;gap:5px}.character-add-section .character-dropdown{border:1px solid var(--color-border-default);border-radius:4px;box-sizing:border-box;flex-grow:1;font-size:12px;height:30px;margin:0;outline:none;padding:0 10px}.character-add-section{margin-bottom:10px}.character-add-section .character-dropdown:focus{border:2px solid var(--color-accent-selection)!important}.character-name{margin-right:5px}.character-entry{border:1px solid var(--color-accent-selection)}.character-names{font-family:Courier New,Courier,monospace;font-size:14px;font-weight:400;line-height:1.2;margin-bottom:10px;padding-bottom:10px}.character-display,.context-sections,.edit-label,.instructions-label,.manual-node-ids{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif}label{display:block;margin-bottom:5px}.edit-textarea:focus,.instructions-textarea:focus,textarea:focus{border:none!important;box-shadow:none;outline:none}.context-nodeid-input{margin-bottom:10px}.context-nodeid-input input{align-items:center;margin-bottom:0}.character-add-section button,.context-nodeid-input button{background-color:var(--color-bg-tertiary);font-size:18px;font-weight:700;transition:background-color .2s ease-in-out}.character-add-section button:hover:not(:disabled),.context-nodeid-input button:hover:not(:disabled){background-color:var(--color-border-default)}.character-add-section button:disabled,.context-nodeid-input button:disabled{opacity:.6}.node-id-section label{color:var(--color-text-primary);display:block;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-size:12px;font-weight:700;margin-bottom:5px}.node-id-section{border:1px solid var(--color-border-default);border-radius:4px;margin-bottom:10px;padding:10px;width:100%}.context-nodeid-input{align-items:center;display:flex;gap:5px}.context-nodeid-input input{border:1px solid var(--color-border-default);border-radius:4px;flex:1 1;font-size:12px;outline:none;padding:5px}.context-nodeid-input input:focus{border:2px solid var(--color-accent-selection)}.context-nodeid-input button{background-color:var(--color-bg-tertiary);border:1px solid var(--color-border-default);border-radius:4px;cursor:pointer;font-size:12px;padding:5px 10px}.context-nodeid-input button:hover{background-color:var(--color-border-default)}.structure-nodeid-input{align-items:center;display:flex;gap:5px}.structure-nodeid-input input{border:1px solid var(--color-border-default);border-radius:4px;flex:1 1;font-size:12px;outline:none;padding:5px}.structure-nodeid-input input:focus{border:2px solid var(--color-accent-selection)}.structure-nodeid-input button{background-color:var(--color-bg-tertiary);border:1px solid var(--color-border-default);border-radius:4px;cursor:pointer;font-size:12px;padding:5px 10px}.structure-nodeid-input button:hover{background-color:var(--color-border-default)}.beat-error-message{color:red;font-size:12px;margin-top:5px}.beat-node-container .edit-textarea,.beat-node-container .instructions-textarea{border:none;border-radius:4px;font-family:Courier New,Courier,monospace;font-size:12px;line-height:1.5;min-height:200px;overflow-y:auto;resize:vertical}.character-add-section button,.context-nodeid-input button{align-items:center;background-color:var(--color-button-default-bg);border:1px solid var(--color-border-default);border-radius:4px;box-sizing:border-box;color:var(--color-text-secondary);cursor:pointer;display:flex;flex-shrink:0;font-size:20px;font-weight:500;height:30px;justify-content:center;line-height:1;padding:0;transition:background-color .2s ease,color .2s ease;width:30px}.character-add-section button:hover:not(:disabled),.context-nodeid-input button:hover:not(:disabled){background-color:var(--color-button-default-hover-bg);color:var(--color-text-primary)}.character-add-section button:disabled,.context-nodeid-input button:disabled{cursor:not-allowed;opacity:.5}.generation-section{border:1px solid var(--color-border-default);border-radius:4px;margin-bottom:10px;padding:10px}.generation-header{align-items:center;display:flex;margin-bottom:10px}.generation-section .generation-input textarea{background-color:var(--color-bg-canvas)!important;border:1px solid var(--color-border-default)!important;border-radius:4px!important;box-sizing:border-box!important;color:var(--color-text-primary)!important;flex-grow:0!important;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif!important;font-size:12px!important;height:auto!important;line-height:1.4!important;margin-bottom:10px!important;max-height:none!important;min-height:0!important;outline:none!important;overflow:visible!important;padding:8px!important;resize:vertical!important}.generation-input textarea:focus{border:2px solid var(--color-accent-selection)}.generation-input textarea::placeholder{color:var(--color-text-secondary);opacity:.7}.generation-generate-button{background-color:var(--color-button-default-highlight);border:1px solid var(--color-border-default);border-radius:6px;box-sizing:border-box;color:var(--color-text-primary);cursor:pointer;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-size:14px;padding:8px 12px;position:relative;text-align:center;transition:background-color .2s ease-in-out,border-color .2s ease-in-out;width:100%}.generation-generate-button:hover:not(:disabled){background-color:var(--color-bg-secondary);border-color:var(--color-border-default)}.generation-generate-button:disabled{background-color:var(--color-bg-tertiary);border-color:var(--color-border-default);color:var(--color-text-secondary);cursor:not-allowed}.beat-composer-instructions-textarea{min-height:70px!important;resize:vertical}.content-section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:5px}.expand-modal-button{align-items:center;background:none;border:none;border-radius:4px;color:var(--color-text-secondary);cursor:pointer;display:flex;font-size:20px;justify-content:center;padding:4px;transition:color .2s,background-color .2s}.expand-modal-button:hover{background-color:var(--color-bg-tertiary);color:var(--color-text-primary)}.beat-composer-modal-content{display:flex;flex-direction:column;gap:12px;height:100%}.beat-composer-modal-content label{color:var(--color-text-primary);display:block;font-size:13px;font-weight:600;margin-bottom:4px}.modal-primary-content{display:flex;flex:1 1;flex-direction:column;min-height:0}.modal-secondary-content{display:flex;flex:0 0 auto;flex-direction:column;gap:8px}.modal-textarea{background-color:var(--color-bg-primary);border:1px solid var(--color-border-default);border-radius:4px;color:var(--color-text-primary);font-family:inherit;font-size:14px;line-height:1.5;padding:10px;resize:none;transition:border-color .2s;width:100%}.modal-textarea:focus{border:1px solid var(--color-border-subtle)!important}.modal-primary-content .modal-textarea{flex:1 1}.modal-secondary-content .modal-textarea{height:80px}.modal-generate-button{align-self:flex-end;background-color:var(--color-button-default-highlight);border:1px solid var(--color-border-default);border-radius:6px;color:var(--color-text-primary);cursor:pointer;font-size:13px;font-weight:600;padding:8px 16px;transition:background-color .2s,border-color .2s;width:auto}.modal-generate-button:hover:not(:disabled){background-color:var(--color-bg-secondary);border-color:var(--color-accent-selection)}.modal-generate-button:disabled{cursor:not-allowed;opacity:.6}.beat-composer-modal{height:90vh!important;max-width:95%;width:800px}.offline-alert{background:#727272;border-radius:5px;color:#fff;font-weight:400;left:50%;padding:10px 20px;position:fixed;top:50px;transform:translateX(-50%);z-index:100}.scene-node{align-items:stretch;background-color:var(--node-bg-shell);border:1px solid var(--node-border-color,var(--color-border-default));border-radius:4px;border-radius:var(--node-border-radius,4px);box-shadow:-2px 2px 4px #0000001a;box-shadow:var(--node-box-shadow,-2px 2px 4px #0000001a);display:flex;flex-direction:column;font-family:Inter,sans-serif;font-family:var(--node-font-family,"Inter",sans-serif);overflow:visible;padding-bottom:0;position:relative;transition:all .2s ease-in-out}.scene-node .header-bar-container{align-items:center;background-color:var(--node-header-bg);background-color:var(--node-header-bg-color,var(--node-header-bg));border-bottom:1px solid #0000;border-bottom:1px solid var(--node-header-border-color,#0000);border-top-left-radius:4px;border-top-left-radius:var(--node-border-radius,4px);border-top-right-radius:4px;border-top-right-radius:var(--node-border-radius,4px);box-sizing:border-box;cursor:grab;display:flex;flex-shrink:0;height:40px;height:var(--node-header-height,40px);justify-content:space-between;padding:6px 10px;padding:var(--node-header-padding,6px 10px);padding-right:10px;width:100%}.scene-node .scene-baked-led{background-color:#333;border-radius:50%;box-shadow:inset 0 0 1px #00000080;flex-shrink:0;height:5px;margin-left:8px;transition:all .3s ease;width:5px}.scene-node .scene-baked-led.is-baked{background-color:#4ade80;box-shadow:0 0 4px #4ade80,inset 0 0 1px #0003}.scene-node .scene-icon.editable{color:#3b82f6;color:var(--node-edit-icon-color,#3b82f6);cursor:pointer;opacity:.8;transition:all .2s ease-in-out}.scene-node .scene-icon.editable:hover{background-color:#3b82f61a;background-color:var(--node-edit-icon-hover-bg,#3b82f61a);border-radius:4px;color:#2563eb;color:var(--node-edit-icon-hover-color,#2563eb);opacity:1;padding:2px;transform:scale(1.1)}.scene-node .scene-icon.editable:active{transform:scale(.95)}.dark-mode .scene-node .scene-icon.editable{color:#60a5fa;color:var(--dark-mode-edit-icon-color,#60a5fa)}.dark-mode .scene-node .scene-icon.editable:hover{background-color:#60a5fa1a;background-color:var(--dark-mode-edit-icon-hover-bg,#60a5fa1a);color:#93c5fd;color:var(--dark-mode-edit-icon-hover-color,#93c5fd)}.scene-node .scene-icon{flex-shrink:0;font-size:18px;font-size:var(--node-header-icon-size,18px);margin-right:8px;margin-right:var(--node-header-icon-margin-right,8px)}.scene-node .scene-icon,.scene-node .scene-name-input{color:var(--color-text-primary);color:var(--node-header-text-color,var(--color-text-primary))}.scene-node .scene-name-input{background-color:var(--color-bg-ui);border:1px solid #0000;border-radius:4px;border-radius:var(--node-input-border-radius,4px);box-sizing:border-box;flex-grow:1;font-family:var(--node-font-family);font-family:var(--node-input-font-family-override,var(--node-font-family));font-size:16px;font-size:var(--node-header-font-size,16px);font-weight:600;font-weight:var(--node-header-font-weight,600);margin-left:10px;margin-right:10px;outline:none;padding:2px 4px;width:300px}.scene-node .scene-name-input:focus{background-color:var(--color-bg-ui);background-color:var(--node-input-bg-color,var(--color-bg-ui));border:var(--node-input-focus-border-width,2px) solid var(--node-input-focus-border-color,var(--flow-selection-outline));box-shadow:none;box-shadow:var(--node-input-focus-box-shadow,none);color:var(--color-accent-secondary-active-text);color:var(--node-input-text-color,var(--color-accent-secondary-active-text))}.scene-node .node-id-selectable{background-color:initial;border:var(--node-id-container-border,1px solid var(--color-border-strong));border-radius:3px;border-radius:var(--node-id-container-radius,3px);box-sizing:border-box;color:var(--color-text-secondary);color:var(--node-id-text-color,var(--color-text-secondary));cursor:default;flex-shrink:0;font-family:Courier New,monospace;font-family:var(--node-monospace-font-family,"Courier New",monospace);font-size:10px;font-size:var(--node-id-font-size,10px);font-weight:400;height:auto;line-height:normal;max-width:70px;max-width:var(--node-id-display-max-width,70px);min-width:40px;min-width:var(--node-id-display-min-width,40px);outline:none;padding:3px 5px;text-align:center;-webkit-user-select:text;user-select:text;width:70px}.scene-node .node-id-selectable:focus{background-color:#0000000d;border-color:var(--node-input-focus-border-color,var(--flow-selection-outline))}.scene-node .header-buttons{align-items:center;display:flex;flex-shrink:0;gap:8px}.scene-node .header-buttons .node-color-picker-trigger{border-radius:3px;cursor:pointer;flex-shrink:0;transition:transform .2s}.scene-node .header-buttons .id-container{align-items:center;background-color:initial;border-radius:3px;cursor:pointer;display:flex;flex-shrink:0;padding:2px 4px;transition:background-color .2s ease-in-out,border-color .2s ease-in-out}.scene-node .header-buttons .id-container:hover{background-color:var(--color-bg-ui);background-color:var(--node-button-hover-bg-color,var(--color-bg-ui));border-color:var(--color-strong,var(--flow-selection-outline))}.scene-node .node-edit-button{align-items:center;background-color:initial;border:none;border-radius:4px;border-radius:var(--node-button-border-radius,4px);cursor:pointer;display:flex;flex-shrink:0;font-size:25px;justify-content:center;padding:0;transition:all .2s ease-in-out}.scene-node .node-edit-button:hover{background-color:var(--color-bg-ui);border-color:var(--node-input-focus-border-color,var(--flow-selection-outline));color:var(--color-accent-secondary-active-text)}.scene-node .node-duplicate-button{align-items:center;background-color:initial;border:none;border-radius:4px;border-radius:var(--node-button-border-radius,4px);color:var(--color-border-light);cursor:pointer;display:flex;flex-shrink:0;font-size:27px;justify-content:center;padding:0;transition:all .2s ease-in-out}.scene-node .node-duplicate-button:hover{background-color:var(--color-bg-ui);border-color:var(--node-input-focus-border-color,var(--flow-selection-outline));color:var(--color-accent-secondary-active-text)}.scene-node .header-bar-container[style*="--color-brand-primary"] .node-duplicate-button{color:var(--color-text-inverted)!important}.scene-node .header-bar-container[style*="--color-brand-primary"] .node-duplicate-button:hover{background-color:#ffffff1a!important;color:var(--color-text-inverted)!important}.scene-node .header-bar-container[style*="--color-brand-primary"] .node-color-picker-trigger{border-color:#ffffff80!important}.scene-node .nowheel.nodrag{box-sizing:border-box;min-height:0;padding:10px;padding:var(--node-content-padding,10px);width:100%}.scene-node .Scene-Text-Container,.scene-node .group.width.resizable,.scene-node .nowheel.nodrag{display:flex;flex-direction:column;flex-grow:1;pointer-events:auto}.scene-node .Scene-Text-Container{min-height:120px}.scene-node .Scene-Text-Container .textarea{background-color:var(--color-bg-ui);border-radius:4px;border-radius:var(--node-textarea-border-radius,4px);box-sizing:border-box;color:var(--color-accent-secondary-active-text);color:var(--node-textarea-text-color,var(--color-accent-secondary-active-text));flex-grow:1;font-family:Courier New,monospace;font-family:var(--node-monospace-font-family,"Courier New",monospace);font-size:12px;font-size:var(--node-textarea-font-size,12px);line-height:1.5;line-height:var(--node-textarea-line-height,1.5);min-height:120px;outline:none;overflow-y:auto;padding:15px;pointer-events:auto;resize:vertical;width:100%}.scene-node .Scene-Text-Container .textarea::placeholder{color:var(--color-text-tertiary);color:var(--node-textarea-placeholder-color,var(--color-text-tertiary));opacity:.8}.scene-node .Scene-Text-Container .textarea:focus{border:none;box-shadow:none;outline:none}.scene-node .aggregated-beats-section{background-color:none;border:none;border-radius:6px;overflow:hidden;padding:8px 10px;pointer-events:none}.dark-mode .scene-node .aggregated-beats-section{background-color:var(--node-bg-shell);border-color:#374151;border-color:var(--dark-mode-border-light,#374151)}.scene-node .beats-toggle-button{align-items:center;background:none;border:none;color:var(--color-text-primary);cursor:pointer;display:flex;font-size:12px;font-weight:500;justify-content:space-between;padding:8px 12px;text-align:left;transition:background-color .2s ease;width:100%}.dark-mode .scene-node .beats-toggle-button{color:#f9fafb;color:var(--dark-mode-text-primary,#f9fafb)}.scene-node .beats-toggle-button:hover{background-color:#f3f4f6;background-color:var(--color-bg-hover,#f3f4f6)}.dark-mode .scene-node .beats-toggle-button:hover{background-color:#374151;background-color:var(--dark-mode-bg-hover,#374151)}.scene-node .beats-toggle-button .beat-count{align-items:center;color:var(--dark-mode-text-primary);display:flex;font-weight:600;gap:4px}.scene-node .beats-list{border-top:1px solid #e5e7eb;border-top:1px solid var(--color-border-light,#e5e7eb);max-height:300px;overflow-y:auto}.dark-mode .scene-node .beats-list{border-top-color:#374151;border-top-color:var(--dark-mode-border-light,#374151)}.scene-node .beat-item{background-color:#fff;background-color:var(--color-bg-primary,#fff);border-bottom:1px solid #f3f4f6;border-bottom:1px solid var(--color-border-lightest,#f3f4f6);padding:10px 12px}.dark-mode .scene-node .beat-item{background-color:var(--node-bg-shell);border-bottom-color:#374151;border-bottom-color:var(--dark-mode-border-lightest,#374151)}.scene-node .beat-item:last-child{border-bottom:none}.scene-node .beat-header{align-items:center;display:flex;gap:8px;margin-bottom:6px}.scene-node .beat-order{color:#6b7280;color:var(--color-text-secondary,#6b7280);font-size:11px;font-weight:600;min-width:16px}.dark-mode .scene-node .beat-order{color:#d1d5db;color:var(--dark-mode-text-secondary,#d1d5db)}.scene-node .beat-id{color:#374151;color:var(--color-text-primary,#374151);font-family:Courier New,monospace;font-family:var(--node-monospace-font-family,"Courier New",monospace);font-size:12px;font-weight:500}.dark-mode .scene-node .beat-id{color:#f9fafb;color:var(--dark-mode-text-primary,#f9fafb)}.scene-node .beat-status{font-size:12px;font-weight:600;margin-left:auto}.scene-node .beat-preview{color:#6b7280;color:var(--color-text-secondary,#6b7280);font-family:Inter,sans-serif;font-family:var(--node-font-family,"Inter",sans-serif);font-size:11px;line-height:1.4;margin-left:24px}.dark-mode .scene-node .beat-preview{color:#d1d5db;color:var(--dark-mode-text-secondary,#d1d5db)}.scene-node .no-beats-message{color:#9ca3af;color:var(--color-text-tertiary,#9ca3af);font-size:12px;line-height:1.5;padding:16px 12px;text-align:center}.dark-mode .scene-node .no-beats-message{color:#6b7280;color:var(--dark-mode-text-tertiary,#6b7280)}.scene-node .no-beats-message p{margin:0 0 4px}.scene-node .no-beats-message p:last-child{margin-bottom:0}.scene-node .scene-node-bottom-section{align-items:center;background-color:#f9fafb;background-color:var(--node-bg-shell,#f9fafb);border-top:1px solid #e5e7eb;border-top:1px solid var(--color-border-light,#e5e7eb);display:flex;justify-content:flex-end;padding:8px 10px}.scene-node-bottom-section{background-color:var(--node-bg-shell)}.dark-mode .scene-node{background-color:#1f2937;background-color:var(--dark-mode-bg-ui,#1f2937);border-top-color:#374151;border-top-color:var(--dark-mode-border-light,#374151)}.scene-node .scene-node-bottom-section .node-edit-button{align-items:center;background-color:var(--color-border-strong);border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:500;justify-content:center;min-width:100px;padding:8px 16px;text-align:center;transition:all .2s ease-in-out}.scene-node .scene-node-bottom-section .send-to-editor-button{margin-left:8px}.scene-node .scene-node-bottom-section .node-edit-button:hover{background-color:#2563eb;background-color:var(--color-accent-primary-hover,#2563eb);box-shadow:0 2px 4px #0000001a;transform:translateY(-1px)}.scene-node .scene-node-bottom-section .node-edit-button:active{box-shadow:none;transform:translateY(0)}.arc-node .Arc-Text-Container,.arc-node .character-arc-selection-container,.arc-node .nowheel.nodrag{pointer-events:none}.arc-node .Arc-Text-Container .Arc-textarea,.arc-node .character-selection,.arc-node .character-selection .node-dropdown{pointer-events:auto}.arc-node.selectable.selected{box-shadow:0 0 0 2px #60a5fa!important}.CharacterSelect-container{align-items:stretch;background-color:#f9f9f9;border:1px solid #ddd;border-radius:4px;box-shadow:-2px 2px 4px #0000001a;color:#000;cursor:pointer;display:flex;flex-direction:column;font-size:16px;height:120px;overflow:visible;transition:background-color .3s;width:300px}.CharacterSelect-header-bar{align-items:center;background-color:#e3e3e3;border-bottom:1px solid #ddd;border-radius:4px 4px 0 0;display:flex;gap:8px;height:40px;padding:0 10px;width:100%}.character-select-icon{color:#333;font-size:18px;margin-right:4px;position:relative;top:-1px}.CharacterSelect-header{background-color:#f3f3f3;border-bottom:1px solid #ddd;border-radius:4px 4px 0 0;box-sizing:border-box;font-size:14px;font-weight:600;height:22px;margin-bottom:5px;text-align:left}.CharacterSelect-header-title{align-items:center;display:flex;flex:1 1;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-size:16px;font-weight:600;justify-content:left;line-height:1;margin-right:10px;position:relative}.character-element-container{align-items:center;display:flex;justify-content:center;padding:5px 5px 7px}.character-dropdown{border:1px solid #ccc;border-radius:4px;font-size:14px;margin-top:20px;width:95%}.character-dropdown:focus{border:2px solid #add8e6;outline:none!important}.character-dropdown:active{border:2px solid #add8e6!important;outline:none!important}.top-bar{background-color:var(--color-bg-ui);border-bottom:1px solid var(--color-border-default);box-sizing:border-box;gap:20px;height:60px;left:0;padding:0 20px;position:fixed;top:0;width:100%;z-index:10}.save-load-container,.top-bar{align-items:center;display:flex}.save-load-container{gap:10px;position:absolute;right:20px}.export-button,.load-button,.save-button{background-color:var(--color-button-default-bg);color:var(--color-text-secondary);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-size:12px;padding:3px;text-align:center;width:45px}.export-button,.load-button,.save-button,.setting-button{border:1px solid var(--color-border-default);border-radius:4px}.setting-button{align-items:center;background-color:var(--color-button-default-bg)!important;cursor:pointer;display:flex;font-size:20px;justify-content:center}.setting-button:hover{background-color:var(--color-button-default-hover-bg);color:var(--color-text-primary)}.export-button:hover,.load-button:hover,.save-button:hover{background-color:var(--color-bg-ui)}.export-button:active,.load-button:active,.save-button:active{background-color:var(--color-text-secondary);color:var(--color-text-inverted)}.setting-button:active{background-color:var(--color-text-secondary)}.title{color:var(--color-text-primary);font-family:Courier New,Courier,monospace;font-size:25px;font-weight:600}.navigation-menu{align-items:left;background-color:var(--color-bg-topbar-nav);border:1px solid var(--color-border-subtle);border-radius:4px;box-sizing:border-box;color:var(--color-text-inverted);display:flex;flex-grow:0;flex-shrink:0;flex-wrap:nowrap;height:38px;margin-left:5%;min-width:0;overflow-x:auto;overflow-y:hidden}.nav-item{color:var(--color-text-tertiary);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-size:14px;padding:4px 10px;text-decoration:none;transition:background-color .2s,color .2s}.exit-item,.nav-item{align-items:center;border-radius:4px;display:flex;white-space:nowrap}.exit-item{color:var(--color-text-primary);font-size:22px;padding:3px 7px}.exit-item:hover{background-color:var(--color-border-subtle);color:var(--color-text-primary)!important}.nav-item:hover{background-color:var(--color-bg-ui);color:var(--color-text-secondary)}.nav-item.active,.nav-item:active{background-color:var(--color-bg-ui);border:1px solid var(--color-border-strong);color:var(--color-accent-secondary-active-text);padding:4px 10px}.top-bar .logo-container{align-items:center;display:flex;flex-shrink:0;justify-content:flex-start}.top-bar .logo-image{flex-shrink:0;height:35px;margin-right:0;object-fit:contain;width:35px}.top-bar .storyflow-logo{color:var(--color-text-primary);display:inline;flex-shrink:0;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-size:28px;font-weight:700!important;margin:0;margin-right:0!important;padding:0!important}.top-bar .storyflow-logo,.top-bar .version-beta{align-items:center;line-height:1;white-space:nowrap}.top-bar .version-beta{background-color:#049dc81a;border-radius:4px;color:var(--color-accent-primary-hover);display:flex;display:inline-block;font-size:.7em;font-weight:700;margin-left:0;padding:2px 6px}.top-bar .left-section{align-items:center;display:flex;gap:0;margin:0;padding:0}.feedback-button{background:var(--color-button-default-highlight);border:none;border-radius:5px;color:var(--color-text-inverted);cursor:pointer;padding:5px 12px}.feedback-button:hover{background:var(--color-accent-primary-hover)}.feedback-modal{background:var(--color-bg-ui);border-radius:8px;box-shadow:0 4px 10px #0000001a;left:50%;padding:20px;position:fixed;top:50%;transform:translate(-50%,-50%)}.feedback-content{align-items:center;display:flex;flex-direction:column}.feedback-textarea{height:100px;margin:10px 0;padding:5px;resize:none;width:300px}.feedback-buttons button{border:none;cursor:pointer;margin:5px;padding:5px 10px}.feedback-buttons button:first-child{background:var(--color-text-secondary);color:var(--color-text-inverted)}.feedback-buttons button:last-child{background:var(--flow-selection-outline);color:var(--color-text-inverted)}@media (max-width:850px){.top-bar .feedback-button,.top-bar .tidy-layout-button{display:none}}.tidy-layout-button{align-items:center;background-color:var(--color-button-default-highlight);background:var(--color-button-default-highlight)!important;border:none;border-radius:5px;color:var(--color-text-inverted);cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:8px;padding:10px!important;transition:background-color .2s ease-in-out,transform .1s ease}.tidy-layout-button:hover{background-color:var(--color-accent-primary-hover)!important}.tidy-layout-button:active{transform:scale(.98)}@media (max-width:880px){.top-bar .feedback-button,.top-bar .tidy-layout-button{display:none}}.nav-item.disabled{cursor:not-allowed;opacity:.6}.nav-item.disabled:hover{background-color:initial;color:inherit}.top-bar-right-actions{align-items:center;display:flex;margin-right:15px}.top-bar-right-actions .exit-item{align-items:center;color:var(--color-text-secondary);display:flex;gap:8px;padding:8px 12px}.feedback-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.feedback-modal{background:#edf0f4;border-radius:5px;box-shadow:0 10px 20px #0003;box-sizing:border-box;max-height:90vh;overflow-y:auto;padding:10px;position:relative;width:400px}.feedback-form{display:flex;flex-direction:column}.feedback-form h2{color:#333;font-size:1.2rem;text-align:center}.feedback-subtext{color:#666;font-size:14px;margin-bottom:10px;margin-top:10px;text-align:left}fieldset{border:none;padding:0}legend{color:#333;font-size:1.1rem;font-weight:700;padding:0 5px}.form-group,legend{margin-bottom:10px}textarea.feedback-textarea-large{border:1px solid #ccc;border-radius:5px;box-sizing:border-box;font-size:.9rem;min-height:150px;padding:10px;resize:vertical;width:100%}.form-buttons{display:flex;gap:10px;justify-content:space-between}.submit-button{background:#05b1e1;color:#fff}.cancel-button,.submit-button{border:none;border-radius:5px;cursor:pointer;flex:1 1;font-size:.9rem;padding:5px 0}.cancel-button{background:#ccc;color:#333}.submit-button:hover{background:#049dc8}.cancel-button:hover{background:#bbb}.submit-button:disabled{background-color:#add8e6;cursor:not-allowed}.feedback-confirmation{color:#05b1e1;font-size:14px;margin-top:10px;text-align:center}.feedback-close-button{background:none;border:none;color:#333;cursor:pointer;font-size:16px;line-height:1;padding:5px;position:absolute;right:10px;top:10px;transition:color .2s ease-in-out}.feedback-close-button:hover{color:#ff0090}.feedback-success-container{align-items:center;display:flex;flex-direction:column;justify-content:center;min-height:150px;padding:20px 0;text-align:center}.feedback-confirmation-main{color:#28a745;font-size:1.1em;font-weight:700;margin-bottom:20px}.close-after-thanks-button{background-color:#6c757d;border:none;border-radius:5px;color:#fff;cursor:pointer;font-size:.9em;margin-top:15px;padding:8px 16px}.close-after-thanks-button:hover{background-color:#5a6268}body,html{box-sizing:border-box;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;height:100%;margin:0;overflow-x:hidden;padding:0;width:100%}*,:after,:before{box-sizing:inherit}body{min-height:100vh;text-rendering:optimizeLegibility}#root,body{display:flex;flex-direction:column}#root{flex-grow:1}.public-layout-container{background-color:var(--color-bg-paper);display:flex;flex-direction:column;min-height:100vh;width:100%}.public-content-area{box-sizing:border-box;flex-grow:1;margin:0 auto;max-width:1600px;padding:2rem 30px;width:100%}.site-header{background-color:var(--color-bg-ui);border-bottom:1px solid var(--color-border-subtle);box-sizing:border-box;padding:15px 0;width:100%;z-index:10}.header-content{align-items:center;display:flex;gap:20px;justify-content:space-between;margin:0 auto;max-width:1200px;padding:0 30px}.logo-container{align-items:center;color:inherit;display:flex;flex-shrink:0;gap:10px;text-decoration:none}.logo-image{display:block;height:35px;object-fit:contain;width:35px}.logo-text{color:var(--color-text-primary);font-size:30px;font-weight:700;line-height:1;margin:0;padding:0;white-space:nowrap}.nav-list{align-items:center;display:flex;flex-wrap:wrap;gap:20px;justify-content:flex-end;list-style:none;margin:0;padding:0}.nav-link{background:none;border:none;color:var(--color-text-primary);cursor:pointer;font-family:inherit;font-size:16px;font-weight:600;padding:5px 0;text-decoration:none;transition:color .2s}.nav-link:hover{color:var(--color-primary)}.login-button{background-color:var(--color-primary);border:none;border-radius:3px;color:var(--color-primary)!important;cursor:pointer;display:inline-block;font-size:inherit;font-weight:700;line-height:normal;padding:7px 12px;transition:background-color .2s,color .2s;white-space:nowrap}.login-button:hover:not(:disabled){background-color:var(--color-primary);color:var(--color-text-inverted)!important}.login-button:disabled{background-color:var(--color-bg-button-disabled);color:var(--color-text-secondary)!important;cursor:not-allowed;opacity:.7}.footer{background:var(--color-bg-default);border-top:1px solid var(--color-border-subtle);box-sizing:border-box;color:var(--color-text-secondary);flex-shrink:0;font-size:.9rem;margin-top:auto;padding:20px 30px;text-align:center;width:100%}.footer p{margin:0}.footer-link{color:var(--color-text-link);margin:0 8px;text-decoration:none}.footer-link:hover{text-decoration:underline}.dark-mode .ask-alex-messages-area,.dark-mode .card-content,.dark-mode .conversation-list,.dark-mode .dashboard-container,.dark-mode .editor-main-container,.dark-mode .generation-textarea.is-instruction-view,.dark-mode .images-grid,.dark-mode .sfv-container,.dark-mode .shot-list-content,.dark-mode .storyboard-grid,.dark-mode .update-card .card-content,.dark-mode .voice-dropdown,.dark-mode textarea{scrollbar-color:var(--color-border-strong) var(--color-bg-ui);scrollbar-width:thin}.dark-mode .ask-alex-messages-area::-webkit-scrollbar,.dark-mode .card-content::-webkit-scrollbar,.dark-mode .conversation-list::-webkit-scrollbar,.dark-mode .dashboard-container::-webkit-scrollbar,.dark-mode .editor-main-container::-webkit-scrollbar,.dark-mode .generation-textarea.is-instruction-view::-webkit-scrollbar,.dark-mode .images-grid::-webkit-scrollbar,.dark-mode .sfv-container::-webkit-scrollbar,.dark-mode .shot-list-content::-webkit-scrollbar,.dark-mode .storyboard-grid::-webkit-scrollbar,.dark-mode .update-card .card-content::-webkit-scrollbar,.dark-mode .voice-dropdown::-webkit-scrollbar,.dark-mode textarea::-webkit-scrollbar{height:10px;width:10px}.dark-mode .ask-alex-messages-area::-webkit-scrollbar-track,.dark-mode .card-content::-webkit-scrollbar-track,.dark-mode .conversation-list::-webkit-scrollbar-track,.dark-mode .dashboard-container::-webkit-scrollbar-track,.dark-mode .editor-main-container::-webkit-scrollbar-track,.dark-mode .generation-textarea.is-instruction-view::-webkit-scrollbar-track,.dark-mode .images-grid::-webkit-scrollbar-track,.dark-mode .sfv-container::-webkit-scrollbar-track,.dark-mode .shot-list-content::-webkit-scrollbar-track,.dark-mode .storyboard-grid::-webkit-scrollbar-track,.dark-mode .update-card .card-content::-webkit-scrollbar-track,.dark-mode .voice-dropdown::-webkit-scrollbar-track,.dark-mode textarea::-webkit-scrollbar-track{background:var(--color-bg-ui);border-radius:5px}.dark-mode .ask-alex-messages-area::-webkit-scrollbar-thumb,.dark-mode .card-content::-webkit-scrollbar-thumb,.dark-mode .conversation-list::-webkit-scrollbar-thumb,.dark-mode .dashboard-container::-webkit-scrollbar-thumb,.dark-mode .editor-main-container::-webkit-scrollbar-thumb,.dark-mode .generation-textarea.is-instruction-view::-webkit-scrollbar-thumb,.dark-mode .images-grid::-webkit-scrollbar-thumb,.dark-mode .sfv-container::-webkit-scrollbar-thumb,.dark-mode .shot-list-content::-webkit-scrollbar-thumb,.dark-mode .storyboard-grid::-webkit-scrollbar-thumb,.dark-mode .update-card .card-content::-webkit-scrollbar-thumb,.dark-mode .voice-dropdown::-webkit-scrollbar-thumb,.dark-mode textarea::-webkit-scrollbar-thumb{background-color:var(--color-border-strong);border:2px solid var(--color-bg-ui);border-radius:5px}.dark-mode .ask-alex-messages-area::-webkit-scrollbar-thumb:hover,.dark-mode .card-content::-webkit-scrollbar-thumb:hover,.dark-mode .conversation-list::-webkit-scrollbar-thumb:hover,.dark-mode .dashboard-container::-webkit-scrollbar-thumb:hover,.dark-mode .editor-main-container::-webkit-scrollbar-thumb:hover,.dark-mode .generation-textarea.is-instruction-view::-webkit-scrollbar-thumb:hover,.dark-mode .images-grid::-webkit-scrollbar-thumb:hover,.dark-mode .sfv-container::-webkit-scrollbar-thumb:hover,.dark-mode .shot-list-content::-webkit-scrollbar-thumb:hover,.dark-mode .storyboard-grid::-webkit-scrollbar-thumb:hover,.dark-mode .update-card .card-content::-webkit-scrollbar-thumb:hover,.dark-mode .voice-dropdown::-webkit-scrollbar-thumb:hover,.dark-mode textarea::-webkit-scrollbar-thumb:hover{background-color:var(--color-text-secondary)}.Hero-above{background-color:#cdf3fe;border-radius:20px;color:#05b1e1;display:inline-flex;font-size:14px;font-weight:400;justify-content:flex-start;margin-bottom:12px;padding:5px 15px;text-align:left}.hero{box-sizing:border-box;padding:4rem 0 2rem;width:100%;z-index:1}.hero-content{align-items:center;display:flex;flex-direction:row;gap:2rem;justify-content:space-between}.hero-text-container{flex:1 1;max-width:50%}.hero-title{color:#333;font-size:48px;font-weight:700;line-height:1.2;margin-bottom:1.5rem;text-align:left}.hero-text{flex:1 1;max-width:100%;text-align:left}.hero-subtext{color:#666;font-size:1.2rem;line-height:1.6;margin-bottom:2rem;text-align:left}.lego-text{-webkit-text-fill-color:#0000;background:#049dc8;-webkit-background-clip:text;background-clip:text;display:inline-block;font-weight:700}.buttons{display:flex;flex-wrap:wrap;gap:1rem;margin-top:2rem}.buttons a{text-decoration:none!important;text-decoration-line:none!important}.cta-primary,.cta-secondary{border-radius:4px;display:inline-block;font-size:1rem;max-width:200px;padding:.8rem 1.2rem;text-align:center;text-decoration:none!important;text-decoration-line:none!important;-webkit-text-decoration-line:none!important;transition:all .2s;width:auto}.cta-primary:focus,.cta-primary:hover,.cta-secondary:focus,.cta-secondary:hover{text-decoration:none!important;text-decoration-line:none!important;-webkit-text-decoration-line:none!important}.cta-primary{background-color:#cdf3fe;border:none;color:#666}.cta-primary:hover{background-color:#049dc8;color:#fff}.cta-secondary{background-color:#fff;border:2px solid #cdf3fe;color:#049dc8}.cta-secondary:hover{background-color:#049dc8;border-color:#049dc8;color:#fff}.section{align-items:center;background:#fff;display:flex;flex-direction:column;padding:3rem 0;width:100%}.Title-above{color:#05c1f5;font-size:1rem;font-weight:600;line-height:1.6;margin:0 auto 10px;max-width:800px;text-align:center}.section-title{color:#333;display:block;font-size:36px;font-weight:700;margin:0 0 20px;text-align:center;width:100%}.main-grid{grid-gap:30px;display:grid;gap:30px;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin:20px 0;max-width:800px;width:100%}.grid-item{align-items:flex-start;background:#fff;border-radius:8px;display:flex;gap:20px}.grid-item .icon{color:#05c1f5;flex-shrink:0;font-size:2rem}.grid-item h4{color:#333;font-size:1.2rem;font-weight:700;margin-bottom:5px;margin-top:0}.grid-item p{color:#666;font-size:1rem;line-height:1.6;margin:0}@media (max-width:768px){.hero{height:auto;padding:1rem 0}.hero-content{flex-direction:column;height:auto}.hero-text-container{max-width:100%;padding:0 1rem}.hero-title{font-size:32px}.hero-text,.hero-title{text-align:center}.buttons{justify-content:center}.cta-primary,.cta-secondary{max-width:280px;width:80%}.section{padding:2rem 0}.section-title{font-size:28px;margin-bottom:30px}.main-grid{gap:25px;grid-template-columns:1fr;max-width:100%}.section-image:before,.spline-container{display:none}}.bottom-grid-item,.grid-item{backface-visibility:hidden;transform:translateZ(0);will-change:transform}.hero-background{height:100%;left:0;overflow:hidden;pointer-events:none;position:absolute;top:0;width:100%;z-index:-1}.spline-container{display:none}.circle-container{animation:rotate 30s linear infinite;height:1200px;left:70%;top:50%;transform:translate(-50%,-50%);width:1200px}.circle-container,.circlea{align-items:center;display:flex;justify-content:center;position:absolute}.circlea{height:100%;width:100%}.circleb{animation:pulse 6s ease-in-out infinite;border-radius:50%;box-shadow:0 0 0 60px #fffc,0 0 0 61px #cce7ff99,0 0 0 120px #f5faff80,0 0 0 121px #d6ecff66,0 0 0 180px #fff6,0 0 0 181px #d6ecff4d,0 0 0 240px #fafdff4d,0 0 0 241px #e0f1ff33,0 0 0 300px #fff3,0 0 0 301px #e0f1ff26,0 0 0 360px #fafdff26,0 0 0 361px #ebf5ff1a,0 0 0 420px #ffffff1a;height:150px;position:absolute;width:150px}@keyframes rotate{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@keyframes pulse{0%,to{opacity:.6;transform:scale(1)}50%{opacity:.9;transform:scale(1.05)}}@media (max-width:768px){.circle-container,.hero-background{display:none}}.section-image{margin:2rem auto}.section-image,.section-image img{max-width:800px;position:relative;width:100%}.section-image img{border-radius:8px;box-shadow:0 5px 25px #00000014;display:block;height:auto;margin:0 auto;z-index:2}.section-image:before{background:linear-gradient(180deg,#05b1e11a,#05b1e100);border-radius:8px;content:"";filter:blur(40px);height:calc(100% - 20px);left:50%;max-width:760px;opacity:.6;position:absolute;top:30px;transform:translateX(-50%);width:95%;z-index:1}.section-description,.section-subtitle{color:#555;font-size:1.1rem;line-height:1.7;margin:0 auto 25px;max-width:700px;text-align:center}.bottom-grid{grid-gap:25px;display:grid;gap:25px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));margin:30px auto 0;max-width:800px;width:100%}.bottom-grid-item{align-items:flex-start;background:none;display:flex;gap:15px;padding:15px 0}.bottom-grid-item .icon{color:#05c1f5;flex-shrink:0;font-size:1.8rem;margin-top:2px}.bottom-grid-item h4{color:#333;font-size:1.1rem;font-weight:600;margin-bottom:3px;margin-top:0}.bottom-grid-item p{color:#555;font-size:.95rem;line-height:1.6;margin:0}@media (max-width:768px){.bottom-grid{grid-template-columns:1fr;max-width:100%}}.site-header{background-color:#fff;box-shadow:0 2px 4px #0000000d;position:sticky;top:0;z-index:1000}.nav-link.login-button{background-color:#cdf3fe;border:none;border-radius:3px;color:#06a8d5!important;font-weight:500;padding:7px 12px;transition:background-color .2s ease-in-out,transform .1s ease-in-out}.nav-link.login-button:hover{background-color:#038ab1;color:#fff;transform:translateY(-1px)}.nav-link.login-button:active{transform:translateY(0)}.scene-sidebar{background-color:var(--color-bg-ui);border-right:1px solid var(--color-border-subtle);box-shadow:1px 0 2px #0000001a;box-sizing:border-box;flex-shrink:0;height:100%;padding-top:0;position:relative;transition:width .3s ease,left .3s ease,padding-left .3s ease,padding-right .3s ease;z-index:99}.scene-sidebar,.scene-sidebar.open{left:0;padding-left:15px;padding-right:15px;width:200px}.scene-sidebar.closed{left:-200px;overflow:visible!important;padding-left:0;padding-right:0;width:0}.scene-sidebar.open .toggle-button.left{left:100%;margin-left:0}.scene-sidebar.closed .toggle-button.left{left:200px;margin-left:0}.scene-sidebar.open .sidebar-content{opacity:1;transition-delay:.1s;visibility:visible}.scene-sidebar.closed .sidebar-content{opacity:0;visibility:hidden}.project-title-input{margin-bottom:20px;position:relative}.project-title-input-field{background-color:var(--color-bg-canvas);border:1px solid var(--color-border-default);border-radius:4px;color:var(--color-text-primary);font-family:Courier New,Courier,monospace;font-size:14px!important;font-weight:700;margin-top:20px;padding:5px!important;width:100%}.project-title-input-field:focus{border:1px solid var(--color-border-default);outline:none}.saved-indicator{color:var(--color-text-tertiary);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-size:12px!important;font-weight:200;left:0;position:relative;right:10px;top:0}.scene-dndnode{align-items:center;background-color:var(--node-bg-shell);border:1px solid var(--color-border-default);border-radius:4px;cursor:grab;display:flex;margin-bottom:10px;padding:10px}.scene-dndnode:hover{background-color:var(--color-button-default-hover-bg)}.scene-BsPersonVcard-icon,.scene-heartbeat-icon,.scene-movie-icon,.scene-palette-icon,.scene-sticky-icon,.visual-style-icon{color:var(--color-text-primary);font-size:20px;margin-right:10px}.scene-drag-icon{color:var(--color-text-secondary);font-size:20px}.scene-text-left{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-size:14px;margin-right:auto}.dark-mode .edit-textarea::-webkit-scrollbar,.dark-mode .instructions-textarea::-webkit-scrollbar{width:8px}.dark-mode .edit-textarea::-webkit-scrollbar-track,.dark-mode .instructions-textarea::-webkit-scrollbar-track{background:#252526;background:var(--color-bg-ui,#252526);border-radius:4px}.dark-mode .edit-textarea::-webkit-scrollbar-thumb,.dark-mode .instructions-textarea::-webkit-scrollbar-thumb{background-color:#666;background-color:var(--color-border-strong,#666);border:2px solid #252526;border:2px solid var(--color-bg-ui,#252526);border-radius:4px}.dark-mode .edit-textarea::-webkit-scrollbar-thumb:hover,.dark-mode .instructions-textarea::-webkit-scrollbar-thumb:hover{background-color:#8a8a8a;background-color:var(--color-text-secondary,#8a8a8a)}.dark-mode .edit-textarea,.dark-mode .instructions-textarea{scrollbar-color:#666 #252526;scrollbar-color:var(--color-border-strong,#666) var(--color-bg-ui,#252526);scrollbar-width:thin}.character-sidebar{background-color:var(--color-bg-ui);border-right:1px solid var(--color-border-subtle);box-shadow:1px 0 2px #0000001a;box-sizing:border-box;flex-shrink:0;height:100%;padding-top:0;position:relative;transition:width .3s ease,left .3s ease,padding-left .3s ease,padding-right .3s ease;z-index:99}.character-sidebar,.character-sidebar.open{left:0;padding-left:15px;padding-right:15px;width:200px}.character-sidebar.closed{left:-200px;overflow:visible!important;padding-left:0;padding-right:0;width:0}.character-sidebar .toggle-button.left{background:var(--color-bg-ui);border:1px solid var(--color-border-default);border-bottom-right-radius:4px;border-left:none;border-top-right-radius:4px;box-shadow:2px 0 4px -2px #0000004d;color:var(--color-text-secondary);cursor:pointer;padding:10px 0;position:absolute;top:70px;transition:left .3s ease,transform .3s ease;z-index:100}.character-sidebar.open .toggle-button.left{left:100%;margin-left:0}.character-sidebar.closed .toggle-button.left{left:200px;margin-left:0}.character-dndcontainer{margin-top:80px}.Guide-dndnode,.character-dndnode,.dndnode-image-gen,.world-dndnode{align-items:center;background-color:var(--node-bg-shell);border:1px solid var(--color-border-default);border-radius:3px;cursor:grab;display:flex;font-size:14px;justify-content:space-between;margin-bottom:10px;padding:10px;text-align:left}.Guide-dndnode:hover,.character-dndnode:hover,.world-dndnode:hover{background-color:var(--color-button-default-hover-bg)}.character-BiCustomize-icon,.character-BiWorld-icon,.character-BsPersonVcard-icon,.character-FaRegCompass-icon,.character-palette-icon,.character-sticky-icon,.history-movie-icon{color:var(--color-text-primary);font-size:20px;margin-right:10px}.character-drag-icon{color:var(--color-text-secondary);font-size:20px}.character-text-left{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-size:14px;margin-right:auto;padding-left:0}.character-icon,.character-icon-rotated{transition:transform .3s ease}.character-icon-rotated{transform:rotate(90deg)}.structure-sidebar{background-color:var(--color-bg-ui);border-right:1px solid var(--color-border-subtle);box-shadow:1px 0 2px #0000001a;box-sizing:border-box;flex-shrink:0;height:100%;padding-top:0;position:relative;transition:width .3s ease,left .3s ease,padding-left .3s ease,padding-right .3s ease;z-index:99}.structure-sidebar,.structure-sidebar.open{left:0;padding-left:15px;padding-right:15px;width:200px}.structure-sidebar.closed{left:-200px;overflow:visible!important;padding-left:0;padding-right:0;width:0}.toggle-button.left{background:var(--color-bg-ui);border:1px solid var(--color-border-default);border-bottom-right-radius:4px;border-left:none;border-top-right-radius:4px;box-shadow:2px 0 4px -2px #0000004d;color:var(--color-text-secondary);cursor:pointer;padding:10px 0;position:absolute;top:70px;transition:left .3s ease,transform .3s ease;z-index:100}.structure-sidebar.open .toggle-button.left{left:100%;margin-left:0}.structure-sidebar.closed .toggle-button.left{left:200px;margin-left:0}.sidebar-content{box-sizing:border-box;height:100%;overflow-y:auto;overflow:hidden;padding-bottom:70px;transition:opacity .1s ease-out}.structure-sidebar.open .sidebar-content{opacity:1;transition-delay:.1s;visibility:visible}.structure-sidebar.closed .sidebar-content{opacity:0;visibility:hidden}.structure-dndcontainer{margin-top:80px}.dndnode{align-items:center;background-color:var(--node-bg-shell);border:1px solid var(--color-border-default);border-radius:4px;color:var(--color-text-primary);cursor:grab;display:flex;margin-bottom:10px;padding:10px;transition:background-color .2s ease-in-out}.dndnode:hover{background-color:var(--color-button-default-hover-bg)}.plot-icon,.structure-MdMovieEdit-icon,.theme-LuMailSearch-icon,.visual-style-icon{color:var(--color-text-primary);font-size:20px;margin-right:10px}.text-left{flex-grow:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.drag-icon{color:var(--color-text-tertiary);font-size:18px;margin-left:auto}.read-only-project-wrapper{background:#fff;bottom:0;display:flex;flex-direction:column;left:0;position:fixed;right:0;top:0;z-index:9999}.read-only-banner{align-items:center;background:#dc3545;box-shadow:0 2px 4px #0000001a;color:#fff;display:flex;justify-content:space-between;padding:12px 20px;z-index:10000}.banner-content{align-items:center;display:flex;gap:10px}.banner-icon{font-size:18px}.banner-text{font-size:14px;font-weight:700;max-width:calc(100vw - 200px);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.close-admin-view{align-items:center;background:#fff3;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:20px;height:30px;justify-content:center;transition:background-color .2s;width:30px}.close-admin-view:hover{background:#ffffff4d}.read-only-overlay{flex:1 1;overflow:hidden;position:relative}.read-only-overlay button:not(.close-admin-view){opacity:.6!important;pointer-events:none!important}.read-only-overlay input,.read-only-overlay select,.read-only-overlay textarea{background:#f8f9fa!important;border-color:#dee2e6!important;pointer-events:none!important}.read-only-overlay .react-flow__node{pointer-events:none!important}.read-only-overlay .react-flow__node:hover{box-shadow:none!important}.read-only-overlay .react-flow__edge:hover .react-flow__edge-path{stroke:#b1b1b7!important}.read-only-overlay .add-node-btn,.read-only-overlay .delete-node-btn,.read-only-overlay .node-edit-controls{display:none!important}.read-only-error,.read-only-loading{align-items:center;background:#fff;display:flex;flex-direction:column;height:100vh;justify-content:center}.read-only-error p,.read-only-loading p{color:#6c757d;font-size:16px;margin:20px 0}.read-only-error h2{color:#dc3545;margin-bottom:10px}.error-close-btn{background:#007bff;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:14px;padding:10px 20px;transition:background-color .2s}.error-close-btn:hover{background:#0056b3}@media (max-width:768px){.read-only-banner{padding:10px 15px}.banner-text{font-size:13px;max-width:calc(100vw - 150px)}.close-admin-view{font-size:16px;height:25px;width:25px}}@media (max-width:480px){.read-only-banner{align-items:flex-start;flex-direction:column;gap:8px}.banner-content{width:100%}.banner-text{max-width:calc(100vw - 40px)}.close-admin-view{position:absolute;right:10px;top:8px}}.ghost-bar{background:linear-gradient(90deg,#ff4b2b,#ff416c);border-bottom:2px solid #fff3;box-shadow:0 2px 10px #0000004d;color:#fff;font-family:Inter,sans-serif;height:40px;justify-content:space-between;left:0;padding:0 20px;position:fixed;right:0;top:0;z-index:9999}.ghost-bar,.ghost-bar-left{align-items:center;display:flex}.ghost-bar-left{gap:12px}.ghost-icon{animation:ghost-float 2s ease-in-out infinite;font-size:20px}@keyframes ghost-float{0%,to{transform:translateY(0)}50%{transform:translateY(-3px)}}.ghost-mode-label{font-size:14px;font-weight:800;letter-spacing:1px;text-transform:uppercase}.ghost-bar-center{align-items:center;display:flex;gap:15px}.target-user-pill{align-items:center;background:#0003;border:1px solid #ffffff4d;border-radius:20px;display:flex;font-size:13px;gap:8px;padding:4px 12px}.target-email{font-weight:400;opacity:.9}.readonly-badge{background:gold;border-radius:4px;color:#000;font-size:11px;font-weight:700;padding:2px 8px;text-transform:uppercase}.ghost-bar-right{display:flex;gap:10px}.ghost-bar-btn{align-items:center;background:#fff;border:none;border-radius:4px;color:#ff416c;cursor:pointer;display:flex;font-size:12px;font-weight:600;gap:6px;padding:4px 12px;transition:all .2s}.ghost-bar-btn:hover{background:#f0f0f0;transform:translateY(-1px)}.ghost-bar-btn.exit-btn{background:#000;color:#fff}.ghost-bar-btn.exit-btn:hover{background:#333}body.ghost-mode-active{padding-top:40px!important}body.ghost-mode-active .app-topbar,body.ghost-mode-active .sidebar-container{top:40px!important}:root{--color-bg-canvas:#fff;--color-bg-ui:#fff;--color-bg-topbar-nav:#efefef;--color-brand-primary:#049dc8;--color-text-primary:#333;--color-text-secondary:#6e6e6e;--color-text-tertiary:#a2a2a2;--color-text-inverted:#fff;--color-border-default:#ddd;--color-border-strong:#a0a0a0;--color-border-subtle:#dadada;--color-accent-primary:#697486;--color-accent-primary-hover:#306b87;--color-accent-secondary:#efefef;--color-accent-secondary-active-text:#000;--color-success:#28a745;--color-success-hover:#218838;--color-button-default-bg:#f3f3f3;--color-button-default-hover-bg:#e9e9e9;--color-button-default-highlight:#3a8dad;--node-bg-shell:#f9f9f9;--node-header-bg:#e3e3e3;--node-shadow:-2px 2px 4px #0000001a;--node-input-bg-color:#fff;--flow-dots:silver;--flow-selection-outline:#2f9ac4}:root.dark-mode{--color-bg-canvas:#1e1e1e;--color-bg-ui:#252526;--color-bg-topbar:#252526;--color-bg-topbar-nav:#333;--color-brand-primary:#049dc8;--color-text-primary:#e0e0e0;--color-text-secondary:#8a8a8a;--color-text-tertiary:#b0b0b0;--color-text-inverted:#fff;--color-border-default:#444;--color-border-strong:#666;--color-border-subtle:#535353;--color-border-light:#b1b1b1;--color-accent-primary:#1f2328;--color-accent-primary-hover:#5a94ab;--color-accent-secondary:#3e3e42;--color-accent-secondary-active-text:#fff;--color-success:#28a745;--color-success-hover:#218838;--color-button-default-bg:#3e3e42;--color-button-default-text:#ccc;--color-button-default-hover-bg:#4a4a4f;--color-button-default-highlight:#3d6575;--node-bg-shell:#2d2d30;--node-header-bg:#38383b;--node-shadow:-2px 2px 6px #0006;--node-input-bg-color:#3e3e42;--flow-dots:#404040;--flow-selection-outline:#3e7e97;--node-color-1:#4a4a4a;--node-color-2:#264a59;--node-color-3:#7c3b62;--node-color-4:#2e6750;--node-color-5:#675f2e;--node-color-6:#5d476b;--node-color-7:#7c4a3b;--node-dropdown-border-color:#6b6b6b;--modal-bg:#2d2d30;--modal-header-bg:#38383b;--modal-border:#444;--modal-title-color:#e0e0e0;--modal-close-color:#8a8a8a;--modal-close-hover-bg:#4a4a4f;--modal-close-hover-color:#e0e0e0;--rich-editor-bg:#2c2c2c;--rich-editor-border:#404040;--rich-toolbar-bg:#1e1e1e;--rich-toolbar-border:#404040;--rich-toolbar-color:#e0e0e0;--rich-toolbar-hover-bg:#404040;--rich-toolbar-hover-color:#fff;--rich-editor-text-color:#e0e0e0;--rich-editor-placeholder-color:#888;--rich-editor-heading-color:#fff;--rich-actions-bg:#1e1e1e;--rich-status-color:#b0b0b0;--rich-cancel-bg:#2c2c2c;--rich-cancel-border:#555;--rich-cancel-color:#b0b0b0;--rich-cancel-hover-bg:#404040;--rich-cancel-hover-border:#666;--rich-cancel-hover-color:#fff;--rich-scene-save-bg:#306b87;--rich-scene-save-border:#306b87;--rich-scene-save-color:#fff;--rich-scene-save-hover-bg:#1f4e79;--rich-scene-save-hover-border:#1f4e79;--rich-save-disabled-bg:#555;--rich-save-disabled-border:#555;--rich-save-disabled-color:#888;--rich-unsaved-color:#e67e22;--rich-wordcount-color:#95a5a6}.beat-node-container .node-label,.beat-node-container label{color:var(--color-text-primary)}.beat-node-container .character-add-section .character-dropdown,.beat-node-container .context-nodeid-input input,.beat-node-container .edit-textarea,.beat-node-container .instructions-textarea{background-color:var(--color-bg-canvas);border:none;color:var(--color-text-primary)}.beat-node-container .character-entry,.beat-node-container .manual-node-item{background-color:var(--color-bg-ui);border:1px solid var(--color-border-strong)}.beat-node-container .character-name,.beat-node-container .manual-node-item .node-name{color:var(--color-text-primary)}.delete-context-button{background:none;border:none;color:var(--color-text-secondary);cursor:pointer;font-size:16px;padding:0 3px}.delete-context-button:hover{color:var(--color-text-primary)}.beat-header-bar .heart-icon{margin-right:8px}.beat-node-container input:focus,.beat-node-container select:focus,.beat-node-container textarea:focus{border:none!important;box-shadow:none;outline:none}.main-gallery-area::-webkit-scrollbar{width:8px}.main-gallery-area::-webkit-scrollbar-track{background:var(--color-bg-canvas)}.main-gallery-area::-webkit-scrollbar-thumb{background:var(--color-border-strong);border-radius:4px}.main-gallery-area::-webkit-scrollbar-thumb:hover{background:var(--color-border-light)}.character-add-section .character-dropdown:focus{padding:0 9px}.react-flow__controls-button{background-color:var(--color-bg-ui);border:1px solid var(--color-border-default);color:var(--color-text-secondary)}.react-flow__controls-button:hover{background-color:var(--color-button-default-hover-bg)}.react-flow__controls-button svg{fill:currentColor}.react-flow__panel.react-flow__attribution.bottom.right{background-color:var(--color-bg-ui)}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--color-bg-canvas);color:var(--color-text-primary);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}#app{height:100vh;width:100%}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.react-flow__node{pointer-events:auto!important}.react-flow-container{contain:layout style!important}.react-flow__pane,.react-flow__renderer{contain:layout!important}.react-flow__viewport{contain:none!important}.react-rnd{pointer-events:auto!important;-webkit-user-select:auto!important;user-select:auto!important}.asset-picker-grid{grid-gap:1rem;background-color:var(--color-bg-inset);border-radius:8px;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));max-height:400px;overflow-y:auto;padding:1rem}.asset-picker-item{border:2px solid #0000;border-radius:8px;cursor:pointer;overflow:hidden;position:relative;transition:border-color .2s}.asset-picker-item.selected,.asset-picker-item:hover{border-color:var(--color-accent-fg)}.asset-picker-item img{display:block;height:80px;object-fit:cover;width:100%}.asset-name{background-color:var(--color-bg-inset);color:var(--color-text-primary);font-size:.8rem;overflow:hidden;padding:4px 8px;text-align:center;text-overflow:ellipsis;white-space:nowrap}.asset-picker-checkmark{align-items:center;background-color:var(--color-accent-fg);border-radius:50%;color:var(--color-fg-on-accent);display:flex;font-weight:700;height:24px;justify-content:center;opacity:0;position:absolute;right:8px;top:8px;transform:scale(.5);transition:opacity .2s,transform .2s;width:24px}.asset-picker-item.selected .asset-picker-checkmark{opacity:1;transform:scale(1)}.asset-picker-upload-prompt{color:var(--color-text-secondary);font-size:.9rem;margin-top:1rem;text-align:center}.upload-link{background:none;border:none;color:var(--color-accent-fg);cursor:pointer;font-weight:500;margin-left:.5rem}.upload-link:hover{text-decoration:underline}.asset-picker-modal-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background-color:#000000bf;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1100}.asset-picker-modal-content{background-color:var(--color-bg-ui);border:1px solid var(--color-border-subtle);border-radius:12px;box-shadow:0 8px 30px #0006;display:flex;flex-direction:column;gap:16px;max-width:800px;padding:24px;position:relative;width:90%}.asset-picker-modal-header{align-items:center;display:flex;justify-content:space-between;padding-bottom:8px}.asset-picker-modal-header h2{color:var(--color-text-primary);font-size:1.2em;font-weight:600}.asset-picker-modal-body{display:flex;flex-direction:column;gap:16px;overflow-y:auto}.asset-picker-modal-footer{align-items:center;border-top:1px solid var(--color-border-subtle);display:flex;gap:15px;justify-content:flex-end;padding-top:16px}.asset-picker-modal-header .p-1{align-items:center;background:none;border:none;border-radius:50%;color:#9ca3af;cursor:pointer;display:flex;justify-content:center;padding:4px;transition:background-color .2s}.asset-picker-modal-header .p-1:hover{background-color:#6b728033}.asset-picker-modal-header .p-1 svg{stroke:currentColor;height:24px;width:24px}.asset-picker-modal-body::-webkit-scrollbar{width:8px}.asset-picker-modal-body::-webkit-scrollbar-track{background:var(--color-bg-inset);border-radius:4px}.asset-picker-modal-body::-webkit-scrollbar-thumb{background:var(--color-border-strong);border-radius:4px}.asset-picker-modal-body::-webkit-scrollbar-thumb:hover{background:var(--color-border-light)}.asset-picker-grid::-webkit-scrollbar{width:8px}.asset-picker-grid::-webkit-scrollbar-track{background:var(--color-bg-inset);border-radius:4px}.asset-picker-grid::-webkit-scrollbar-thumb{background:var(--color-border-strong);border-radius:4px}.asset-picker-grid::-webkit-scrollbar-thumb:hover{background:var(--color-border-light)}