.app-sidebar{display:flex;height:100vh;flex-shrink:0}.sidebar-rail{width:48px;display:flex;flex-direction:column;background:var(--bg-tertiary);border-right:1px solid var(--border-default);padding:8px 0;transition:width .2s ease;overflow:hidden;z-index:100}.sidebar-rail:hover{width:180px}.rail-logo{display:flex;align-items:center;gap:10px;padding:4px 10px;height:40px;cursor:pointer;white-space:nowrap}.logo-mark{width:28px;height:28px;min-width:28px;background:var(--accent-primary);color:#fff;border-radius:6px;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px}.logo-text{font-size:14px;font-weight:600;color:var(--text-primary);opacity:0;transition:opacity .15s ease}.sidebar-rail:hover .logo-text{opacity:1}.rail-nav{flex:1;display:flex;flex-direction:column;padding:8px 6px;gap:2px}.rail-item{display:flex;align-items:center;gap:10px;padding:8px;border:none;background:transparent;color:var(--text-muted);border-radius:6px;cursor:pointer;transition:all .15s ease;white-space:nowrap;text-align:left}.rail-item svg{min-width:18px}.rail-item:hover{background:var(--bg-hover);color:var(--text-primary)}.rail-item.active{background:var(--accent-primary);color:#fff}.rail-label{font-size:13px;opacity:0;transition:opacity .15s ease}.sidebar-rail:hover .rail-label{opacity:1}.rail-footer{padding:8px 6px;border-top:1px solid var(--border-default)}.tables-panel{width:220px;display:flex;flex-direction:column;background:var(--bg-secondary);border-right:1px solid var(--border-default)}.base-switcher{position:relative;padding:8px 12px;border-bottom:1px solid var(--border-default)}.base-switcher-btn{display:flex;align-items:center;gap:8px;width:100%;padding:8px 10px;background:var(--bg-tertiary);border:1px solid var(--border-default);border-radius:6px;color:var(--text-primary);font-size:13px;cursor:pointer;transition:all .15s ease}.base-switcher-btn:hover{background:var(--bg-hover);border-color:var(--accent-primary)}.base-switcher-btn .base-name-text{flex:1;text-align:left;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:500}.base-switcher-btn svg.rotated{transform:rotate(180deg)}.base-dropdown{position:absolute;top:100%;left:12px;right:12px;margin-top:4px;background:var(--bg-primary);border:1px solid var(--border-default);border-radius:6px;box-shadow:0 8px 24px #0000001f;z-index:200;max-height:300px;overflow-y:auto}.dropdown-header{padding:8px 12px;font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border-default)}.dropdown-item{display:flex;align-items:center;gap:8px;width:100%;padding:10px 12px;border:none;background:transparent;color:var(--text-secondary);font-size:13px;cursor:pointer;text-align:left}.dropdown-item:hover{background:var(--bg-hover);color:var(--text-primary)}.dropdown-item.active{background:var(--selection-bg);color:var(--accent-primary)}.dropdown-item span{flex:1}.dropdown-empty{padding:16px;text-align:center;color:var(--text-muted);font-size:12px}.panel-header{padding:14px 16px;border-bottom:1px solid var(--border-default)}.panel-title{font-size:14px;font-weight:600;color:var(--text-primary)}.panel-search{display:flex;align-items:center;gap:8px;margin:8px 12px;padding:6px 10px;background:var(--bg-tertiary);border:1px solid var(--border-default);border-radius:4px}.panel-search svg{color:var(--text-muted);flex-shrink:0}.panel-search input{flex:1;border:none;background:transparent;outline:none;font-size:12px;color:var(--text-primary)}.panel-search input::placeholder{color:var(--text-muted)}.tables-list{flex:1;overflow-y:auto;padding:4px 8px}.table-item{display:flex;align-items:center;gap:8px;padding:6px 8px;border-radius:4px;cursor:pointer;color:var(--text-secondary);font-size:13px}.table-item:hover{background:var(--bg-hover);color:var(--text-primary)}.table-item.active{background:var(--selection-bg);color:var(--accent-primary)}.table-item svg{flex-shrink:0;color:var(--text-muted)}.table-item.active svg{color:var(--accent-primary)}.no-results{padding:12px;text-align:center;color:var(--text-muted);font-size:12px}.new-table-btn{display:flex;align-items:center;justify-content:center;gap:6px;margin:8px 12px 12px;padding:8px;background:transparent;border:1px dashed var(--border-default);border-radius:4px;color:var(--text-muted);font-size:12px;cursor:pointer;transition:all .15s ease}.new-table-btn:hover{background:var(--bg-hover);border-color:var(--accent-primary);color:var(--accent-primary)}.app-layout{display:flex;height:100vh;width:100vw;overflow:hidden;background:var(--bg-primary)}.app-content{flex:1;display:flex;flex-direction:column;overflow:hidden;background:var(--bg-primary)}.table-context-menu{position:fixed;background:var(--bg-secondary);border:1px solid var(--border-default);border-radius:8px;box-shadow:0 4px 12px #00000026;min-width:160px;padding:4px;z-index:1000}.table-context-menu button{display:flex;align-items:center;gap:10px;width:100%;padding:8px 12px;background:transparent;border:none;border-radius:4px;color:var(--text-primary);font-size:13px;cursor:pointer;text-align:left;transition:all .15s ease}.table-context-menu button:hover{background:var(--bg-hover)}.table-context-menu button.danger{color:var(--danger)}.table-context-menu button.danger:hover{background:var(--danger-bg)}.context-divider{height:1px;background:var(--border-default);margin:4px 8px}.loading-spinner-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:9999}.loading-spinner-content{display:flex;flex-direction:column;align-items:center;gap:16px;padding:32px 48px;background:var(--bg-secondary, #1e293b);border-radius:16px;box-shadow:0 24px 64px #0006}.loading-spinner-icon{color:var(--accent-primary, #10b981);animation:spin 1s linear infinite}.loading-spinner-text{font-size:16px;font-weight:500;color:var(--text-primary, #f4f4f5)}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.deferred-loading-indicator{position:fixed;bottom:24px;right:24px;min-width:200px;max-width:280px;background:var(--bg-secondary, #1e293b);border:1px solid var(--border-default, #27332c);border-radius:12px;box-shadow:0 8px 32px #0000004d;padding:12px 16px;z-index:1000}.deferred-loading-header{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:var(--text-primary, #f4f4f5);margin-bottom:8px;padding-bottom:8px;border-bottom:1px solid var(--border-default, #27332c)}.deferred-loading-spinner{color:var(--accent-primary, #10b981);animation:spin 1s linear infinite}.deferred-loading-list{list-style:none;margin:0;padding:0;max-height:150px;overflow-y:auto}.deferred-loading-item{display:flex;align-items:center;gap:8px;padding:4px 0;font-size:12px;color:var(--text-secondary, #a1a1aa)}.deferred-item-spinner{color:var(--text-muted, #71717a);animation:spin 1.5s linear infinite}.auth-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background-color:var(--bg-secondary, #f3f4f6)}.auth-card{background:var(--bg-primary, white);padding:2.5rem;border-radius:12px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;width:100%;max-width:400px}.auth-card h1{font-size:1.5rem;font-weight:600;margin-bottom:.5rem;text-align:center;color:var(--text-primary, #111827)}.auth-subtitle{text-align:center;color:var(--text-secondary, #6b7280);margin-bottom:2rem;font-size:.875rem}.form-group{margin-bottom:1.25rem}.form-group label{display:block;margin-bottom:.5rem;font-size:.875rem;font-weight:500;color:var(--text-primary, #374151)}.form-group input{width:100%;padding:.625rem .875rem;border:1px solid var(--border-color, #d1d5db);border-radius:6px;font-size:.875rem;outline:none;transition:border-color .15s;background:var(--bg-tertiary, white);color:var(--text-primary, black)}.form-group input:focus{border-color:var(--accent-color, #10b981);box-shadow:0 0 0 3px #10b9811a}.auth-btn{width:100%;padding:.75rem;background-color:var(--accent-color, #10b981);color:#fff;border:none;border-radius:6px;font-weight:500;font-size:.875rem;cursor:pointer;transition:background-color .15s}.auth-btn:hover{background-color:var(--accent-hover, #059669)}.auth-btn:disabled{opacity:.7;cursor:not-allowed}.auth-footer{margin-top:1.5rem;text-align:center;font-size:.875rem;color:var(--text-secondary, #6b7280)}.auth-footer a{color:var(--accent-color, #10b981);font-weight:500;text-decoration:none}.auth-footer a:hover{text-decoration:underline}.auth-error{background-color:#fee2e2;color:#ef4444;padding:.75rem;border-radius:6px;margin-bottom:1.5rem;font-size:.875rem;text-align:center}:root{--mode: dark;--bg-primary: #0a0f0d;--bg-secondary: #121a16;--bg-tertiary: #1a241e;--bg-hover: #222e28;--bg-selected: #2a3a32;--accent-primary: #10b981;--accent-secondary: #059669;--accent-light: #34d399;--accent-success: #22c55e;--accent-warning: #f59e0b;--accent-error: #ef4444;--text-primary: #f4f4f5;--text-secondary: #a1a1aa;--text-muted: #71717a;--text-disabled: #52525b;--border-default: #27332c;--border-hover: #3f4f46;--border-focus: #10b981;--cell-height: 34px;--cell-min-width: 140px;--header-bg: #18201c;--header-border: #27332c;--row-number-width: 50px;--selection-bg: rgba(16, 185, 129, .15);--selection-border: #10b981;--font-mono: "SF Mono", "Cascadia Code", "Consolas", monospace;--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 12px;--spacing-lg: 16px;--spacing-xl: 24px;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px rgba(0, 0, 0, .4);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .5);--transition-fast: .1s ease;--transition-normal: .2s ease}[data-theme=light]{--bg-primary: #ffffff;--bg-secondary: #f8faf9;--bg-tertiary: #f0f4f2;--bg-hover: #e8ece9;--bg-selected: #d0e8dc;--accent-primary: #059669;--accent-secondary: #047857;--accent-light: #10b981;--text-primary: #1a1a1a;--text-secondary: #52525b;--text-muted: #71717a;--text-disabled: #a1a1aa;--border-default: #d4d9d6;--border-hover: #b0b8b3;--border-focus: #059669;--header-bg: #f0f4f2;--header-border: #d4d9d6;--selection-bg: rgba(5, 150, 105, .12);--selection-border: #059669;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .08);--shadow-md: 0 4px 6px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .15)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;width:100%;overflow:hidden}body{font-family:var(--font-sans);font-size:14px;line-height:1.5;color:var(--text-primary);background:var(--bg-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.spreadsheet-container{user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--border-hover);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}:focus-visible{outline:2px solid var(--accent-primary);outline-offset:2px}.app-layout{display:flex;height:100vh;width:100vw;overflow:hidden}.app-loading{display:flex;align-items:center;justify-content:center;height:100vh;width:100vw;background:var(--bg-primary);color:var(--text-secondary);font-size:16px}.app-container{display:flex;flex-direction:column;flex:1;min-width:0;background:var(--bg-primary)}.app-container:focus{outline:none}.app-content{flex:1;display:flex;flex-direction:column;min-width:0;overflow:hidden;background:var(--bg-primary)}.main-area{flex:1;display:flex;flex-direction:column;min-width:0;min-height:0;overflow:hidden}.app-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-sm) var(--spacing-lg);background:var(--bg-secondary);border-bottom:1px solid var(--border-default);min-height:48px}.app-logo{display:flex;align-items:center;gap:var(--spacing-sm);font-weight:600;font-size:18px;color:var(--text-primary)}.app-logo svg{width:28px;height:28px}.app-title{font-weight:600;font-size:16px;color:var(--text-primary)}.toolbar{display:flex;align-items:center;gap:var(--spacing-sm)}.toolbar-button{display:flex;align-items:center;justify-content:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-md);background:var(--bg-tertiary);border:1px solid var(--border-default);border-radius:var(--radius-sm);color:var(--text-secondary);font-size:13px;cursor:pointer;transition:all var(--transition-fast)}.toolbar-button:hover{background:var(--bg-hover);border-color:var(--border-hover);color:var(--text-primary)}.toolbar-button.primary{background:var(--accent-primary);border-color:var(--accent-primary);color:#fff}.toolbar-button.primary:hover{background:var(--accent-secondary);border-color:var(--accent-secondary)}.theme-toggle{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm);background:var(--bg-tertiary);border:1px solid var(--border-default);border-radius:var(--radius-sm);cursor:pointer;color:var(--text-secondary);font-size:16px;transition:all var(--transition-fast)}.theme-toggle:hover{background:var(--bg-hover);color:var(--text-primary)}.sheet-tabs{display:flex;align-items:center;gap:2px;padding:var(--spacing-xs) var(--spacing-sm);background:var(--bg-secondary);border-top:1px solid var(--border-default);overflow-x:auto}.sheet-tab{padding:var(--spacing-xs) var(--spacing-md);background:var(--bg-tertiary);border:1px solid var(--border-default);border-bottom:none;border-radius:var(--radius-sm) var(--radius-sm) 0 0;font-size:12px;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.sheet-tab:hover{background:var(--bg-hover);color:var(--text-primary)}.sheet-tab.active{background:var(--bg-primary);color:var(--accent-primary);border-color:var(--accent-primary);border-bottom:1px solid var(--bg-primary);margin-bottom:-1px;font-weight:500}.sheet-tab.add-tab{padding:var(--spacing-xs) var(--spacing-sm);background:transparent;border:1px dashed var(--border-default);color:var(--text-muted)}.sheet-tab.add-tab:hover{background:var(--selection-bg);color:var(--accent-primary);border-color:var(--accent-primary)}.formula-bar{display:flex;align-items:center;padding:var(--spacing-xs) var(--spacing-lg);background:var(--bg-secondary);border-bottom:1px solid var(--border-default);gap:var(--spacing-sm)}.cell-address{display:flex;align-items:center;justify-content:center;min-width:60px;padding:var(--spacing-xs) var(--spacing-sm);background:var(--bg-tertiary);border:1px solid var(--border-default);border-radius:var(--radius-sm);font-family:var(--font-mono);font-size:12px;color:var(--text-secondary)}.formula-input-wrapper{flex:1;position:relative}.formula-input{width:100%;padding:var(--spacing-xs) var(--spacing-sm);background:var(--bg-tertiary);border:1px solid var(--border-default);border-radius:var(--radius-sm);font-family:var(--font-mono);font-size:13px;color:var(--text-primary)}.formula-input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 2px #10b98133}.formula-input.formula-mode{border-color:var(--accent-primary);background:var(--selection-bg)}.main-content{flex:1;display:flex;overflow:hidden}.spreadsheet-container{flex:1;overflow:auto;position:relative}.spreadsheet-grid{display:grid;position:relative;min-width:max-content}.column-headers{display:flex;position:sticky;top:0;z-index:10;background:var(--header-bg)}.corner-cell{min-width:var(--row-number-width);height:var(--cell-height);background:var(--header-bg);border-right:1px solid var(--header-border);border-bottom:1px solid var(--header-border);position:sticky;left:0;z-index:20}.column-header{display:flex;align-items:center;justify-content:flex-start;height:var(--cell-height);padding:0 var(--spacing-sm);background:var(--header-bg);border-right:1px solid var(--header-border);border-bottom:1px solid var(--header-border);font-size:12px;font-weight:600;color:var(--text-secondary);cursor:pointer;transition:background var(--transition-fast);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.column-header:hover{background:var(--bg-hover)}.column-header.selected,.column-header.in-selection{background:var(--header-bg)}.column-header{position:relative}.column-resize-handle{position:absolute;right:0;top:0;bottom:0;width:5px;cursor:col-resize;background:transparent;z-index:10}.column-resize-handle:hover{background:var(--accent-primary)}.spreadsheet-row{display:flex}.row-number{display:flex;align-items:center;justify-content:center;min-width:var(--row-number-width);height:var(--cell-height);background:var(--header-bg);border-right:1px solid var(--header-border);border-bottom:1px solid var(--header-border);font-size:12px;color:var(--text-muted);cursor:pointer;position:sticky;left:0;z-index:5;transition:background var(--transition-fast)}.row-number:hover{background:var(--bg-hover)}.row-number.selected,.row-number.in-selection{background:var(--header-bg)}.cell{display:flex;align-items:center;height:var(--cell-height);padding:0 var(--spacing-sm);background:var(--bg-primary);border-right:1px solid var(--border-default);border-bottom:1px solid var(--border-default);font-size:13px;color:var(--text-primary);cursor:default;overflow:hidden;white-space:nowrap;text-overflow:ellipsis;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}.cell.selected{background:var(--bg-selected);outline:2px solid var(--selection-border);outline-offset:-1px;border-radius:4px;z-index:100;position:relative}.cell.in-selection{background:var(--selection-bg)}.cell.formula-ref{outline:2px dashed var(--accent-light);outline-offset:-2px;background:#34d3991a}.cell.editing{padding:0;outline:2px solid var(--accent-primary)}.cell-input{width:100%;height:100%;padding:0 var(--spacing-sm);background:var(--bg-primary);border:none;font-family:var(--font-sans);font-size:13px;color:var(--text-primary);outline:none}.cell.type-number{justify-content:flex-end;font-family:var(--font-mono)}.cell.type-formula{color:var(--accent-primary)}.cell.type-error{color:var(--accent-error);font-style:italic}.cell.type-checkbox{justify-content:center}.cell-checkbox{width:18px;height:18px;accent-color:var(--accent-primary);cursor:pointer}.status-bar{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-xs) var(--spacing-lg);background:var(--bg-secondary);border-top:1px solid var(--border-default);font-size:12px;color:var(--text-muted)}.status-info{display:flex;align-items:center;gap:var(--spacing-lg)}.status-item{display:flex;align-items:center;gap:var(--spacing-xs)}.status-mode{padding:2px 8px;background:var(--accent-primary);color:#fff;border-radius:var(--radius-sm);font-weight:500}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal{background:var(--bg-secondary);border:1px solid var(--border-default);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);min-width:400px;max-width:90vw;max-height:90vh;overflow:hidden}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-lg);border-bottom:1px solid var(--border-default)}.modal-title{font-size:16px;font-weight:600;color:var(--text-primary)}.modal-body{padding:var(--spacing-lg);overflow-y:auto}.modal-footer{display:flex;align-items:center;justify-content:flex-end;gap:var(--spacing-sm);padding:var(--spacing-lg);border-top:1px solid var(--border-default)}.sort-indicator-bar{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-lg);background:linear-gradient(135deg,#fef3c7,#fde68a);border-bottom:1px solid #f59e0b}.sort-indicator-icon{font-size:16px}.sort-indicator-text{flex:1;font-size:13px;font-weight:500;color:#92400e}.sort-indicator-btn{padding:6px 12px;border:1px solid #d97706;border-radius:var(--radius-sm);font-size:12px;font-weight:500;cursor:pointer;background:#fff;color:#92400e;transition:all var(--transition-fast)}.sort-indicator-btn:hover{background:#fef3c7}.sort-indicator-btn.primary{background:#059669;border-color:#059669;color:#fff}.sort-indicator-btn.primary:hover{background:#047857;border-color:#047857}[data-theme=dark] .sort-indicator-bar{background:linear-gradient(135deg,#422006,#713f12);border-color:#a16207}[data-theme=dark] .sort-indicator-text{color:#fde68a}[data-theme=dark] .sort-indicator-btn{background:#292524;border-color:#a16207;color:#fde68a}[data-theme=dark] .sort-indicator-btn:hover{background:#422006}[data-theme=dark] .sort-indicator-btn.primary{background:#10b981;border-color:#10b981;color:#fff}
