.language-selector{position:relative;z-index:1000}.language-selector-button{display:flex;align-items:center;gap:var(--space-xs);padding:var(--space-sm) var(--space-md);background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-md);color:var(--color-text-primary);cursor:pointer;transition:all var(--transition-base);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);font-size:var(--font-size-sm)}.language-selector-button:hover{background:#1a1a24e6;border-color:#fff3}.language-code{font-weight:600;min-width:32px;text-align:center}.spinning{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.language-selector-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:999}.language-selector-dropdown{position:absolute;top:calc(100% + var(--space-sm));right:0;min-width:280px;max-width:320px;max-height:500px;background:var(--color-bg-secondary);border:1px solid var(--glass-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:1000;overflow:hidden;animation:slideDown var(--transition-base)}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.language-selector-header{padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--glass-border)}.language-selector-header h3{font-size:var(--font-size-base);margin:0;font-weight:600}.language-search-container{position:relative;padding:var(--space-md);border-bottom:1px solid var(--glass-border);display:flex;align-items:center;gap:var(--space-xs)}.language-search-icon{color:var(--color-text-secondary);flex-shrink:0}.language-search-input{flex:1;padding:var(--space-xs) var(--space-sm);background:var(--color-bg-tertiary);border:1px solid var(--glass-border);border-radius:var(--radius-sm);color:var(--color-text-primary);font-size:var(--font-size-sm);outline:none;transition:all var(--transition-base)}.language-search-input:focus{border-color:var(--gradient-primary);background:var(--color-bg-secondary)}.language-search-input::placeholder{color:var(--color-text-tertiary)}.language-search-clear{display:flex;align-items:center;justify-content:center;width:20px;height:20px;padding:0;background:transparent;border:none;color:var(--color-text-secondary);cursor:pointer;border-radius:var(--radius-sm);transition:all var(--transition-base);flex-shrink:0}.language-search-clear:hover{background:var(--color-bg-tertiary);color:var(--color-text-primary)}.language-no-results{padding:var(--space-xl);text-align:center;color:var(--color-text-secondary)}.language-no-results p{margin:0 0 var(--space-xs) 0;font-size:var(--font-size-sm);font-weight:500}.language-no-results span{font-size:var(--font-size-xs);color:var(--color-text-tertiary)}.language-selector-header h3{font-size:var(--font-size-base);font-weight:600;margin:0;color:var(--color-text-primary)}.language-selector-list{max-height:400px;overflow-y:auto;padding:var(--space-xs)}.language-option{width:100%;padding:var(--space-sm) var(--space-md);background:transparent;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);text-align:left}.language-option:hover{background:var(--color-bg-tertiary)}.language-option.active{background:#667eea1a;border:1px solid rgba(102,126,234,.3)}.language-option-content{display:flex;align-items:center;justify-content:space-between;gap:var(--space-md)}.language-option-name{display:flex;flex-direction:column;gap:var(--space-xs);flex:1}.language-name{font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-primary)}.language-native{font-size:var(--font-size-xs);color:var(--color-text-secondary)}.language-check{color:var(--color-accent-purple);flex-shrink:0}.language-selector-footer{padding:var(--space-sm) var(--space-lg);border-top:1px solid var(--glass-border);display:flex;justify-content:center}.language-cache-info{font-size:var(--font-size-xs);color:var(--color-text-tertiary)}[dir=rtl] .language-selector-dropdown{right:auto;left:0}[dir=rtl] .language-option{text-align:right}.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%}.template-card{position:relative;overflow:hidden;cursor:pointer;animation:fadeIn var(--transition-base) ease-out;animation-fill-mode:both;display:flex;flex-direction:column;min-height:320px}.template-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--gradient-primary);transform:scaleX(0);transform-origin:left;transition:transform var(--transition-base)}.template-card:hover:before{transform:scaleX(1)}.template-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-md)}.template-icon{width:60px;height:60px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;font-size:2rem;box-shadow:var(--shadow-md);transition:all var(--transition-base)}.template-card:hover .template-icon{transform:scale(1.1) rotate(5deg);box-shadow:var(--shadow-lg)}.template-badge{background:var(--bg-elevated);color:var(--text-secondary);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:500;border:1px solid var(--border-color)}.template-card-content{flex:1;display:flex;flex-direction:column;gap:var(--spacing-sm)}.template-name{font-size:var(--font-size-xl);font-weight:600;margin:0;color:var(--text-primary)}.template-description{font-size:var(--font-size-sm);color:var(--text-secondary);margin:0;line-height:1.5}.template-sheets{display:flex;flex-wrap:wrap;gap:var(--spacing-xs);margin-top:var(--spacing-sm)}.sheet-tag{display:inline-flex;align-items:center;gap:var(--spacing-xs);background:var(--bg-tertiary);color:var(--text-secondary);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);font-size:var(--font-size-xs);border:1px solid var(--border-color);transition:all var(--transition-fast)}.sheet-tag svg{width:12px;height:12px}.template-card:hover .sheet-tag{background:var(--bg-elevated);border-color:var(--border-hover)}.template-card-footer{margin-top:var(--spacing-lg);padding-top:var(--spacing-md);border-top:1px solid var(--divider)}.template-select-btn{width:100%;justify-content:center;font-weight:600;position:relative;overflow:hidden}.template-select-btn:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:#fff3;transform:translate(-50%,-50%);transition:width .6s,height .6s}.template-select-btn:hover:before{width:300px;height:300px}.template-select-btn span,.template-select-btn svg{position:relative;z-index:1}.template-select-btn svg{transition:transform var(--transition-fast)}.template-select-btn:hover svg{transform:translate(4px)}.template-card-glow{position:absolute;bottom:-100px;right:-100px;width:200px;height:200px;border-radius:50%;opacity:0;filter:blur(60px);transition:opacity var(--transition-slow);pointer-events:none}.template-card:hover .template-card-glow{opacity:.15}@media (prefers-reduced-motion: no-preference){.template-card{animation:fadeIn var(--transition-base) ease-out}}.confirm-dialog-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#1e3c3466;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn var(--transition-base) ease-out}.confirm-dialog{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);max-width:400px;width:90%;padding:var(--spacing-xl);animation:slideIn var(--transition-base) ease-out;text-align:center}.confirm-dialog-icon{display:flex;align-items:center;justify-content:center;margin-bottom:var(--spacing-lg)}.confirm-dialog-icon svg{color:var(--accent-warning);filter:drop-shadow(0 0 8px rgba(245,158,11,.3))}.confirm-dialog-content h3{font-size:var(--font-size-xl);font-weight:600;margin:0 0 var(--spacing-sm) 0;color:var(--text-primary)}.confirm-dialog-content p{font-size:var(--font-size-base);color:var(--text-secondary);margin:0 0 var(--spacing-xl) 0;line-height:1.5}.confirm-dialog-actions{display:flex;gap:var(--spacing-md);justify-content:center}.confirm-dialog-actions .btn{flex:1;justify-content:center}.btn-danger{background:var(--accent-danger);color:#faf6f1;box-shadow:var(--shadow-md)}.btn-danger:hover{background:#8f3528;box-shadow:var(--shadow-lg);transform:translateY(-1px)}.btn-danger:active{transform:translateY(0)}.create-project-dialog-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#1e3c3466;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn var(--transition-base) ease-out}.create-project-dialog{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);max-width:500px;width:90%;animation:slideIn var(--transition-base) ease-out}.create-project-header{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-xl);border-bottom:1px solid var(--border-color)}.template-preview{width:60px;height:60px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;font-size:2rem;flex-shrink:0;box-shadow:var(--shadow-md)}.create-project-header h3{font-size:var(--font-size-xl);font-weight:600;margin:0;color:var(--text-primary)}.create-project-header p{font-size:var(--font-size-sm);color:var(--text-secondary);margin:var(--spacing-xs) 0 0 0}.create-project-content{padding:var(--spacing-xl)}.create-project-content label{display:block;font-size:var(--font-size-sm);font-weight:500;color:var(--text-secondary);margin-bottom:var(--spacing-sm)}.create-project-content input{width:100%;padding:var(--spacing-md);font-size:var(--font-size-base);margin-bottom:var(--spacing-sm)}.input-hint{font-size:var(--font-size-xs);color:var(--text-tertiary);margin:0;font-style:italic}.create-project-actions{display:flex;gap:var(--spacing-md);padding:var(--spacing-lg) var(--spacing-xl);border-top:1px solid var(--border-color);justify-content:flex-end}.create-project-actions .btn{min-width:120px;justify-content:center}@keyframes slideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.project-selector{min-height:100vh;position:relative;overflow:hidden}.project-selector-header{background:var(--bg-secondary);border-bottom:1px solid var(--border-color);padding:var(--spacing-xl) 0;position:relative;z-index:10}.header-content{display:flex;justify-content:space-between;align-items:center;gap:var(--spacing-lg)}.logo-section{display:flex;align-items:center;gap:var(--spacing-md)}.logo-icon{width:70px;height:70px;display:flex;align-items:center;justify-content:center;background:var(--bg-tertiary);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);overflow:hidden}.logo-icon-img{width:100%;height:100%;object-fit:contain;padding:6px}.logo-title{font-size:var(--font-size-3xl);font-weight:700;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0}.logo-subtitle{color:var(--text-secondary);font-size:var(--font-size-sm);margin:0}.header-actions{display:flex;gap:var(--spacing-md)}.project-selector-content{padding:var(--spacing-2xl) 0;position:relative;z-index:10}.recent-section{margin-bottom:var(--spacing-2xl)}.section-title{font-size:var(--font-size-2xl);font-weight:600;margin-bottom:var(--spacing-lg);color:var(--text-primary)}.recent-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--spacing-md)}.recent-project-card{display:flex;align-items:center;gap:var(--spacing-md);cursor:pointer;padding:var(--spacing-lg);animation:slideIn var(--transition-base) ease-out;animation-fill-mode:both}.recent-project-card:hover{transform:translate(4px)}.recent-project-icon{width:50px;height:50px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:1.5rem;flex-shrink:0;box-shadow:var(--shadow-md)}.recent-project-info{flex:1;min-width:0}.recent-project-name{font-size:var(--font-size-base);font-weight:600;margin:0 0 var(--spacing-xs) 0;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.recent-project-type{font-size:var(--font-size-sm);color:var(--text-secondary);margin:0 0 var(--spacing-xs) 0}.recent-project-date{font-size:var(--font-size-xs);color:var(--text-tertiary);margin:0}.recent-project-delete{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;background:transparent;color:var(--text-tertiary);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);flex-shrink:0;opacity:0}.recent-project-card:hover .recent-project-delete{opacity:1}.recent-project-delete:hover{background:var(--accent-danger);color:#fff;transform:scale(1.1)}.recent-project-arrow{color:var(--text-tertiary);font-size:var(--font-size-xl);transition:all var(--transition-fast)}.recent-project-card:hover .recent-project-arrow{color:var(--accent-primary);transform:translate(4px)}.templates-section{animation:fadeIn var(--transition-base) ease-out;animation-fill-mode:both}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-lg);gap:var(--spacing-lg);flex-wrap:wrap}.search-box{display:flex;align-items:center;gap:var(--spacing-sm);background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--spacing-sm) var(--spacing-md);min-width:250px;transition:all var(--transition-fast)}.search-box:focus-within{border-color:var(--accent-primary);box-shadow:0 0 0 3px #6366f11a}.search-box svg{color:var(--text-tertiary);flex-shrink:0}.search-box input{border:none;background:transparent;padding:0;flex:1;min-width:0}.search-box input:focus{box-shadow:none}.templates-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--spacing-lg)}.no-results{text-align:center;padding:var(--spacing-2xl);color:var(--text-secondary)}.bg-decoration{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:0;overflow:hidden}.bg-gradient-1,.bg-gradient-2,.bg-gradient-3{position:absolute;border-radius:50%;filter:blur(80px);opacity:.15;animation:float 20s ease-in-out infinite}.bg-gradient-1{width:500px;height:500px;background:var(--accent-primary);top:-250px;right:-100px}.bg-gradient-2{width:400px;height:400px;background:var(--accent-secondary);bottom:-200px;left:-100px;animation-delay:-5s}.bg-gradient-3{width:350px;height:350px;background:var(--accent-success);top:50%;left:50%;transform:translate(-50%,-50%);animation-delay:-10s}@keyframes float{0%,to{transform:translate(0)}33%{transform:translate(30px,-30px)}66%{transform:translate(-20px,20px)}}@media (max-width: 768px){.header-content,.section-header{flex-direction:column;align-items:flex-start}.search-box{width:100%}.templates-grid,.recent-grid{grid-template-columns:1fr}}.spreadsheet-grid{width:100%;height:100%;overflow:auto;background:var(--bg-primary)}.grid-table{border-collapse:collapse;width:max-content;min-width:100%;background:var(--bg-primary)}.grid-table thead{position:sticky;top:0;z-index:10;background:var(--bg-secondary)}.grid-table tbody tr td:first-child{position:sticky;left:0;z-index:5;background:var(--bg-secondary)}.corner-cell{position:sticky;left:0;z-index:15;background:var(--bg-elevated)}.column-header,.row-header{background:var(--bg-secondary);color:var(--text-secondary);font-size:var(--font-size-xs);font-weight:600;text-align:center;padding:var(--spacing-sm);border:1px solid var(--border-color);-webkit-user-select:none;user-select:none;min-width:100px}.row-header{min-width:50px;width:50px}.grid-cell{border:1px solid var(--border-color);padding:0;height:32px;min-width:100px;background:var(--bg-primary);cursor:cell;position:relative;transition:all var(--transition-fast);-webkit-user-select:none;user-select:none}.grid-cell:hover{background:var(--bg-secondary)}.grid-cell.selected{outline:2px solid var(--accent-primary);outline-offset:-2px;z-index:1}.grid-cell.has-formula{background:#8b5cf608}.grid-cell.has-formula:after{content:"";position:absolute;top:2px;right:2px;width:0;height:0;border-style:solid;border-width:0 6px 6px 0;border-color:transparent var(--accent-secondary) transparent transparent}.cell-value{display:block;padding:var(--spacing-xs) var(--spacing-sm);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--text-primary);font-size:var(--font-size-sm);line-height:1.5}.cell-input{width:100%;height:100%;border:none;background:#fff;color:#000;padding:var(--spacing-xs) var(--spacing-sm);font-family:var(--font-family);font-size:var(--font-size-sm);outline:none;box-shadow:0 0 0 2px var(--accent-primary)}.spreadsheet-grid::-webkit-scrollbar{width:12px;height:12px}.spreadsheet-grid::-webkit-scrollbar-track{background:var(--bg-secondary)}.spreadsheet-grid::-webkit-scrollbar-thumb{background:var(--bg-elevated);border-radius:var(--radius-sm);border:2px solid var(--bg-secondary)}.spreadsheet-grid::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.spreadsheet-grid::-webkit-scrollbar-corner{background:var(--bg-secondary)}.fill-handle{position:absolute;width:6px;height:6px;background:var(--accent-primary);border:1px solid white;bottom:-3px;right:-3px;cursor:crosshair;z-index:10;border-radius:1px}.fill-handle:hover{width:8px;height:8px;bottom:-4px;right:-4px}.grid-cell.fill-preview{background:#1a73e81a;outline:1px dashed var(--accent-primary)}.grid-cell.reference-picking{outline:2px solid #4285f4!important;outline-offset:-2px;background-color:#4285f41a!important;z-index:10}.grid-cell.reference-picking-start{outline:3px solid #4285f4!important;outline-offset:-3px;background-color:#4285f426!important;z-index:11}.formula-bar{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-secondary);border-bottom:1px solid var(--border-color);min-height:48px}.formula-bar-cell-ref{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-xs) var(--spacing-md);background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-sm);min-width:120px}.formula-bar-cell-ref svg{color:var(--text-tertiary);flex-shrink:0}.cell-address{font-size:var(--font-size-sm);font-weight:600;color:var(--text-primary);font-family:Courier New,monospace}.formula-bar-divider{width:1px;height:24px;background:var(--divider)}.formula-bar-input-wrapper{flex:1;display:flex;align-items:center;gap:var(--spacing-sm);background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-sm);padding:0 var(--spacing-md);transition:all var(--transition-fast)}.formula-bar-input-wrapper:focus-within{border-color:var(--accent-primary);box-shadow:0 0 0 3px #6366f11a}.formula-bar-input-wrapper svg{color:var(--text-tertiary);flex-shrink:0}.formula-input{flex:1;border:none;background:transparent;padding:var(--spacing-sm) 0;color:var(--text-primary);font-family:Courier New,monospace;font-size:var(--font-size-sm);outline:none}.formula-input:disabled{opacity:.5;cursor:not-allowed}.formula-input::placeholder{color:var(--text-muted);font-family:var(--font-family)}.sheet-tabs{display:flex;align-items:center;justify-content:space-between;background:var(--bg-secondary);border-top:1px solid var(--border-color);padding:0 var(--spacing-sm);min-height:44px;overflow-x:auto}.tabs-container{display:flex;gap:var(--spacing-xs);flex:1;overflow-x:auto}.sheet-tab{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);background:transparent;border:none;border-bottom:2px solid transparent;color:var(--text-secondary);font-size:var(--font-size-sm);font-weight:500;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;font-family:var(--font-family)}.sheet-tab:hover{background:var(--bg-tertiary);color:var(--text-primary)}.sheet-tab.active{color:var(--accent-primary);border-bottom-color:var(--accent-primary);background:var(--bg-tertiary)}.sheet-tab svg{width:14px;height:14px}.tabs-actions{display:flex;gap:var(--spacing-xs);padding-left:var(--spacing-sm);border-left:1px solid var(--divider)}.btn-sm{padding:var(--spacing-xs) var(--spacing-sm);min-width:auto}.tabs-container::-webkit-scrollbar{height:4px}.tabs-container::-webkit-scrollbar-track{background:transparent}.tabs-container::-webkit-scrollbar-thumb{background:var(--bg-elevated);border-radius:var(--radius-sm)}.chart-preview{width:100%;height:200px;background:var(--bg-tertiary);border-radius:var(--radius-md);padding:var(--spacing-md);border:1px solid var(--border-color);display:flex;flex-direction:column}.chart-title{font-size:var(--font-size-xs);color:var(--text-secondary);margin:0 0 var(--spacing-sm) 0;text-transform:uppercase;letter-spacing:.5px}.chart-container{flex:1;min-height:0}.chart-preview-empty{width:100%;height:150px;background:var(--bg-tertiary);border-radius:var(--radius-md);border:1px dashed var(--border-color);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-md);text-align:center}.chart-icon{color:var(--text-tertiary);margin-bottom:var(--spacing-sm);opacity:.5}.chart-preview-empty p{font-size:var(--font-size-xs);color:var(--text-secondary);margin:0}.inspector{width:320px;background:var(--bg-secondary);border-left:1px solid var(--border-color);display:flex;flex-direction:column;overflow:hidden}.inspector-header{padding:var(--spacing-md) var(--spacing-lg);border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;align-items:center;background:var(--bg-elevated)}.inspector-header h3{font-size:var(--font-size-base);font-weight:600;margin:0;color:var(--text-primary)}.inspector-cell-badge{background:var(--gradient-primary);color:#fff;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:600;font-family:Courier New,monospace}.inspector-content{flex:1;overflow-y:auto;padding:var(--spacing-md)}.inspector-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--text-tertiary);text-align:center;padding:var(--spacing-2xl)}.inspector-empty svg{margin-bottom:var(--spacing-md);opacity:.5}.inspector-empty p{font-size:var(--font-size-sm);margin:0}.inspector-section{margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-lg);border-bottom:1px solid var(--divider)}.inspector-section:last-child{border-bottom:none}.section-title{font-size:var(--font-size-sm);font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin:0 0 var(--spacing-md) 0}.property-row{display:flex;flex-direction:column;gap:var(--spacing-xs);margin-bottom:var(--spacing-md)}.property-row:last-child{margin-bottom:0}.property-row label{font-size:var(--font-size-xs);color:var(--text-tertiary);font-weight:500}.property-value{background:var(--bg-tertiary);padding:var(--spacing-sm);border-radius:var(--radius-sm);font-size:var(--font-size-sm);color:var(--text-primary);border:1px solid var(--border-color);word-break:break-all}.property-value.mono{font-family:Courier New,monospace}.formula-value{background:#8b5cf61a;border-color:#8b5cf633;color:var(--accent-secondary)}.empty-value{color:var(--text-muted);font-style:italic}.type-badge{display:inline-block;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:600;text-transform:uppercase;letter-spacing:.05em}.type-integer,.type-float{background:#10b9811a;color:var(--accent-success)}.type-string{background:#6366f11a;color:var(--accent-primary)}.type-boolean{background:#f59e0b1a;color:var(--accent-warning)}.type-empty{background:var(--bg-elevated);color:var(--text-muted)}.formula-info{display:flex;flex-direction:column;gap:var(--spacing-sm)}.info-item{display:flex;align-items:flex-start;gap:var(--spacing-sm);font-size:var(--font-size-xs);color:var(--text-secondary);line-height:1.5}.info-item svg{flex-shrink:0;margin-top:2px;color:var(--accent-primary)}.quick-actions{display:flex;flex-direction:column;gap:var(--spacing-sm)}.quick-actions .btn{justify-content:flex-start;width:100%}.inspector-content::-webkit-scrollbar{width:6px}.inspector-content::-webkit-scrollbar-track{background:transparent}.inspector-content::-webkit-scrollbar-thumb{background:var(--bg-elevated);border-radius:var(--radius-sm)}@media (max-width: 1024px){.inspector{width:280px}}@media (max-width: 768px){.inspector{position:fixed;right:0;top:0;bottom:0;z-index:100;box-shadow:var(--shadow-xl)}}.export-dialog-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#1e3c3466;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--spacing-lg);animation:fadeIn var(--transition-base) ease-out}.export-dialog{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);max-width:600px;width:100%;max-height:90vh;display:flex;flex-direction:column;animation:slideIn var(--transition-base) ease-out}.export-dialog-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-lg) var(--spacing-xl);border-bottom:1px solid var(--border-color)}.export-dialog-header h2{font-size:var(--font-size-xl);font-weight:600;margin:0;color:var(--text-primary)}.export-dialog-content{flex:1;overflow-y:auto;padding:var(--spacing-xl)}.export-section{margin-bottom:var(--spacing-xl)}.export-section:last-child{margin-bottom:0}.export-section h3{font-size:var(--font-size-base);font-weight:600;margin:0 0 var(--spacing-md) 0;color:var(--text-primary)}.export-section input[type=text]{width:100%}.format-options{display:flex;flex-direction:column;gap:var(--spacing-sm)}.format-option{cursor:pointer}.format-option input[type=radio]{display:none}.format-card{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background:var(--bg-tertiary);border:2px solid var(--border-color);border-radius:var(--radius-lg);transition:all var(--transition-base)}.format-option:hover .format-card{border-color:var(--border-hover);background:var(--bg-elevated)}.format-option.selected .format-card{border-color:var(--accent-primary);background:#6366f10d;box-shadow:0 0 0 3px #6366f11a}.format-icon{font-size:2rem;width:50px;height:50px;display:flex;align-items:center;justify-content:center;background:var(--bg-primary);border-radius:var(--radius-md);flex-shrink:0}.format-info h4{font-size:var(--font-size-base);font-weight:600;margin:0 0 var(--spacing-xs) 0;color:var(--text-primary)}.format-info p{font-size:var(--font-size-sm);color:var(--text-secondary);margin:0}.sheet-selection{display:flex;flex-direction:column;gap:var(--spacing-sm)}.sheet-checkbox{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.sheet-checkbox:hover{background:var(--bg-elevated);border-color:var(--border-hover)}.sheet-checkbox input[type=checkbox]{margin:0;cursor:pointer}.sheet-checkbox span{font-size:var(--font-size-sm);color:var(--text-primary)}.export-dialog-footer{display:flex;justify-content:flex-end;gap:var(--spacing-md);padding:var(--spacing-lg) var(--spacing-xl);border-top:1px solid var(--border-color)}.export-dialog-footer .btn:disabled{opacity:.5;cursor:not-allowed}.export-dialog-content::-webkit-scrollbar{width:8px}.export-dialog-content::-webkit-scrollbar-track{background:transparent}.export-dialog-content::-webkit-scrollbar-thumb{background:var(--bg-elevated);border-radius:var(--radius-sm)}@media (max-width: 768px){.export-dialog{max-width:100%;max-height:100vh;border-radius:0}}.workspace{display:flex;flex-direction:column;height:100vh;background:var(--bg-primary)}.workspace-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md) var(--spacing-lg);background:var(--bg-secondary);border-bottom:1px solid var(--border-color);gap:var(--spacing-lg);flex-wrap:wrap}.workspace-header-left,.workspace-header-right,.workspace-title{display:flex;align-items:center;gap:var(--spacing-md)}.project-icon{width:40px;height:40px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:1.25rem;box-shadow:var(--shadow-md)}.workspace-title h1{font-size:var(--font-size-lg);font-weight:600;margin:0;color:var(--text-primary)}.workspace-title p{font-size:var(--font-size-sm);color:var(--text-secondary);margin:0}.save-status{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:var(--font-size-sm);color:var(--text-secondary)}.save-status svg{color:var(--accent-success);flex-shrink:0}.save-spinner{width:16px;height:16px;border:2px solid var(--bg-elevated);border-top-color:var(--accent-primary);border-radius:50%;animation:spin .8s linear infinite;flex-shrink:0}.workspace-content{display:flex;flex:1;overflow:hidden}.workspace-main{flex:1;display:flex;flex-direction:column;overflow:hidden}.spreadsheet-container{flex:1;overflow:auto;background:var(--bg-primary)}.workspace-loading{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-lg);padding:var(--spacing-2xl)}.loading-spinner{width:48px;height:48px;border:4px solid var(--bg-elevated);border-top-color:var(--accent-primary);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.workspace-loading p{color:var(--text-secondary);font-size:var(--font-size-base);margin:0}@media (max-width: 768px){.workspace-header{flex-direction:column;align-items:flex-start}.workspace-header-left,.workspace-header-right{width:100%;justify-content:space-between}.workspace-content{flex-direction:column}}.evaluate-container{width:100%;height:100%;min-height:0;display:flex;flex-direction:column;background:var(--color-bg-primary)}.evaluate-content{flex:1;min-height:0;overflow-y:auto;max-width:1000px;margin:0 auto;padding:var(--space-xl);width:100%}.evaluate-tabs{display:flex;gap:var(--space-xs);margin-bottom:var(--space-xl);border-bottom:1px solid var(--glass-border);padding-bottom:var(--space-md)}.evaluate-tabs button{padding:var(--space-sm) var(--space-lg);border:1px solid var(--glass-border);background:var(--color-bg-tertiary);color:var(--color-text-primary);border-radius:var(--radius-md);cursor:pointer;font-size:var(--font-size-sm);font-weight:500;transition:all var(--transition-fast)}.evaluate-tabs button:hover{background:var(--color-bg-elevated);border-color:#2d5a4a4d}.evaluate-tabs button.active{background:var(--gradient-primary);color:#faf6f1;border-color:transparent}.evaluate-tool-card{background:var(--color-bg-secondary);border:1px solid var(--glass-border);border-radius:var(--radius-xl);padding:var(--space-xl);box-shadow:var(--shadow-md)}.evaluate-tool-title{font-size:var(--font-size-xl);font-weight:600;color:var(--color-text-primary);margin:0 0 var(--space-sm) 0}.evaluate-tool-desc{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--space-lg);line-height:1.5}.evaluate-form{display:flex;flex-direction:column;gap:var(--space-lg)}.evaluate-field{display:flex;flex-direction:column;gap:var(--space-xs)}.evaluate-field label,.evaluate-label{font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-primary)}.evaluate-field input[type=number],.evaluate-field textarea{padding:var(--space-sm) var(--space-md);background:var(--color-bg-tertiary);border:1px solid var(--glass-border);border-radius:var(--radius-md);color:var(--color-text-primary);font-size:var(--font-size-sm)}.evaluate-field input:focus,.evaluate-field textarea:focus{outline:none;border-color:var(--color-accent-purple);box-shadow:0 0 0 2px #2d5a4a26}.evaluate-field textarea{resize:vertical;min-height:80px}.evaluate-mode-tabs{display:flex;flex-wrap:wrap;gap:var(--space-sm);align-items:center}.evaluate-mode-tabs button{padding:var(--space-xs) var(--space-md);border:1px solid var(--glass-border);background:var(--color-bg-tertiary);color:var(--color-text-primary);border-radius:var(--radius-md);cursor:pointer;font-size:var(--font-size-xs);transition:all var(--transition-fast)}.evaluate-mode-tabs button:hover{background:var(--color-bg-elevated)}.evaluate-mode-tabs button.active{background:#2d5a4a33;border-color:var(--color-accent-purple)}.evaluate-import-json{padding:var(--space-xs) var(--space-md);background:var(--color-bg-tertiary);border:1px solid var(--glass-border);border-radius:var(--radius-md);font-size:var(--font-size-xs);cursor:pointer;color:var(--color-text-primary)}.evaluate-import-json:hover{background:var(--color-bg-elevated)}.evaluate-error{font-size:var(--font-size-xs);color:var(--hub-red)}.evaluate-computed{font-size:var(--font-size-xs);color:var(--color-text-secondary);margin-top:var(--space-xs)}.evaluate-results{margin-top:var(--space-xl);padding-top:var(--space-lg);border-top:1px solid var(--glass-border)}.evaluate-results h4{font-size:var(--font-size-base);font-weight:600;color:var(--color-text-primary);margin:0 0 var(--space-md) 0}.evaluate-results ul{margin:0;padding-left:var(--space-lg)}.evaluate-results li{margin-bottom:var(--space-xs);color:var(--color-text-secondary);font-size:var(--font-size-sm)}.evaluate-results p{margin:0 0 var(--space-xs) 0;font-size:var(--font-size-sm);color:var(--color-text-secondary)}.evaluate-chart-wrap{margin-top:var(--space-xl)}.evaluate-chart-wrap h4{margin-bottom:var(--space-sm)}.evaluate-chart-hint{font-size:var(--font-size-xs);color:var(--color-text-tertiary);margin-bottom:var(--space-md)}.evaluate-chart{background:var(--color-bg-tertiary);border-radius:var(--radius-lg);padding:var(--space-md);border:1px solid var(--glass-border)}.evaluate-bell-result{margin-top:var(--space-lg)}.evaluate-tooltip-wrap{position:relative;display:inline-flex;align-items:center;gap:var(--space-xs)}.evaluate-tooltip-trigger{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;background:#2d5a4a33;color:var(--color-accent-purple);font-size:12px;font-weight:600;cursor:help}.evaluate-tooltip-trigger:hover{background:#2d5a4a59}.evaluate-tooltip-popover{position:absolute;left:0;bottom:100%;margin-bottom:6px;max-width:320px;padding:var(--space-sm) var(--space-md);background:var(--color-bg-elevated);border:1px solid var(--glass-border);border-radius:var(--radius-md);font-size:var(--font-size-xs);color:var(--color-text-secondary);line-height:1.5;box-shadow:var(--shadow-lg);z-index:10;pointer-events:none}.portfolio-lock-wrap{flex:1;display:flex;align-items:center;justify-content:center;padding:var(--space-xl)}.portfolio-lock-card{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-xl);padding:var(--space-xl);max-width:360px;width:100%;box-shadow:var(--shadow-lg)}.portfolio-lock-title{font-size:var(--font-size-xl);margin:0 0 var(--space-xs) 0;color:var(--color-text-primary)}.portfolio-lock-hint{font-size:var(--font-size-sm);color:var(--color-text-muted);margin:0 0 var(--space-lg) 0}.portfolio-lock-form{display:flex;flex-direction:column;gap:var(--space-md)}.portfolio-lock-input-wrap{display:flex;align-items:center;gap:0;border:1px solid var(--glass-border);border-radius:var(--radius-md);background:var(--color-bg-primary)}.portfolio-lock-input-wrap:focus-within{border-color:var(--color-accent-purple)}.portfolio-lock-input{flex:1;padding:var(--space-sm) var(--space-md);font-size:var(--font-size-base);border:none;background:transparent;color:var(--color-text-primary)}.portfolio-lock-input:focus{outline:none}.portfolio-lock-eye{display:flex;align-items:center;justify-content:center;padding:var(--space-sm) var(--space-md);border:none;border-left:1px solid var(--glass-border);background:transparent;color:var(--color-text-muted);cursor:pointer;transition:color var(--transition-fast)}.portfolio-lock-eye:hover{color:var(--color-text-primary)}.portfolio-lock-btn{align-self:stretch}.portfolio-lock-error{margin:var(--space-sm) 0 0 0;font-size:var(--font-size-sm);color:var(--color-error, #c45c4a)}.portfolio-mobile-message{text-align:center;font-size:var(--font-size-lg);color:var(--color-text-secondary);margin:0;padding:var(--space-lg)}.portfolio-container{display:flex;flex-direction:column;height:100%;background:var(--color-bg-primary)}.portfolio-toolbar{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-sm) var(--space-lg);background:var(--glass-bg);border-bottom:1px solid var(--glass-border);flex-shrink:0}.portfolio-toolbar-title{font-weight:600;font-size:var(--font-size-lg);color:var(--color-text-primary)}.portfolio-toolbar-hint{font-size:var(--font-size-xs);color:var(--color-text-muted);margin-left:auto}.portfolio-iframe-wrap{flex:1;min-height:0;display:flex;flex-direction:column;background:var(--color-bg-primary)}.portfolio-iframe{width:100%;height:55vh;min-height:320px;border:none;display:block;flex-shrink:0}.portfolio-detail-panel{flex:1;min-height:120px;overflow:auto;padding:var(--space-lg);background:var(--color-bg-primary);border-top:1px solid var(--glass-border)}.portfolio-detail-placeholder{color:var(--color-text-muted);font-size:var(--font-size-sm);text-align:center;padding:var(--space-xl);margin:0}.portfolio-detail-content{max-width:720px;margin:0 auto}.portfolio-detail-header{display:flex;gap:var(--space-lg);align-items:flex-start;margin-bottom:var(--space-lg)}.portfolio-detail-img{width:120px;height:90px;object-fit:cover;border-radius:var(--radius-md);background:var(--color-bg-tertiary);flex-shrink:0}.portfolio-detail-title{font-size:var(--font-size-xl);margin:0 0 var(--space-xs) 0}.portfolio-detail-year{font-size:var(--font-size-sm);color:var(--color-text-muted);margin:0}.portfolio-detail-body{margin-top:var(--space-md)}.portfolio-detail-desc{font-size:var(--font-size-sm);line-height:1.6;color:var(--color-text-secondary);margin:0 0 var(--space-lg) 0}.portfolio-detail-links{display:flex;flex-wrap:wrap;gap:var(--space-sm)}.portfolio-detail-link{display:inline-flex;align-items:center;gap:var(--space-xs)}.portfolio-game-wrap{flex:1;display:flex;align-items:center;justify-content:center;padding:var(--space-lg);min-height:0}.portfolio-game{position:relative;width:100%;max-width:1000px;height:420px;background:linear-gradient(180deg,#5c94fc,#87ceeb 60%,#b8e0a8 85%,#8b7355);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-xl) inset 0 0 80px #0000001a}.portfolio-ground{position:absolute;left:0;right:0;bottom:0;height:40px;background:linear-gradient(180deg,#8b7355,#6b5344);box-shadow:0 -2px #0003}.portfolio-brick{position:absolute;transition:transform .15s ease}.portfolio-brick-texture{width:100%;height:100%;background:linear-gradient(180deg,#c45c4a,#a63d2e,#8b2e20);border:3px solid #5a1a12;border-radius:4px;box-shadow:inset 2px 2px #fff3,inset -2px -2px #0003}.portfolio-brick-texture:before{content:"";position:absolute;top:6px;left:6px;right:6px;bottom:6px;border:2px solid rgba(0,0,0,.15);border-radius:2px;pointer-events:none}.portfolio-brick.revealed .portfolio-brick-texture{display:none}.portfolio-card{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4px;background:var(--glass-bg);border:2px solid var(--glass-border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);box-shadow:var(--shadow-md);overflow:hidden}.portfolio-card:hover{transform:scale(1.05);border-color:var(--color-accent-purple);box-shadow:var(--shadow-lg),var(--shadow-glow)}.portfolio-card-img{width:100%;height:32px;object-fit:cover;border-radius:2px;flex-shrink:0}.portfolio-card-name{font-size:8px;font-weight:600;color:var(--color-text-primary);text-align:center;line-height:1.2;margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.portfolio-card-year{font-size:7px;color:var(--color-text-muted)}.portfolio-player{position:absolute;bottom:40px;left:80px;pointer-events:none}.portfolio-player-sprite{image-rendering:pixelated;image-rendering:crisp-edges;transform-origin:center bottom}.portfolio-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#1e3c3480;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--space-xl);animation:portfolio-fadeIn .2s ease}@keyframes portfolio-fadeIn{0%{opacity:0}to{opacity:1}}.portfolio-modal{position:relative;background:var(--color-bg-primary);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);max-width:480px;width:100%;max-height:90vh;overflow:auto;animation:portfolio-slideUp .25s ease}@keyframes portfolio-slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.portfolio-modal-close{position:absolute;top:var(--space-sm);right:var(--space-sm);width:32px;height:32px;border:none;background:var(--color-bg-tertiary);border-radius:var(--radius-full);font-size:1.25rem;line-height:1;cursor:pointer;color:var(--color-text-secondary);transition:all var(--transition-fast);z-index:1}.portfolio-modal-close:hover{background:var(--color-text-muted);color:#fff}.portfolio-modal-content{padding:var(--space-xl)}.portfolio-modal-img{width:100%;height:200px;object-fit:cover;border-radius:var(--radius-md);margin-bottom:var(--space-md);background:var(--color-bg-tertiary)}.portfolio-modal-title{font-size:var(--font-size-xl);margin-bottom:var(--space-xs)}.portfolio-modal-year{font-size:var(--font-size-sm);color:var(--color-text-muted);margin-bottom:var(--space-md)}.portfolio-modal-details{font-size:var(--font-size-sm);line-height:1.6;color:var(--color-text-secondary)}.portfolio-modal-details p{margin:0}.resource-hub-container{display:flex;flex-direction:column;height:100%;background:var(--color-bg-primary)}.resource-hub-toolbar{flex-shrink:0}.resource-hub-content{flex:1;min-height:0;overflow:auto;padding:var(--space-lg);display:flex;flex-direction:column;gap:var(--space-lg)}.resource-hub-intro{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:0 0 var(--space-lg) 0;max-width:100%}.resource-hub-layout{display:flex;gap:var(--space-xl)}.resource-hub-tabs{display:flex;flex-direction:column;align-items:stretch;gap:var(--space-xs);margin-bottom:0;width:300px;min-width:300px;flex-shrink:0}.resource-hub-tab-chip{display:inline-flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);font-size:var(--font-size-sm);font-weight:500;border-radius:var(--radius-lg);border:1px solid var(--glass-border);background:var(--glass-bg);color:var(--color-text-secondary);cursor:pointer;text-align:left;transition:background var(--transition-fast),color var(--transition-fast),border-color var(--transition-fast),box-shadow var(--transition-fast),transform var(--transition-fast)}.resource-hub-tab-chip:hover{background:var(--color-bg-elevated);color:var(--color-text-primary);box-shadow:var(--shadow-sm)}.resource-hub-tab-chip.active{background:var(--gradient-primary);color:#fff;border-color:transparent;box-shadow:var(--shadow-md),var(--shadow-glow);transform:translateY(-1px)}.resource-hub-tab-icon-wrap{width:20px;height:20px;border-radius:999px;background:#0000000a;display:flex;align-items:center;justify-content:center}.resource-hub-tab-chip.active .resource-hub-tab-icon-wrap{background:#fdfbf740}.resource-hub-tab-label{flex:1;min-width:0;word-break:break-word;line-height:1.3}.resource-hub-list{display:flex;flex-direction:column;gap:var(--space-md);flex:1;min-width:0}@media (max-width: 768px){.resource-hub-content,.resource-hub-layout{flex-direction:column}.resource-hub-tabs{flex-direction:row;flex-wrap:wrap;width:auto}}.resource-card{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-md);padding:var(--space-md) var(--space-lg);background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:box-shadow var(--transition-fast),border-color var(--transition-fast)}.resource-card:hover{box-shadow:var(--shadow-md);border-color:#2d5a4a40}.resource-card-main{display:flex;gap:var(--space-md);flex:1;min-width:0}.resource-card-icon{flex-shrink:0;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--color-bg-tertiary);border-radius:var(--radius-md);color:var(--color-text-muted)}.resource-card-icon-img{width:100%;height:100%;object-fit:cover;border-radius:inherit;display:block}.resource-card-body{min-width:0}.resource-card-title{margin:0 0 var(--space-xs) 0;font-size:var(--font-size-base);font-weight:600;line-height:1.3}.resource-card-title-text{color:var(--color-text-primary)}.resource-card-embed-wrap{margin-top:var(--space-sm);margin-bottom:var(--space-xs)}.resource-card-embed{display:block;border:none;border-radius:var(--radius-md);background:var(--color-bg-tertiary)}.resource-card-embed-video{width:100%;max-width:560px;aspect-ratio:16 / 9;height:auto}.resource-card-embed-pdf{width:100%;max-width:100%;height:320px}.resource-card-open-link{display:inline-flex;align-items:center;gap:var(--space-xs);font-size:var(--font-size-sm);color:var(--color-accent-purple);text-decoration:none;margin-top:var(--space-xs)}.resource-card-open-link:hover{text-decoration:underline}.resource-card-clickable{cursor:pointer}.resource-card-clickable:hover{border-color:#2d5a4a59}.resource-card-teaser{font-size:var(--font-size-sm);color:var(--color-text-muted);margin:var(--space-xs) 0 0 0;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.resource-card-chevron{flex-shrink:0;opacity:.5;margin-left:var(--space-xs)}.resource-card-link{color:var(--color-text-primary);text-decoration:none;display:inline-flex;align-items:center;gap:var(--space-xs)}.resource-card-link:hover{color:var(--color-accent-purple);text-decoration:underline}.resource-card-external{flex-shrink:0;opacity:.6}.resource-card-category{display:inline-block;font-size:var(--font-size-xs);color:var(--color-text-muted);margin-bottom:var(--space-xs)}.resource-card-notes{font-size:var(--font-size-sm);color:var(--color-text-secondary);line-height:1.5;margin:0}.resource-card-actions{display:flex;gap:var(--space-xs);flex-shrink:0}.resource-card-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;border:none;border-radius:var(--radius-md);background:var(--color-bg-tertiary);color:var(--color-text-muted);cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast)}.resource-card-btn:hover{background:var(--color-bg-elevated);color:var(--color-text-primary)}.resource-card-btn-danger:hover{background:#c45c4a26;color:var(--color-accent-pink)}.resource-hub-empty{padding:var(--space-2xl);text-align:center;color:var(--color-text-muted);font-size:var(--font-size-sm)}.resource-hub-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#1e3c3466;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--space-xl);animation:resource-hub-fadeIn .2s ease}@keyframes resource-hub-fadeIn{0%{opacity:0}to{opacity:1}}.resource-hub-modal{background:var(--color-bg-primary);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);max-width:480px;width:100%;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;animation:resource-hub-slideUp .25s ease}@keyframes resource-hub-slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.resource-hub-modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-lg) var(--space-xl);border-bottom:1px solid var(--glass-border);flex-shrink:0}.resource-hub-modal-header h2{margin:0;font-size:var(--font-size-xl)}.resource-hub-modal-close{display:flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;border:none;border-radius:var(--radius-full);background:var(--color-bg-tertiary);color:var(--color-text-muted);cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast)}.resource-hub-modal-close:hover{background:var(--color-text-muted);color:#fff}.resource-hub-modal-body{padding:var(--space-xl);overflow:auto}.resource-form{display:flex;flex-direction:column;gap:var(--space-lg)}.resource-form-row{display:flex;flex-direction:column;gap:var(--space-xs)}.resource-form-row label{font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-secondary)}.resource-form-row input,.resource-form-row textarea,.resource-form-row select{padding:var(--space-sm) var(--space-md);font-size:var(--font-size-base);border:1px solid var(--glass-border);border-radius:var(--radius-md);background:var(--color-bg-primary);color:var(--color-text-primary);font-family:inherit}.resource-form-row input:focus,.resource-form-row textarea:focus,.resource-form-row select:focus{outline:none;border-color:var(--color-accent-purple)}.resource-form-row textarea{resize:vertical;min-height:72px}.resource-form-row-inline{flex-direction:row;flex-wrap:wrap;gap:var(--space-md)}.resource-form-row-inline>div{flex:1;min-width:140px;display:flex;flex-direction:column;gap:var(--space-xs)}.resource-form-actions{display:flex;gap:var(--space-md);justify-content:flex-end;padding-top:var(--space-sm)}.resource-form-links-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:var(--space-sm)}.resource-form-links-header label{margin:0}.resource-form-add-link{font-size:var(--font-size-sm);display:inline-flex;align-items:center;gap:var(--space-xs)}.resource-form-link-row{display:flex;gap:var(--space-sm);align-items:center;margin-bottom:var(--space-sm)}.resource-form-link-label{width:160px;flex-shrink:0;padding:var(--space-sm) var(--space-md);font-size:var(--font-size-sm);border:1px solid var(--glass-border);border-radius:var(--radius-md);background:var(--color-bg-primary);color:var(--color-text-primary)}.resource-form-link-url{flex:1;min-width:0;padding:var(--space-sm) var(--space-md);font-size:var(--font-size-sm);border:1px solid var(--glass-border);border-radius:var(--radius-md);background:var(--color-bg-primary);color:var(--color-text-primary)}.resource-form-remove-link{flex-shrink:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border:none;border-radius:var(--radius-md);background:var(--color-bg-tertiary);color:var(--color-text-muted);cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast)}.resource-form-remove-link:hover{background:#c45c4a26;color:var(--color-accent-pink)}.resource-detail{display:flex;flex-direction:column;height:100%;background:var(--color-bg-primary)}.resource-detail-toolbar{display:flex;align-items:center;justify-content:space-between;gap:var(--space-md);padding:var(--space-sm) var(--space-lg);background:var(--glass-bg);border-bottom:1px solid var(--glass-border);flex-shrink:0}.resource-detail-actions{display:flex;gap:var(--space-sm)}.resource-detail-delete:hover{color:var(--color-accent-pink)}.resource-detail-content{flex:1;overflow:auto;padding:var(--space-xl);max-width:900px;margin:0 auto;width:100%}.resource-detail-header{display:flex;gap:var(--space-lg);align-items:flex-start;margin-bottom:var(--space-xl)}.resource-detail-icon-wrap{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:var(--color-bg-tertiary);border-radius:var(--radius-lg);color:var(--color-text-muted);flex-shrink:0}.resource-detail-icon-img{width:100%;height:100%;object-fit:cover;border-radius:inherit;display:block}.resource-detail-title{font-size:var(--font-size-2xl);margin:0 0 var(--space-xs) 0}.resource-detail-category,.resource-detail-type{display:inline-block;font-size:var(--font-size-sm);color:var(--color-text-muted);margin-right:var(--space-md)}.resource-detail-section{margin-bottom:var(--space-xl)}.resource-detail-section-title{font-size:var(--font-size-lg);margin:0 0 var(--space-md) 0;color:var(--color-text-secondary)}.resource-detail-description{font-size:var(--font-size-base);line-height:1.7;color:var(--color-text-primary);white-space:pre-wrap}.resource-detail-embed-wrap{margin-bottom:var(--space-md)}.resource-detail-embed{display:block;border:none;border-radius:var(--radius-md);background:var(--color-bg-tertiary)}.resource-detail-embed-video{width:100%;max-width:560px;aspect-ratio:16 / 9;height:auto}.resource-detail-embed-pdf{width:100%;height:400px}.resource-detail-links{list-style:none;margin:0;padding:0}.resource-detail-link-item{margin-bottom:var(--space-sm)}.resource-detail-link{display:inline-flex;align-items:center;gap:var(--space-xs);font-size:var(--font-size-base);color:var(--color-accent-purple);text-decoration:none}.resource-detail-link:hover{text-decoration:underline}.resource-detail-description-html{line-height:1.7}.resource-detail-description-html img{max-width:100%;height:auto;border-radius:var(--radius-md);margin:var(--space-sm) 0}.resource-detail-description-html strong{font-weight:700}.resource-detail-description-html em{font-style:italic}.resource-detail-description-html u{text-decoration:underline}.resource-detail-description-html s{text-decoration:line-through}.resource-hub-unlock-btn{display:inline-flex;align-items:center;gap:var(--space-xs)}.resource-hub-unlock-modal{max-width:440px}.resource-hub-unlock-form{display:flex;flex-direction:column;gap:var(--space-lg);padding:var(--space-xl);text-align:center}.resource-hub-unlock-hint{font-size:var(--font-size-sm);color:var(--color-text-secondary);line-height:1.5;max-width:360px;margin:0 auto}.resource-hub-unlock-input{padding:var(--space-sm) var(--space-md);font-size:var(--font-size-base);border:1px solid var(--glass-border);border-radius:var(--radius-md);background:var(--color-bg-primary);color:var(--color-text-primary);width:100%;max-width:320px;align-self:center;text-align:center}.resource-hub-unlock-input:focus{outline:none;border-color:var(--color-accent-purple)}.resource-hub-unlock-error{font-size:var(--font-size-sm);color:var(--color-accent-pink);margin:0}.resource-hub-unlock-modal .resource-form-actions{justify-content:center}.resource-editor-page{display:flex;flex-direction:column;height:100%;background:var(--color-bg-primary)}.resource-editor-header{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md) var(--space-lg);background:var(--glass-bg);border-bottom:1px solid var(--glass-border);flex-shrink:0}.resource-editor-header-title{flex:1;margin:0;font-size:var(--font-size-xl);font-weight:600;text-align:center}.resource-editor-body{flex:1;overflow:auto;padding:var(--space-xl)}.resource-editor-form{max-width:720px;margin:0 auto;display:flex;flex-direction:column;gap:var(--space-xl)}.resource-editor-input{width:100%;padding:var(--space-sm) var(--space-md);font-size:var(--font-size-base);border:1px solid var(--glass-border);border-radius:var(--radius-md);background:var(--color-bg-primary);color:var(--color-text-primary)}.resource-editor-input:focus{outline:none;border-color:var(--color-accent-purple)}.resource-editor-hint{font-size:var(--font-size-xs);color:var(--color-text-muted);margin:0 0 var(--space-sm) 0}.resource-icon-picker{display:flex;gap:var(--space-md);align-items:flex-start;flex-wrap:wrap}.resource-icon-preview{width:64px;height:64px;border-radius:var(--radius-lg);border:1px dashed rgba(45,90,74,.35);background:var(--color-bg-tertiary);display:flex;align-items:center;justify-content:center;cursor:pointer;-webkit-user-select:none;user-select:none}.resource-icon-preview:hover{border-color:#2d5a4a8c}.resource-icon-preview-img{width:100%;height:100%;object-fit:cover;border-radius:inherit;display:block}.resource-icon-preview-placeholder{font-size:28px;line-height:1;color:var(--color-text-muted)}.resource-icon-actions{display:flex;flex-direction:column;gap:var(--space-sm);min-width:240px}.resource-icon-hint{margin:0;font-size:var(--font-size-xs);color:var(--color-text-muted);line-height:1.4}.resource-richtext-wrap{border:1px solid var(--glass-border);border-radius:var(--radius-lg);background:var(--color-bg-primary);overflow:hidden}.resource-richtext-toolbar{display:flex;align-items:center;gap:2px;padding:var(--space-xs) var(--space-sm);background:var(--color-bg-tertiary);border-bottom:1px solid var(--glass-border);flex-wrap:wrap}.resource-richtext-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--color-text-secondary);cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast)}.resource-richtext-btn:hover{background:var(--color-bg-elevated);color:var(--color-text-primary)}.resource-richtext-color-wrap{position:relative;margin-left:var(--space-xs)}.resource-richtext-color-panel{position:absolute;top:100%;left:0;margin-top:2px;padding:var(--space-sm);background:var(--color-bg-primary);border:1px solid var(--glass-border);border-radius:var(--radius-md);box-shadow:var(--shadow-md);display:flex;gap:var(--space-xs);z-index:10}.resource-richtext-color-swatch{width:24px;height:24px;padding:0;border:2px solid var(--glass-border);border-radius:var(--radius-sm);cursor:pointer;transition:transform var(--transition-fast)}.resource-richtext-color-swatch:hover{transform:scale(1.1)}.resource-richtext-editor{min-height:280px;padding:var(--space-md) var(--space-lg);font-size:var(--font-size-base);line-height:1.6;color:var(--color-text-primary);outline:none}.resource-richtext-editor:empty:before{content:attr(data-placeholder);color:var(--color-text-muted)}.resource-richtext-editor img{max-width:100%;height:auto;border-radius:var(--radius-md);margin:var(--space-sm) 0}:root{--color-bg-primary: #faf6f1;--color-bg-secondary: #fdfbf7;--color-bg-tertiary: #f5f0e8;--color-bg-elevated: #f0ebe3;--glass-bg: rgba(253, 251, 247, .85);--glass-border: rgba(45, 90, 74, .18);--glass-shadow: 0 4px 24px rgba(30, 60, 52, .08);--gradient-primary: linear-gradient(135deg, #2d5a4a 0%, #1e3c34 100%);--gradient-secondary: linear-gradient(135deg, #c45c4a 0%, #a63d2e 100%);--gradient-accent: linear-gradient(135deg, #c9a227 0%, #b8952e 100%);--gradient-success: linear-gradient(135deg, #3d6b5a 0%, #2d5a4a 100%);--color-text-primary: #2d3d36;--color-text-secondary: #4a5c54;--color-text-tertiary: #6b7c74;--color-text-muted: #7a8a82;--color-accent-purple: #2d5a4a;--color-accent-pink: #c45c4a;--color-accent-blue: #3d6b5a;--color-accent-cyan: #2d5a4a;--color-accent-green: #2d5a4a;--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 3rem;--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 2rem;--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(30, 60, 52, .06);--shadow-md: 0 4px 12px rgba(30, 60, 52, .08);--shadow-lg: 0 10px 24px rgba(30, 60, 52, .1);--shadow-xl: 0 20px 40px rgba(30, 60, 52, .12);--shadow-glow: 0 0 24px rgba(45, 90, 74, .2);--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .25s cubic-bezier(.4, 0, .2, 1);--transition-slow: .35s cubic-bezier(.4, 0, .2, 1)}html,body,#root{width:100%;height:100%;overflow:hidden}body{font-family:var(--font-family);font-size:var(--font-size-base);line-height:1.6;color:var(--color-text-primary);background:var(--color-bg-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}h1,h2,h3,h4,h5,h6{font-weight:600;line-height:1.2;margin-bottom:var(--space-md)}h1{font-size:var(--font-size-3xl)}h2{font-size:var(--font-size-2xl)}h3{font-size:var(--font-size-xl)}h4{font-size:var(--font-size-lg)}.btn{display:inline-flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-lg);font-size:var(--font-size-sm);font-weight:500;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-base);white-space:nowrap;-webkit-user-select:none;user-select:none}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--shadow-lg),var(--shadow-glow)}.btn-secondary{background:var(--glass-bg);color:var(--color-text-primary);border:1px solid var(--glass-border);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.btn-secondary:hover:not(:disabled){background:var(--color-bg-tertiary);border-color:#2d5a4a4d}.btn-icon{padding:var(--space-sm);aspect-ratio:1}.btn-sm{padding:var(--space-xs) var(--space-md);font-size:var(--font-size-xs)}input,textarea{width:100%;padding:var(--space-sm) var(--space-md);font-family:var(--font-family);font-size:var(--font-size-sm);color:var(--color-text-primary);background:var(--color-bg-tertiary);border:1px solid var(--glass-border);border-radius:var(--radius-md);transition:all var(--transition-base)}input:focus,textarea:focus{outline:none;border-color:var(--color-accent-purple);box-shadow:0 0 0 3px #2d5a4a26}textarea{resize:vertical;min-height:100px}.card{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-lg);padding:var(--space-lg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:var(--glass-shadow)}.card-hover{transition:all var(--transition-base)}.card-hover:hover{transform:translateY(-4px);box-shadow:var(--shadow-xl);border-color:#2d5a4a4d}.app-container{width:100%;height:100%;display:flex;flex-direction:column;background:var(--color-bg-primary)}.toolbar{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md) var(--space-lg);background:var(--glass-bg);border-bottom:1px solid var(--glass-border);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:100}.toolbar-brand{display:flex;align-items:center;gap:var(--space-md)}.toolbar-brand-icon{width:36px;height:36px;object-fit:contain}.toolbar-title{font-size:var(--font-size-lg);font-weight:600;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0}.toolbar-spacer{flex:1}.toolbar-group{display:flex;align-items:center;gap:var(--space-sm)}.canvas-container{flex:1;position:relative;overflow:hidden}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#1e3c3466;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn var(--transition-base)}.modal{background:var(--color-bg-secondary);border:1px solid var(--glass-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);max-width:600px;width:90%;max-height:80vh;overflow:hidden;display:flex;flex-direction:column;animation:slideUp var(--transition-slow)}.modal-header{padding:var(--space-lg);border-bottom:1px solid var(--glass-border);display:flex;align-items:center;justify-content:space-between}.modal-title{font-size:var(--font-size-xl);font-weight:600;margin:0}.modal-body{padding:var(--space-lg);overflow-y:auto;flex:1}.modal-footer{padding:var(--space-lg);border-top:1px solid var(--glass-border);display:flex;gap:var(--space-md);justify-content:flex-end}.form-group{margin-bottom:var(--space-lg)}.form-label{display:block;font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-secondary);margin-bottom:var(--space-sm)}.form-hint{display:block;font-size:var(--font-size-xs);color:var(--color-text-tertiary);margin-top:var(--space-xs)}.react-flow{background:var(--color-bg-primary)}.react-flow__background{background-color:var(--color-bg-primary)}.react-flow__node{border-radius:var(--radius-lg)}.react-flow__edge-path{stroke:#2d5a4a;stroke-width:2}.react-flow__edge.selected .react-flow__edge-path{stroke:#1e3c34;stroke-width:3}.react-flow__handle{width:10px;height:10px;background:var(--color-accent-purple);border:2px solid var(--color-bg-primary)}.react-flow__handle:hover{background:#1e3c34;transform:scale(1.2)}.react-flow__controls{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-md);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.react-flow__controls-button{background:transparent;border:none;border-bottom:1px solid var(--glass-border);color:var(--color-text-primary)}.react-flow__controls-button:hover{background:#2d5a4a14}.react-flow__minimap{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-md);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.story-node{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-lg);padding:var(--space-md);min-width:250px;max-width:300px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:var(--glass-shadow);transition:all var(--transition-base)}.story-node:hover{border-color:#2d5a4a59;box-shadow:var(--shadow-xl);transform:translateY(-2px)}.story-node.selected{border-color:var(--color-accent-purple);box-shadow:0 0 0 3px #2d5a4a40,var(--shadow-xl)}.story-node-header{margin-bottom:var(--space-sm)}.story-node-title{font-size:var(--font-size-base);font-weight:600;color:var(--color-text-primary);margin-bottom:var(--space-xs);word-wrap:break-word}.story-node-content{font-size:var(--font-size-sm);color:var(--color-text-secondary);line-height:1.5;margin-bottom:var(--space-md);max-height:100px;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical}.story-node-choices{display:flex;flex-direction:column;gap:var(--space-xs)}.story-node-choice{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-xs) var(--space-sm);background:#2d5a4a1a;border:1px solid rgba(45,90,74,.2);border-radius:var(--radius-sm);font-size:var(--font-size-xs);color:var(--color-text-secondary);position:relative;transition:all var(--transition-fast)}.story-node-choice:hover{background:#2d5a4a26;border-color:#2d5a4a59}.story-node-tags{display:flex;flex-wrap:wrap;gap:var(--space-xs);margin-top:var(--space-sm)}.story-node-tag{padding:var(--space-xs) var(--space-sm);background:#2d5a4a1f;border:1px solid rgba(45,90,74,.25);border-radius:var(--radius-full);font-size:var(--font-size-xs);color:var(--color-accent-green)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--color-bg-tertiary)}::-webkit-scrollbar-thumb{background:var(--color-accent-purple);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-accent-cyan)}.text-gradient{background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-sm{gap:var(--space-sm)}.gap-md{gap:var(--space-md)}.w-full{width:100%}.h-full{height:100%}.hub-container{--hub-cream: #faf6f1;--hub-cream-soft: #f5f0e8;--hub-cream-card: #fdfbf7;--hub-pine: #1e3c34;--hub-pine-mid: #2d5a4a;--hub-pine-light: #3d6b5a;--hub-red: #a63d2e;--hub-red-soft: #c45c4a;--hub-gold: #b8952e;--hub-gold-light: #c9a227;--hub-text: #2d3d36;--hub-text-secondary: #4a5c54;--hub-text-muted: #6b7c74;--hub-border: rgba(45, 90, 74, .18);--hub-shadow: 0 4px 24px rgba(30, 60, 52, .08);--hub-shadow-hover: 0 12px 40px rgba(30, 60, 52, .12);--hub-glow-pine: 0 0 24px rgba(45, 90, 74, .2);--hub-glow-red: 0 0 20px rgba(166, 61, 46, .15);--hub-glow-gold: 0 0 20px rgba(184, 149, 46, .2)}.hub-container{width:100%;height:100vh;overflow-y:auto;background:var(--hub-cream);position:relative}.hub-feature-corner-tag{position:absolute;top:0;right:0;z-index:2;padding:var(--space-xs) var(--space-sm);font-size:var(--font-size-xs);font-weight:600;color:var(--hub-cream);background:linear-gradient(135deg,var(--hub-red-soft) 0%,var(--hub-red) 100%);border-radius:0 var(--radius-xl) 0 var(--radius-md);box-shadow:0 2px 8px #a63d2e40;letter-spacing:.02em}.hub-header{padding:var(--space-xl) var(--space-2xl);background:var(--hub-cream-card);border-bottom:1px solid var(--hub-border);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);position:sticky;top:0;z-index:100;display:flex;align-items:center;justify-content:space-between;box-shadow:var(--hub-shadow)}.hub-header-actions{display:flex;align-items:center;gap:var(--space-md)}.hub-logo{display:flex;align-items:center;gap:var(--space-lg)}.hub-logo-icon{width:80px;height:80px;display:flex;align-items:center;justify-content:center}.hub-logo-image{width:100%;height:100%;object-fit:contain;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--hub-pine-mid) 0%,var(--hub-pine) 100%);border-radius:var(--radius-xl);box-shadow:var(--hub-glow-pine);border:1px solid var(--hub-border)}.hub-title{font-size:var(--font-size-3xl);font-weight:700;color:var(--hub-pine);margin:0;letter-spacing:-.02em}.hub-subtitle{font-size:var(--font-size-base);color:var(--hub-text-secondary);margin:var(--space-xs) 0 0 0}.hub-content{max-width:1400px;margin:0 auto;padding:var(--space-2xl)}.hub-intro{text-align:center;margin-bottom:var(--space-2xl);animation:fadeIn var(--transition-base)}.hub-intro h2{font-size:var(--font-size-2xl);font-weight:600;color:var(--hub-text);margin-bottom:var(--space-sm)}.hub-intro p{font-size:var(--font-size-lg);color:var(--hub-text-secondary)}.hub-features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:var(--space-lg);animation:fadeIn var(--transition-slow)}.hub-feature-card{background:var(--hub-cream-card);border:1px solid var(--hub-border);border-radius:var(--radius-xl);padding:var(--space-xl);cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:var(--hub-shadow);display:flex;flex-direction:column;gap:var(--space-md);animation:slideUp var(--transition-slow);transform-origin:center}.hub-feature-card.available:before{content:"";position:absolute;top:-2px;right:-2px;bottom:-2px;left:-2px;border-radius:inherit;background:linear-gradient(135deg,var(--hub-pine-mid) 0%,var(--hub-gold) 100%);opacity:0;transition:opacity .3s ease;z-index:-1;filter:blur(14px);pointer-events:none}.hub-feature-card.available:hover{transform:scale(1.03) translateY(-6px);border-color:#2d5a4a59;box-shadow:var(--hub-shadow-hover),var(--hub-glow-pine);filter:brightness(1.02)}.hub-feature-card.available:hover:before{opacity:.4}.hub-feature-card.coming-soon{opacity:.7;cursor:not-allowed;background:var(--hub-cream-soft)}.hub-feature-icon{width:64px;height:64px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;color:var(--hub-cream);box-shadow:var(--hub-shadow);transition:transform .3s ease,filter .3s ease}.hub-feature-card.available:hover .hub-feature-icon{transform:scale(1.08) rotate(4deg);filter:drop-shadow(0 4px 12px rgba(30,60,52,.25));animation:iconPulse 1.5s ease-in-out infinite}.hub-feature-image-container{width:100%;height:200px;border-radius:var(--radius-lg);overflow:hidden;margin-bottom:var(--space-md);background:var(--hub-cream-soft);display:flex;align-items:center;justify-content:center;position:relative;border:1px solid var(--hub-border)}.hub-feature-image{width:100%;height:100%;object-fit:cover;transition:opacity .3s ease}.hub-feature-card.available:hover .hub-feature-image{opacity:1}@keyframes iconPulse{0%,to{transform:scale(1.08) rotate(4deg);filter:drop-shadow(0 4px 12px rgba(30,60,52,.25))}50%{transform:scale(1.12) rotate(6deg);filter:drop-shadow(0 6px 16px rgba(45,90,74,.35))}}.hub-feature-card.available.hovered:before{animation:glowPulse 2s ease-in-out infinite}@keyframes glowPulse{0%,to{opacity:.4;transform:scale(1)}50%{opacity:.6;transform:scale(1.03)}}.hub-feature-content{flex:1}.hub-feature-name{font-size:var(--font-size-xl);font-weight:600;color:var(--hub-text);margin-bottom:var(--space-sm);display:flex;align-items:center;gap:var(--space-sm)}.hub-badge{font-size:var(--font-size-xs);padding:var(--space-xs) var(--space-sm);background:linear-gradient(135deg,var(--hub-red-soft) 0%,var(--hub-red) 100%);color:var(--hub-cream);border-radius:var(--radius-full);font-weight:500;box-shadow:0 2px 8px #a63d2e33}.hub-feature-description{font-size:var(--font-size-sm);color:var(--hub-text-secondary);line-height:1.6}.hub-feature-arrow{position:absolute;top:var(--space-xl);right:var(--space-xl);color:var(--hub-text-muted);transition:all var(--transition-base)}.hub-feature-card.available:hover .hub-feature-arrow{transform:translate(4px);color:var(--hub-pine-mid)}.hub-bg-decoration{position:fixed;top:0;left:0;right:0;bottom:0;pointer-events:none;z-index:0;overflow:hidden}.hub-bg-gradient-1,.hub-bg-gradient-2,.hub-bg-gradient-3{position:absolute;border-radius:50%;filter:blur(100px);opacity:.2;animation:pulse 10s ease-in-out infinite}.hub-bg-gradient-1{width:480px;height:480px;background:linear-gradient(135deg,#2d5a4a66,#1e3c344d);top:-180px;left:-180px;animation-delay:0s}.hub-bg-gradient-2{width:380px;height:380px;background:linear-gradient(135deg,#a63d2e26,#c45c4a1f);bottom:-120px;right:-120px;animation-delay:2s}.hub-bg-gradient-3{width:320px;height:320px;background:linear-gradient(135deg,#b8952e33,#c9a22726);top:50%;right:8%;animation-delay:4s}.hub-container .language-selector-button{background:var(--hub-cream-card);border:1px solid var(--hub-border);color:var(--hub-text)}.hub-container .language-selector-button:hover{background:var(--hub-cream-soft);border-color:#2d5a4a4d}.hub-container .language-selector-dropdown{background:var(--hub-cream-card);border:1px solid var(--hub-border);box-shadow:var(--hub-shadow-hover)}.hub-container .language-selector-header,.hub-container .language-selector-header h3{border-color:var(--hub-border);color:var(--hub-text)}.hub-container .language-search-container{border-color:var(--hub-border)}.hub-container .language-search-input{background:var(--hub-cream-soft);border-color:var(--hub-border);color:var(--hub-text)}.hub-container .language-search-input:focus{border-color:var(--hub-pine-mid)}.hub-container .language-search-input::placeholder{color:var(--hub-text-muted)}.hub-container .language-option:hover{background:var(--hub-cream-soft)}.hub-container .language-option.active{background:#2d5a4a1a;border:1px solid var(--hub-border)}.hub-container .language-name{color:var(--hub-text)}.hub-container .language-native{color:var(--hub-text-secondary)}.hub-container .language-check{color:var(--hub-pine-mid)}.hub-container .language-cache-info,.hub-container .language-no-results{color:var(--hub-text-secondary)}:root{--bg-primary: #faf6f1;--bg-secondary: #fdfbf7;--bg-tertiary: #f5f0e8;--bg-elevated: #f0ebe3;--accent-primary: #2d5a4a;--accent-secondary: #1e3c34;--accent-success: #3d6b5a;--accent-warning: #b8952e;--accent-danger: #a63d2e;--gradient-primary: linear-gradient(135deg, #2d5a4a 0%, #1e3c34 100%);--gradient-success: linear-gradient(135deg, #3d6b5a 0%, #2d5a4a 100%);--gradient-card: linear-gradient(135deg, rgba(45, 90, 74, .08) 0%, rgba(30, 60, 52, .06) 100%);--text-primary: #2d3d36;--text-secondary: #4a5c54;--text-tertiary: #6b7c74;--text-muted: #7a8a82;--border-color: rgba(45, 90, 74, .18);--border-hover: rgba(45, 90, 74, .3);--divider: rgba(45, 90, 74, .1);--shadow-sm: 0 1px 2px rgba(30, 60, 52, .06);--shadow-md: 0 4px 12px rgba(30, 60, 52, .08);--shadow-lg: 0 10px 24px rgba(30, 60, 52, .1);--shadow-xl: 0 20px 40px rgba(30, 60, 52, .12);--shadow-glow: 0 0 24px rgba(45, 90, 74, .2);--glass-bg: rgba(253, 251, 247, .85);--glass-border: rgba(45, 90, 74, .18);--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .25s cubic-bezier(.4, 0, .2, 1);--transition-slow: .35s cubic-bezier(.4, 0, .2, 1);--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--font-size-4xl: 2.25rem}*{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font-family);background:var(--bg-primary);color:var(--text-primary);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden}#root{min-height:100vh;width:100%}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--bg-elevated);border-radius:var(--radius-md);border:2px solid var(--bg-secondary)}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}::selection{background:var(--accent-primary);color:#faf6f1}.container{max-width:1400px;margin:0 auto;padding:0 var(--spacing-lg)}.glass{background:var(--glass-bg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--glass-border)}.gradient-text{background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--spacing-lg);transition:all var(--transition-base)}.card:hover{border-color:var(--border-hover);box-shadow:var(--shadow-lg);transform:translateY(-2px)}.btn{display:inline-flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-lg);border:none;border-radius:var(--radius-md);font-family:var(--font-family);font-size:var(--font-size-sm);font-weight:500;cursor:pointer;transition:all var(--transition-base);outline:none;text-decoration:none}.btn-primary{background:var(--gradient-primary);color:#faf6f1;box-shadow:var(--shadow-md)}.btn-primary:hover{box-shadow:var(--shadow-lg),var(--shadow-glow);transform:translateY(-1px)}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:var(--bg-elevated);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover{background:var(--bg-tertiary);border-color:var(--border-hover)}.btn-ghost{background:transparent;color:var(--text-secondary)}.btn-ghost:hover{background:var(--bg-elevated);color:var(--text-primary)}input,textarea,select{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--spacing-sm) var(--spacing-md);color:var(--text-primary);font-family:var(--font-family);font-size:var(--font-size-sm);transition:all var(--transition-fast);outline:none}input:focus,textarea:focus,select:focus{border-color:var(--accent-primary);box-shadow:0 0 0 3px #2d5a4a26}input::placeholder,textarea::placeholder{color:var(--text-muted)}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes shimmer{0%{background-position:-1000px 0}to{background-position:1000px 0}}.fade-in{animation:fadeIn var(--transition-base) ease-out}.slide-in{animation:slideIn var(--transition-base) ease-out}@media (max-width: 768px){:root{--spacing-lg: 1rem;--spacing-xl: 1.5rem;--spacing-2xl: 2rem}.container{padding:0 var(--spacing-md)}}
