.react-flow{direction:ltr}.react-flow__container{position:absolute;width:100%;height:100%;top:0;left:0}.react-flow__pane{z-index:1;cursor:-webkit-grab;cursor:grab}.react-flow__pane.selection{cursor:pointer}.react-flow__pane.dragging{cursor:-webkit-grabbing;cursor:grabbing}.react-flow__viewport{transform-origin:0 0;z-index:2;pointer-events:none}.react-flow__renderer{z-index:4}.react-flow__selection{z-index:6}.react-flow__nodesselection-rect:focus,.react-flow__nodesselection-rect:focus-visible{outline:none}.react-flow .react-flow__edges{pointer-events:none;overflow:visible}.react-flow__edge-path,.react-flow__connection-path{stroke:#b1b1b7;stroke-width:1;fill:none}.react-flow__edge{pointer-events:visibleStroke;cursor:pointer}.react-flow__edge.animated path{stroke-dasharray:5;-webkit-animation:dashdraw .5s linear infinite;animation:dashdraw .5s linear infinite}.react-flow__edge.animated path.react-flow__edge-interaction{stroke-dasharray:none;-webkit-animation: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;-moz-user-select:none;user-select:none}.react-flow__connection{pointer-events:none}.react-flow__connection .animated{stroke-dasharray:5;-webkit-animation:dashdraw .5s linear infinite;animation:dashdraw .5s linear infinite}.react-flow__connectionline{z-index:1001}.react-flow__nodes{pointer-events:none;transform-origin:0 0}.react-flow__node{position:absolute;-webkit-user-select:none;-moz-user-select:none;user-select:none;pointer-events:all;transform-origin:0 0;box-sizing:border-box;cursor:-webkit-grab;cursor:grab}.react-flow__node.dragging{cursor:-webkit-grabbing;cursor:grabbing}.react-flow__nodesselection{z-index:3;transform-origin:left top;pointer-events:none}.react-flow__nodesselection-rect{position:absolute;pointer-events:all;cursor:-webkit-grab;cursor:grab}.react-flow__handle{position:absolute;pointer-events:none;min-width:5px;min-height:5px;width:6px;height:6px;background:#1a192b;border:1px solid white;border-radius:100%}.react-flow__handle.connectionindicator{pointer-events:all;cursor:crosshair}.react-flow__handle-bottom{top:auto;left:50%;bottom:-4px;transform:translate(-50%)}.react-flow__handle-top{left:50%;top:-4px;transform:translate(-50%)}.react-flow__handle-left{top:50%;left:-4px;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{position:absolute;z-index:5;margin:15px}.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:translate(-50%)}.react-flow__attribution{font-size:10px;background:#ffffff80;padding:2px 3px;margin:0}.react-flow__attribution a{text-decoration:none;color:#999}@-webkit-keyframes dashdraw{0%{stroke-dashoffset:10}}@keyframes dashdraw{0%{stroke-dashoffset:10}}.react-flow__edgelabel-renderer{position:absolute;width:100%;height:100%;pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.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-input,.react-flow__node-output,.react-flow__node-group{padding:10px;border-radius:3px;width:150px;font-size:12px;color:#222;text-align:center;border-width:1px;border-style:solid;border-color:#1a192b;background-color:#fff}.react-flow__node-default.selectable:hover,.react-flow__node-input.selectable:hover,.react-flow__node-output.selectable:hover,.react-flow__node-group.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-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,.react-flow__node-group.selectable.selected,.react-flow__node-group.selectable:focus,.react-flow__node-group.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 rgba(0,89,220,.8)}.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{border:none;background:#fefefe;border-bottom:1px solid #eee;box-sizing:content-box;display:flex;justify-content:center;align-items:center;width:16px;height:16px;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;padding:5px}.react-flow__controls-button:hover{background:#f4f4f4}.react-flow__controls-button svg{width:100%;max-width:12px;max-height:12px}.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.top,.react-flow__resize-control.bottom{cursor:ns-resize}.react-flow__resize-control.top.left,.react-flow__resize-control.bottom.right{cursor:nwse-resize}.react-flow__resize-control.bottom.left,.react-flow__resize-control.top.right{cursor:nesw-resize}.react-flow__resize-control.handle{width:4px;height:4px;border:1px solid #fff;border-radius:1px;background-color:#3367d9;transform:translate(-50%,-50%)}.react-flow__resize-control.handle.left{left:0;top:50%}.react-flow__resize-control.handle.right{left:100%;top:50%}.react-flow__resize-control.handle.top{left:50%;top:0}.react-flow__resize-control.handle.bottom{left:50%;top:100%}.react-flow__resize-control.handle.top.left,.react-flow__resize-control.handle.bottom.left{left:0}.react-flow__resize-control.handle.top.right,.react-flow__resize-control.handle.bottom.right{left:100%}.react-flow__resize-control.line{border-color:#3367d9;border-width:0;border-style:solid}.react-flow__resize-control.line.left,.react-flow__resize-control.line.right{width:1px;transform:translate(-50%);top:0;height:100%}.react-flow__resize-control.line.left{left:0;border-left-width:1px}.react-flow__resize-control.line.right{left:100%;border-right-width:1px}.react-flow__resize-control.line.top,.react-flow__resize-control.line.bottom{height:1px;transform:translateY(-50%);left:0;width:100%}.react-flow__resize-control.line.top{top:0;border-top-width:1px}.react-flow__resize-control.line.bottom{border-bottom-width:1px;top:100%}html,body,#root{margin:0;padding:0;height:100%;width:100%;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*,*:before,*:after{box-sizing:border-box}.app-container{display:flex;flex-direction:column;min-height:100vh;height:100%;width:100vw;background-color:#fff;color:#333;transition:background-color .3s ease,color .3s ease;position:relative;--background-color: #ffffff;--text-color: #333333;--text-color-light: #666666;--primary-color: #007bff;--primary-color-dark: #0056b3;--primary-color-rgb: 0, 123, 255;--border-color: #cccccc;--border-color-light: #eeeeee;--input-background-color: #f8f8f8;--button-secondary-background: #e0e0e0;--panel-background-color: #ffffff;--button-secondary-background-hover: #d0d0d0;--button-secondary-text: #333333;--button-secondary-text-hover: #333333;--button-secondary-border: #cccccc;--button-secondary-border-hover: #bbbbbb;--danger-color: #dc3545;--danger-color-dark: #a71d2a;--danger-color-light: #f5c6cb;--modal-background-light: #ffffff;--modal-background-dark: #282c34}.app-container.dark-mode{background-color:#282c34;color:#f8f8f2;--background-color: #282c34;--text-color: #f8f8f2;--text-color-light: #cccccc;--primary-color: #007bff;--primary-color-dark: #0056b3;--primary-color-rgb: 97, 218, 251;--border-color: #555555;--border-color-light: #444444;--input-background-color: #3a3f4b;--button-secondary-background: #5a5f6b;--button-secondary-background-hover: #6a6f7b;--button-secondary-text: #f8f8f2;--button-secondary-text-hover: #f8f8f2;--button-secondary-border: #555555;--button-secondary-border-hover: #666666;--danger-color: #ff6b6b;--danger-color-dark: #e63946;--danger-color-light: #ffcccc;--success-background-dark: #2d573c;--success-text-dark: #a8e6cf;--error-background-dark: #6b2d30;--error-text-dark: #ffb3b3;--panel-background-color: #3a3f4b;--input-text-color: #ffffff}.app-container.dark-mode{background-color:#282c34;color:#f8f8f2}.app-main-container{display:flex;flex-direction:row;height:100%;width:100%}.canvas-container{flex-grow:1;height:100%;width:100%;touch-action:pan-x pan-y}.react-flow__renderer{width:100%;height:100%}.story-panel{position:absolute;top:100px;left:10px;width:calc(100% - 20px);right:10px;box-sizing:border-box;max-height:50vh;padding:15px;border-radius:15px;background-color:var(--panel-background-color);box-shadow:0 4px 12px #00000026;display:flex;flex-direction:column;overflow-y:auto;transition:all .3s ease-in-out;z-index:10}.story-panel.collapsed{max-height:40px;padding:10px 15px;overflow:hidden}.story-panel.collapsed h2{margin-bottom:0;font-size:1em}.story-panel.collapsed .form-group,.story-panel.collapsed .no-node-selected-message,.story-panel.collapsed .story-panel-label,.story-panel.collapsed .error-message{display:none}.app-container.dark-mode .story-panel{background-color:#3a3f4b;box-shadow:0 4px 12px #0006}.story-panel h2{margin-top:0;color:inherit;font-size:1.2em;margin-bottom:10px;display:flex;align-items:center;cursor:pointer}.story-panel-title svg{margin-right:8px;width:20px;height:20px;transition:transform .3s ease}.story-panel.collapsed .story-panel-title svg{transform:rotate(0)}.no-node-selected-message{color:inherit;margin:0;padding:0;width:100%;box-sizing:border-box}.no-node-selected-message strong{font-weight:700;color:inherit}.story-panel .form-group{display:flex;flex-direction:column;gap:5px;margin-top:15px}.story-panel label{font-weight:700;color:inherit;font-size:.9em}.input-field{padding:8px;border:1px solid var(--border-color);border-radius:4px;font-size:.9em;background-color:var(--input-background-color);color:var(--input-text-color);transition:background-color .3s ease,color .3s ease,border-color .3s ease}.input-field:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 2px rgba(var(--primary-color-rgb),.25)}.button{padding:10px 15px;border:none;border-radius:4px;font-size:1em;cursor:pointer;transition:background-color .2s ease,border-color .2s ease,color .2s ease}.button:disabled{background-color:var(--button-secondary-background);color:var(--button-secondary-text);cursor:not-allowed}.button.primary{background-color:var(--primary-color);color:#fff}.button.primary:hover:not(:disabled){background-color:var(--primary-color-dark)}.button.secondary:hover:not(:disabled){background-color:var(--button-secondary-background-hover);border-color:var(--button-secondary-border-hover);color:var(--button-secondary-text-hover)}.button.danger:hover:not(:disabled){background-color:var(--danger-color-dark)}.story-panel button{margin-bottom:10px}.error-message{color:#dc3545;background-color:#f8d7da;border:1px solid #f5c6cb;padding:10px;border-radius:4px;margin-bottom:10px}.validation-error{color:#dc3545;font-size:.8em;margin-top:3px}.story-panel-label{margin-bottom:0}.node-image-container{position:relative}.download-button{position:absolute;bottom:5px;right:5px;background-color:#0009;border:none;border-radius:4px;padding:5px;cursor:pointer;display:flex;justify-content:center;align-items:center;transition:background-color .2s ease;z-index:1}.download-button:hover{background-color:#000c}.download-button svg{fill:#fff;width:18px;height:18px}.app-container.dark-mode .download-button{background-color:#fff3}.app-container.dark-mode .download-button:hover{background-color:#fff6}.app-container.dark-mode .download-button svg{fill:#f8f8f2}.reactflow-node{width:200px;height:250px;border:1px solid #ccc;border-radius:5px;background-color:#fff;box-shadow:0 2px 5px #0000001a;text-align:center;font-size:.9em;transition:background-color .3s ease,border-color .3s ease,box-shadow .3s ease;display:flex;flex-direction:column;padding:0;overflow:hidden}.app-container.dark-mode .reactflow-node{background-color:#4a4f5b;border-color:#555;color:#f8f8f2;box-shadow:0 2px 5px #0000004d}.reactflow-node.selected{border-color:#007bff;box-shadow:0 0 0 3px #007bff,0 0 0 6px #007bff4d}.app-container.dark-mode .reactflow-node.selected{border-color:#007bff;box-shadow:0 0 0 3px #007bff,0 0 0 6px #007bff80}.node-image-container{width:100%;height:200px;overflow:hidden;position:relative}.node-image-container img{width:100%;height:100%;object-fit:cover;display:block;border-radius:3px 3px 0 0}.node-text-content{flex-grow:1;padding:5px 10px;display:flex;flex-direction:column;justify-content:center;align-items:center}.node-text-content strong{display:block;margin-bottom:3px;word-break:break-word;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical}.node-text-content span{color:inherit;font-size:.8em;word-break:break-word}.node-author-pic{width:20px;height:20px;border-radius:50%;object-fit:cover;margin-right:5px;vertical-align:middle}.genesis-author-pic{background-color:#fff;padding:1px;border:1px solid #eee;box-shadow:0 0 2px #0000001a;width:16px;height:16px}.react-flow__controls,.react-flow__minimap{background-color:#fff;border:1px solid #eee;transition:background-color .3s ease,border-color .3s ease}.app-container.dark-mode .react-flow__controls,.app-container.dark-mode .react-flow__minimap{background-color:#3a3f4b;border-color:#444}.react-flow__controls-button{background-color:#f9f9f9;border-bottom:1px solid #eee;transition:background-color .3s ease,border-color .3s ease}.app-container.dark-mode .react-flow__controls-button{background-color:#4a4f5b;border-bottom-color:#555}.react-flow__controls-button svg{fill:#333;transition:fill .3s ease}.app-container.dark-mode .react-flow__controls-button svg{fill:#f8f8f2}.react-flow__controls-button:hover{background-color:#eee}.app-container.dark-mode .react-flow__controls-button:hover{background-color:#5a5f6b}.react-flow__background.react-flow__background-dots{background-image:radial-gradient(#ccc 1px,transparent 1px)}.app-container.dark-mode .react-flow__background.react-flow__background-dots{background-image:radial-gradient(#555 1px,transparent 1px)}.dark-mode-toggle-button{margin-top:15px;background-color:#6c757d}.dark-mode-toggle-button:hover:not(:disabled){background-color:#5a6268}.app-header{position:fixed;top:0;left:0;width:100%;z-index:10;background-color:var(--background-color);box-shadow:0 2px 5px #0000001a;display:flex;flex-direction:column;align-items:center;padding-bottom:10px}@media (min-width: 769px){.app-header{position:absolute;top:auto;left:auto;width:auto;background-color:transparent;box-shadow:none;flex-direction:row;padding-bottom:0}}.header-left{z-index:11;display:flex;flex-direction:row;align-items:center;gap:10px;padding:5px 15px;border-radius:25px;background-color:#f0f0f0;box-shadow:0 2px 5px #0000001a;transition:background-color .3s ease,box-shadow .3s ease}.header-mobile-wrapper{display:flex;flex-direction:column;width:100%;position:fixed;top:0;left:0;z-index:11;background-color:var(--background-color);box-shadow:0 2px 5px #0000001a;padding-bottom:10px}@media (min-width: 769px){.header-mobile-wrapper{display:contents}}.main-menu-container{position:relative;display:flex;align-items:center}.main-menu-dropdown{position:absolute;top:50px;left:0;background-color:#f0f0f0;border-radius:8px;box-shadow:0 4px 12px #00000026;padding:10px 0;min-width:180px;display:flex;flex-direction:column;z-index:10}.app-container.dark-mode .main-menu-dropdown{background-color:#4a4f5b;box-shadow:0 4px 12px #0006}.app-container.dark-mode .header-left{background-color:#4a4f5b;box-shadow:0 2px 5px #0000004d}.header-left .logo{font-weight:700;font-size:1em;line-height:1;color:#333;transition:color .3s ease;display:inline-block}.app-container.dark-mode .header-left .logo{color:#f8f8f2}.canvas-name-display{margin-left:10px;display:flex;align-items:center}.canvas-name-text{font-size:1.2em;font-weight:700;color:var(--text-color);cursor:pointer;padding:5px 8px;height:34px;line-height:22px;border-radius:5px;transition:background-color .2s ease;margin:0;border:1px solid transparent;box-sizing:border-box;vertical-align:middle}.canvas-name-text:hover{background-color:#0000000d}.app-container.dark-mode .canvas-name-text:hover{background-color:#ffffff1a}.canvas-name-input{font-family:inherit;font-size:1.2em;font-weight:700;color:var(--text-color);background-color:var(--input-background-color);border:1px solid transparent;border-radius:5px;padding:5px 8px;width:200px;height:34px;line-height:22px;box-sizing:border-box;vertical-align:middle;outline:none}.canvas-name-input:focus{border-color:var(--border-color)}.app-container.dark-mode .canvas-name-input{background-color:var(--input-background-color);color:var(--input-text-color);border-color:var(--border-color)}.header-left .control-button{width:32px;height:32px;display:flex;justify-content:center;align-items:center;cursor:pointer;transition:background-color .2s ease,border-color .2s ease,box-shadow .2s ease}.header-left .control-button svg{fill:#666;transition:fill .2s ease}.app-container.dark-mode .header-left .control-button svg{fill:#ccc;stroke:#ccc}.header-left .control-button:hover{background-color:#d0d0d0}.app-container.dark-mode .header-left .control-button:hover{background-color:#5a5f6b}.header-left .feedback-link{display:none}@media (min-width: 769px){.header-left .feedback-link{display:block;color:#007bff;text-decoration:none;font-size:.9em;padding:5px 10px;border-radius:15px;background-color:#007bff1a;transition:background-color .2s ease,color .2s ease}.app-container.dark-mode .header-left .feedback-link{color:#90baff;background-color:#007bff33}.header-left .feedback-link:hover{background-color:#007bff33}.app-container.dark-mode .header-left .feedback-link:hover{background-color:#007bff4d}}.header-right{z-index:11;display:flex;align-items:center;gap:10px}@media (max-width: 768px){.header-left{position:relative;top:auto;left:auto;width:100%;justify-content:center;padding:10px;border-radius:0;box-shadow:none;background-color:transparent;z-index:3}.app-container.dark-mode .header-left{background-color:transparent;box-shadow:none}.header-right{position:relative;top:auto;right:auto;width:100%;justify-content:center;padding:10px;gap:5px;z-index:2}.share-button{padding:6px 10px;font-size:.8em}.share-button svg{width:16px;height:16px}.profile-pill{padding:3px 10px 3px 3px}.profile-pic-container{width:28px;height:28px}.profile-arrow{font-size:.7em}.main-menu-dropdown{left:auto;right:0;min-width:150px}.story-panel{top:150px;z-index:1}}.share-button{display:flex;align-items:center;gap:5px;background-color:var(--primary-color);color:#fff;padding:8px 15px;border-radius:25px;border:none;cursor:pointer;font-weight:700;box-shadow:0 2px 5px #0000001a;transition:background-color .2s ease,box-shadow .2s ease}.share-button:hover{background-color:var(--primary-color-dark)}.share-button svg{fill:#fff;width:20px;height:20px}.share-button span{display:inline-block;font-size:.9em;margin-left:5px}.profile-pill{display:flex;align-items:center;background-color:#f0f0f0;padding:5px 15px 5px 5px;border-radius:25px;cursor:pointer;box-shadow:0 2px 5px #0000001a;transition:background-color .3s ease,box-shadow .3s ease}.app-container.dark-mode .profile-pill{background-color:#4a4f5b;box-shadow:0 2px 5px #0000004d}.profile-pill:hover{background-color:#e0e0e0}.app-container.dark-mode .profile-pill:hover{background-color:#5a5f6b}.profile-pic-container{position:relative;width:32px;height:32px;margin-right:8px}.profile-pic,.profile-pic-display{width:100%;height:100%;border-radius:50%;object-fit:cover}.founding-member-badge{position:absolute;bottom:0;right:0;background-color:gold;border-radius:50%;width:16px;height:16px;display:flex;justify-content:center;align-items:center;font-size:10px;line-height:1;color:#000;border:1px solid white;box-shadow:0 0 3px #0000004d;z-index:1}.profile-arrow{color:var(--text-color-light);font-size:.8em;transition:color .3s ease}.app-container.dark-mode .profile-arrow{color:#ccc}.profile-dropdown{position:absolute;top:50px;right:0;background-color:#f0f0f0;border-radius:8px;box-shadow:0 4px 12px #00000026;padding:10px 0;min-width:180px;display:flex;flex-direction:column;z-index:10}.app-container.dark-mode .profile-dropdown{background-color:#4a4f5b;box-shadow:0 4px 12px #0006}.profile-dropdown-item{display:flex;align-items:center;padding:8px 15px;color:var(--text-color);text-decoration:none;transition:background-color .2s ease;border:none;background:transparent;gap:10px}.app-container.dark-mode .profile-dropdown-item{color:var(--text-color)}.profile-dropdown-item:hover,.app-container.dark-mode .profile-dropdown-item:hover{background-color:var(--button-secondary-background-hover)}.profile-dropdown-item svg{fill:none;stroke:currentColor;transition:stroke .2s ease;width:16px;height:16px}.profile-dropdown-item img{width:32px;height:32px;border-radius:50%;object-fit:cover;margin-right:10px}.profile-dropdown-item .profile-pic{width:32px;height:32px;margin-right:10px}.profile-dropdown-item span{font-size:1em}.profile-info{display:flex;flex-direction:column}.profile-info .name{font-weight:700}.profile-info .status{font-size:.8em;color:var(--text-color-light)}.app-container.dark-mode .profile-info .status{color:var(--text-color-light)}.logout-button{background:none;border:none;color:var(--danger-color);cursor:pointer;padding:8px 15px;text-align:left;width:100%;transition:background-color .2s ease}.logout-button:hover{background-color:var(--danger-color-light)}.app-container.dark-mode .logout-button{color:#f99}.app-container.dark-mode .logout-button:hover{background-color:#6a3d3d}@media (min-width: 769px){.app-container{flex-direction:row}.canvas-container{height:100%}.story-panel{position:absolute;inset:100px auto auto 20px;transform:none;max-height:calc(100vh - 100px);padding:20px;border-radius:8px;box-shadow:0 4px 12px #00000026;gap:15px;width:350px;z-index:1}.app-container.dark-mode .story-panel{box-shadow:0 4px 12px #0006}.story-panel h2{font-size:1.5em}.story-panel label{font-size:1em}.story-panel input[type=text]{padding:10px;font-size:1em}.validation-error{font-size:.85em;margin-top:5px}.header-left{position:fixed;top:20px;left:20px;flex-direction:row}.header-right{position:fixed;top:20px;right:20px}}@keyframes focus-glow{0%{box-shadow:0 0 #007bffb3}50%{box-shadow:0 0 0 12px #007bff00}to{box-shadow:0 0 #007bff00}}.reactflow-node.focused{animation:focus-glow 1.5s 1}.loading-node{background-color:#f0f8ff}.loading-overlay{position:absolute;inset:0;background-color:#ffffffe6;display:flex;flex-direction:column;justify-content:center;align-items:center;color:#333;font-weight:700;border-radius:3px 3px 0 0;z-index:10;transition:background-color .3s ease,color .3s ease}.app-container.dark-mode .loading-overlay{background-color:#282c34e6;color:#f8f8f2}.loading-overlay .loader{width:55px!important;aspect-ratio:1!important;--g1:conic-gradient(from 90deg at 3px 3px ,#0000 90deg,#333 0);--g2:conic-gradient(from -90deg at 22px 22px,#0000 90deg,#333 0);background-image:var(--g1),var(--g1),var(--g1),var(--g2),var(--g2),var(--g2)!important;background-size:25px 25px!important;background-repeat:no-repeat!important;animation:l7 1.5s infinite!important}.app-container.dark-mode .loading-overlay .loader{--g1:conic-gradient(from 90deg at 3px 3px ,#0000 90deg,#f8f8f2 0);--g2:conic-gradient(from -90deg at 22px 22px,#0000 90deg,#f8f8f2 0)}@keyframes l7{0%{background-position:0 0,0 100%,100% 100%}25%{background-position:100% 0,0 100%,100% 100%}50%{background-position:100% 0,0 0,100% 100%}75%{background-position:100% 0,0 0,0 100%}to{background-position:100% 100%,0 0,0 100%}}.node-status-message{font-size:1.2em;font-weight:700;color:inherit}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.modal-content{background-color:var(--background-color);padding:20px;border-radius:8px;box-shadow:0 4px 12px #00000026;max-width:500px;width:90%;text-align:left;position:relative;color:var(--text-color)}.app-container.dark-mode .modal-content{box-shadow:0 4px 12px #0006}.modal-content h2{margin-top:0;margin-bottom:15px;color:inherit}.modal-content p{margin-bottom:20px;color:inherit}.modal-content input[type=text]{width:calc(100% - 20px);padding:10px;margin-bottom:20px;border:1px solid var(--border-color);border-radius:4px;font-size:1em;background-color:var(--input-background-color);color:var(--text-color);transition:border-color .3s ease,background-color .3s ease,color .3s ease}.modal-content input[type=text]:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 2px rgba(var(--primary-color-rgb),.25)}.modal-actions{display:flex;justify-content:center;gap:10px}.modal-actions button{padding:10px 20px;border:none;border-radius:4px;cursor:pointer;font-size:1em;transition:background-color .2s ease}.modal-actions button.primary{background-color:var(--primary-color);color:#fff}.modal-actions button.primary:hover{background-color:var(--primary-color-dark)}.modal-actions button.secondary{background-color:var(--button-secondary-background);color:var(--button-secondary-text);border:1px solid var(--button-secondary-border)}.modal-actions button.secondary:hover{background-color:var(--button-secondary-background-hover);border-color:var(--button-secondary-border-hover);color:var(--button-secondary-text-hover)}.auth-page-container{display:flex;justify-content:center;align-items:center;min-height:100vh;width:100%;background-color:var(--background-color);color:var(--text-color)}.auth-form-panel{background-color:var(--panel-background-color);padding:40px;border-radius:8px;box-shadow:0 4px 20px #00000080;max-width:400px}.auth-form-panel .logo{max-width:100px;height:auto;margin:0 auto 20px;border-radius:8px;display:block}.auth-form-panel h2{color:var(--primary-color);margin-bottom:20px}.auth-form-panel .form-group{margin-bottom:15px;text-align:left}.auth-form-panel label{display:block;margin-bottom:8px;font-weight:700;color:var(--text-color)}.auth-form-panel .input-field{width:calc(100% - 20px);padding:10px;font-size:16px}.auth-form-panel .button[type=submit]{padding:12px 20px;font-size:18px;font-weight:700}.auth-form-panel .error-message{color:var(--danger-color);margin-top:10px}.auth-form-panel .success-message{color:var(--success-text-dark);margin-top:10px}.auth-form-panel p{margin-top:20px;font-size:14px}.auth-form-panel p a{color:var(--primary-color);text-decoration:none}.auth-form-panel p a:hover{text-decoration:underline}.landing-container{display:flex;flex-direction:column;height:100vh;width:100%;background-color:var(--background-color);color:var(--text-color);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;box-sizing:border-box;margin:0;padding:0 20px;position:relative}.public-canvas-preview{position:absolute;top:0;left:0;width:100%;height:100%;z-index:0}.dark-canvas-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background-color:#0000004d;z-index:1}.public-canvas-viewer{width:100%;height:100%}.hero-overlay{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:50px;z-index:2;padding:50px 20px;box-sizing:border-box}.hero-header{display:flex;flex-direction:column;align-items:center;text-align:center;color:var(--text-color);z-index:2}.landing-logo-hero{width:120px;height:auto;filter:drop-shadow(0 0 20px rgba(0,0,0,.9));margin-bottom:10px}.hero-header h1{font-size:3.5em;color:var(--text-color);font-weight:800;line-height:1.1;text-shadow:0 0 25px rgba(0,0,0,1);margin-bottom:10px}.tagline{font-size:1.5em;color:var(--text-color-light);text-shadow:0 0 20px rgba(0,0,0,.9);margin-bottom:0}.public-demo-panel{background-color:#000000b3;color:#fff;padding:8px 12px;border-radius:8px;font-size:.9em}.landing-card{background-color:#2a2a2a99;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);padding:40px;border-radius:12px;box-shadow:0 8px 32px #0000005e;text-align:center;max-width:450px;margin:0 auto;box-sizing:border-box;border:1px solid rgba(255,255,255,.18);z-index:2}.landing-logo{width:120px;height:auto;margin-bottom:30px}.landing-card h2{font-size:2.2em;margin-bottom:25px;color:var(--text-color);font-weight:700}.founding-members-status{font-size:1.1em;margin-bottom:25px;color:var(--text-color-light)}.landing-form{display:flex;flex-direction:column;gap:20px}.landing-input{width:100%;padding:15px;font-size:1em;box-sizing:border-box}.landing-input::placeholder{color:var(--text-color-light)}.landing-button{width:100%;padding:15px;font-size:1.1em;font-weight:600;transform:translateY(0)}.landing-button:hover{transform:translateY(-2px)}.landing-button:active{transform:translateY(0)}.message{padding:15px;border-radius:8px;margin-bottom:20px;font-weight:500;text-align:left}.message.success{background-color:var(--success-background-dark);color:var(--success-text-dark)}.message.error{background-color:var(--danger-color-dark);color:var(--error-text-dark)}.login-link-container{margin-top:20px;font-size:.9em;color:var(--text-color-light)}.login-link{color:var(--primary-color);text-decoration:none;font-weight:700}.login-link:hover{text-decoration:underline}@media (max-width: 768px){.landing-hero h1{font-size:2.5em}.tagline{font-size:1.2em}.public-canvas-preview{height:100%}.landing-card{padding:30px;max-width:90%}.landing-logo-hero{width:100px}.landing-card h2{font-size:1.8em}}.main-menu-dropdown{min-width:220px}.main-menu-dropdown .profile-dropdown-item{width:100%;box-sizing:border-box}.logo-area{display:flex;flex-direction:row;align-items:center;gap:5px;cursor:pointer;transition:opacity .2s ease}.logo-area:hover{opacity:.8}.tooltip-container{position:relative;display:inline-block}.tooltip-content{font-weight:400;visibility:hidden;background-color:#000;color:#fff;text-align:center;border-radius:6px;padding:5px 10px;position:absolute;z-index:1000;top:150%;left:50%;transform:translate(-50%);opacity:0;transition:opacity .3s;white-space:nowrap}.tooltip-content:after{content:"";position:absolute;bottom:100%;left:50%;margin-left:-5px;border-width:5px;border-style:solid;border-color:transparent transparent #000 transparent}.tooltip-container:hover .tooltip-content{visibility:visible;opacity:1}.app-container.dark-mode .tooltip-content{background-color:#000}.app-container.dark-mode .tooltip-content:after{border-color:transparent transparent #000 transparent}.story-panel-caption-wrapper,.story-panel-label{margin-bottom:0}.story-panel .form-group{margin-top:15px}.story-panel button{margin-bottom:0}.story-panel .button.primary{margin-top:15px}.story-panel .button.secondary,.story-panel .error-message,.story-panel .validation-error{margin-top:10px}.story-panel .no-node-selected-message{margin-bottom:10px}.story-panel .story-panel-label{margin-bottom:0}.show-more-less-button{margin-top:0}.loading-overlay-container{position:fixed;top:0;left:0;width:100vw;height:100vh;background-color:#000c;display:flex;flex-direction:column;justify-content:center;align-items:center;z-index:9999;color:#fff;font-size:1.2em;font-family:Inter,sans-serif}.spinner{border:8px solid rgba(255,255,255,.3);border-top:8px solid #61dafb;border-radius:50%;width:60px;height:60px;animation:spin 1s linear infinite;margin-bottom:20px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.modal-content{background-color:var(--modal-background-light);color:var(--text-color);padding:25px;border-radius:12px;width:90%;max-width:600px;box-shadow:0 8px 30px #0000004d;display:flex;flex-direction:column;max-height:90vh;overflow-y:auto;border:1px solid var(--border-color)}.modal-header{display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--border-color);padding-bottom:15px;margin-bottom:20px}.modal-header h2{margin:0;font-size:1.8em;color:var(--primary-color)}.close-button{background:none;border:none;font-size:2em;color:var(--text-color-light);cursor:pointer;transition:color .2s ease}.close-button:hover{color:var(--primary-color)}.modal-body{flex-grow:1;padding-right:10px}.profile-section{margin-bottom:30px;padding-bottom:20px;border-bottom:1px solid var(--border-color-light)}.profile-section:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.profile-section h3{font-size:1.4em;color:var(--text-color);margin-bottom:15px;border-left:4px solid var(--primary-color);padding-left:10px}.profile-picture-area{display:flex;align-items:center;gap:25px;margin-bottom:20px}.current-profile-pic{width:100px;height:100px;border-radius:50%;background-color:var(--input-background-color);display:flex;justify-content:center;align-items:center;overflow:hidden;border:2px solid var(--primary-color)}.profile-pic-placeholder{width:100%;height:100%}.profile-pic-display{width:100%;height:100%;object-fit:cover}.profile-picture-actions{display:flex;flex-direction:column;gap:10px}.form-group{margin-bottom:18px}.form-group label{display:block;margin-bottom:8px;font-weight:700;color:var(--text-color-light);font-size:.95em}.form-group input[type=text],.form-group input[type=email],.form-group input[type=password],.form-group select{width:calc(100% - 20px);padding:12px;margin-top:5px;border:1px solid var(--border-color);border-radius:8px;background-color:var(--input-background-color);color:var(--text-color);font-size:1em;transition:border-color .2s ease,box-shadow .2s ease}.form-group input:focus,.form-group select:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px rgba(var(--primary-color-rgb),.2);outline:none}.form-group input[readOnly]{background-color:var(--background-color-light);cursor:not-allowed}.form-group button{margin-top:10px;padding:8px 15px;font-size:.9em}.button{background-color:var(--primary-color);color:#fff;border:none;padding:10px 20px;border-radius:8px;cursor:pointer;font-size:1em;transition:background-color .2s ease,transform .1s ease}.button:hover{background-color:var(--primary-color-dark);transform:translateY(-1px)}.button.secondary{background-color:var(--button-secondary-background);color:var(--button-secondary-text);border:1px solid var(--button-secondary-border)}.button.secondary:hover{background-color:var(--button-secondary-background-hover);color:var(--button-secondary-text-hover);border-color:var(--button-secondary-border-hover)}.danger-zone{padding-bottom:10px;margin-bottom:20px}.danger-zone h3{color:var(--danger-color);border-left-color:var(--danger-color)}.button.danger{background-color:var(--danger-color);color:#fff}.button.danger:hover{background-color:var(--danger-color-dark)}.modal-footer{display:flex;justify-content:flex-end;gap:15px;border-top:1px solid var(--border-color);padding-top:20px;margin-top:20px}.modal-message{padding:10px;margin-bottom:15px;border-radius:8px;font-weight:700;text-align:center}.modal-message.success{background-color:#d4edda;color:#155724;border:1px solid #c3e6cb}.app-container.dark-mode .modal-message.success{background-color:var(--success-background-dark);color:var(--success-text-dark)}.modal-message.error{background-color:#f8d7da;color:#721c24;border:1px solid #f5c6cb}.app-container.dark-mode .modal-message.error{background-color:var(--error-background-dark);color:var(--error-text-dark)}.email-change-form,.password-change-form,.delete-confirmation{margin-top:20px;padding:15px;border:1px solid var(--border-color-light);border-radius:8px;background-color:var(--background-color-light)}.email-change-form .form-group,.password-change-form .form-group,.delete-confirmation .form-group{margin-bottom:10px}.email-change-form .form-actions,.password-change-form .form-actions,.delete-confirmation .form-actions{display:flex;gap:10px;margin-top:15px;justify-content:flex-end}.email-change-form .form-actions button,.password-change-form .form-actions button,.delete-confirmation .form-actions button{margin-left:0}@media (max-width: 768px){.modal-content{width:95%;padding:20px}.modal-header h2{font-size:1.5em}.close-button{font-size:1.8em}.profile-picture-area{flex-direction:column;text-align:center}.profile-picture-actions{flex-direction:row;flex-wrap:wrap;justify-content:center}.form-group input,.form-group select{width:100%;margin-left:0}.form-group button{margin-left:0;margin-top:10px;width:100%}.modal-footer{flex-direction:column-reverse;gap:10px}.modal-footer button{width:100%}}.public-canvas-viewer{width:100%;height:100%;position:relative}.public-demo-panel{font-size:1.1em;font-weight:700;color:var(--text-color);background-color:var(--background-color);padding:10px 20px;border-radius:8px;box-shadow:0 2px 5px #0000001a}.app-container.dark-mode .public-demo-panel{box-shadow:0 2px 5px #0000004d}.create-own-panel{width:100%;display:flex;justify-content:center;padding-bottom:20px}.create-my-own-prominent-button{padding:12px 25px;background-color:var(--primary-color);color:#fff;border:none;border-radius:25px;font-size:1.1em;font-weight:700;cursor:pointer;transition:background-color .2s ease,transform .2s ease;box-shadow:0 4px 10px #007bff4d}.create-my-own-prominent-button:hover{background-color:var(--primary-color-dark);transform:translateY(-2px)}.create-my-own-prominent-button:active{transform:translateY(0)}.canvas-dashboard-container{padding:20px;max-width:1200px;margin:20px auto;background-color:var(--panel-background-color);border-radius:8px;box-shadow:0 4px 12px #0000001a;color:var(--text-color)}.app-container.dark-mode .canvas-dashboard-container{box-shadow:0 4px 12px #0006}.canvas-dashboard-container h2{color:var(--primary-color);margin-bottom:20px;font-size:2em;text-align:center}.canvas-dashboard-container .message{padding:10px;margin-bottom:15px;border-radius:8px;font-weight:700;text-align:center}.canvas-dashboard-container .message.success{background-color:#d4edda;color:#155724;border:1px solid #c3e6cb}.app-container.dark-mode .canvas-dashboard-container .message.success{background-color:var(--success-background-dark);color:var(--success-text-dark)}.canvas-dashboard-container .message.error{background-color:#f8d7da;color:#721c24;border:1px solid #f5c6cb}.app-container.dark-mode .canvas-dashboard-container .message.error{background-color:var(--error-background-dark);color:var(--error-text-dark)}.canvas-dashboard-container .button.primary{display:block;margin:0 auto 30px;padding:12px 25px;font-size:1.1em}.canvas-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}.canvas-card{background-color:var(--background-color);border:1px solid var(--border-color);border-radius:8px;padding:20px;box-shadow:0 2px 8px #0000000d;display:flex;flex-direction:column;justify-content:space-between;transition:transform .2s ease,box-shadow .2s ease;cursor:pointer}.icon-button{background:none;border:none;font-size:1.5em;cursor:pointer;color:var(--text-color-light);transition:color .2s ease;padding:0;display:flex;align-items:center;justify-content:center}.icon-button.danger{color:var(--danger-color)}.icon-button:hover{color:var(--primary-color)}.icon-button.danger:hover{color:var(--danger-color-dark)}.app-container.dark-mode .canvas-card{background-color:var(--input-background-color);border-color:var(--border-color);box-shadow:0 2px 8px #0003}.canvas-card:hover{transform:translateY(-5px);box-shadow:0 6px 16px #0000001a}.app-container.dark-mode .canvas-card:hover{box-shadow:0 6px 16px #0000004d}.canvas-card h3{margin-top:0;color:var(--text-color);font-size:1.4em;margin-bottom:10px}.canvas-card p{font-size:.9em;color:var(--text-color-light);margin-bottom:5px}.canvas-actions{display:flex;gap:10px;margin-top:15px;justify-content:flex-end}.canvas-actions .button{padding:8px 15px;font-size:.9em}.modal-overlay{position:fixed;inset:0;background-color:#000000b3;display:flex;justify-content:center;align-items:center;z-index:1000}.modal-content{background-color:var(--modal-background-light);color:var(--text-color);padding:25px;border-radius:12px;width:90%;max-width:500px;box-shadow:0 8px 30px #0000004d;display:flex;flex-direction:column;max-height:90vh;overflow-y:auto;border:1px solid var(--border-color)}.app-container.dark-mode .modal-content{background-color:var(--modal-background-dark)}.modal-content h3{margin-top:0;margin-bottom:20px;color:var(--primary-color);font-size:1.6em}.modal-content .form-group{margin-bottom:20px}.modal-content label{display:block;margin-bottom:8px;font-weight:700;color:var(--text-color-light)}.modal-content input[type=text]{width:calc(100% - 20px);padding:12px;border:1px solid var(--border-color);border-radius:8px;background-color:var(--input-background-color);color:var(--text-color);font-size:1em}.modal-content .modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:20px}.modal-content .modal-actions .button{padding:10px 20px}.header-left .header-logo{height:32px;width:auto}.logo.react:hover{filter:drop_shadow(0 0 2em #61dafbaa)}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (prefers-reduced-motion: no-preference){a:nth-of-type(2) .logo{animation:logo-spin infinite 20s linear}}.card{padding:2em}.read-the-docs{color:#888}.main-menu-button{background:none;border:none;padding:0;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text-color)}.main-menu-button:hover{background:none;border:none;color:var(--accent-color)}.main-menu-button svg{width:24px;height:24px}.node-credits-pill{display:inline-flex;align-items:center;gap:8px;padding:10px 15px;border-radius:20px;background-color:#ffffff26;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);color:var(--text-color);font-size:.9em;font-weight:700;margin-right:0;box-shadow:0 4px 12px #0000001a;border:1px solid rgba(255,255,255,.2);position:relative}.app-container.dark-mode .node-credits-pill{background-color:#0003;border:1px solid rgba(255,255,255,.1);box-shadow:0 4px 12px #0000004d}.node-credits-pill .sparkle-icon{width:16px;height:16px;color:var(--accent-color)}.story-panel-label{overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical}.story-panel-label.expanded{-webkit-line-clamp:unset}.show-more-less-button{background:none;border:none;color:var(--primary-color);cursor:pointer;padding:0;font-size:.9em;text-align:left;margin-top:0}.show-more-less-button:hover{text-decoration:underline}.add-node-button{position:absolute;bottom:-10px;left:50%;transform:translate(-50%);background-color:var(--accent-color);color:#fff;border:none;border-radius:50%;width:20px;height:20px;display:flex;align-items:center;justify-content:center;cursor:pointer;opacity:0;transition:opacity .2s ease-in-out,transform .2s ease-in-out;z-index:10}.reactflow-node:hover .add-node-button{opacity:1;transform:translate(-50%) scale(1.1);background-color:var(--primary-color)}.add-node-button:hover{background-color:var(--primary-color-dark)!important}.add-node-button svg{width:16px;height:16px}
