:root{--primary-color: #1a73e8;--border-color: #e0e0e0;--header-bg: #f8f9fa;--cell-bg: #ffffff;--text-color: #202124;--selection-bg: rgba(26, 115, 232, .1);--selection-border: #1a73e8;--cell-height: 24px;--cell-width: 100px;--header-height: 24px;--row-header-width: 40px;--font-family: "Inter", sans-serif;--font-size: 13px}*{box-sizing:border-box}body{margin:0;padding:0;font-family:var(--font-family);font-size:var(--font-size);color:var(--text-color);background-color:#f9f9f9;overflow:hidden}#root{height:100vh;display:flex;flex-direction:column}@media print{.toolbar-area,.menu-bar,.corner-header,.resize-handle-col,.resize-handle-row{display:none!important}.spreadsheet-layout{height:auto!important;overflow:visible!important}.grid-area{overflow:visible!important;height:auto!important}.col-header,.row-header{background-color:#fff!important;border-color:#000!important;color:#000!important}.cell{border-color:#000!important}}.menu-bar{display:flex;align-items:center;height:30px;background-color:#fff;border-bottom:1px solid var(--border-color);padding:0 8px}.menu-item{position:relative;padding:4px 10px;cursor:pointer;font-size:14px;color:#202124;border-radius:4px;-webkit-user-select:none;user-select:none}.menu-item:hover{background-color:#f1f3f4}.dropdown-menu{position:absolute;top:100%;left:0;background-color:#fff;border:1px solid var(--border-color);box-shadow:0 2px 6px #0003;border-radius:4px;z-index:100;min-width:150px;padding:4px 0}.dropdown-item{padding:6px 16px;display:flex;align-items:center;cursor:pointer;font-size:13px}.dropdown-item:hover{background-color:#f1f3f4}.dropdown-item.disabled{color:#80868b;cursor:default}.dropdown-item.disabled:hover{background-color:transparent}.shortcut{margin-left:auto;font-size:12px;color:#5f6368}.dropdown-divider{height:1px;background-color:#dadce0;margin:4px 0}.dropdown-item .material-icons{font-size:16px;margin-right:8px;color:#5f6368}.toolbar{display:flex;align-items:center;padding:8px;background-color:#f1f3f4;border-bottom:1px solid #e0e0e0;gap:8px}.toolbar-btn{background:none;border:none;padding:4px 8px;border-radius:4px;cursor:pointer;font-weight:700;color:#5f6368}.toolbar-btn:hover{background-color:#e8eaed}.toolbar-btn.active{background-color:#e8f0fe;color:#1a73e8}.color-picker-wrapper{position:relative;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;border-radius:4px}.color-picker-wrapper:hover{background-color:#f1f3f4}.color-picker-wrapper input[type=color]{position:absolute;top:0;left:0;width:100%;height:100%;opacity:0;cursor:pointer}.divider{width:1px;height:20px;background:#e0e0e0;margin:0 8px}.formula-bar{display:flex;align-items:center;padding:4px 8px;border-bottom:1px solid #e0e0e0;background-color:#fff;height:28px}.fx-icon{color:#5f6368;font-style:italic;font-weight:700;margin-right:8px;-webkit-user-select:none;user-select:none}.formula-input{flex:1;border:none;outline:none;font-family:inherit;font-size:13px;height:100%}.cell{border-right:1px solid var(--border-color);border-bottom:1px solid var(--border-color);padding:0 4px;outline:none;font-size:13px;display:flex;align-items:center;overflow:hidden;white-space:nowrap;cursor:cell;-webkit-user-select:none;user-select:none}.cell.selected{border:2px solid var(--selection-border);z-index:2}.cell input{width:100%;height:100%;border:none;outline:none;font-family:inherit;font-size:inherit;background:transparent;text-align:inherit}.auto-fill-handle{position:absolute;bottom:-4px;right:-4px;width:8px;height:8px;background-color:var(--selection-border);border:1px solid #fff;cursor:crosshair;z-index:3}.grid-container{display:grid;grid-template-columns:var(--row-header-width) 1fr;grid-template-rows:var(--header-height) 1fr;height:100%;overflow:auto;position:relative;background-color:#f8f9fa}.corner-header{position:sticky;top:0;left:0;z-index:3;background-color:var(--header-bg);border-right:1px solid var(--border-color);border-bottom:1px solid var(--border-color)}.column-headers{display:flex;position:sticky;top:0;z-index:2;background-color:var(--header-bg)}.col-header{display:flex;align-items:center;justify-content:center;border-right:1px solid var(--border-color);border-bottom:1px solid var(--border-color);background-color:var(--header-bg);font-weight:700;-webkit-user-select:none;user-select:none;cursor:pointer}.col-header.selected{background-color:#d2e3fc;color:var(--primary-color)}.row-headers{display:flex;flex-direction:column;position:sticky;left:0;z-index:2;background-color:var(--header-bg)}.row-header{display:flex;align-items:center;justify-content:center;-webkit-user-select:none;user-select:none}.grid-body{position:relative;background-color:var(--cell-bg)}.grid-row{display:flex}.resize-handle-col{position:absolute;right:0;top:0;bottom:0;width:4px;cursor:col-resize;z-index:10}.resize-handle-col:hover{background-color:#1a73e8}.resize-handle-row{position:absolute;bottom:0;left:0;right:0;height:4px;cursor:row-resize;z-index:10}.resize-handle-row:hover{background-color:#1a73e8}.sheet-tabs{display:flex;align-items:center;height:36px;background-color:#f8f9fa;border-top:1px solid var(--border-color);padding:0 8px;position:fixed;bottom:0;left:0;right:0;z-index:100}.sheet-tab{display:flex;align-items:center;padding:0 16px;height:30px;background-color:#fff;border:1px solid var(--border-color);border-bottom:none;border-radius:4px 4px 0 0;font-size:13px;font-weight:500;color:var(--primary-color);cursor:pointer;margin-right:4px;box-shadow:0 1px 2px #0000001a}.sheet-tab .material-icons{font-size:14px;margin-left:8px;color:#5f6368}.add-sheet-btn{display:flex;align-items:center;justify-content:center;width:30px;height:30px;border:none;background:transparent;cursor:pointer;color:#5f6368}.add-sheet-btn:hover{background-color:#e8eaed;border-radius:50%}.profile-popup-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.profile-popup{background:#fff;border-radius:8px;padding:32px;width:90%;max-width:400px;box-shadow:0 8px 16px #0003;text-align:center}.profile-avatar-large{width:80px;height:80px;border-radius:50%;background-color:#1a73e8;color:#fff;display:flex;align-items:center;justify-content:center;font-size:36px;font-weight:500;margin:0 auto 16px}.profile-name{font-size:24px;font-weight:500;color:#202124;margin-bottom:4px}.profile-email{font-size:14px;color:#5f6368;margin-bottom:16px}.profile-verified{display:inline-flex;align-items:center;gap:4px;background-color:#e8f5e9;color:#1e8e3e;padding:4px 12px;border-radius:12px;font-size:13px;margin-bottom:16px}.profile-verified .material-icons{font-size:16px}.profile-address{font-size:14px;color:#5f6368;margin-top:8px}.profile-loading,.profile-error{padding:32px;text-align:center;color:#5f6368}.profile-error{color:#d93025}.profile-actions{display:flex;flex-direction:column;gap:12px;margin-top:24px}.logout-button{padding:10px 24px;background-color:#1a73e8;color:#fff;border:none;border-radius:4px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s;width:100%}.logout-button:hover{background-color:#1557b0}.reset-pass-button{padding:10px 24px;background-color:transparent;color:#1a73e8;border:1px solid #dadce0;border-radius:4px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s;width:100%}.reset-pass-button:hover{background-color:#1a73e80a;border-color:#1a73e8}.reset-pass-button:disabled{color:#dadce0;border-color:#dadce0;cursor:not-allowed}.profile-message{margin-top:12px;font-size:13px;padding:8px;border-radius:4px}.profile-message.success{background-color:#e6f4ea;color:#137333}.profile-message.error{background-color:#fce8e6;color:#c5221f}.spreadsheet-layout{display:flex;flex-direction:column;height:100vh;overflow:hidden}.toolbar-area{flex:0 0 auto;background-color:#fff;z-index:10}.header-menu-btn:hover{background-color:#3c404314}.sheet-name-container{margin-left:8px;margin-right:auto}.sheet-name{font-size:18px;color:#202124;padding:8px 12px;cursor:pointer;border-radius:4px;transition:background-color .2s}.sheet-name:hover{background-color:#3c404314}.sheet-name-input{font-size:18px;color:#202124;padding:8px 12px;border:1px solid #1a73e8;border-radius:4px;outline:none;min-width:200px}.user-avatar-small{width:28px;height:28px;border-radius:50%;background-color:#1a73e8;color:#fff;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:500}.grid-area{flex:1;overflow:auto;position:relative;padding-bottom:36px}.home-container{display:flex;flex-direction:column;height:100vh;background-color:#fff;font-family:Roboto,sans-serif;overflow-y:auto}.home-header{display:flex;align-items:center;padding:8px 16px;background-color:#fff;border-bottom:1px solid #e8eaed;gap:16px}.header-left{display:flex;align-items:center;gap:16px}.menu-icon{cursor:pointer;padding:8px;border-radius:50%;display:flex;align-items:center;justify-content:center}.menu-icon:hover{background-color:#3c404314}.header-menu-btn{padding:12px;margin-right:4px;border-radius:50%;cursor:pointer;color:#5f6368}.header-menu-btn:hover{background-color:#f1f3f4}.header-logo{display:flex;align-items:center;font-size:22px;color:#5f6368;font-weight:400}.header-logo img{height:32px;width:32px;margin-right:8px}.search-bar{flex:1;max-width:720px;background:#f1f3f4;border-radius:8px;padding:8px 16px;height:48px;display:flex;align-items:center;color:#5f6368;gap:12px}.search-bar input{border:none;background:transparent;flex:1;margin-left:12px;font-size:16px;outline:none;color:#202124}.search-bar .material-icons{color:#5f6368;font-size:20px}.header-right{display:flex;align-items:center;gap:8px;margin-left:auto}.header-right .material-icons{cursor:pointer;padding:8px;border-radius:50%;color:#5f6368}.header-right .material-icons:hover{background-color:#3c404314}.user-avatar{width:32px;height:32px;border-radius:50%;background-color:#1a73e8;color:#fff;display:flex;align-items:center;justify-content:center;font-weight:500;cursor:pointer}.template-gallery{background-color:#f9f9f9;padding:24px 64px;border-bottom:1px solid #e8eaed}.gallery-content{max-width:1200px;margin:0 auto}.gallery-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;font-size:14px;color:#202124}.gallery-options{display:flex;align-items:center;gap:4px;color:#1a73e8;cursor:pointer;font-size:14px}.gallery-options:hover{text-decoration:underline}.template-cards{display:flex;gap:16px}.template-card{cursor:pointer;transition:transform .2s}.template-card:hover{transform:translateY(-2px)}.card-preview{width:120px;height:140px;background-color:#fff;border:1px solid #dadce0;border-radius:4px;display:flex;align-items:center;justify-content:center;margin-bottom:8px;transition:border-color .2s}.card-preview:hover{border-color:#1a73e8}.plus-icon{color:#ea4335;background:linear-gradient(to bottom right,#1a73e8 0% 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;font-size:48px;background-clip:text}.card-title{font-size:14px;color:#202124;font-weight:500;text-align:center}.file-list-section{flex:1;overflow-y:auto;padding:24px 64px}.file-list-content{max-width:1000px;margin:0 auto;padding:0 16px}.file-list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;font-size:14px;color:#202124;font-weight:500}.view-options{display:flex;align-items:center;gap:16px;color:#5f6368;font-size:13px;font-weight:400}.view-options .material-icons{font-size:20px;cursor:pointer;padding:4px;border-radius:4px}.view-options .material-icons:hover{background-color:#3c404314}.list-header{display:flex;align-items:center;padding:8px 0;font-size:14px;color:#202124;font-weight:500;border-bottom:1px solid #e8eaed}.list-header-name{flex:1}.list-header-owner,.list-header-date{width:150px}.file-grid{display:flex;gap:24px;padding:16px 0;overflow-x:auto;overflow-y:hidden;max-width:100%}.file-grid::-webkit-scrollbar{height:8px}.file-grid::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.file-grid::-webkit-scrollbar-thumb{background:#888;border-radius:4px}.file-grid::-webkit-scrollbar-thumb:hover{background:#555}.file-card{border:1px solid #dadce0;border-radius:8px;cursor:pointer;transition:box-shadow .2s,border-color .2s;background:#fff;overflow:hidden;min-width:180px;max-width:180px;flex-shrink:0}.file-card:hover{box-shadow:0 1px 3px #3c40434d,0 4px 8px #3c404326;border-color:#dadce0}.file-card-preview{height:120px;background-color:#f8f9fa;display:flex;align-items:center;justify-content:center;border-bottom:1px solid #e8eaed}.file-icon-large{font-size:48px;opacity:.6}.file-card-info{padding:12px 16px}.file-name{font-size:14px;color:#202124;font-weight:400;margin-bottom:8px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.file-meta{display:flex;align-items:center;font-size:12px;color:#5f6368;gap:6px}.more-vert{margin-left:auto;font-size:18px;color:#5f6368;padding:4px;border-radius:50%}.more-vert:hover{background-color:#3c404314}.drag-overlay{position:fixed;inset:0;background-color:#1a73e8f2;z-index:1000;display:flex;align-items:center;justify-content:center;pointer-events:none}.drag-message{color:#fff;font-size:24px;display:flex;flex-direction:column;align-items:center;font-weight:400}.file-row{display:flex;align-items:center;padding:12px 16px;border-bottom:1px solid #e8eaed;cursor:pointer;transition:background-color .1s}.file-row:hover{background-color:#f1f3f4}.file-icon{color:#1a73e8;margin-right:16px}.file-name{flex:1;font-size:14px;color:#202124;font-weight:500}.file-owner,.file-date{width:150px;font-size:13px;color:#5f6368}.menu-overlay{position:fixed;inset:0;z-index:999}.file-menu-popup{background:#fff;border-radius:4px;box-shadow:0 2px 10px #0003;z-index:1000;min-width:160px;padding:8px 0}.file-menu-popup .menu-item{display:flex;align-items:center;gap:12px;padding:10px 16px;cursor:pointer;font-size:14px;color:#202124;transition:background-color .1s}.file-menu-popup .menu-item:hover{background-color:#f1f3f4}.file-menu-popup .menu-item .material-icons{font-size:20px;color:#5f6368}.file-menu-btn{position:absolute;top:8px;right:8px;color:#5f6368;opacity:0;padding:4px;border-radius:50%;transition:opacity .2s,background-color .2s;z-index:10}.file-card{position:relative}.file-card:hover .file-menu-btn{opacity:1}.file-menu-btn:hover{background-color:#3c404314}.loading-spinner{width:40px;height:40px;border:4px solid #f3f3f3;border-top:4px solid #1a73e8;border-radius:50%;animation:spin 1s linear infinite}.loading-spinner-large{width:60px;height:60px;border:6px solid #f3f3f3;border-top:6px solid #1a73e8;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-overlay{position:fixed;inset:0;background-color:#ffffffe6;display:flex;align-items:center;justify-content:center;z-index:2000}.rename-dialog{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:#fff;border-radius:8px;box-shadow:0 4px 16px #0003;padding:24px;z-index:1001;min-width:400px}.rename-dialog h3{margin:0 0 16px;font-size:18px;font-weight:500;color:#202124}.rename-dialog input{width:100%;padding:12px;border:1px solid #dadce0;border-radius:4px;font-size:14px;margin-bottom:20px;box-sizing:border-box}.rename-dialog input:focus{outline:none;border-color:#1a73e8}.dialog-buttons{display:flex;justify-content:flex-end;gap:8px}.dialog-buttons button{padding:8px 24px;border:none;border-radius:4px;font-size:14px;cursor:pointer;font-weight:500;transition:background-color .2s}.dialog-buttons button:first-child{background:transparent;color:#1a73e8}.dialog-buttons button:first-child:hover{background-color:#1a73e814}.dialog-buttons button.primary{background-color:#1a73e8;color:#fff}.dialog-buttons button.primary:hover{background-color:#1557b0}.login-container{display:flex;align-items:center;justify-content:center;height:100vh;background-color:#f0f2f5;font-family:Roboto,sans-serif}.login-card{background:#fff;padding:40px;border-radius:8px;box-shadow:0 2px 4px #0000001a,0 8px 16px #0000001a;width:100%;max-width:400px;text-align:center}.login-logo{margin-bottom:24px}.login-logo .material-icons{font-size:48px;color:#1a73e8}.login-title{font-size:24px;color:#202124;margin-bottom:8px;font-weight:500}.login-subtitle{font-size:16px;color:#5f6368;margin-bottom:32px}.login-form{display:flex;flex-direction:column;gap:16px}.form-group{text-align:left}.form-input{width:100%;padding:12px;border:1px solid #dadce0;border-radius:4px;font-size:16px;box-sizing:border-box;transition:border-color .2s}.form-input:focus{border-color:#1a73e8;outline:none}.password-group{position:relative}.password-toggle-btn{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:#5f6368;padding:4px;display:flex;align-items:center;justify-content:center}.password-toggle-btn:hover{color:#202124}.password-toggle-btn .material-icons{font-size:20px}.login-btn{background-color:#1a73e8;color:#fff;border:none;padding:12px;border-radius:4px;font-size:16px;font-weight:500;cursor:pointer;transition:background-color .2s;margin-top:16px}.login-btn:hover{background-color:#1557b0}.login-btn:disabled{background-color:#dadce0;cursor:not-allowed}.error-message{color:#d93025;font-size:14px;margin-top:16px;display:flex;align-items:center;justify-content:center;gap:8px}.forgot-pass-container{text-align:left;margin-top:-8px}.forgot-pass-link{color:#1a73e8;font-size:14px;font-weight:500;cursor:pointer;text-decoration:none}.forgot-pass-link:hover{text-decoration:underline}.modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#fff;padding:24px;border-radius:8px;width:100%;max-width:400px;box-shadow:0 4px 20px #00000026}.modal-content h2{margin:0 0 16px;font-size:20px;color:#202124}.modal-content p{margin:0 0 24px;font-size:14px;color:#5f6368;line-height:1.5}.modal-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:24px}.cancel-btn{background:transparent;color:#1a73e8;border:none;padding:8px 16px;border-radius:4px;font-size:14px;font-weight:500;cursor:pointer}.cancel-btn:hover{background-color:#1a73e80a}.submit-btn{background-color:#1a73e8;color:#fff;border:none;padding:8px 24px;border-radius:4px;font-size:14px;font-weight:500;cursor:pointer}.submit-btn:hover{background-color:#1557b0}.submit-btn:disabled{background-color:#dadce0;cursor:not-allowed}.message{margin-top:12px;font-size:14px;padding:8px;border-radius:4px}.message.success{background-color:#e6f4ea;color:#137333}.message.error{background-color:#fce8e6;color:#c5221f}.app-container{display:flex;flex-direction:column;height:100%}
