:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light;color:#213547;background-color:#fff;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;min-width:320px;min-height:100vh}#root{min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#f9f9f9;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}*{box-sizing:border-box}.app-container{display:flex;flex-direction:column;height:100vh;overflow:hidden}.app-header{background:linear-gradient(135deg,#1a1a1a,#0f0f0f);color:#fff;padding:1rem 2rem;border-bottom:1px solid #2a2a2a;flex-shrink:0;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:1000;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.app-header h1{margin:0;font-size:1.5rem;font-weight:700;background:linear-gradient(135deg,#fff,#a0a0a0);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.header-user{display:flex;align-items:center;gap:1rem}.user-email{font-size:.9rem;color:#999}.logout-button{padding:.5rem 1rem;background-color:transparent;color:#fff;border:1px solid #3a3a3a;border-radius:6px;cursor:pointer;font-size:.9rem;font-weight:500;transition:all .2s ease}.logout-button:hover{background-color:#2a2a2a;border-color:#fff}.login-button{padding:.6rem 1.5rem;background-color:#fff;color:#0a0a0a;border:none;border-radius:6px;cursor:pointer;font-size:.9rem;font-weight:600;transition:all .2s ease;box-shadow:0 2px 10px #ffffff1a}.login-button:hover{transform:translateY(-1px);box-shadow:0 4px 15px #fff3}.app-layout{display:flex;flex:1;overflow:hidden}.sidebar{width:350px;background:linear-gradient(180deg,#0f0f0f,#1a1a1a);border-right:1px solid #2a2a2a;display:flex;flex-direction:column;transition:width .3s ease;position:relative;flex-shrink:0}.sidebar.collapsed{width:50px}.sidebar-toggle{position:absolute;top:10px;right:10px;width:30px;height:30px;background-color:#1a1a1a;border:1px solid #3a3a3a;border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1rem;color:#fff;z-index:10;transition:all .2s ease}.sidebar-toggle:hover{background-color:#2a2a2a;border-color:#fff}.sidebar-content{flex:1;overflow-y:auto;padding:3rem 1.5rem 1.5rem}.sidebar-section{margin-bottom:2rem}.sidebar-section h3{margin:0 0 1rem;font-size:1rem;color:#fff;font-weight:600}.section-header-with-button{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.section-header-with-button h3{margin:0}.reset-button,.upload-new-button{padding:.4rem .75rem;color:#fff;border:none;border-radius:4px;font-size:.8rem;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap}.reset-button{background:linear-gradient(135deg,#d97706,#b45309)}.reset-button:hover{background:linear-gradient(135deg,#b45309,#92400e);transform:scale(1.05)}.reset-button:active{transform:scale(.98)}.upload-new-button{background:linear-gradient(135deg,#d97706,#b45309)}.upload-new-button:hover{background:linear-gradient(135deg,#b45309,#92400e);transform:scale(1.05)}.upload-new-button:active{transform:scale(.98)}.upload-new-button-large{width:100%;padding:1rem 1.5rem;background:linear-gradient(135deg,#d97706,#b45309);color:#fff;border:none;border-radius:8px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 8px #d977064d;display:flex;align-items:center;justify-content:center;gap:.5rem}.upload-new-button-large:hover{background:linear-gradient(135deg,#b45309,#92400e);transform:translateY(-2px);box-shadow:0 4px 12px #d9770666}.upload-new-button-large:active{transform:translateY(0)}.upload-center{display:flex;align-items:center;justify-content:center;min-height:100%;padding:2rem;overflow-y:auto}.upload-center .file-upload{max-width:600px;width:100%}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000b3;display:flex;align-items:center;justify-content:center;z-index:10000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-content{background-color:#fff;border-radius:12px;padding:2rem;max-width:600px;width:90%;max-height:90vh;overflow-y:auto;box-shadow:0 10px 40px #0000004d;position:relative;border:2px solid #d97706}.modal-close{position:absolute;top:1rem;right:1rem;background:transparent;border:none;font-size:1.5rem;cursor:pointer;color:#666;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s ease}.modal-close:hover{background-color:#f0f0f0;color:#333}.modal-title{margin:0 0 1.5rem;font-size:1.5rem;color:#333;font-weight:700}.main-content{flex:1;overflow:hidden;background:linear-gradient(135deg,#0a0a0a,#1a1a1a);padding:1.5rem;display:flex;flex-direction:column}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:#666}.empty-icon{font-size:4rem;margin-bottom:1rem}.empty-state h2{margin:0 0 .5rem;color:#999;font-size:1.5rem}.empty-state p{margin:0;color:#666}.generated-sql-container{margin-top:1.5rem;padding:1rem;background-color:#1a1a1a;border:2px solid #d97706;border-radius:8px;box-shadow:0 2px 8px #d9770626}.generated-sql-header{margin-bottom:.75rem;color:#fff;font-size:.85rem;font-weight:600;display:flex;align-items:center;justify-content:space-between;gap:.5rem}.validation-badge{font-size:.75rem;padding:.25rem .5rem;border-radius:4px;font-weight:600}.validation-badge.valid{background-color:#d1fae5;color:#065f46}.validation-badge.invalid{background-color:#fee2e2;color:#991b1b}.validation-warning{margin-bottom:1rem;padding:.75rem;background-color:#fef3c7;border-left:3px solid #f59e0b;border-radius:4px}.validation-warning strong{display:block;margin-bottom:.5rem;color:#92400e;font-size:.85rem}.validation-warning p{margin:0;color:#78350f;font-size:.8rem;line-height:1.4}.generated-sql-code{margin:0 0 1rem;padding:.75rem;background-color:#2d2d2d;color:#f8f8f2;border-radius:4px;font-family:Courier New,monospace;font-size:.75rem;overflow-x:auto;white-space:pre-wrap;word-break:break-all;line-height:1.5}.execute-sql-button{width:100%;padding:.75rem;background:linear-gradient(135deg,#ca8a04,#a16207);color:#fff;border:none;border-radius:6px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 4px #ca8a0433}.execute-sql-button:hover{background:linear-gradient(135deg,#a16207,#92400e);box-shadow:0 4px 8px #ca8a044d;transform:translateY(-1px)}.execute-sql-button:active{transform:translateY(0)}.collapsible-header{display:flex;justify-content:space-between;align-items:center;cursor:pointer;padding:.75rem;border-radius:6px;transition:background-color .2s ease;margin-bottom:.5rem}.collapsible-header:hover{background-color:#1a1a1a}.collapsible-header h3{margin:0;font-size:1rem;color:#fff;font-weight:600}.collapse-icon{font-size:.9rem;color:#d97706;transition:transform .2s ease;-webkit-user-select:none;user-select:none}.collapsible-content{margin-top:.5rem}.sidebar-contact{margin-top:auto;padding:1.5rem .75rem;border-top:1px solid #2a2a2a;text-align:center}.contact-text{margin:0 0 .5rem;font-size:.85rem;color:#999}.contact-email{display:inline-block;color:#d97706;text-decoration:none;font-size:.85rem;font-weight:500;transition:color .2s ease}.contact-email:hover{color:#b45309;text-decoration:underline}.file-upload{margin:0;padding:1rem;border:2px solid #d97706;border-radius:8px;background-color:#fff;box-shadow:0 2px 8px #d9770626}.upload-zone{border:2px dashed #ccc;border-radius:8px;padding:1.5rem 1rem;text-align:center;cursor:pointer;transition:all .3s ease;background-color:#fafafa}.upload-zone:hover{border-color:#d97706;background-color:#fef3e2}.upload-zone.dragging{border-color:#ca8a04;background-color:#fde8c7;transform:scale(1.02)}.upload-icon{width:64px;height:64px;display:block;margin:0 auto 1rem;color:#d97706;transition:all .3s ease}.upload-zone:hover .upload-icon{color:#ca8a04;transform:translateY(-4px)}.upload-prompt p{margin:.25rem 0;color:#333;font-size:.9rem}.upload-subtitle{font-size:.85rem;color:#666}.upload-limit{font-size:.75rem;color:#999;margin-top:.5rem}.file-selected{display:flex;align-items:center;justify-content:center;gap:1rem}.file-icon{font-size:2rem}.file-name{font-size:1.1rem;color:#ca8a04;font-weight:500}.load-button{margin-top:1rem;padding:.75rem 2rem;width:100%;background-color:#ca8a04;color:#fff;border:none;border-radius:6px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 4px #ca8a0433}.load-button:hover:not(:disabled){background-color:#a16207;transform:translateY(-2px);box-shadow:0 4px 12px #ca8a044d}.load-button:disabled{background-color:#ccc;cursor:not-allowed;transform:none}.progress-container{margin-top:1rem}.progress-bar{width:100%;height:8px;background-color:#e0e0e0;border-radius:4px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,#d97706,#ca8a04);transition:width .3s ease;border-radius:4px}.progress-text{margin-top:.5rem;text-align:center;font-size:.85rem;color:#ca8a04;font-weight:500}.upload-footer{margin-top:1.5rem;padding-top:1rem;border-top:1px solid #e0e0e0;text-align:center;font-size:.85rem;color:#666}.upload-footer a{color:#d97706;text-decoration:none;font-weight:600;transition:color .2s ease}.upload-footer a:hover{color:#b45309;text-decoration:underline}.data-table-container{margin:0;height:100%;display:flex;flex-direction:column}.table-info{margin-bottom:.75rem;color:#666;font-size:.85rem}.table-wrapper{flex:1;overflow:auto;border:2px solid #d97706;border-radius:8px;box-shadow:0 2px 8px #d9770626}.data-table{width:max-content;min-width:100%;border-collapse:collapse;background-color:#fff;font-size:.75rem;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}.data-table thead{position:sticky;top:0;background-color:#f8f9fa;z-index:10}.data-table th{padding:4px 8px;text-align:left;font-weight:600;font-size:.7rem;color:#333;border:1px solid #d0d0d0;border-right:1px solid #d0d0d0;white-space:nowrap;background-color:#f8f9fa;vertical-align:top}.row-number-header{width:45px;text-align:center!important;background-color:#e9ecef!important;font-weight:700;position:sticky;left:0;z-index:11;font-size:.65rem}.sortable-header{-webkit-user-select:none;user-select:none;transition:background-color .2s ease}.sortable-header:hover .header-content{background-color:#e9ecef}.header-content{display:flex;align-items:center;justify-content:space-between;gap:.3rem;cursor:pointer;padding:2px 4px;margin-bottom:4px;border-radius:3px;transition:background-color .2s ease}.column-filter{width:100%;padding:2px 6px;font-size:.65rem;border:1px solid #d0d0d0;border-radius:3px;background-color:#fff;color:#333;outline:none;transition:border-color .2s ease,box-shadow .2s ease}.column-filter:focus{border-color:#d97706;box-shadow:0 0 0 2px #d977061a}.column-filter::placeholder{color:#999;font-style:italic}.sort-icon{font-size:.6rem;color:#666;opacity:.6}.sortable-header:hover .sort-icon{opacity:1}.sort-info{color:#ca8a04;font-weight:500;font-size:.85rem}.data-table td{padding:3px 8px;border:1px solid #e0e0e0;border-right:1px solid #e0e0e0;white-space:nowrap;color:#2c3e50;font-size:.75rem;line-height:1.3}.row-number-cell{text-align:center;background-color:#f8f9fa;font-weight:600;color:#666;font-size:.65rem;position:sticky;left:0;z-index:5;border-right:2px solid #d0d0d0!important}.data-table tbody tr:hover{background-color:#f0f8ff}.data-table tbody tr:nth-child(2n){background-color:#fafafa}.data-table tbody tr:nth-child(2n):hover{background-color:#f0f8ff}.pagination-debug{text-align:center;margin-top:1rem;padding:.5rem;background-color:#fff3cd;border:1px solid #ffc107;border-radius:4px;font-size:.85rem;color:#856404}.pagination{display:flex;align-items:center;justify-content:center;gap:.5rem;margin-top:1.5rem;padding:1rem}.pagination-btn{padding:.5rem .75rem;background-color:#fff;border:1px solid #e0e0e0;border-radius:4px;cursor:pointer;font-size:1rem;transition:all .2s ease;min-width:40px}.pagination-btn:hover:not(:disabled){border-color:#d97706;color:#d97706;background-color:#fef3e2}.pagination-btn:disabled{cursor:not-allowed;opacity:.4;background-color:#f5f5f5}.pagination-info{margin:0 1rem;font-size:.9rem;color:#666;font-weight:500}.table-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem;padding:.5rem 0}.table-actions{display:flex;align-items:center;gap:.5rem}.export-dropdown{position:relative}.export-menu{position:absolute;top:100%;right:0;margin-top:.5rem;background:#fff;border:2px solid #d97706;border-radius:6px;box-shadow:0 4px 12px #00000026;z-index:1000;min-width:160px;overflow:hidden}.export-menu-item{width:100%;padding:.75rem 1rem;background:#fff;border:none;text-align:left;cursor:pointer;font-size:.9rem;display:flex;align-items:center;gap:.5rem;transition:background-color .2s ease;color:#333}.export-menu-item:hover{background-color:#fef3e2}.export-menu-item span{font-size:1.1rem}.column-menu{position:absolute;top:100%;right:0;margin-top:.5rem;background:#fff;border:2px solid #d97706;border-radius:6px;box-shadow:0 4px 12px #00000026;z-index:1000;min-width:200px;max-height:400px;display:flex;flex-direction:column}.column-menu-header{padding:.75rem 1rem;border-bottom:1px solid #e0e0e0;background-color:#fef3e2;display:flex;flex-direction:column;gap:.5rem}.column-menu-header strong{color:#333;font-size:.9rem}.column-menu-actions{display:flex;gap:.5rem}.column-toggle-all{padding:.25rem .5rem;background:#fff;border:1px solid #d97706;border-radius:4px;cursor:pointer;font-size:.75rem;color:#d97706;transition:all .2s ease}.column-toggle-all:hover{background-color:#d97706;color:#fff}.column-menu-list{overflow-y:auto;max-height:320px}.column-menu-item{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;cursor:pointer;transition:background-color .2s ease;font-size:.85rem;color:#333}.column-menu-item:hover{background-color:#fef3e2}.column-menu-item input[type=checkbox]{cursor:pointer;width:16px;height:16px;accent-color:#d97706}.column-menu-item span{-webkit-user-select:none;user-select:none}.table-column-button{padding:.5rem .75rem;background-color:#d97706;border:none;border-radius:6px;cursor:pointer;transition:all .2s ease;color:#fff;min-width:44px;height:44px;display:flex;align-items:center;justify-content:center}.table-column-button svg{width:20px;height:20px}.table-column-button:hover{background-color:#b45309;transform:scale(1.05)}.table-export-button{padding:.5rem .75rem;background-color:#d97706;border:none;border-radius:6px;cursor:pointer;transition:all .2s ease;color:#fff;min-width:44px;height:44px;display:flex;align-items:center;justify-content:center}.table-export-button svg{width:20px;height:20px}.table-export-button:hover{background-color:#b45309;transform:scale(1.05)}.table-reset-button{padding:.5rem .75rem;background-color:#d97706;border:none;border-radius:6px;cursor:pointer;transition:all .2s ease;color:#fff;min-width:44px;height:44px;display:flex;align-items:center;justify-content:center}.table-reset-button svg{width:20px;height:20px}.table-reset-button:hover{background-color:#b45309;transform:scale(1.05)}.fullscreen-button{padding:.5rem .75rem;background-color:#fff;border:2px solid #d97706;border-radius:6px;cursor:pointer;font-size:1.2rem;transition:all .2s ease;color:#d97706;min-width:44px;height:44px;display:flex;align-items:center;justify-content:center}.fullscreen-button:hover{background-color:#d97706;color:#fff;transform:scale(1.05)}.data-table-container.fullscreen{position:fixed;top:0;left:0;width:100vw;height:100vh;z-index:9999;background-color:#fff;padding:1rem;display:flex;flex-direction:column}.data-table-container.fullscreen .table-wrapper{flex:1;overflow:auto;margin-bottom:1rem}.data-table-container.fullscreen .pagination{margin-top:auto}.query-interface{margin:0;padding:1rem;background-color:#fff;border:2px solid #d97706;border-radius:8px;box-shadow:0 2px 8px #d9770626}.mode-selector{display:flex;gap:.5rem;margin-bottom:1rem}.mode-button{flex:1;padding:.6rem;background-color:#fff;color:#666;border:2px solid #e0e0e0;border-radius:6px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s ease}.mode-button:hover{border-color:#d97706;color:#d97706}.mode-button.active{background-color:#ca8a04;color:#fff;border-color:#ca8a04}.query-interface h2{margin:0 0 .25rem;font-size:1rem;color:#333;font-weight:600}.query-subtitle{margin:0 0 1rem;font-size:.85rem;color:#666}.ai-queries-badge{margin-bottom:1rem;padding:.6rem 1rem;background-color:#f0f9ff;border:1px solid #bfdbfe;border-radius:6px;display:flex;align-items:center;justify-content:center}.queries-remaining{font-size:.85rem;font-weight:600;color:#1e40af}.query-form{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.5rem}.query-input{width:100%;padding:.75rem 1rem;border:2px solid #e0e0e0;border-radius:6px;font-size:.9rem;font-family:inherit;resize:vertical;min-height:60px;transition:border-color .3s ease}.query-input:focus{outline:none;border-color:#d97706}.query-input:disabled{background-color:#f5f5f5;cursor:not-allowed}.query-button{width:100%;padding:.75rem 1.5rem;background-color:#ca8a04;color:#fff;border:none;border-radius:6px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 4px #ca8a0433}.query-button:hover:not(:disabled){background-color:#a16207;box-shadow:0 4px 8px #ca8a044d;transform:translateY(-1px)}.query-button:disabled{background-color:#ccc;cursor:not-allowed;box-shadow:none}.example-queries{margin-top:1rem}.example-queries>p{margin:0 0 .5rem;font-size:.9rem;color:#666}.examples{display:flex;flex-wrap:wrap;gap:.5rem}.example-button{padding:.5rem 1rem;background-color:#fff;border:1px solid #e0e0e0;border-radius:6px;font-size:.85rem;cursor:pointer;transition:all .2s ease}.example-button:hover:not(:disabled){border-color:#646cff;color:#646cff;background-color:#f0f0ff}.example-button:disabled{cursor:not-allowed;opacity:.5}.chart-generator{background:#fff;border:2px solid #d97706;border-radius:8px;padding:1.5rem;margin-bottom:1.5rem}.chart-generator h3{margin:0 0 1.5rem;color:#333;font-size:1.1rem;font-weight:600}.chart-config{display:flex;flex-direction:column;gap:1rem}.chart-config-row{display:flex;flex-direction:column;gap:.5rem}.chart-config-row label{font-weight:600;font-size:.9rem;color:#555}.chart-type-buttons{display:flex;gap:.5rem}.chart-type-buttons button{flex:1;padding:.75rem 1rem;background:#fff;border:2px solid #e0e0e0;border-radius:6px;cursor:pointer;font-size:.9rem;transition:all .2s ease;color:#333;font-weight:500}.chart-type-buttons button:hover{border-color:#d97706;background-color:#fef3e2}.chart-type-buttons button.active{border-color:#d97706;background-color:#d97706;color:#fff}.chart-config-row select{padding:.75rem;border:2px solid #e0e0e0;border-radius:6px;font-size:.9rem;background:#fff;color:#333;cursor:pointer;transition:border-color .2s ease}.chart-config-row select:focus{outline:none;border-color:#d97706}.chart-config-actions{display:flex;gap:.75rem;margin-top:.5rem}.generate-chart-btn,.export-chart-btn{padding:.75rem 1.5rem;border:none;border-radius:6px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s ease}.generate-chart-btn{background:#d97706;color:#fff;flex:1}.generate-chart-btn:hover{background:#b45309;transform:translateY(-2px);box-shadow:0 4px 12px #d977064d}.export-chart-btn{background:#fff;color:#d97706;border:2px solid #d97706}.export-chart-btn:hover{background:#fef3e2;transform:translateY(-2px)}.chart-display{margin-top:2rem;padding:1.5rem;background:#fafafa;border-radius:8px;border:1px solid #e0e0e0}.chart-title{font-size:1.1rem;font-weight:600;color:#333;margin-bottom:1.5rem;text-align:center;text-transform:capitalize}.chart-empty{text-align:center;padding:3rem;color:#999;font-size:1rem}.chart-info{margin-top:1rem;text-align:center;font-size:.85rem;color:#666;font-style:italic}.chart-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:10000;padding:2rem}.chart-modal-content{background:#fff;border-radius:12px;max-width:1400px;width:100%;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d}.chart-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;border-bottom:2px solid #e0e0e0;background:#fafafa;border-radius:12px 12px 0 0}.chart-modal-title{margin:0;font-size:1.3rem;font-weight:600;color:#333;text-transform:capitalize}.chart-modal-actions{display:flex;gap:1rem;align-items:center}.chart-modal-close{background:transparent;border:none;font-size:1.8rem;color:#666;cursor:pointer;padding:.25rem .5rem;transition:color .2s ease;line-height:1}.chart-modal-close:hover{color:#d97706}.chart-modal-body{flex:1;padding:2rem;overflow:auto;background:#fff}@media (max-width: 768px){.chart-type-buttons,.chart-config-actions{flex-direction:column}.generate-chart-btn,.export-chart-btn{width:100%}.chart-modal-overlay{padding:1rem}.chart-modal-header{flex-direction:column;gap:1rem;align-items:flex-start}.chart-modal-title{font-size:1.1rem}.chart-modal-body{padding:1rem}}.pivot-table-generator{background:#fff;border:2px solid #d97706;border-radius:8px;padding:1.5rem;margin-bottom:1.5rem}.pivot-table-generator h3{margin:0 0 1.5rem;color:#333;font-size:1.1rem;font-weight:600}.pivot-config{display:flex;flex-direction:column;gap:1rem}.pivot-config-row{display:flex;flex-direction:column;gap:.5rem}.pivot-config-row label{font-weight:600;font-size:.9rem;color:#555}.pivot-config-row select{padding:.75rem;border:2px solid #e0e0e0;border-radius:6px;font-size:.9rem;background:#fff;color:#333;cursor:pointer;transition:border-color .2s ease}.pivot-config-row select:focus{outline:none;border-color:#d97706}.pivot-config-actions{display:flex;gap:.75rem;margin-top:.5rem}.generate-pivot-btn{padding:.75rem 1.5rem;border:none;border-radius:6px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s ease;background:#d97706;color:#fff;flex:1}.generate-pivot-btn:hover{background:#b45309;transform:translateY(-2px);box-shadow:0 4px 12px #d977064d}.pivot-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:10000;padding:2rem}.pivot-modal-content{background:#fff;border-radius:12px;max-width:1400px;width:100%;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d}.pivot-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;border-bottom:2px solid #e0e0e0;background:#fafafa;border-radius:12px 12px 0 0}.pivot-modal-title{margin:0;font-size:1.3rem;font-weight:600;color:#333}.pivot-modal-actions{display:flex;gap:1rem;align-items:center}.ai-analysis-btn{padding:.75rem 1.5rem;background:#10b981;color:#fff;border:none;border-radius:6px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s ease}.ai-analysis-btn:hover:not(:disabled){background:#059669;transform:translateY(-2px)}.ai-analysis-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.export-pivot-btn{padding:.75rem 1.5rem;background:#fff;color:#d97706;border:2px solid #d97706;border-radius:6px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s ease}.export-pivot-btn:hover{background:#fef3e2;transform:translateY(-2px)}.pivot-modal-close{background:transparent;border:none;font-size:1.8rem;color:#666;cursor:pointer;padding:.25rem .5rem;transition:color .2s ease;line-height:1}.pivot-modal-close:hover{color:#d97706}.pivot-modal-body{flex:1;padding:2rem;overflow:auto;background:#fff}.pivot-table-wrapper{overflow:auto;border:2px solid #e0e0e0;border-radius:8px}.pivot-table{width:100%;border-collapse:collapse;background:#fff;font-size:.85rem}.pivot-table thead{background:#f8f9fa;position:sticky;top:0;z-index:10}.pivot-table th{padding:.75rem 1rem;text-align:left;font-weight:600;color:#333;border:1px solid #d0d0d0;white-space:nowrap;background:#f8f9fa}.pivot-row-header{background:#e9ecef!important;font-weight:700;position:sticky;left:0;z-index:11}.pivot-table tbody tr:hover{background-color:#f0f8ff}.pivot-table tbody tr:nth-child(2n){background-color:#fafafa}.pivot-table tbody tr:nth-child(2n):hover{background-color:#f0f8ff}.pivot-table td{padding:.5rem 1rem;border:1px solid #e0e0e0;white-space:nowrap;color:#2c3e50}.pivot-row-label{font-weight:600;background-color:#f8f9fa;position:sticky;left:0;z-index:5;border-right:2px solid #d0d0d0!important}.pivot-value{text-align:right;font-family:Courier New,monospace;font-size:.85rem}.pivot-info{margin-top:1rem;text-align:center;font-size:.85rem;color:#666;font-style:italic}.ai-analysis-section{margin-top:2rem;padding:1.5rem;background:#f0fdf4;border:2px solid #10b981;border-radius:8px}.ai-analysis-title{margin:0 0 1rem;font-size:1.1rem;font-weight:600;color:#065f46}.ai-analysis-content{background:#fff;border-radius:6px;padding:1.5rem;box-shadow:0 1px 3px #0000001a}.ai-analysis-text{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-size:.9rem;line-height:1.6;color:#1f2937;white-space:pre-wrap;word-wrap:break-word}@media (max-width: 768px){.pivot-modal-overlay{padding:1rem}.pivot-modal-header{flex-direction:column;gap:1rem;align-items:flex-start}.pivot-modal-title{font-size:1.1rem}.pivot-modal-body{padding:1rem}.pivot-table{font-size:.75rem}}.landing{min-height:100vh;background:#0a0a0a;color:#fff;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;overflow-y:auto;overflow-x:hidden}.landing-header{background:#1a1a1a;border-bottom:1px solid #2a2a2a;padding:1.5rem 0;position:sticky;top:0;z-index:1000;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.header-content{max-width:1200px;margin:0 auto;padding:0 2rem;display:flex;justify-content:space-between;align-items:center}.logo{font-size:1.5rem;font-weight:700;margin:0;background:linear-gradient(135deg,#fff,#a0a0a0);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.header-cta{background:transparent;border:1px solid #3a3a3a;color:#fff;padding:.6rem 1.5rem;border-radius:6px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease}.header-cta:hover{background:#2a2a2a;border-color:#fff}.hero{padding:8rem 2rem;text-align:center;background:radial-gradient(ellipse at center,#1a1a1a,#0a0a0a 70%)}.hero-content{max-width:900px;margin:0 auto}.hero-title{font-size:4rem;font-weight:800;line-height:1.1;margin:0 0 1.5rem;letter-spacing:-.02em}.hero-highlight{background:linear-gradient(135deg,#fff,#666);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-subtitle{font-size:1.25rem;color:#999;line-height:1.6;margin:0 0 2.5rem;max-width:700px;margin-left:auto;margin-right:auto}.hero-cta{background:#fff;color:#0a0a0a;border:none;padding:1rem 3rem;font-size:1.1rem;font-weight:600;border-radius:8px;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 20px #ffffff1a}.hero-cta:hover{transform:translateY(-2px);box-shadow:0 6px 30px #fff3}.hero-note{margin-top:1rem;font-size:.9rem;color:#666}.how-it-works{padding:6rem 2rem;background:#0a0a0a}.section-title{text-align:center;font-size:2.5rem;font-weight:700;margin:0 0 4rem;background:linear-gradient(135deg,#fff,#999);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.steps{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:3rem}.step{background:#1a1a1a;border:1px solid #2a2a2a;border-radius:12px;padding:2.5rem;transition:all .3s ease}.step:hover{background:#1f1f1f;border-color:#3a3a3a;transform:translateY(-4px)}.step-number{width:60px;height:60px;background:linear-gradient(135deg,#2a2a2a,#1a1a1a);border:2px solid #3a3a3a;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:700;margin-bottom:1.5rem;color:#fff}.step-title{font-size:1.5rem;font-weight:600;margin:0 0 1rem;color:#fff}.step-description{color:#999;line-height:1.6;margin:0;font-size:1rem}.features{padding:6rem 2rem;background:#0f0f0f}.feature-grid{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2rem}.feature{background:#1a1a1a;border:1px solid #2a2a2a;border-radius:10px;padding:2rem;transition:all .3s ease}.feature:hover{background:#1f1f1f;border-color:#3a3a3a;transform:translateY(-2px)}.feature-icon{font-size:3rem;margin-bottom:1rem}.feature-title{font-size:1.25rem;font-weight:600;margin:0 0 .75rem;color:#fff}.feature-description{color:#999;line-height:1.5;margin:0;font-size:.95rem}.cta-section{padding:6rem 2rem;background:radial-gradient(ellipse at center,#1a1a1a,#0a0a0a 70%);text-align:center}.cta-content{max-width:700px;margin:0 auto}.cta-title{font-size:2.5rem;font-weight:700;margin:0 0 1rem;color:#fff}.cta-subtitle{font-size:1.2rem;color:#999;margin:0 0 2.5rem}.cta-button{background:#fff;color:#0a0a0a;border:none;padding:1rem 3rem;font-size:1.1rem;font-weight:600;border-radius:8px;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 20px #ffffff1a}.cta-button:hover{transform:translateY(-2px);box-shadow:0 6px 30px #fff3}.landing-footer{background:#0a0a0a;border-top:1px solid #2a2a2a;padding:2rem;text-align:center}.footer-text{color:#666;font-size:.9rem;margin:0}@media (max-width: 768px){.hero-title{font-size:2.5rem}.hero-subtitle{font-size:1.1rem}.steps,.feature-grid{grid-template-columns:1fr}.section-title,.cta-title{font-size:2rem}}.auth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#0a0a0a;padding:2rem;position:relative}.auth-card{background:#1a1a1a;border:1px solid #2a2a2a;padding:2.5rem;border-radius:12px;box-shadow:0 10px 40px #00000080;width:100%;max-width:400px}.back-button{position:absolute;top:2rem;left:2rem;background:transparent;border:1px solid #3a3a3a;color:#999;padding:.6rem 1rem;border-radius:6px;font-size:.9rem;cursor:pointer;transition:all .2s ease;z-index:10}.back-button:hover:not(:disabled){border-color:#fff;color:#fff;background-color:#2a2a2a}.back-button:disabled{opacity:.5;cursor:not-allowed}.auth-card h2{margin:0 0 1.5rem;text-align:center;color:#fff;font-size:1.75rem;font-weight:700}.auth-error{background-color:#2a1a1a;color:#ff6b6b;padding:.75rem;border-radius:6px;margin-bottom:1.5rem;font-size:.9rem;border-left:3px solid #dc2626}.form-group{margin-bottom:1.25rem}.form-group label{display:block;margin-bottom:.5rem;color:#ccc;font-weight:500;font-size:.9rem}.form-group input{width:100%;padding:.75rem;background-color:#0f0f0f;color:#fff;border:2px solid #2a2a2a;border-radius:6px;font-size:1rem;transition:border-color .2s ease}.form-group input::placeholder{color:#666}.form-group input:focus{outline:none;border-color:#fff;background-color:#1a1a1a}.form-group input:disabled{background-color:#0a0a0a;cursor:not-allowed;opacity:.5}.auth-button{width:100%;padding:.875rem;background:#fff;color:#0a0a0a;border:none;border-radius:6px;font-size:1rem;font-weight:600;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease;margin-top:.5rem}.auth-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 20px #fff3}.auth-button:disabled{opacity:.6;cursor:not-allowed}.auth-divider{display:flex;align-items:center;margin:1.5rem 0;color:#666;font-size:.85rem}.auth-divider:before,.auth-divider:after{content:"";flex:1;border-bottom:1px solid #2a2a2a}.auth-divider span{padding:0 1rem}.google-button{width:100%;padding:.875rem;background:#1a1a1a;color:#fff;border:2px solid #3a3a3a;border-radius:6px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:.75rem}.google-button:hover:not(:disabled){border-color:#fff;background-color:#2a2a2a}.google-button:disabled{opacity:.6;cursor:not-allowed}.google-icon{flex-shrink:0}.auth-link{text-align:center;margin-top:1.5rem;color:#999;font-size:.9rem}.auth-link a{color:#fff;text-decoration:none;font-weight:600;transition:color .2s ease}.auth-link a:hover{color:#ccc;text-decoration:underline}
