.email-verification{margin-bottom:30px}.email-label{display:block;font-weight:600;margin-bottom:8px;color:#333;font-size:1rem}.email-input-container{display:flex;gap:8px;align-items:stretch}.email-input{flex:1;padding:12px 16px;font-size:1rem;border:2px solid #e0e0e0;border-radius:8px;transition:all .3s ease;background-color:#fff}.email-input:focus{outline:none;border-color:#6c757d;box-shadow:0 0 0 3px #6c757d1a}.email-input.valid{border-color:#28a745}.email-input.invalid{border-color:#dc3545}.email-input:disabled{background-color:#f5f5f5;cursor:not-allowed}.validation-message{margin-top:8px;font-size:.9rem;padding:8px 12px;border-radius:6px}.validation-message.validating{color:#007bff;background-color:#e7f3ff}.validation-message.success{color:#155724;background-color:#d4edda;border:1px solid #c3e6cb}.validation-message.error{color:#721c24;background-color:#f8d7da;border:1px solid #f5c6cb}.email-submit-button{padding:10px 16px;background-color:#6c757d;color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:background-color .3s ease;min-width:45px;display:flex;align-items:center;justify-content:center}.email-submit-button:hover:not(:disabled){background-color:#5a6268}.email-submit-button:disabled{background-color:#c6c8ca;cursor:not-allowed;opacity:.6}.database-connection{margin-bottom:20px;padding:0;background:transparent}.section-title{font-size:1rem;margin-bottom:15px;color:#333;border-bottom:1px solid #e0e0e0;padding-bottom:8px;font-weight:600}.db-connection-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;margin-bottom:20px}.db-field{display:flex;flex-direction:column}.db-field-wide{grid-column:span 2}.field-label{font-weight:600;margin-bottom:8px;color:#555;font-size:.95rem}.db-select,.db-input{padding:10px 12px;border:2px solid #e0e0e0;border-radius:6px;font-size:1rem;transition:all .3s ease;background-color:#fff}.db-select:focus,.db-input:focus{outline:none;border-color:#6c757d;box-shadow:0 0 0 3px #6c757d1a}.db-select:disabled,.db-input:disabled{background-color:#f5f5f5;cursor:not-allowed;opacity:.6}.db-help-text{margin-top:10px;padding:12px;background-color:#f8f9fa;border-left:4px solid #6c757d;border-radius:4px;font-size:.9rem;color:#555}.db-help-text code{display:block;margin-top:8px;padding:8px;background-color:#e9ecef;border-radius:4px;font-family:Courier New,monospace;font-size:.85rem}.tables-multiselect{display:flex;flex-wrap:wrap;gap:12px;padding:12px;border:2px solid #e0e0e0;border-radius:6px;min-height:60px;max-height:200px;overflow-y:auto;background-color:#fff}.table-checkbox{display:flex;align-items:center;gap:8px;padding:8px 12px;background-color:#f8f9fa;border-radius:6px;cursor:pointer;transition:all .2s ease;-webkit-user-select:none;user-select:none}.table-checkbox:hover{background-color:#e9ecef}.table-checkbox input[type=checkbox]{cursor:pointer;width:18px;height:18px}.table-checkbox input[type=checkbox]:checked+span{font-weight:600;color:#333}.table-checkbox:has(input:checked){background-color:#e9ecef;border:2px solid #6c757d}.error-message{padding:12px;background-color:#f8d7da;color:#721c24;border:1px solid #f5c6cb;border-radius:6px;margin-top:15px}.loading-message{padding:12px;color:#007bff;text-align:center;margin-top:15px}.table-previews{margin-top:20px;padding-top:15px;border-top:2px solid #e0e0e0}.preview-title{font-size:1rem;margin-bottom:12px;color:#333;font-weight:600}.table-preview{margin-bottom:15px;border:1px solid #e0e0e0;border-radius:8px;overflow:hidden}.table-preview-header{display:flex;justify-content:space-between;align-items:center;padding:10px 15px;background-color:#f8f9fa;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background-color .2s}.table-preview-header:hover{background-color:#e9ecef}.table-preview-header h5{font-size:.95rem;margin:0;color:#333;font-weight:600}.table-preview-toggle{font-size:.85rem;color:#6c757d}.table-preview-content{max-height:300px;overflow-y:auto;overflow-x:auto}.table-preview-content::-webkit-scrollbar{width:8px;height:8px}.table-preview-content::-webkit-scrollbar-track{background:#f1f1f1}.table-preview-content::-webkit-scrollbar-thumb{background:#888;border-radius:4px}.table-preview-content::-webkit-scrollbar-thumb:hover{background:#555}.table-preview-content.collapsed{display:none}.preview-table{overflow-x:auto;border:none}.preview-table table{width:100%;border-collapse:collapse;font-size:.85rem}.preview-table thead{background-color:#f8f9fa;position:sticky;top:0;z-index:1}.preview-table th{padding:8px 10px;text-align:left;font-weight:600;border-bottom:2px solid #dee2e6;color:#495057;white-space:nowrap}.preview-table td{padding:6px 10px;border-bottom:1px solid #e9ecef;white-space:nowrap}.preview-table tbody tr:hover{background-color:#f8f9fa}.loading-preview{padding:15px;text-align:center;color:#6c757d;font-size:.9rem}.chat-interface{display:flex;flex-direction:column;height:100%;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;overflow:hidden}.chat-header{padding:15px 20px;border-bottom:2px solid #e0e0e0;background:#fff;color:#333;flex-shrink:0}.chat-header h3{margin:0 0 5px;font-size:1.2rem}.chat-header p{margin:0;opacity:.9;font-size:.85rem}.chat-messages{flex:1;overflow-y:auto;overflow-x:hidden;padding:15px;background-color:#f8f9fa;min-height:0}.chat-messages::-webkit-scrollbar{width:8px}.chat-messages::-webkit-scrollbar-track{background:#f1f1f1}.chat-messages::-webkit-scrollbar-thumb{background:#888;border-radius:4px}.chat-messages::-webkit-scrollbar-thumb:hover{background:#555}.welcome-message{text-align:center;padding:40px 20px;color:#6c757d}.welcome-message p{margin:10px 0;font-size:1.1rem}.welcome-message .hint{font-size:.9rem;font-style:italic;color:#999}.message{margin-bottom:20px;display:flex}.message.user{justify-content:flex-end}.message.assistant{justify-content:flex-start}.message-content{max-width:95%;padding:12px 16px;border-radius:12px;box-sizing:border-box;overflow:hidden}.message.user .message-content{background-color:#e9ecef;color:#333;border-bottom-right-radius:4px}.message.assistant .message-content{background-color:#fff;color:#333;border:1px solid #e0e0e0;border-bottom-left-radius:4px}.message.assistant .message-content.loading-message{background-color:transparent!important;border:none!important;padding:4px 0!important}.user-message{margin:0;white-space:pre-wrap}.assistant-response{width:100%;max-width:100%;box-sizing:border-box;overflow:hidden}.response-grid{display:flex;flex-direction:column;gap:15px;width:100%;max-width:100%;box-sizing:border-box}.response-left{display:flex;flex-direction:column;gap:15px;width:100%;max-width:100%;box-sizing:border-box;overflow:hidden}.response-right{display:flex;flex-direction:column;width:100%;max-width:100%;box-sizing:border-box;overflow:hidden}.sql-query h4,.explanation h4,.data-table h4,.chart-container h4{margin:0 0 10px;font-size:1rem;color:#333;font-weight:600}.sql-query pre{background-color:#f8f9fa;padding:10px;border-radius:6px;border-left:4px solid #6c757d;overflow-x:auto;font-family:Courier New,monospace;font-size:.8rem;margin:0;white-space:pre-wrap;word-break:break-word}.explanation p{margin:0;line-height:1.6;color:#555}.table-container{overflow-x:auto;overflow-y:auto;max-height:300px;max-width:100%;border:1px solid #dee2e6;border-radius:6px;box-sizing:border-box}.table-container table{width:100%;border-collapse:collapse;font-size:.85rem;min-width:400px}.table-container thead{background-color:#f8f9fa}.table-container th{padding:10px 12px;text-align:left;font-weight:600;border-bottom:2px solid #dee2e6;color:#495057}.table-container td{padding:8px 12px;border-bottom:1px solid #dee2e6}.table-container tbody tr:hover{background-color:#f8f9fa}.chart-container{background-color:#fff;padding:15px;border-radius:8px;border:1px solid #e0e0e0;width:100%;max-width:100%;overflow:hidden;box-sizing:border-box;position:relative}.chart-container h4{margin:0 0 10px;font-size:1rem;color:#333;font-weight:600}.chart-container .js-plotly-plot{width:100%!important;max-width:100%!important;height:350px!important;overflow:hidden!important;position:relative}.chart-container .js-plotly-plot .plotly{width:100%!important;max-width:100%!important;overflow:hidden!important}.chart-container .js-plotly-plot svg{max-width:100%!important;overflow:hidden!important}.error-response{color:#555;padding:12px 16px;background-color:#fff;border-radius:6px;border:1px solid #e0e0e0}.upgrade-action{margin-top:12px}.upgrade-button-inline{padding:10px 20px;background-color:#6c757d;color:#fff;border:none;border-radius:6px;font-size:.95rem;font-weight:600;cursor:pointer;transition:background-color .3s ease}.upgrade-button-inline:hover{background-color:#5a6268}.loading-message{padding:4px 0;background:transparent!important;border:none!important;box-shadow:none!important}.loading-indicator{display:inline-flex;align-items:center;gap:6px;color:#999;font-size:.8rem;padding:0;background:transparent;font-style:italic;opacity:.8}.spinner{width:12px;height:12px;border:1.5px solid #e9ecef;border-top:1.5px solid #999;border-radius:50%;animation:spin .7s linear infinite;flex-shrink:0}.chat-placeholder{padding:40px;text-align:center;color:#6c757d;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a}.chat-input-container{display:flex;gap:10px;padding:15px 20px;border-top:2px solid #e0e0e0;background-color:#fff;flex-shrink:0}.chat-input{flex:1;padding:12px 16px;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;font-family:inherit;resize:none;transition:all .3s ease}.chat-input:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 3px #007bff1a}.chat-input:disabled{background-color:#f5f5f5;cursor:not-allowed}.send-button{padding:12px 24px;background-color:#6c757d;color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease}.send-button:hover:not(:disabled){background-color:#5a6268}.send-button:disabled{background-color:#6c757d;cursor:not-allowed;opacity:.6}@media (max-width: 768px){.response-grid{flex-direction:column}.message-content{max-width:95%}.chart-container{padding:10px}.chart-container .js-plotly-plot{height:300px!important}}.home-page{min-height:100vh;background:#f5f5f5;padding:0}.home-container{display:flex;gap:20px;max-width:1600px;margin:0 auto;padding:20px;height:calc(100vh - 80px)}.main-content{flex:0 0 45%;min-width:0;overflow-y:auto;background:#fff;border-radius:12px;padding:25px;box-shadow:0 2px 8px #0000001a}.chat-sidebar{flex:0 0 55%;min-width:550px;display:flex;flex-direction:column}@media (max-width: 1024px){.home-container{flex-direction:column;height:auto;min-height:calc(100vh - 80px)}.main-content{flex:1;overflow-y:visible}.chat-sidebar{flex:1;width:100%;min-width:100%;max-width:100%;height:600px}}@media (max-width: 768px){.home-container{padding:10px;gap:15px}.main-content{padding:15px}.chat-sidebar{height:500px}}.faq-page{min-height:100vh;background:#f5f5f5;padding:20px}.faq-container{max-width:900px;margin:0 auto;background:#fff;border-radius:16px;padding:40px;box-shadow:0 10px 40px #0003}.faq-header{text-align:center;margin-bottom:40px;padding-bottom:20px;border-bottom:2px solid #ddd}.faq-header h1{font-size:2.5rem;color:#333;margin:0}.faq-section{margin-bottom:40px}.faq-section h2{font-size:1.5rem;color:#333;margin-bottom:15px;padding-bottom:10px;border-bottom:2px solid #e0e0e0}.faq-content{line-height:1.8;color:#555}.faq-content ol{margin:15px 0;padding-left:25px}.faq-content li{margin:10px 0}.faq-content a{color:#007bff;text-decoration:none;font-weight:600}.faq-content a:hover{text-decoration:underline}.gif-container{margin-top:20px;text-align:center;width:100%}.demo-gif{max-width:90%;height:auto;border-radius:8px;box-shadow:0 4px 12px #0000001a}@media (max-width: 768px){.faq-container{padding:20px}.faq-header h1{font-size:2rem}}.subscription-page{min-height:100vh;background:#f5f5f5;padding:20px}.subscription-container{max-width:800px;margin:0 auto;background:#fff;border-radius:12px;padding:25px;box-shadow:0 2px 8px #0000001a}.subscription-header{margin-bottom:25px;padding-bottom:15px;border-bottom:1px solid #e0e0e0}.subscription-header h1{font-size:1.5rem;color:#333;margin:0;font-weight:600}.subscription-content{display:flex;flex-direction:column;gap:20px}.subscription-card{background-color:#fff;padding:20px;border-radius:8px;border:1px solid #e0e0e0}.subscription-card h2{margin:0 0 20px;color:#333;font-size:1.3rem;font-weight:600}.status-section{padding:20px 0}.status-row{display:flex;justify-content:space-between;align-items:center;padding:15px 0;border-bottom:1px solid #e0e0e0}.status-row .label{font-weight:600;color:#333;font-size:1rem}.status-row .value{color:#555;font-size:1rem}.detail-row{display:flex;justify-content:space-between;padding:12px 0;border-bottom:1px solid #e0e0e0}.detail-row:last-child{border-bottom:none}.detail-row .label{font-weight:600;color:#333}.detail-row .value{color:#555}.status-active{color:#28a745;font-weight:600}.status-premium{color:#007bff;font-weight:600}.status-free{color:#6c757d;font-weight:600}.subscription-actions{display:flex;flex-direction:column;gap:15px}.success-message,.warning-message,.error-message,.info-message{padding:12px 16px;border-radius:6px;text-align:center;font-size:.95rem}.success-message{background-color:#d4edda;color:#155724;border:1px solid #c3e6cb}.warning-message{background-color:#fff3cd;color:#856404;border:1px solid #ffeaa7}.error-message{background-color:#f8d7da;color:#721c24;border:1px solid #f5c6cb}.info-message{background-color:#f8f9fa;color:#495057;border:1px solid #dee2e6;margin-bottom:10px}.cancel-button,.upgrade-button{padding:10px 20px;border:none;border-radius:6px;font-size:.95rem;font-weight:600;cursor:pointer;transition:background-color .3s ease}.cancel-button{background-color:#dc3545;color:#fff}.cancel-button:hover{background-color:#c82333}.upgrade-button{background-color:#6c757d;color:#fff}.upgrade-button:hover{background-color:#5a6268}.no-subscription{text-align:center;padding:40px 20px}.no-subscription p{font-size:1rem;color:#555;margin-bottom:20px}.loading-indicator{display:flex;align-items:center;justify-content:center;gap:12px;padding:60px 40px;color:#6c757d;font-size:1rem}.spinner{width:24px;height:24px;border:3px solid #f3f3f3;border-top:3px solid #6c757d;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (max-width: 768px){.subscription-container{padding:20px}.subscription-header h1{font-size:2rem}.detail-row{flex-direction:column;gap:5px}}.navigation{background:#fff;box-shadow:0 2px 10px #0000001a;position:sticky;top:0;z-index:1000}.nav-container{max-width:1200px;margin:0 auto;padding:15px 20px;display:flex;justify-content:space-between;align-items:center}.nav-logo{text-decoration:none;color:#007bff}.nav-logo h2{margin:0;font-size:1.8rem;color:#333}.nav-links{display:flex;gap:20px;align-items:center}.nav-link{text-decoration:none;color:#555;font-weight:500;padding:8px 16px;border-radius:6px;transition:all .3s ease}.nav-link:hover{color:#333;background-color:#f8f9fa}.nav-link.active{color:#333;background-color:#e9ecef;font-weight:600}@media (max-width: 768px){.nav-container{flex-direction:column;gap:15px}.nav-links{width:100%;justify-content:center}.nav-logo h2{font-size:1.5rem}}.app{min-height:100vh;display:flex;flex-direction:column}.container{max-width:800px;width:100%;background:#fff;border-radius:12px;box-shadow:0 2px 10px #0000001a;padding:40px}header{text-align:center;margin-bottom:40px}header h1{color:#333;font-size:2.5rem;margin-bottom:10px}.subtitle{color:#666;font-size:1.1rem}.test-section{margin-bottom:30px}.button-group{display:flex;gap:15px;margin-bottom:20px;flex-wrap:wrap}.btn{padding:12px 24px;border:none;border-radius:6px;font-size:1rem;cursor:pointer;transition:all .3s ease;font-weight:500}.btn-primary{background-color:#007bff;color:#fff}.btn-primary:hover:not(:disabled){background-color:#0056b3}.btn-secondary{background-color:#6c757d;color:#fff}.btn-secondary:hover:not(:disabled){background-color:#545b62}.btn:disabled{opacity:.6;cursor:not-allowed}.message{padding:15px;border-radius:6px;margin-bottom:20px;font-weight:500}.message.success{background-color:#d4edda;color:#155724;border:1px solid #c3e6cb}.message.error{background-color:#f8d7da;color:#721c24;border:1px solid #f5c6cb}.error-box{background-color:#f8d7da;color:#721c24;padding:15px;border-radius:6px;margin-bottom:20px;border:1px solid #f5c6cb}.error-box p{margin-top:10px;font-size:.9rem}.response-box{background-color:#f8f9fa;padding:15px;border-radius:6px;margin-bottom:20px;border:1px solid #dee2e6}.response-box pre{margin-top:10px;background-color:#fff;padding:15px;border-radius:4px;overflow-x:auto;font-size:.9rem}.info-box{background-color:#e7f3ff;padding:20px;border-radius:6px;border:1px solid #b3d9ff}.info-box h3{color:#004085;margin-bottom:15px}.info-box ul{list-style:none;padding-left:0}.info-box li{padding:8px 0;color:#004085;border-bottom:1px solid #b3d9ff}.info-box li:last-child{border-bottom:none}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f5f5}#root{min-height:100vh}
