@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500&family=JetBrains+Mono:wght@300;400&display=swap";.react-flow{direction:ltr;--xy-edge-stroke-default: #b1b1b7;--xy-edge-stroke-width-default: 1;--xy-edge-stroke-selected-default: #555;--xy-connectionline-stroke-default: #b1b1b7;--xy-connectionline-stroke-width-default: 1;--xy-attribution-background-color-default: rgba(255, 255, 255, .5);--xy-minimap-background-color-default: #fff;--xy-minimap-mask-background-color-default: rgba(240, 240, 240, .6);--xy-minimap-mask-stroke-color-default: transparent;--xy-minimap-mask-stroke-width-default: 1;--xy-minimap-node-background-color-default: #e2e2e2;--xy-minimap-node-stroke-color-default: transparent;--xy-minimap-node-stroke-width-default: 2;--xy-background-color-default: transparent;--xy-background-pattern-dots-color-default: #91919a;--xy-background-pattern-lines-color-default: #eee;--xy-background-pattern-cross-color-default: #e2e2e2;background-color:var(--xy-background-color, var(--xy-background-color-default));--xy-node-color-default: inherit;--xy-node-border-default: 1px solid #1a192b;--xy-node-background-color-default: #fff;--xy-node-group-background-color-default: rgba(240, 240, 240, .25);--xy-node-boxshadow-hover-default: 0 1px 4px 1px rgba(0, 0, 0, .08);--xy-node-boxshadow-selected-default: 0 0 0 .5px #1a192b;--xy-node-border-radius-default: 3px;--xy-handle-background-color-default: #1a192b;--xy-handle-border-color-default: #fff;--xy-selection-background-color-default: rgba(0, 89, 220, .08);--xy-selection-border-default: 1px dotted rgba(0, 89, 220, .8);--xy-controls-button-background-color-default: #fefefe;--xy-controls-button-background-color-hover-default: #f4f4f4;--xy-controls-button-color-default: inherit;--xy-controls-button-color-hover-default: inherit;--xy-controls-button-border-color-default: #eee;--xy-controls-box-shadow-default: 0 0 2px 1px rgba(0, 0, 0, .08);--xy-edge-label-background-color-default: #ffffff;--xy-edge-label-color-default: inherit;--xy-resize-background-color-default: #3367d9}.react-flow.dark{--xy-edge-stroke-default: #3e3e3e;--xy-edge-stroke-width-default: 1;--xy-edge-stroke-selected-default: #727272;--xy-connectionline-stroke-default: #b1b1b7;--xy-connectionline-stroke-width-default: 1;--xy-attribution-background-color-default: rgba(150, 150, 150, .25);--xy-minimap-background-color-default: #141414;--xy-minimap-mask-background-color-default: rgba(60, 60, 60, .6);--xy-minimap-mask-stroke-color-default: transparent;--xy-minimap-mask-stroke-width-default: 1;--xy-minimap-node-background-color-default: #2b2b2b;--xy-minimap-node-stroke-color-default: transparent;--xy-minimap-node-stroke-width-default: 2;--xy-background-color-default: #141414;--xy-background-pattern-dots-color-default: #777;--xy-background-pattern-lines-color-default: #777;--xy-background-pattern-cross-color-default: #777;--xy-node-color-default: #f8f8f8;--xy-node-border-default: 1px solid #3c3c3c;--xy-node-background-color-default: #1e1e1e;--xy-node-group-background-color-default: rgba(240, 240, 240, .25);--xy-node-boxshadow-hover-default: 0 1px 4px 1px rgba(255, 255, 255, .08);--xy-node-boxshadow-selected-default: 0 0 0 .5px #999;--xy-handle-background-color-default: #bebebe;--xy-handle-border-color-default: #1e1e1e;--xy-selection-background-color-default: rgba(200, 200, 220, .08);--xy-selection-border-default: 1px dotted rgba(200, 200, 220, .8);--xy-controls-button-background-color-default: #2b2b2b;--xy-controls-button-background-color-hover-default: #3e3e3e;--xy-controls-button-color-default: #f8f8f8;--xy-controls-button-color-hover-default: #fff;--xy-controls-button-border-color-default: #5b5b5b;--xy-controls-box-shadow-default: 0 0 2px 1px rgba(0, 0, 0, .08);--xy-edge-label-background-color-default: #141414;--xy-edge-label-color-default: #f8f8f8}.react-flow__background{background-color:var(--xy-background-color-props, var(--xy-background-color, var(--xy-background-color-default)));pointer-events:none;z-index:-1}.react-flow__container{position:absolute;width:100%;height:100%;top:0;left:0}.react-flow__pane{z-index:1}.react-flow__pane.draggable{cursor:grab}.react-flow__pane.dragging{cursor:grabbing}.react-flow__pane.selection{cursor:pointer}.react-flow__viewport{transform-origin:0 0;z-index:2;pointer-events:none}.react-flow__renderer{z-index:4}.react-flow__selection{z-index:6}.react-flow__nodesselection-rect:focus,.react-flow__nodesselection-rect:focus-visible{outline:none}.react-flow__edge-path{stroke:var(--xy-edge-stroke, var(--xy-edge-stroke-default));stroke-width:var(--xy-edge-stroke-width, var(--xy-edge-stroke-width-default));fill:none}.react-flow__connection-path{stroke:var(--xy-connectionline-stroke, var(--xy-connectionline-stroke-default));stroke-width:var(--xy-connectionline-stroke-width, var(--xy-connectionline-stroke-width-default));fill:none}.react-flow .react-flow__edges{position:absolute}.react-flow .react-flow__edges svg{overflow:visible;position:absolute;pointer-events:none}.react-flow__edge{pointer-events:visibleStroke}.react-flow__edge.selectable{cursor:pointer}.react-flow__edge.animated path{stroke-dasharray:5;animation:dashdraw .5s linear infinite}.react-flow__edge.animated path.react-flow__edge-interaction{stroke-dasharray:none;animation:none}.react-flow__edge.inactive{pointer-events:none}.react-flow__edge.selected,.react-flow__edge:focus,.react-flow__edge:focus-visible{outline:none}.react-flow__edge.selected .react-flow__edge-path,.react-flow__edge.selectable:focus .react-flow__edge-path,.react-flow__edge.selectable:focus-visible .react-flow__edge-path{stroke:var(--xy-edge-stroke-selected, var(--xy-edge-stroke-selected-default))}.react-flow__edge-textwrapper{pointer-events:all}.react-flow__edge .react-flow__edge-text{pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-flow__arrowhead polyline{stroke:var(--xy-edge-stroke, var(--xy-edge-stroke-default))}.react-flow__arrowhead polyline.arrowclosed{fill:var(--xy-edge-stroke, var(--xy-edge-stroke-default))}.react-flow__connection{pointer-events:none}.react-flow__connection .animated{stroke-dasharray:5;animation:dashdraw .5s linear infinite}svg.react-flow__connectionline{z-index:1001;overflow:visible;position:absolute}.react-flow__nodes{pointer-events:none;transform-origin:0 0}.react-flow__node{position:absolute;-webkit-user-select:none;-moz-user-select:none;user-select:none;pointer-events:all;transform-origin:0 0;box-sizing:border-box;cursor:default}.react-flow__node.selectable{cursor:pointer}.react-flow__node.draggable{cursor:grab;pointer-events:all}.react-flow__node.draggable.dragging{cursor:grabbing}.react-flow__nodesselection{z-index:3;transform-origin:left top;pointer-events:none}.react-flow__nodesselection-rect{position:absolute;pointer-events:all;cursor:grab}.react-flow__handle{position:absolute;pointer-events:none;min-width:5px;min-height:5px;width:6px;height:6px;background-color:var(--xy-handle-background-color, var(--xy-handle-background-color-default));border:1px solid var(--xy-handle-border-color, var(--xy-handle-border-color-default));border-radius:100%}.react-flow__handle.connectingfrom{pointer-events:all}.react-flow__handle.connectionindicator{pointer-events:all;cursor:crosshair}.react-flow__handle-bottom{top:auto;left:50%;bottom:0;transform:translate(-50%,50%)}.react-flow__handle-top{top:0;left:50%;transform:translate(-50%,-50%)}.react-flow__handle-left{top:50%;left:0;transform:translate(-50%,-50%)}.react-flow__handle-right{top:50%;right:0;transform:translate(50%,-50%)}.react-flow__edgeupdater{cursor:move;pointer-events:all}.react-flow__pane.selection .react-flow__panel{pointer-events:none}.react-flow__panel{position:absolute;z-index:5;margin:15px}.react-flow__panel.top{top:0}.react-flow__panel.bottom{bottom:0}.react-flow__panel.top.center,.react-flow__panel.bottom.center{left:50%;transform:translate(-15px) translate(-50%)}.react-flow__panel.left{left:0}.react-flow__panel.right{right:0}.react-flow__panel.left.center,.react-flow__panel.right.center{top:50%;transform:translateY(-15px) translateY(-50%)}.react-flow__attribution{font-size:10px;background:var(--xy-attribution-background-color, var(--xy-attribution-background-color-default));padding:2px 3px;margin:0}.react-flow__attribution a{text-decoration:none;color:#999}@keyframes dashdraw{0%{stroke-dashoffset:10}}.react-flow__edgelabel-renderer{position:absolute;width:100%;height:100%;pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none;left:0;top:0}.react-flow__viewport-portal{position:absolute;width:100%;height:100%;left:0;top:0;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-flow__minimap{background:var( --xy-minimap-background-color-props, var(--xy-minimap-background-color, var(--xy-minimap-background-color-default)) )}.react-flow__minimap-svg{display:block}.react-flow__minimap-mask{fill:var( --xy-minimap-mask-background-color-props, var(--xy-minimap-mask-background-color, var(--xy-minimap-mask-background-color-default)) );stroke:var( --xy-minimap-mask-stroke-color-props, var(--xy-minimap-mask-stroke-color, var(--xy-minimap-mask-stroke-color-default)) );stroke-width:var( --xy-minimap-mask-stroke-width-props, var(--xy-minimap-mask-stroke-width, var(--xy-minimap-mask-stroke-width-default)) )}.react-flow__minimap-node{fill:var( --xy-minimap-node-background-color-props, var(--xy-minimap-node-background-color, var(--xy-minimap-node-background-color-default)) );stroke:var( --xy-minimap-node-stroke-color-props, var(--xy-minimap-node-stroke-color, var(--xy-minimap-node-stroke-color-default)) );stroke-width:var( --xy-minimap-node-stroke-width-props, var(--xy-minimap-node-stroke-width, var(--xy-minimap-node-stroke-width-default)) )}.react-flow__background-pattern.dots{fill:var( --xy-background-pattern-color-props, var(--xy-background-pattern-color, var(--xy-background-pattern-dots-color-default)) )}.react-flow__background-pattern.lines{stroke:var( --xy-background-pattern-color-props, var(--xy-background-pattern-color, var(--xy-background-pattern-lines-color-default)) )}.react-flow__background-pattern.cross{stroke:var( --xy-background-pattern-color-props, var(--xy-background-pattern-color, var(--xy-background-pattern-cross-color-default)) )}.react-flow__controls{display:flex;flex-direction:column;box-shadow:var(--xy-controls-box-shadow, var(--xy-controls-box-shadow-default))}.react-flow__controls.horizontal{flex-direction:row}.react-flow__controls-button{display:flex;justify-content:center;align-items:center;height:26px;width:26px;padding:4px;border:none;background:var(--xy-controls-button-background-color, var(--xy-controls-button-background-color-default));border-bottom:1px solid var( --xy-controls-button-border-color-props, var(--xy-controls-button-border-color, var(--xy-controls-button-border-color-default)) );color:var( --xy-controls-button-color-props, var(--xy-controls-button-color, var(--xy-controls-button-color-default)) );cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-flow__controls-button svg{width:100%;max-width:12px;max-height:12px;fill:currentColor}.react-flow__edge.updating .react-flow__edge-path{stroke:#777}.react-flow__edge-text{font-size:10px}.react-flow__node.selectable:focus,.react-flow__node.selectable:focus-visible{outline:none}.react-flow__node-input,.react-flow__node-default,.react-flow__node-output,.react-flow__node-group{padding:10px;border-radius:var(--xy-node-border-radius, var(--xy-node-border-radius-default));width:150px;font-size:12px;color:var(--xy-node-color, var(--xy-node-color-default));text-align:center;border:var(--xy-node-border, var(--xy-node-border-default));background-color:var(--xy-node-background-color, var(--xy-node-background-color-default))}.react-flow__node-input.selectable:hover,.react-flow__node-default.selectable:hover,.react-flow__node-output.selectable:hover,.react-flow__node-group.selectable:hover{box-shadow:var(--xy-node-boxshadow-hover, var(--xy-node-boxshadow-hover-default))}.react-flow__node-input.selectable.selected,.react-flow__node-input.selectable:focus,.react-flow__node-input.selectable:focus-visible,.react-flow__node-default.selectable.selected,.react-flow__node-default.selectable:focus,.react-flow__node-default.selectable:focus-visible,.react-flow__node-output.selectable.selected,.react-flow__node-output.selectable:focus,.react-flow__node-output.selectable:focus-visible,.react-flow__node-group.selectable.selected,.react-flow__node-group.selectable:focus,.react-flow__node-group.selectable:focus-visible{box-shadow:var(--xy-node-boxshadow-selected, var(--xy-node-boxshadow-selected-default))}.react-flow__node-group{background-color:var(--xy-node-group-background-color, var(--xy-node-group-background-color-default))}.react-flow__nodesselection-rect,.react-flow__selection{background:var(--xy-selection-background-color, var(--xy-selection-background-color-default));border:var(--xy-selection-border, var(--xy-selection-border-default))}.react-flow__nodesselection-rect:focus,.react-flow__nodesselection-rect:focus-visible,.react-flow__selection:focus,.react-flow__selection:focus-visible{outline:none}.react-flow__controls-button:hover{background:var( --xy-controls-button-background-color-hover-props, var(--xy-controls-button-background-color-hover, var(--xy-controls-button-background-color-hover-default)) );color:var( --xy-controls-button-color-hover-props, var(--xy-controls-button-color-hover, var(--xy-controls-button-color-hover-default)) )}.react-flow__controls-button:disabled{pointer-events:none}.react-flow__controls-button:disabled svg{fill-opacity:.4}.react-flow__controls-button:last-child{border-bottom:none}.react-flow__controls.horizontal .react-flow__controls-button{border-bottom:none;border-right:1px solid var( --xy-controls-button-border-color-props, var(--xy-controls-button-border-color, var(--xy-controls-button-border-color-default)) )}.react-flow__controls.horizontal .react-flow__controls-button:last-child{border-right:none}.react-flow__resize-control{position:absolute}.react-flow__resize-control.left,.react-flow__resize-control.right{cursor:ew-resize}.react-flow__resize-control.top,.react-flow__resize-control.bottom{cursor:ns-resize}.react-flow__resize-control.top.left,.react-flow__resize-control.bottom.right{cursor:nwse-resize}.react-flow__resize-control.bottom.left,.react-flow__resize-control.top.right{cursor:nesw-resize}.react-flow__resize-control.handle{width:5px;height:5px;border:1px solid #fff;border-radius:1px;background-color:var(--xy-resize-background-color, var(--xy-resize-background-color-default));translate:-50% -50%}.react-flow__resize-control.handle.left{left:0;top:50%}.react-flow__resize-control.handle.right{left:100%;top:50%}.react-flow__resize-control.handle.top{left:50%;top:0}.react-flow__resize-control.handle.bottom{left:50%;top:100%}.react-flow__resize-control.handle.top.left,.react-flow__resize-control.handle.bottom.left{left:0}.react-flow__resize-control.handle.top.right,.react-flow__resize-control.handle.bottom.right{left:100%}.react-flow__resize-control.line{border-color:var(--xy-resize-background-color, var(--xy-resize-background-color-default));border-width:0;border-style:solid}.react-flow__resize-control.line.left,.react-flow__resize-control.line.right{width:1px;transform:translate(-50%);top:0;height:100%}.react-flow__resize-control.line.left{left:0;border-left-width:1px}.react-flow__resize-control.line.right{left:100%;border-right-width:1px}.react-flow__resize-control.line.top,.react-flow__resize-control.line.bottom{height:1px;transform:translateY(-50%);left:0;width:100%}.react-flow__resize-control.line.top{top:0;border-top-width:1px}.react-flow__resize-control.line.bottom{border-bottom-width:1px;top:100%}.react-flow__edge-textbg{fill:var(--xy-edge-label-background-color, var(--xy-edge-label-background-color-default))}.react-flow__edge-text{fill:var(--xy-edge-label-color, var(--xy-edge-label-color-default))}.studio-layout{display:flex;flex-direction:column;height:100vh;background:var(--white);overflow:hidden}.studio-main{display:flex;flex:1;min-height:0}.studio-center{flex:1;display:flex;flex-direction:column;position:relative;min-width:0}.header{display:flex;align-items:center;justify-content:space-between;height:var(--h-xl);padding:0 var(--sp-4);background:var(--white);border-bottom:1px solid var(--line)}.header-left{display:flex;align-items:center;gap:var(--sp-4)}.header-logo{font-family:var(--font-sans);font-size:var(--text-lg);font-weight:var(--weight-medium);letter-spacing:var(--tracking-tight);color:var(--text);cursor:pointer;transition:color var(--duration) var(--ease)}.header-logo:hover{color:var(--accent)}.header-world-name{display:inline-flex;align-items:center;color:var(--text-secondary);font-size:var(--text-base)}.header-world-name:before{content:"/";margin-right:var(--sp-2);color:var(--text-tertiary)}.header-right{display:flex;align-items:center;gap:var(--sp-2)}.header-mode-badge{font-size:var(--text-2xs);font-weight:var(--weight-medium);letter-spacing:var(--tracking-wide);padding:2px var(--sp-2);border-radius:var(--radius-sm);margin-left:var(--sp-2)}.header-mode-badge--edit{background:var(--gray-100);color:var(--text-secondary)}.header-mode-badge--play{background:var(--positive);color:var(--white)}.header-help-btn{font-weight:var(--weight-medium);font-size:var(--text-md);width:var(--h-sm);padding:0}.header-dirty-indicator{color:var(--warning);font-weight:var(--weight-medium);margin-left:2px}.library-panel{width:300px;display:flex;flex-direction:column;background:var(--white);border-right:1px solid var(--line);position:relative;will-change:width;transition:width var(--duration-normal) var(--ease-out-expo)}.library-panel--collapsed{width:0;min-width:0;border-right:none;overflow:visible}.library-panel>*:not(.panel-collapse-toggle):not(.resize-handle){opacity:1;transform:translate(0);will-change:transform,opacity;transition:opacity var(--duration-normal) var(--ease),transform var(--duration-normal) var(--ease)}.library-panel--collapsed>*:not(.panel-collapse-toggle):not(.resize-handle){opacity:0;transform:translate(-20px);pointer-events:none}.library-tabs{display:flex;border-bottom:1px solid var(--line);background:var(--white)}.library-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:var(--sp-1);height:var(--h-lg);padding:0 var(--sp-2);font-size:var(--text-xs);font-weight:var(--weight-medium);color:var(--text-tertiary);background:transparent;border:none;border-bottom:2px solid transparent;cursor:pointer;transition:color var(--duration) var(--ease),border-color var(--duration) var(--ease),background var(--duration) var(--ease)}.library-tab svg{width:14px;height:14px;flex-shrink:0}.library-tab:hover{color:var(--text-secondary);background:var(--surface-hover)}.library-tab--active{color:var(--accent);border-bottom-color:var(--accent)}.library-tab--active:hover{color:var(--accent);background:transparent}.library-tab:focus-visible{outline:2px solid var(--accent);outline-offset:-2px}.library-tab-content{display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden}.library-tab-content .generation-section{flex:1;display:flex;flex-direction:column;border-top:none;min-height:0}.library-tab-content .generation-section__queue{flex:1;max-height:none}.library-tab-content .library-items{flex:1;min-height:0}.library-tab-content .library-search{flex-shrink:0}.library-header{display:flex;align-items:center;height:var(--h-lg);padding:0 var(--sp-3);border-bottom:1px solid var(--line)}.library-title{font-size:var(--text-2xs);font-weight:var(--weight-medium);letter-spacing:var(--tracking-wide);text-transform:uppercase;color:var(--text-tertiary)}.library-search{padding:var(--sp-2) var(--sp-3);border-bottom:1px solid var(--line)}.library-categories{display:flex;flex-wrap:wrap;gap:var(--sp-1);padding:var(--sp-2) var(--sp-3);border-bottom:1px solid var(--line)}.library-category{position:relative;padding:2px var(--sp-2);font-size:var(--text-xs);font-weight:var(--weight-normal);color:var(--text-tertiary);background:transparent;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:background var(--duration) var(--ease),color var(--duration) var(--ease)}.library-category:hover{background:var(--surface-hover);color:var(--text-secondary)}.library-category.active{background:var(--gray-900);color:var(--white)}.library-category:focus-visible{outline:2px solid var(--accent);outline-offset:1px}.library-items{flex:1;padding:var(--sp-2);overflow-y:auto;overflow-x:hidden;display:grid;grid-template-columns:repeat(2,1fr);gap:var(--sp-2);align-content:start;scrollbar-width:none;-ms-overflow-style:none;overscroll-behavior:contain}.library-items::-webkit-scrollbar{display:none}.library-item{display:flex;flex-direction:column;align-items:center;padding:var(--sp-2);background:transparent;border:1px solid var(--line);border-radius:var(--radius-sm);cursor:pointer;position:relative;min-width:0;transition:background var(--duration) var(--ease),border-color var(--duration) var(--ease),transform var(--duration-fast) var(--ease),box-shadow var(--duration-fast) var(--ease)}.library-item[draggable=true]{cursor:grab}.library-item[draggable=true]:active{cursor:grabbing}.library-item:hover{background:var(--surface-hover);border-color:var(--line-hover);box-shadow:0 2px 8px #0000000a}.library-item:active{transform:scale(.98)}.library-item.selected{border-color:var(--accent);background:var(--accent-light)}.library-item-thumbnail{width:100%;min-width:0;aspect-ratio:1;display:flex;align-items:center;justify-content:center;background:var(--surface);border-radius:var(--radius-sm);font-size:20px;color:var(--text-tertiary);overflow:hidden}.library-item-thumbnail img{width:100%;height:100%;object-fit:contain;background:transparent}.library-item-icon{display:flex;align-items:center;justify-content:center;width:100%;height:100%}.library-item-icon svg{width:24px;height:24px;color:var(--text-tertiary)}.library-item-name{margin-top:var(--sp-1);font-size:var(--text-xs);color:var(--text-secondary);text-align:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;width:100%}.library-item:hover .library-item-name{white-space:normal;overflow:visible}.library-empty{grid-column:1 / -1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--sp-8) var(--sp-3);text-align:center;color:var(--text-ghost);font-size:var(--text-xs)}.library-empty__icon{width:40px;height:40px;margin-bottom:var(--sp-3);color:var(--text-ghost)}.library-empty__title{font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--text-secondary);margin-bottom:var(--sp-1)}.library-empty__description{font-size:var(--text-xs);color:var(--text-tertiary);line-height:1.5}.library-empty__hint{font-size:var(--text-xs);color:var(--text-secondary);line-height:1.5;margin-bottom:var(--sp-2)}.library-empty__arrow{width:24px;height:24px;color:var(--accent);animation:bounce-arrow 1.5s ease-in-out infinite;margin-top:var(--sp-2)}@keyframes bounce-arrow{0%,to{transform:translateY(0)}50%{transform:translateY(6px)}}.library-items .tooltip-trigger{display:contents}.panel-collapse-toggle{position:absolute;top:50%;transform:translateY(-50%);width:16px;height:48px;display:flex;align-items:center;justify-content:center;background:var(--white);border:1px solid var(--line);cursor:pointer;z-index:10;transition:all var(--duration-fast) var(--ease)}.panel-collapse-toggle:hover{background:var(--surface-hover);border-color:var(--line-hover)}.panel-collapse-toggle svg{width:10px;height:10px;color:var(--text-tertiary);transition:transform var(--duration-fast) var(--ease)}.panel-collapse-toggle:hover svg{color:var(--text-secondary)}.library-panel .panel-collapse-toggle{right:-8px;border-radius:0 var(--radius-sm) var(--radius-sm) 0;border-left:none}.library-panel--collapsed .panel-collapse-toggle{right:-16px}.library-panel--collapsed .panel-collapse-toggle svg{transform:rotate(180deg)}.toolbar{position:absolute;top:var(--sp-4);left:var(--sp-4);z-index:var(--z-dropdown);display:flex;flex-direction:column;gap:2px;padding:var(--sp-1);background:var(--white);border:1px solid var(--line);border-radius:var(--radius-md);box-shadow:0 4px 12px #00000014}.toolbar-divider{height:1px;margin:var(--sp-1) var(--sp-1);background:var(--line)}.viewport{position:relative;flex:1;min-width:0;background:#2a2a3e}.viewport[data-tool=select]{cursor:default}.viewport[data-tool=terrain]{cursor:cell}.viewport[data-tool=delete]{cursor:not-allowed}.viewport[data-mode=play]{cursor:default}.viewport canvas{display:block;width:100%;height:100%}.viewport-overlay{position:absolute;top:0;left:0;right:0;bottom:0;pointer-events:none}.viewport-info{position:absolute;top:var(--sp-4);right:var(--sp-4);padding:var(--sp-1) var(--sp-2);font-size:var(--text-xs);color:var(--text-secondary);background:#ffffffe6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid var(--line);border-radius:var(--radius-sm)}.viewport-toggle-btn{position:absolute;bottom:var(--sp-4);right:var(--sp-4);padding:var(--sp-1) var(--sp-2);font-size:var(--text-xs);font-weight:var(--weight-medium);color:var(--text-secondary);background:#ffffffe6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid var(--line);border-radius:var(--radius-sm);cursor:pointer;pointer-events:auto;transition:all var(--duration) var(--ease)}.viewport-toggle-btn:hover{background:var(--white);border-color:var(--line-hover);color:var(--text)}.viewport-toggle-btn[data-mode=night]{background:#1e293be6;color:var(--white);border-color:#94a3b84d}.viewport-toggle-btn[data-mode=night]:hover{background:#334155f2;border-color:#94a3b880}.crosshair{position:absolute;top:50%;left:50%;width:24px;height:24px;margin:-12px 0 0 -12px;pointer-events:none;z-index:10}.crosshair:before{content:"";position:absolute;top:50%;left:50%;width:4px;height:4px;margin:-2px 0 0 -2px;background:#ffffffe6;border-radius:50%;box-shadow:0 0 2px #00000080}.crosshair:after{content:"";position:absolute;top:50%;left:50%;width:16px;height:16px;margin:-8px 0 0 -8px;border:1px solid rgba(255,255,255,.6);border-radius:50%}.home-screen{display:flex;flex-direction:column;align-items:center;min-height:100vh;padding:var(--sp-8);padding-top:var(--sp-12);background:var(--white);overflow-y:auto}.home-title{font-family:var(--font-sans);font-size:24px;font-weight:var(--weight-medium);letter-spacing:var(--tracking-tight);color:var(--text);margin-bottom:var(--sp-1)}.home-subtitle{font-size:var(--text-sm);color:var(--text-secondary);margin-bottom:var(--sp-8)}.home-worlds{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:var(--sp-3);width:100%;max-width:600px;margin-bottom:var(--sp-6)}.home-world-card{display:flex;flex-direction:column;align-items:center;padding:var(--sp-3);background:var(--gray-50);border:1px solid var(--line);border-radius:var(--radius-md);cursor:pointer;transition:background var(--duration) var(--ease),border-color var(--duration) var(--ease)}.home-world-card:hover{background:var(--surface-hover);border-color:var(--line-hover)}.home-world-thumbnail{width:100%;aspect-ratio:16 / 9;display:flex;align-items:center;justify-content:center;background:var(--gray-100);border-radius:var(--radius-sm);font-size:24px;color:var(--text-tertiary);margin-bottom:var(--sp-2);overflow:hidden}.home-world-thumbnail img{width:100%;height:100%;object-fit:contain;background:var(--gray-100)}.home-new-world{border:1px dashed var(--line-hover);background:transparent}.home-new-world:hover{border-color:var(--accent);background:var(--accent-light)}.home-new-world .home-world-thumbnail{font-size:32px;background:transparent}.home-world-name{font-size:var(--text-sm);font-weight:var(--weight-normal);color:var(--text);text-align:center}.dialogue-box-wrapper{position:absolute;bottom:var(--sp-6);left:50%;transform:translate(-50%);width:90%;max-width:560px;background:var(--white);border:1px solid var(--line);border-radius:var(--radius-md);padding:var(--sp-4);box-shadow:0 8px 32px #00000014;pointer-events:auto}.dialogue-speaker{font-size:var(--text-2xs);font-weight:var(--weight-medium);text-transform:uppercase;letter-spacing:var(--tracking-wide);color:var(--accent);margin-bottom:var(--sp-2)}.dialogue-text{font-size:var(--text-base);line-height:1.6;color:var(--text);margin-bottom:var(--sp-3)}.dialogue-choices{display:flex;flex-direction:column;gap:var(--sp-2)}.dialogue-choice{width:100%;padding:var(--sp-2) var(--sp-3);background:var(--gray-50);border:1px solid transparent;border-radius:var(--radius-sm);font-size:var(--text-sm);color:var(--text);text-align:left;cursor:pointer;transition:background var(--duration) var(--ease),border-color var(--duration) var(--ease)}.dialogue-choice:hover{background:var(--accent-light);border-color:var(--accent)}.dialogue-advance{font-size:var(--text-2xs);color:var(--text-ghost);text-align:center}.toast-container{position:fixed;bottom:var(--sp-6);right:var(--sp-6);z-index:var(--z-tooltip);display:flex;flex-direction:column;gap:var(--sp-2)}.toast-dismiss{flex-shrink:0;width:20px;height:20px;padding:0;background:transparent;border:none;border-radius:var(--radius-sm);color:var(--text-tertiary);font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center}.toast-dismiss:hover{background:var(--surface-hover);color:var(--text)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--sp-10) var(--sp-4);text-align:center}.empty-state__icon{width:40px;height:40px;margin-bottom:var(--sp-3);color:var(--text-ghost)}.empty-state__title{margin-bottom:var(--sp-1);font-size:var(--text-sm);color:var(--text-secondary)}.empty-state__description{margin-bottom:var(--sp-3);font-size:var(--text-xs);color:var(--text-tertiary)}.spinner{width:20px;height:20px;border:2px solid var(--line);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}.skeleton{background:linear-gradient(90deg,var(--gray-100) 0%,var(--gray-50) 50%,var(--gray-100) 100%);background-size:200% 100%;animation:skeleton-pulse 1.5s ease-in-out infinite;border-radius:var(--radius-sm)}@keyframes skeleton-pulse{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton--thumbnail{width:100%;aspect-ratio:1}.skeleton--text{height:12px;width:70%;margin-top:var(--sp-1)}.skeleton--text-short{height:10px;width:40%}.save-status{display:inline-flex;align-items:center;gap:var(--sp-1);font-size:var(--text-xs);color:var(--text-tertiary);margin-left:var(--sp-2);padding:2px var(--sp-2);border-radius:var(--radius-sm);transition:all var(--duration-normal) var(--ease)}.save-status__dot{width:6px;height:6px;border-radius:50%;transition:background var(--duration-normal) var(--ease)}.save-status--saved .save-status__dot{background:var(--positive)}.save-status--unsaved .save-status__dot{background:var(--warning)}.save-status--saving{color:var(--text-secondary)}.save-status--saving .save-status__dot{background:var(--accent);animation:save-pulse 1s ease-in-out infinite}@keyframes save-pulse{0%,to{opacity:1}50%{opacity:.4}}.save-status--animating .save-status__dot{animation:save-complete-pulse 1s var(--ease-out-expo)}@keyframes save-complete-pulse{0%{transform:scale(1);box-shadow:0 0 #15803d66}50%{transform:scale(1.3);box-shadow:0 0 0 4px #15803d00}to{transform:scale(1);box-shadow:0 0 #15803d00}}.save-status__time{font-size:var(--text-2xs);color:var(--text-ghost);margin-left:var(--sp-1)}@media (prefers-reduced-motion: reduce){.save-status--animating .save-status__dot{animation:none}}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.flex-1{flex:1}.gap-2{gap:var(--sp-2)}.gap-4{gap:var(--sp-4)}.modal--lg{max-width:480px}.modal--xl{max-width:700px}.asset-preview-container{width:100%;height:300px;background:var(--gray-100);border:1px solid var(--line);border-radius:var(--radius-sm);overflow:hidden;position:relative}.input-group{display:flex;flex-direction:column;gap:var(--sp-1)}.input-label{font-size:var(--text-2xs);font-weight:var(--weight-medium);letter-spacing:var(--tracking-wide);text-transform:uppercase;color:var(--text-tertiary)}.library-item{position:relative}.library-item-actions{position:absolute;top:4px;right:4px;display:none;gap:2px;z-index:1}.library-item:hover .library-item-actions{display:flex}.library-item-delete-btn{width:18px;height:18px;padding:0;background:var(--white);border:1px solid var(--line);border-radius:var(--radius-sm);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text-tertiary);transition:all var(--duration) var(--ease);box-shadow:0 1px 2px #0000000d}.library-item-delete-btn svg{width:12px;height:12px}.library-item-delete-btn:hover{background:#b91c1c1a;border-color:var(--negative);color:var(--negative);box-shadow:0 2px 4px #0000001a}.generation-section{display:flex;flex-direction:column;border-top:1px solid var(--line);background:var(--white)}.generation-section__hero{padding:var(--sp-3);background:linear-gradient(to bottom,var(--gray-50),var(--white));border-bottom:1px solid var(--line)}.generation-section__hero-label{font-size:var(--text-2xs);font-weight:var(--weight-medium);letter-spacing:var(--tracking-wide);text-transform:uppercase;color:var(--accent);margin-bottom:var(--sp-2)}.generation-section__form{display:flex;gap:var(--sp-1)}.generation-section__input{flex:1;height:36px;padding:0 var(--sp-3);font-size:var(--text-sm);color:var(--text);background:var(--white);border:1px solid var(--line);border-radius:var(--radius-md);transition:border-color var(--duration) var(--ease),box-shadow var(--duration) var(--ease)}.generation-section__input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-light);outline:none}.generation-section__input::placeholder{color:var(--text-ghost)}.generation-section__submit{width:36px;height:36px;padding:0;display:flex;align-items:center;justify-content:center;background:var(--accent);border:1px solid var(--accent);border-radius:var(--radius-md);color:var(--white);cursor:pointer;transition:all var(--duration) var(--ease)}.generation-section__submit:hover:not(:disabled){background:var(--accent-hover);border-color:var(--accent-hover);transform:scale(1.02)}.generation-section__submit:disabled{opacity:.4;cursor:not-allowed}.generation-section__ideas{border-bottom:1px solid var(--line)}.generation-section__ideas-toggle{display:flex;align-items:center;gap:var(--sp-2);width:100%;padding:var(--sp-2) var(--sp-3);font-size:var(--text-xs);font-weight:var(--weight-medium);color:var(--text-secondary);background:transparent;border:none;cursor:pointer;text-align:left;transition:background var(--duration) var(--ease)}.generation-section__ideas-toggle:hover{background:var(--surface-hover)}.generation-section__ideas-arrow{margin-left:auto;font-size:var(--text-2xs);color:var(--text-tertiary)}.generation-section__suggestions{display:flex;flex-wrap:wrap;gap:var(--sp-1);padding:0 var(--sp-3) var(--sp-2)}.generation-section__chip{padding:2px var(--sp-2);font-size:var(--text-xs);color:var(--text-secondary);background:var(--white);border:1px solid var(--line);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--duration) var(--ease)}.generation-section__chip:hover{background:var(--accent-light);border-color:var(--accent);color:var(--accent)}.generation-section__queue-section{display:flex;flex-direction:column;flex:1;min-height:0;background:var(--gray-50)}.generation-section__queue-header{display:flex;align-items:center;gap:var(--sp-2);padding:var(--sp-2) var(--sp-3);font-size:var(--text-2xs);font-weight:var(--weight-medium);letter-spacing:var(--tracking-wide);text-transform:uppercase;color:var(--text-tertiary);background:var(--white);border-bottom:1px solid var(--line)}.generation-section__badge{font-size:var(--text-2xs);padding:1px 6px;border-radius:10px;font-weight:var(--weight-medium)}.generation-section__badge--active{background:var(--accent-light);color:var(--accent)}.generation-section__badge--ready{background:#22c55e26;color:var(--positive)}.generation-section__queue{flex:1;min-height:80px;max-height:200px;overflow-y:auto;padding:var(--sp-1) var(--sp-2);background:var(--white)}.generation-section__empty{display:flex;align-items:center;justify-content:center;height:60px;font-size:var(--text-xs);color:var(--text-ghost);text-align:center}.gen-queue-item{display:flex;align-items:flex-start;gap:var(--sp-2);padding:var(--sp-2) var(--sp-3);min-height:52px;background:var(--white);border-radius:var(--radius-md);margin-bottom:var(--sp-2);border:1px solid var(--line);transition:background var(--duration) var(--ease),border-color var(--duration) var(--ease),box-shadow var(--duration) var(--ease)}.gen-queue-item:last-child{margin-bottom:var(--sp-1)}.gen-queue-item:hover{background:var(--gray-50);border-color:var(--line-hover)}.gen-queue-item--completed{background:#22c55e0f;border-color:#22c55e33}.gen-queue-item--completed:hover{background:#22c55e1a;border-color:#22c55e4d}.gen-queue-item--failed{background:#ef44440f;border-color:#ef444433}.gen-queue-item--generating{background:var(--accent-light);border-color:var(--accent)}.gen-queue-item__icon{flex-shrink:0;width:18px;height:18px;display:flex;align-items:center;justify-content:center;margin-top:2px}.gen-queue-item__spinner{width:12px;height:12px;border:2px solid var(--line);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}.gen-queue-item__content{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px;overflow:hidden}.gen-queue-item__name{font-size:var(--text-xs);font-weight:var(--weight-medium);color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.gen-queue-item__status-wrap{display:flex;flex-direction:column;gap:2px;min-width:0}.gen-queue-item__status{font-size:10px;color:var(--text-tertiary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.gen-queue-item--failed .gen-queue-item__status{color:var(--negative)}.gen-queue-item__stage{font-size:var(--text-2xs);font-weight:var(--weight-medium);text-transform:uppercase;letter-spacing:var(--tracking-wide);color:var(--accent)}.gen-queue-item__progress{width:100%;height:8px;background:var(--gray-200);border-radius:4px;overflow:hidden;margin-top:2px}.gen-queue-item__progress-bar{height:100%;background:linear-gradient(90deg,var(--accent),var(--accent-hover));border-radius:4px;transition:width .3s var(--ease-out-expo);position:relative}.gen-queue-item__progress-bar:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.3) 50%,transparent 100%);animation:progress-shimmer 1.5s infinite}@keyframes progress-shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.gen-queue-item__actions{display:flex;align-items:center;gap:4px;flex-shrink:0}.gen-queue-item__dismiss{opacity:0;transition:opacity var(--duration) var(--ease)}.gen-queue-item:hover .gen-queue-item__dismiss{opacity:1}.gen-queue-item__reorder{opacity:.5;padding:2px}.gen-queue-item__reorder:hover:not(:disabled){opacity:1}.gen-queue-item__reorder:disabled{opacity:.2;cursor:not-allowed}.welcome-modal{max-width:420px;padding:var(--sp-6)}.welcome-modal__header{text-align:center;margin-bottom:var(--sp-6)}.welcome-modal__title{font-size:20px;font-weight:var(--weight-medium);color:var(--text);margin-bottom:var(--sp-1)}.welcome-modal__subtitle{font-size:var(--text-sm);color:var(--text-secondary)}.welcome-modal__steps{display:flex;flex-direction:column;gap:var(--sp-3);margin-bottom:var(--sp-6)}.welcome-step{display:flex;align-items:flex-start;gap:var(--sp-3);padding:var(--sp-3);background:var(--gray-50);border-radius:var(--radius-md)}.welcome-step__icon{width:32px;height:32px;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:var(--white);border:1px solid var(--line);border-radius:var(--radius-sm);color:var(--accent)}.welcome-step__icon svg{width:16px;height:16px}.welcome-step__content{flex:1}.welcome-step__number{font-size:var(--text-2xs);font-weight:var(--weight-medium);color:var(--accent);margin-bottom:2px}.welcome-step__title{font-size:var(--text-md);font-weight:var(--weight-medium);color:var(--text);margin-bottom:2px}.welcome-step__description{font-size:var(--text-xs);color:var(--text-secondary)}.welcome-modal__footer{display:flex;flex-direction:column;align-items:center;gap:var(--sp-3)}.welcome-modal__footer .btn{min-width:140px}.welcome-modal__skip{font-size:var(--text-sm);color:var(--text-secondary)}.welcome-modal__skip:hover{color:var(--text)}.settings-modal{max-width:400px}.settings-section{margin-bottom:var(--sp-4)}.settings-section:last-child{margin-bottom:0}.settings-label{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--sp-2);font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--text)}.settings-value{font-size:var(--text-xs);font-weight:var(--weight-normal);color:var(--text-tertiary);font-family:var(--font-mono)}.settings-slider{width:100%;height:6px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:var(--gray-200);border-radius:3px;outline:none;cursor:pointer}.settings-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:16px;height:16px;background:var(--accent);border-radius:50%;cursor:pointer;transition:transform var(--duration) var(--ease)}.settings-slider::-webkit-slider-thumb:hover{transform:scale(1.1)}.settings-slider::-moz-range-thumb{width:16px;height:16px;background:var(--accent);border-radius:50%;border:none;cursor:pointer}.settings-checkbox{display:flex;flex-direction:column;gap:var(--sp-1)}.settings-checkbox-label{display:flex;align-items:center;gap:var(--sp-2);font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--text);cursor:pointer}.settings-checkbox-label input[type=checkbox]{width:16px;height:16px;accent-color:var(--accent);cursor:pointer}.settings-hint{font-size:var(--text-xs);color:var(--text-tertiary);margin-left:24px}.settings-stats{display:flex;flex-direction:column;gap:var(--sp-1);font-size:var(--text-sm)}.header-settings-btn{display:flex;align-items:center;justify-content:center;width:var(--h-sm);padding:0}.header-settings-btn svg{width:16px;height:16px}.dialogue-editor-modal{width:90vw;height:80vh;max-width:1200px;background:var(--dark-bg);border-radius:12px;display:flex;flex-direction:column;overflow:hidden}.dialogue-editor-header{padding:var(--sp-4) var(--sp-5);background:var(--dark-bg-alt);display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--dark-border)}.dialogue-editor-header h2{font-size:var(--text-lg);font-weight:var(--weight-medium);color:var(--white);margin:0}.dialogue-editor-actions{display:flex;gap:var(--sp-2)}.dialogue-editor-canvas{flex:1;background:var(--dark-bg-alt)}.dialogue-node{background:var(--dark-bg);border:2px solid var(--dark-border);border-radius:8px;min-width:250px;font-family:var(--font-sans)}.dialogue-node.selected{border-color:var(--dark-accent)}.dialogue-node-header{padding:var(--sp-2) var(--sp-3);background:var(--dark-bg-alt);border-radius:6px 6px 0 0;display:flex;align-items:center;gap:var(--sp-2)}.dialogue-node .start-badge{background:var(--positive);color:#000;font-size:var(--text-xs);font-weight:var(--weight-medium);padding:2px 6px;border-radius:4px}.dialogue-node .node-type{font-size:var(--text-sm);color:var(--dark-text-muted);text-transform:uppercase;letter-spacing:.5px}.dialogue-node-content{padding:var(--sp-3)}.dialogue-node-text{font-size:var(--text-md);color:var(--dark-text);cursor:text;min-height:40px;line-height:1.4}.dialogue-node-textarea{width:100%;min-height:60px;background:var(--dark-bg-alt);border:1px solid var(--dark-border);border-radius:4px;color:var(--dark-text);font-size:var(--text-md);padding:var(--sp-2);resize:vertical;font-family:inherit}.dialogue-node-textarea:focus{outline:none;border-color:var(--dark-accent)}.dialogue-choice-handle{padding:var(--sp-2) var(--sp-3);border-top:1px solid var(--dark-border);display:flex;align-items:center;gap:var(--sp-2)}.dialogue-node .choice-text{font-size:var(--text-sm);color:var(--dark-text-muted);flex:1}.dialogue-node .add-choice-btn{width:100%;padding:var(--sp-2);background:transparent;border:none;border-top:1px dashed var(--dark-border);color:var(--dark-text-muted);font-size:var(--text-sm);cursor:pointer;border-radius:0 0 6px 6px;transition:all var(--duration) var(--ease)}.dialogue-node .add-choice-btn:hover{background:var(--dark-bg-alt);color:var(--dark-text)}.dialogue-editor-canvas .react-flow__node-dialogue{cursor:grab}.dialogue-editor-canvas .react-flow__edge-path{stroke:var(--dark-accent);stroke-width:2}.dialogue-editor-canvas .react-flow__edge-text{fill:var(--dark-text-muted);font-size:var(--text-sm)}.dialogue-editor-canvas .react-flow__controls{background:var(--dark-bg);border:1px solid var(--dark-border);border-radius:8px}.dialogue-editor-canvas .react-flow__controls-button{background:var(--dark-bg);border:none;color:var(--dark-text-muted)}.dialogue-editor-canvas .react-flow__controls-button:hover{background:var(--dark-border);color:var(--white)}.context-menu{position:fixed;z-index:var(--z-tooltip);min-width:180px;max-width:280px;background:var(--white);border:1px solid var(--line);border-radius:var(--radius-md);box-shadow:0 4px 16px #0000001f;padding:var(--sp-1) 0;animation:context-menu-in var(--duration-fast) var(--ease-out-expo)}@keyframes context-menu-in{0%{opacity:0;transform:scale(.95) translateY(-4px)}to{opacity:1;transform:scale(1) translateY(0)}}.context-menu__header{font-size:var(--text-2xs);font-weight:var(--weight-medium);letter-spacing:var(--tracking-wide);text-transform:uppercase;color:var(--text-tertiary);padding:var(--sp-1) var(--sp-3) var(--sp-2);border-bottom:1px solid var(--line);margin-bottom:var(--sp-1)}.context-menu__item{display:flex;align-items:center;justify-content:space-between;width:100%;padding:var(--sp-2) var(--sp-3);background:transparent;border:none;font-size:var(--text-sm);color:var(--text);text-align:left;cursor:pointer;transition:background var(--duration) var(--ease)}.context-menu__item:hover{background:var(--surface-hover)}.context-menu__name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.context-menu__hint{flex-shrink:0;font-family:var(--font-mono);font-size:var(--text-2xs);color:var(--text-tertiary);background:var(--gray-100);padding:2px 6px;border-radius:var(--radius-sm);margin-left:var(--sp-2)}.toolbar-row{display:flex;align-items:center;gap:2px;position:relative}.toolbar-transform-modes{position:absolute;top:50%;left:calc(100% + var(--sp-1) + 1px + var(--sp-2));transform:translateY(-50%);display:flex;align-items:center;gap:2px;padding:var(--sp-1);background:var(--white);border:1px solid var(--line);border-radius:var(--radius-md);box-shadow:0 2px 8px #00000014}.toolbar-divider--vertical{width:1px;height:20px;margin-right:var(--sp-1);background:var(--line)}.tool-btn--sm{width:26px;height:26px}.tool-btn--sm svg{width:14px;height:14px}.inline-editable-text{cursor:text;padding:2px var(--sp-1);margin:-2px calc(-1 * var(--sp-1));border-radius:var(--radius-sm);transition:background var(--duration) var(--ease)}.inline-editable-text:hover{background:var(--surface-hover)}.inline-editable-text:focus{outline:none;background:var(--accent-light)}.inline-editable-input{font:inherit;color:inherit;padding:2px var(--sp-1);margin:-2px calc(-1 * var(--sp-1));background:var(--white);border:1px solid var(--accent);border-radius:var(--radius-sm);outline:none;box-shadow:0 0 0 2px var(--accent-light);min-width:100px;max-width:200px}.resize-handle{position:absolute;top:0;bottom:0;width:6px;cursor:col-resize;z-index:5;transition:background var(--duration) var(--ease)}.resize-handle:hover,.resize-handle:active{background:var(--accent-light)}.resize-handle--right{right:-3px}.resize-handle--left{left:-3px}.variation-gallery-modal{max-width:900px;width:90vw}.variation-gallery__progress{font-size:var(--text-xs);color:var(--text-tertiary);margin-left:auto;margin-right:var(--sp-3)}.variation-gallery__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--sp-3)}.variation-card{display:flex;flex-direction:column;border:2px solid var(--line);border-radius:var(--radius-md);overflow:hidden;cursor:pointer;transition:border-color var(--duration) var(--ease),box-shadow var(--duration) var(--ease)}.variation-card:hover:not(.variation-card--disabled){border-color:var(--line-hover)}.variation-card--selected{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-light)}.variation-card--disabled{cursor:default;opacity:.7}.variation-card__header{display:flex;align-items:center;justify-content:space-between;padding:var(--sp-2) var(--sp-3);background:var(--gray-50);border-bottom:1px solid var(--line)}.variation-card__label{font-size:var(--text-xs);font-weight:var(--weight-medium);color:var(--text-secondary)}.variation-card__radio{width:16px;height:16px;accent-color:var(--accent);cursor:pointer}.variation-card__preview{width:100%;aspect-ratio:1;background:var(--gray-100);position:relative}.variation-card__loading,.variation-card__error{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--sp-2);font-size:var(--text-sm);color:var(--text-tertiary);text-align:center;padding:var(--sp-3)}.variation-card__error{color:var(--negative);background:#ef44440d}.variation-card__info{padding:var(--sp-2) var(--sp-3);background:var(--white);border-top:1px solid var(--line)}.variation-card__name{display:block;font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.variation-card__category{display:block;font-size:var(--text-xs);color:var(--text-tertiary);text-transform:capitalize}.generation-section__submit--variations{width:auto;padding:0 var(--sp-2);font-size:var(--text-xs);font-weight:var(--weight-medium);background:var(--gray-100);border-color:var(--line);color:var(--text-secondary)}.generation-section__submit--variations:hover:not(:disabled){background:var(--surface-hover);border-color:var(--line-hover);color:var(--text)}.home-stats{display:flex;gap:var(--sp-6);justify-content:center;margin:var(--sp-4) 0 var(--sp-6);padding:var(--sp-3) var(--sp-6);background:var(--gray-50);border-radius:var(--radius-md);border:1px solid var(--line)}.home-stats__item{text-align:center}.home-stats__value{display:block;font-size:var(--text-2xl);font-weight:var(--weight-semibold);color:var(--text)}.home-stats__label{font-size:var(--text-xs);color:var(--text-tertiary);text-transform:uppercase;letter-spacing:var(--tracking-wide)}.library-item-group{display:contents}.library-item--variant{opacity:.9}.library-item-variant-badge{position:absolute;top:4px;left:4px;width:16px;height:16px;background:#f59e0b;color:#fff;font-size:9px;font-weight:var(--weight-bold);border-radius:50%;display:flex;align-items:center;justify-content:center;z-index:2}.library-item-variants-badge{position:absolute;bottom:28px;left:4px;display:flex;align-items:center;gap:2px;padding:2px 6px;background:var(--accent);color:#fff;font-size:10px;font-weight:var(--weight-medium);border-radius:var(--radius-xs);border:none;cursor:pointer;z-index:2;transition:all var(--duration) var(--ease)}.library-item-variants-badge:hover{background:var(--accent-dark)}.library-item-variants-badge svg{width:10px;height:10px}.library-item-variants-badge.expanded{background:var(--accent-dark)}.library-item-variants{display:contents}.library-item-variants .library-item{margin-left:8px;position:relative}.library-item-variants .library-item:before{content:"";position:absolute;left:-8px;top:50%;width:6px;height:1px;background:var(--line)}.library-item-variants .library-item:after{content:"";position:absolute;left:-8px;top:0;width:1px;height:100%;background:var(--line)}.tutorial-banner{position:absolute;top:16px;left:50%;transform:translate(-50%) translateY(-100px);z-index:10000;display:flex;align-items:stretch;gap:0;opacity:0;transition:transform .4s cubic-bezier(.34,1.56,.64,1),opacity .25s ease;pointer-events:auto;filter:drop-shadow(0 6px 24px rgba(0,0,0,.12))}.tutorial-banner--visible{transform:translate(-50%) translateY(0);opacity:1}.tutorial-banner__fox{width:80px;height:80px;flex-shrink:0;border-radius:12px;overflow:hidden;background:linear-gradient(135deg,#e8edf2,#d0dbe6);border:2px solid var(--white, #fff);box-shadow:0 2px 8px #0000001a;display:flex;align-items:center;justify-content:center;position:relative;z-index:1}.tutorial-fox-canvas{display:block;width:80px;height:80px}.tutorial-banner__bubble{position:relative;background:var(--white, #fff);border-radius:14px;padding:16px 40px 14px 20px;min-width:380px;max-width:500px;margin-left:-6px;display:flex;flex-direction:column;gap:10px}.tutorial-banner__bubble:before{content:"";position:absolute;left:-8px;top:28px;width:0;height:0;border-top:8px solid transparent;border-bottom:8px solid transparent;border-right:10px solid var(--white, #fff)}.tutorial-banner__text{font-size:15px;line-height:1.5;color:var(--text, #171717);padding-right:8px}.tutorial-banner__footer{display:flex;align-items:center;justify-content:space-between}.tutorial-banner__dots{display:flex;gap:6px;align-items:center}.tutorial-banner__dot{width:7px;height:7px;border-radius:50%;background:var(--line, #e8e8e8);transition:all .2s ease}.tutorial-banner__dot--done{background:var(--accent, #c45500);opacity:.5}.tutorial-banner__dot--current{background:var(--accent, #c45500);width:18px;border-radius:4px}.tutorial-banner__next{padding:6px 18px;border:none;border-radius:8px;background:var(--accent, #c45500);color:var(--white, #fff);font-size:13px;font-weight:500;cursor:pointer;transition:background .15s ease;white-space:nowrap}.tutorial-banner__next:hover{background:var(--accent-hover, #a34700)}.tutorial-banner__dismiss{position:absolute;top:8px;right:10px;width:22px;height:22px;border:none;background:none;color:var(--text-ghost, #8a8a8a);font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:50%;line-height:1;padding:0;transition:all .15s ease}.tutorial-banner__dismiss:hover{background:var(--gray-100, #f5f5f5);color:var(--text, #171717)}.tutorial-glow-ring{box-shadow:0 0 0 3px #2563eb80,0 0 12px 2px #2563eb33;animation:tutorial-glow-pulse 1.5s ease-in-out infinite}@keyframes tutorial-glow-pulse{0%,to{box-shadow:0 0 0 3px #2563eb4d,0 0 8px 1px #2563eb1a}50%{box-shadow:0 0 0 4px #2563eb99,0 0 16px 4px #2563eb40}}.director{display:flex;flex-direction:column;min-height:100vh;background:var(--white)}.director__header{display:flex;align-items:center;justify-content:space-between;padding:var(--sp-3) var(--sp-4);border-bottom:1px solid var(--line);background:var(--surface)}.director__title{font-size:var(--text-lg);font-weight:var(--weight-medium);color:var(--text);margin:0}.director__main{flex:1;display:flex;flex-direction:column;gap:var(--sp-4);padding:var(--sp-6);max-width:1200px;margin:0 auto;width:100%}.director__input-section{display:flex;flex-direction:column;gap:var(--sp-2)}.director__label{font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--text-secondary)}.director__textarea{width:100%;min-height:100px;padding:var(--sp-3);font-size:var(--text-base);font-family:inherit;line-height:1.5;border:1px solid var(--line);border-radius:var(--radius-md);background:var(--white);color:var(--text);resize:vertical;transition:border-color var(--duration) var(--ease)}.director__textarea:focus{outline:none;border-color:var(--accent)}.director__textarea:disabled{background:var(--gray-50);cursor:not-allowed}.director__textarea::placeholder{color:var(--text-tertiary)}.director__actions{display:flex;justify-content:space-between;align-items:center;gap:var(--sp-3)}.director__hint{font-size:var(--text-xs);color:var(--text-tertiary)}.director__preview{position:relative;flex:1;min-height:400px;display:flex;align-items:center;justify-content:center;border:1px solid var(--line);border-radius:var(--radius-md);background:var(--gray-900);overflow:hidden}.director__canvas{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%}.director__canvas canvas{width:100%!important;height:100%!important}.director__preview-empty,.director__preview-loading,.director__preview-error{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--sp-3);color:var(--text-tertiary);text-align:center;background:var(--gray-50);z-index:10}.director__preview-empty svg{opacity:.5}.director__preview-error{color:var(--danger)}.director__spinner{width:32px;height:32px;border:3px solid var(--line);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}.director__playback{position:absolute;bottom:var(--sp-4);left:var(--sp-4);right:var(--sp-4);display:flex;align-items:center;gap:var(--sp-2);padding:var(--sp-2) var(--sp-3);background:#000000d9;border-radius:var(--radius-md);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:20}.director__playback-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--white);cursor:pointer;transition:background .15s ease}.director__playback-btn:hover{background:#ffffff26}.director__playback-btn:active{background:#ffffff40}.director__timeline{flex:1;height:6px;margin:0 var(--sp-2);-webkit-appearance:none;-moz-appearance:none;appearance:none;background:#fff3;border-radius:3px;cursor:pointer}.director__timeline::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:14px;height:14px;background:var(--accent);border-radius:50%;cursor:pointer;transition:transform .15s ease}.director__timeline::-webkit-slider-thumb:hover{transform:scale(1.2)}.director__timeline::-moz-range-thumb{width:14px;height:14px;background:var(--accent);border:none;border-radius:50%;cursor:pointer}.director__time{font-size:var(--text-sm);font-variant-numeric:tabular-nums;color:var(--white);min-width:80px;text-align:right}.director__plan{display:flex;flex-direction:column;gap:var(--sp-4);padding:var(--sp-4);background:var(--gray-50);border:1px solid var(--line);border-radius:var(--radius-md)}.director__plan-title{font-size:var(--text-lg);font-weight:var(--weight-medium);color:var(--text);margin:0;padding-bottom:var(--sp-2);border-bottom:1px solid var(--line)}.director__plan-section{display:flex;flex-direction:column;gap:var(--sp-2)}.director__plan-section h3{font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--text-secondary);margin:0}.director__shots{display:flex;flex-direction:column;gap:var(--sp-2)}.director__shot{padding:var(--sp-3);background:var(--white);border:1px solid var(--line);border-radius:var(--radius-sm);transition:border-color .2s ease,box-shadow .2s ease;cursor:pointer}.director__shot:hover{border-color:var(--gray-300)}.director__shot--active{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-light, rgba(99, 102, 241, .2))}.director__shot-header{display:flex;align-items:center;gap:var(--sp-2);margin-bottom:var(--sp-2)}.director__shot-number{width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:var(--accent);color:#fff;font-size:var(--text-xs);font-weight:var(--weight-medium);border-radius:50%}.director__shot-beat{font-weight:var(--weight-medium);color:var(--text);text-transform:capitalize}.director__shot-duration{margin-left:auto;font-size:var(--text-xs);color:var(--text-tertiary);background:var(--gray-100);padding:2px 6px;border-radius:var(--radius-xs)}.director__shot-desc{font-size:var(--text-sm);color:var(--text-secondary);margin:0 0 var(--sp-2);line-height:1.5}.director__shot-meta{display:flex;flex-wrap:wrap;gap:var(--sp-1)}.director__shot-meta span{font-size:var(--text-2xs);color:var(--text-tertiary);background:var(--gray-100);padding:2px 6px;border-radius:var(--radius-xs)}.director__assets{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--sp-1)}.director__assets li{font-size:var(--text-sm);color:var(--text-secondary)}.director__assets li strong{color:var(--text)}.director__asset-item{display:flex;align-items:center;gap:var(--sp-2)}.director__asset-status{margin-left:auto;font-size:var(--text-sm)}.director__asset-status--generating{animation:pulse 1s infinite}.director__asset-status--completed{color:var(--success)}.director__asset-status--failed{color:var(--danger)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.director__environment,.director__soundtrack{display:flex;flex-wrap:wrap;gap:var(--sp-2)}.director__environment span,.director__soundtrack span{font-size:var(--text-sm);color:var(--text-secondary);background:var(--white);padding:var(--sp-1) var(--sp-2);border:1px solid var(--line);border-radius:var(--radius-xs)}.director__resolved{border-top:2px solid var(--primary);padding-top:var(--sp-3);margin-top:var(--sp-3)}.director__resolved-summary{display:flex;flex-wrap:wrap;gap:var(--sp-2);margin-bottom:var(--sp-3)}.director__resolved-summary span{font-size:var(--text-sm);color:var(--text-primary);background:var(--primary-soft);padding:var(--sp-1) var(--sp-2);border-radius:var(--radius-xs);font-weight:500}.director__resolved-details{margin-top:var(--sp-2)}.director__resolved-details summary{cursor:pointer;font-size:var(--text-sm);font-weight:500;color:var(--text-secondary);padding:var(--sp-1) 0}.director__resolved-details summary:hover{color:var(--primary)}.director__resolved-assets,.director__resolved-shots{list-style:none;padding:0;margin:var(--sp-2) 0 0 0;font-family:var(--font-mono);font-size:var(--text-xs);background:var(--surface-darker);border-radius:var(--radius-sm);padding:var(--sp-2)}.director__resolved-assets li,.director__resolved-shots li{padding:var(--sp-1) 0;border-bottom:1px solid var(--line)}.director__resolved-assets li:last-child,.director__resolved-shots li:last-child{border-bottom:none}.director__resolved-assets li strong,.director__resolved-shots li strong{color:var(--primary)}.passcode-gate{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--bg)}.passcode-gate__card{text-align:center;padding:var(--sp-8);max-width:360px;width:100%}.passcode-gate__title{font-size:2rem;font-weight:700;color:var(--primary);margin:0 0 var(--sp-2);letter-spacing:-.02em}.passcode-gate__subtitle{font-size:var(--text-sm);color:var(--text-tertiary);margin:0 0 var(--sp-8)}.passcode-gate__form{display:flex;flex-direction:column;gap:var(--sp-3)}.passcode-gate__error{color:var(--negative);font-size:var(--text-sm);margin:0}:root{--white: #ffffff;--gray-50: #fafafa;--gray-100: #f5f5f5;--gray-200: #e8e8e8;--gray-300: #8a8a8a;--gray-400: #707070;--gray-500: #737373;--gray-600: #525252;--gray-900: #171717;--decorative: #d4d4d4;--decorative-light: #e8e8e8;--line: var(--decorative-light);--line-hover: var(--decorative);--line-focus: var(--gray-900);--text: var(--gray-900);--text-secondary: var(--gray-500);--text-tertiary: var(--gray-400);--text-ghost: var(--gray-300);--surface: var(--white);--surface-hover: var(--gray-100);--surface-active: var(--gray-200);--accent: #c45500;--accent-light: #fff8f3;--negative: #b91c1c;--positive: #15803d;--warning: #d97706;--info: #2563eb;--accent-hover: #a34700;--color-text-muted: var(--text-tertiary);--bg-secondary: var(--gray-50);--text-primary: var(--text);--dark-bg: #1a1a2e;--dark-bg-alt: #0f0f1a;--dark-border: #3a3a4a;--dark-text: #e0e0e0;--dark-text-muted: #888888;--dark-accent: #d64560;--axis-x: #dc2626;--axis-y: #16a34a;--axis-z: #2563eb;--sp-px: 1px;--sp-0: 0;--sp-1: 4px;--sp-2: 8px;--sp-3: 12px;--sp-4: 16px;--sp-5: 20px;--sp-6: 24px;--sp-8: 32px;--sp-10: 40px;--sp-12: 48px;--sp-16: 64px;--font-sans: "Inter", system-ui, sans-serif;--font-mono: "JetBrains Mono", monospace;--text-2xs: 9px;--text-xs: 10px;--text-sm: 11px;--text-base: 12px;--text-md: 13px;--text-lg: 14px;--weight-light: 300;--weight-normal: 400;--weight-medium: 500;--tracking-tight: -.01em;--tracking-normal: 0;--tracking-wide: .02em;--h-xs: 20px;--h-sm: 24px;--h-md: 28px;--h-lg: 32px;--h-xl: 36px;--h-2xl: 40px;--icon-xs: 12px;--icon-sm: 14px;--icon-md: 16px;--icon-lg: 20px;--radius-none: 0;--radius-sm: 2px;--radius-md: 3px;--radius-lg: 6px;--z-dropdown: 100;--z-overlay: 200;--z-modal: 300;--z-modal-confirm: 350;--z-tooltip: 400;--duration: .1s;--duration-fast: .1s;--duration-normal: .2s;--duration-slow: .3s;--ease: ease-out;--ease-out-expo: cubic-bezier(.16, 1, .3, 1);--ease-spring: cubic-bezier(.34, 1.56, .64, 1)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-sans);font-size:var(--text-base);font-weight:var(--weight-normal);line-height:1.5;color:var(--text);background:var(--white);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*:focus{outline:none}*:focus-visible{outline:1px solid var(--line-focus);outline-offset:1px}.btn:focus-visible{outline:2px solid var(--line-focus);outline-offset:2px;animation:focus-pulse var(--duration-normal) var(--ease-out-expo)}@keyframes focus-pulse{0%{outline-offset:0px}to{outline-offset:2px}}.text-label{font-size:var(--text-xs);font-weight:var(--weight-medium);letter-spacing:var(--tracking-wide);text-transform:uppercase;color:var(--text-tertiary)}.text-mono{font-family:var(--font-mono);font-size:var(--text-xs);font-weight:var(--weight-light);letter-spacing:var(--tracking-tight)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--sp-2);height:var(--h-sm);padding:0 var(--sp-3);font-family:var(--font-sans);font-size:var(--text-sm);font-weight:var(--weight-normal);color:var(--text);background:transparent;border:1px solid var(--line);border-radius:var(--radius-sm);cursor:pointer;transition:border-color var(--duration) var(--ease),background var(--duration) var(--ease),transform var(--duration-fast) var(--ease)}.btn:hover{border-color:var(--line-hover);background:var(--surface-hover)}.btn:active{background:var(--surface-active);transform:scale(.98)}.btn:disabled{color:var(--gray-500);border-color:var(--decorative-light);background:var(--gray-50);cursor:not-allowed}.btn--primary{color:var(--white);background:var(--gray-900);border-color:var(--gray-900)}.btn--primary:hover{background:var(--gray-600);border-color:var(--gray-600)}.btn--primary:disabled{color:var(--gray-400);background:var(--gray-200);border-color:var(--gray-200)}.btn--ghost{border-color:transparent}.btn--ghost:hover{border-color:transparent;background:var(--surface-hover)}.btn--accent{color:var(--white);background:var(--accent);border-color:var(--accent)}.btn--accent:hover{background:var(--accent-hover);border-color:var(--accent-hover)}.btn--danger{color:var(--negative);border-color:var(--line)}.btn--danger:hover{color:var(--white);background:var(--negative);border-color:var(--negative)}.btn--loading{pointer-events:none}.btn__spinner{width:10px;height:10px;border:1px solid currentColor;border-top-color:transparent;border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.btn--icon{width:var(--h-sm);padding:0}.btn--icon svg{width:var(--icon-sm);height:var(--icon-sm);stroke-width:1.5}.btn--sm{height:var(--h-xs);padding:0 var(--sp-2);font-size:var(--text-xs)}.input{display:block;width:100%;height:var(--h-sm);padding:0 var(--sp-2);font-family:var(--font-sans);font-size:var(--text-sm);font-weight:var(--weight-normal);color:var(--text);background:transparent;border:1px solid var(--line);border-radius:var(--radius-sm);transition:border-color var(--duration) var(--ease)}.input::placeholder{color:var(--text-ghost)}.input:hover:not(:disabled):not(:focus){border-color:var(--line-hover);background:var(--surface-hover)}.input:focus{border-color:var(--line-focus);box-shadow:0 0 0 2px var(--accent-light)}.input:disabled{color:var(--text-ghost);background:var(--gray-50);cursor:not-allowed}.input--error{border-color:var(--negative)}.input--mono{font-family:var(--font-mono);font-size:var(--text-xs);font-weight:var(--weight-light);text-align:right}.prop-row{display:grid;grid-template-columns:48px 1fr;align-items:center;gap:var(--sp-3);height:var(--h-sm)}.prop-label{font-size:var(--text-2xs);font-weight:var(--weight-medium);letter-spacing:var(--tracking-wide);text-transform:uppercase;color:var(--text-tertiary)}.prop-fields{display:flex;gap:var(--sp-1)}.prop-field{flex:1;display:flex;align-items:center;gap:var(--sp-1)}.prop-axis{font-family:var(--font-mono);font-size:var(--text-2xs);font-weight:var(--weight-light);width:10px;text-align:center}.prop-axis--x{color:var(--axis-x)}.prop-axis--y{color:var(--axis-y)}.prop-axis--z{color:var(--axis-z)}.prop-input{flex:1;height:var(--h-xs);padding:0 var(--sp-1);font-family:var(--font-mono);font-size:var(--text-xs);font-weight:var(--weight-light);text-align:right;color:var(--text);background:transparent;border:1px solid var(--line);border-radius:var(--radius-sm);transition:border-color var(--duration) var(--ease)}.prop-input:hover:not(:disabled):not(:focus){border-color:var(--line-hover);background:var(--surface-hover)}.prop-input:focus{border-color:var(--line-focus);box-shadow:0 0 0 2px var(--accent-light);outline:none}.tool-btn{display:flex;align-items:center;justify-content:center;width:var(--h-md);height:var(--h-md);color:var(--text-secondary);background:transparent;border:1px solid transparent;border-radius:var(--radius-sm);cursor:pointer;transition:color var(--duration) var(--ease),border-color var(--duration) var(--ease),background var(--duration) var(--ease),transform var(--duration-fast) var(--ease),box-shadow var(--duration-normal) var(--ease)}.tool-btn:active{transform:scale(.95)}.tool-btn svg{width:var(--icon-md);height:var(--icon-md);stroke-width:1.5}.tool-btn:hover{color:var(--text);background:var(--surface-hover)}.tool-btn--active{color:var(--white);background:var(--gray-900);border-color:var(--gray-900);box-shadow:0 0 0 2px var(--gray-200)}.tool-btn--active .tool-btn__shortcut{color:var(--gray-400)}.tool-btn:disabled{color:var(--text-ghost);cursor:not-allowed}.tool-btn__shortcut{position:absolute;bottom:2px;right:3px;font-family:var(--font-mono);font-size:8px;font-weight:var(--weight-medium);color:var(--text-ghost);line-height:1}.tool-btn{position:relative}.menu{min-width:160px;padding:var(--sp-1) 0;background:var(--white);border:1px solid var(--line);border-radius:var(--radius-md);box-shadow:0 4px 12px #00000014}.menu__item{display:flex;align-items:center;gap:var(--sp-2);height:var(--h-md);padding:0 var(--sp-3);font-size:var(--text-sm);color:var(--text);cursor:pointer;transition:background var(--duration) var(--ease)}.menu__item:hover{background:var(--surface-hover)}.menu__item--active{color:var(--accent)}.menu__item--disabled{color:var(--text-ghost);cursor:not-allowed}.menu__item--disabled:hover{background:transparent}.menu__shortcut{margin-left:auto;font-family:var(--font-mono);font-size:var(--text-2xs);font-weight:var(--weight-light);color:var(--text-tertiary)}.menu__divider{height:1px;margin:var(--sp-1) var(--sp-3);background:var(--line)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:var(--z-modal-confirm);background:#fffc;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;will-change:opacity;animation:modal-overlay-in var(--duration-normal) var(--ease-out-expo)}@keyframes modal-overlay-in{0%{opacity:0}to{opacity:1}}.modal{z-index:var(--z-modal);width:100%;max-width:360px;background:var(--white);border:1px solid var(--line);border-radius:var(--radius-md);box-shadow:0 8px 32px #00000014;animation:modal-in var(--duration-normal) var(--ease-out-expo)}@keyframes modal-in{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.modal__header,.modal-header{display:flex;align-items:center;justify-content:space-between;height:var(--h-xl);padding:0 var(--sp-4);border-bottom:1px solid var(--line)}.modal__title,.modal-title{font-size:var(--text-md);font-weight:var(--weight-medium)}.modal-close,.modal__close{display:flex;align-items:center;justify-content:center;width:24px;height:24px;padding:0;background:transparent;border:none;border-radius:var(--radius-sm);color:var(--text-tertiary);font-size:18px;line-height:1;cursor:pointer;transition:all var(--duration-fast) var(--ease)}.modal-close:hover,.modal__close:hover{background:var(--surface-hover);color:var(--text)}.modal__body,.modal-body{padding:var(--sp-4)}.modal__footer,.modal-footer{display:flex;justify-content:flex-end;gap:var(--sp-2);padding:var(--sp-3) var(--sp-4);border-top:1px solid var(--line)}.modal--confirm{max-width:320px}.modal--confirm .modal__body{font-size:var(--text-sm);color:var(--text-secondary);line-height:1.5}.modal--danger .modal__title{color:var(--negative)}.tooltip{display:inline-flex;align-items:center;gap:var(--sp-2);padding:var(--sp-1) var(--sp-2);font-size:var(--text-xs);color:var(--white);background:var(--gray-900);border-radius:var(--radius-sm)}.tooltip__key{font-family:var(--font-mono);font-size:var(--text-2xs);font-weight:var(--weight-light);color:var(--gray-400)}.toast{display:flex;align-items:flex-start;gap:var(--sp-3);width:280px;padding:var(--sp-3);background:var(--white);border:1px solid var(--line);border-radius:var(--radius-md);box-shadow:0 4px 12px #00000014;will-change:transform,opacity;animation:toast-slide-in var(--duration-normal) var(--ease-out-expo)}@keyframes toast-slide-in{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}.toast--success{animation:toast-slide-in var(--duration-normal) var(--ease-out-expo),toast-success-pop var(--duration-slow) var(--ease-spring) var(--duration-normal)}@keyframes toast-success-pop{0%,to{transform:scale(1)}50%{transform:scale(1.02)}}.toast__icon{flex-shrink:0;width:var(--icon-sm);height:var(--icon-sm);margin-top:1px;stroke-width:1.5}.toast__content{flex:1}.toast__title{font-size:var(--text-sm);font-weight:var(--weight-medium)}.toast__message{font-size:var(--text-xs);color:var(--text-secondary);margin-top:2px}.toast--success .toast__icon{color:var(--positive)}.toast--error .toast__icon{color:var(--negative)}.toast--hint .toast__icon{color:var(--warning)}.toast__icon--hint{font-size:20px;font-weight:var(--weight-bold);line-height:1}.toast__action{flex-shrink:0;padding:0 var(--sp-2);height:var(--h-xs);font-size:var(--text-xs);font-weight:var(--weight-medium);color:var(--accent);background:transparent;border:1px solid var(--accent);border-radius:var(--radius-sm);cursor:pointer;transition:background var(--duration) var(--ease),color var(--duration) var(--ease)}.toast__action:hover{background:var(--accent);color:var(--white)}.panel{display:flex;flex-direction:column;background:var(--white);border:1px solid var(--line)}.panel__header{display:flex;align-items:center;justify-content:space-between;height:var(--h-lg);padding:0 var(--sp-3);border-bottom:1px solid var(--line)}.panel__title{font-size:var(--text-2xs);font-weight:var(--weight-medium);letter-spacing:var(--tracking-wide);text-transform:uppercase;color:var(--text-tertiary)}.panel__body{flex:1;overflow-y:auto}.section{border-bottom:1px solid var(--line)}.section__header{display:flex;align-items:center;gap:var(--sp-2);height:var(--h-md);padding:0 var(--sp-3);cursor:pointer}.section__header:hover{background:var(--surface-hover)}.section__chevron{width:8px;height:8px;color:var(--text-tertiary);stroke-width:1.5;transition:transform var(--duration) var(--ease)}.section--open .section__chevron{transform:rotate(90deg)}.section__title{font-size:var(--text-2xs);font-weight:var(--weight-medium);letter-spacing:var(--tracking-wide);text-transform:uppercase;color:var(--text-tertiary)}.section__content{padding:var(--sp-3);display:flex;flex-direction:column;gap:var(--sp-2)}.list-item{display:flex;align-items:center;gap:var(--sp-2);height:var(--h-md);padding:0 var(--sp-3);cursor:pointer}.list-item:hover{background:var(--surface-hover)}.list-item--selected{background:var(--accent-light)}.list-item__icon{width:var(--icon-xs);height:var(--icon-xs);color:var(--text-tertiary);stroke-width:1.5}.list-item--selected .list-item__icon{color:var(--accent)}.list-item__label{flex:1;font-size:var(--text-sm);color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.list-item__meta{font-family:var(--font-mono);font-size:var(--text-2xs);font-weight:var(--weight-light);color:var(--text-tertiary);text-transform:uppercase}.tabs{display:flex;border-bottom:1px solid var(--line)}.tab{height:var(--h-lg);padding:0 var(--sp-3);font-family:var(--font-sans);font-size:var(--text-xs);font-weight:var(--weight-normal);color:var(--text-tertiary);background:none;border:none;border-bottom:1px solid transparent;margin-bottom:-1px;cursor:pointer;transition:color var(--duration) var(--ease)}.tab:hover{color:var(--text-secondary)}.tab--active{color:var(--text);border-bottom-color:var(--text)}.search{display:flex;align-items:center;gap:var(--sp-2);height:var(--h-sm);padding:0 var(--sp-2);background:var(--gray-50);border:1px solid transparent;border-radius:var(--radius-sm);transition:background var(--duration) var(--ease),border-color var(--duration) var(--ease)}.search:focus-within{background:var(--white);border-color:var(--line-focus)}.search__icon{width:var(--icon-xs);height:var(--icon-xs);color:var(--text-tertiary);stroke-width:1.5}.search__input{flex:1;font-family:var(--font-sans);font-size:var(--text-sm);color:var(--text);background:transparent;border:none}.search__input::placeholder{color:var(--text-ghost)}.search__input:focus{outline:none}.empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--sp-10)}.empty__text{font-size:var(--text-sm);color:var(--text-ghost)}.field{display:flex;flex-direction:column;gap:var(--sp-1)}.field__label{font-size:var(--text-2xs);font-weight:var(--weight-medium);letter-spacing:var(--tracking-wide);text-transform:uppercase;color:var(--text-tertiary)}.kbd{display:inline-flex;align-items:center;justify-content:center;min-width:16px;height:16px;padding:0 var(--sp-1);font-family:var(--font-mono);font-size:var(--text-2xs);font-weight:var(--weight-light);color:var(--text-secondary);background:var(--gray-100);border-radius:var(--radius-sm)}.divider{height:1px;background:var(--line)}.divider--vertical{width:1px;height:var(--h-md);background:var(--line)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--decorative-light);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--decorative)}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}html,body,#root{width:100%;height:100%}.text-secondary{color:var(--text-secondary)}.text-tertiary{color:var(--text-tertiary)}.text-accent{color:var(--accent)}.text-xs{font-size:var(--text-xs)}.text-muted{color:var(--text-tertiary)}
