.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:#000000b3;-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:#fff;box-shadow:var(--shadow-md)}.btn-danger:hover{background:#dc2626;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:#000000b3;-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{font-size:3rem;width:70px;height:70px;display:flex;align-items:center;justify-content:center;background:var(--gradient-primary);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg),var(--shadow-glow)}.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:#000000b3;-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}}:root{--color-bg-primary: #0a0a0f;--color-bg-secondary: #13131a;--color-bg-tertiary: #1a1a24;--color-bg-elevated: #20202e;--glass-bg: rgba(26, 26, 36, .7);--glass-border: rgba(255, 255, 255, .1);--glass-shadow: 0 8px 32px 0 rgba(0, 0, 0, .37);--gradient-primary: linear-gradient(135deg, #667eea 0%, #764ba2 100%);--gradient-secondary: linear-gradient(135deg, #f093fb 0%, #f5576c 100%);--gradient-accent: linear-gradient(135deg, #4facfe 0%, #00f2fe 100%);--gradient-success: linear-gradient(135deg, #43e97b 0%, #38f9d7 100%);--color-text-primary: #ffffff;--color-text-secondary: #b4b4c8;--color-text-tertiary: #7a7a8c;--color-text-muted: #4a4a5c;--color-accent-purple: #667eea;--color-accent-pink: #f093fb;--color-accent-blue: #4facfe;--color-accent-cyan: #00f2fe;--color-accent-green: #43e97b;--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 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1);--shadow-glow: 0 0 20px rgba(102, 126, 234, .3);--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:#1a1a24e6;border-color:#fff3}.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 #667eea1a}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:#fff3}.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-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:#000000b3;-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:var(--color-accent-purple);stroke-width:2}.react-flow__edge.selected .react-flow__edge-path{stroke:var(--color-accent-cyan);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:var(--color-accent-cyan);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:#ffffff0d}.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:#fff3;box-shadow:var(--shadow-xl);transform:translateY(-2px)}.story-node.selected{border-color:var(--color-accent-purple);box-shadow:0 0 0 3px #667eea33,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:#667eea1a;border:1px solid rgba(102,126,234,.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:#667eea33;border-color:#667eea66}.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:#43e97b1a;border:1px solid rgba(67,233,123,.2);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{width:100%;height:100vh;overflow-y:auto;background:var(--color-bg-primary);position:relative}.hub-construction-banner{width:100%;background:linear-gradient(135deg,#ff6b6b,#ee5a6f);border-bottom:2px solid rgba(255,255,255,.2);padding:var(--space-md) var(--space-xl);text-align:center;position:sticky;top:0;z-index:200;box-shadow:0 4px 12px #ff6b6b4d;animation:pulse-banner 2s ease-in-out infinite}.hub-construction-content{display:flex;align-items:center;justify-content:center;gap:var(--space-sm);color:#fff;font-weight:600;font-size:var(--font-size-lg)}.hub-construction-icon{font-size:1.5rem;animation:rotate-icon 3s linear infinite}.hub-construction-text{text-shadow:0 2px 4px rgba(0,0,0,.2)}@keyframes pulse-banner{0%,to{opacity:1}50%{opacity:.9}}@keyframes rotate-icon{0%{transform:rotate(0)}25%{transform:rotate(-10deg)}50%{transform:rotate(0)}75%{transform:rotate(10deg)}to{transform:rotate(0)}}.hub-header{padding:var(--space-xl) var(--space-2xl);background:var(--glass-bg);border-bottom:1px solid var(--glass-border);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);position:sticky;top:0;z-index:100;display:flex;align-items:center;justify-content:space-between}.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:var(--gradient-primary);border-radius:var(--radius-xl);box-shadow:var(--shadow-glow)}.hub-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}.hub-subtitle{font-size:var(--font-size-base);color:var(--color-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(--color-text-primary);margin-bottom:var(--space-sm)}.hub-intro p{font-size:var(--font-size-lg);color:var(--color-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(--glass-bg);border:1px solid var(--glass-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(10px);backdrop-filter:blur(10px);box-shadow:var(--glass-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:var(--gradient-primary);opacity:0;transition:opacity .3s ease;z-index:-1;filter:blur(12px);pointer-events:none}.hub-feature-card.available:hover{transform:scale(1.05) translateY(-6px);border-color:#667eea66;box-shadow:0 16px 40px #667eea4d,0 0 0 1px #667eea33,var(--shadow-glow);filter:brightness(1.05)}.hub-feature-card.available:hover:before{opacity:.5}.hub-feature-card.coming-soon{opacity:.6;cursor:not-allowed}.hub-feature-icon{width:64px;height:64px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:var(--shadow-md);transition:transform .3s ease,filter .3s ease}.hub-feature-card.available:hover .hub-feature-icon{transform:scale(1.1) rotate(5deg);filter:drop-shadow(0 4px 12px rgba(102,126,234,.4));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(--color-bg-tertiary);display:flex;align-items:center;justify-content:center;position:relative}.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.1) rotate(5deg);filter:drop-shadow(0 4px 12px rgba(102,126,234,.4))}50%{transform:scale(1.15) rotate(8deg);filter:drop-shadow(0 6px 16px rgba(102,126,234,.6))}}.hub-feature-card.available.hovered:before{animation:glowPulse 2s ease-in-out infinite}@keyframes glowPulse{0%,to{opacity:.5;transform:scale(1)}50%{opacity:.8;transform:scale(1.05)}}.hub-feature-content{flex:1}.hub-feature-name{font-size:var(--font-size-xl);font-weight:600;color:var(--color-text-primary);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:var(--gradient-secondary);color:#fff;border-radius:var(--radius-full);font-weight:500}.hub-feature-description{font-size:var(--font-size-sm);color:var(--color-text-secondary);line-height:1.6}.hub-feature-arrow{position:absolute;top:var(--space-xl);right:var(--space-xl);color:var(--color-text-tertiary);transition:all var(--transition-base)}.hub-feature-card.available:hover .hub-feature-arrow{transform:translate(4px);color:var(--color-accent-purple)}.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(80px);opacity:.3;animation:pulse 8s ease-in-out infinite}.hub-bg-gradient-1{width:500px;height:500px;background:var(--gradient-primary);top:-200px;left:-200px;animation-delay:0s}.hub-bg-gradient-2{width:400px;height:400px;background:var(--gradient-success);bottom:-150px;right:-150px;animation-delay:2s}.hub-bg-gradient-3{width:350px;height:350px;background:var(--gradient-accent);top:50%;right:10%;animation-delay:4s}:root{--bg-primary: #0a0e1a;--bg-secondary: #131827;--bg-tertiary: #1a2035;--bg-elevated: #222b42;--accent-primary: #6366f1;--accent-secondary: #8b5cf6;--accent-success: #10b981;--accent-warning: #f59e0b;--accent-danger: #ef4444;--gradient-primary: linear-gradient(135deg, #6366f1 0%, #8b5cf6 100%);--gradient-success: linear-gradient(135deg, #10b981 0%, #059669 100%);--gradient-card: linear-gradient(135deg, rgba(99, 102, 241, .1) 0%, rgba(139, 92, 246, .1) 100%);--text-primary: #f1f5f9;--text-secondary: #94a3b8;--text-tertiary: #64748b;--text-muted: #475569;--border-color: rgba(148, 163, 184, .1);--border-hover: rgba(148, 163, 184, .2);--divider: rgba(148, 163, 184, .08);--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .4), 0 2px 4px -1px rgba(0, 0, 0, .3);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .5), 0 4px 6px -2px rgba(0, 0, 0, .4);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .6), 0 10px 10px -5px rgba(0, 0, 0, .5);--shadow-glow: 0 0 20px rgba(99, 102, 241, .3);--glass-bg: rgba(26, 32, 53, .7);--glass-border: rgba(255, 255, 255, .1);--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:#fff}.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:#fff;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 #6366f11a}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)}}
