.auth-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2)}.auth-card{background:#fff;padding:2.5rem;border-radius:12px;box-shadow:0 10px 40px #0003;width:100%;max-width:400px}.auth-card h1{color:#3498db;font-size:2rem;margin-bottom:.5rem;text-align:center}.auth-card h2{color:#2c3e50;font-size:1.5rem;margin-bottom:1.5rem;text-align:center;font-weight:400}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;color:#2c3e50;font-weight:500}.form-group input{width:100%;padding:.75rem;border:2px solid #e1e8ed;border-radius:6px;font-size:1rem;transition:border-color .3s}.form-group input:focus{outline:none;border-color:#3498db}.form-group input:disabled{background:#f5f7fa;cursor:not-allowed}.auth-card button[type=submit]{width:100%;background:#3498db;color:#fff;border:none;padding:.875rem;border-radius:6px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:background .3s;margin-top:1rem}.auth-card button[type=submit]:hover{background:#2980b9}.auth-card button[type=submit]:disabled{background:#95a5a6;cursor:not-allowed}.auth-link{text-align:center;margin-top:1.5rem;color:#7f8c8d}.auth-link a{color:#3498db;text-decoration:none;font-weight:500}.auth-link a:hover{text-decoration:underline}.dashboard h2{margin-bottom:1.5rem;color:#2c3e50}.empty-state{text-align:center;padding:3rem;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a}.empty-state p{color:#7f8c8d;font-size:1.1rem;margin-bottom:1.5rem}.uploads-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.upload-card{background:#fff;padding:1.5rem;border-radius:12px;box-shadow:0 2px 8px #0000001a;transition:transform .2s,box-shadow .2s}.upload-card:hover{transform:translateY(-4px);box-shadow:0 4px 16px #00000026}.upload-card h3{color:#2c3e50;font-size:1.2rem;margin-bottom:.75rem;word-break:break-word}.upload-info{display:flex;gap:.5rem;color:#7f8c8d;font-size:.9rem;margin-bottom:.5rem}.upload-date{color:#95a5a6;font-size:.85rem;margin-bottom:1rem}.card-actions{display:flex;gap:.75rem}.card-actions button{flex:1}.upload-page h2{margin-bottom:2rem;color:#2c3e50}.dropzone{border:3px dashed #bdc3c7;border-radius:12px;padding:4rem 2rem;text-align:center;cursor:pointer;transition:all .3s;background:#fff;margin-bottom:2rem}.dropzone.active{border-color:#3498db;background:#ebf5fb}.dropzone.disabled{cursor:not-allowed;opacity:.6}.dropzone:hover:not(.disabled){border-color:#3498db;background:#f8f9fa}.upload-icon{font-size:4rem;margin-bottom:1rem}.dropzone p{color:#2c3e50;font-size:1.1rem;margin:.5rem 0}.upload-hint{color:#7f8c8d;font-size:.9rem!important}.upload-progress{display:flex;flex-direction:column;align-items:center;gap:1rem}.spinner{border:4px solid #f3f3f3;border-top:4px solid #3498db;border-radius:50%;width:50px;height:50px;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.progress-bar{width:100%;max-width:400px;height:8px;background:#ecf0f1;border-radius:4px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,#3498db,#2ecc71);transition:width .3s}.upload-info-box{background:#fff;padding:2rem;border-radius:12px;box-shadow:0 2px 8px #0000001a}.upload-info-box h3{color:#2c3e50;margin-bottom:1rem}.upload-info-box ul{list-style:none;padding-left:0}.upload-info-box li{padding:.5rem 0 .5rem 1.5rem;position:relative;color:#34495e}.upload-info-box li:before{content:"✓";position:absolute;left:0;color:#2ecc71;font-weight:700}.chat-page{height:100vh;display:flex;flex-direction:column}.nav-left{display:flex;align-items:center;gap:2rem}.upload-info{display:flex;gap:1rem;align-items:center;padding:.5rem 1rem;background:#ecf0f1;border-radius:6px}.filename{font-weight:500;color:#2c3e50}.sheet-count{color:#7f8c8d;font-size:.9rem}.chat-container{flex:1;display:flex;flex-direction:column;overflow:hidden}.messages-area{flex:1;overflow-y:auto;padding:2rem;background:#f5f7fa}.empty-chat{text-align:center;padding:3rem;color:#7f8c8d}.empty-chat h3{color:#2c3e50;margin-bottom:1rem}.empty-chat ul{list-style:none;padding:0;margin-top:1rem}.empty-chat li{padding:.5rem;color:#95a5a6;font-style:italic}.message{margin-bottom:1.5rem;display:flex}.user-message{justify-content:flex-end}.user-message .message-content{background:#3498db;color:#fff;padding:1rem 1.5rem;border-radius:18px 18px 4px;max-width:70%}.assistant-message .message-content{background:#fff;padding:1.5rem;border-radius:18px 18px 18px 4px;max-width:85%;box-shadow:0 2px 8px #0000001a}.sql-block{margin-bottom:1rem}.sql-label{font-weight:600;color:#2c3e50;margin-bottom:.5rem}.sql-block pre{background:#2c3e50;color:#2ecc71;padding:1rem;border-radius:6px;overflow-x:auto;font-family:Courier New,monospace;font-size:.9rem;line-height:1.5}.results-block{margin-bottom:1rem}.results-label{font-weight:600;color:#2c3e50;margin-bottom:.5rem}.results-table-wrapper{overflow-x:auto}.results-table{width:100%;border-collapse:collapse;font-size:.9rem}.results-table th{background:#34495e;color:#fff;padding:.75rem;text-align:left;font-weight:600}.results-table td{padding:.75rem;border-bottom:1px solid #ecf0f1}.results-table tbody tr:hover{background:#f8f9fa}.execution-time{color:#7f8c8d;font-size:.85rem;font-style:italic;margin-top:.5rem}.error-result{color:#e74c3c}.error-label{font-weight:600;margin-bottom:.5rem}.typing-indicator{display:flex;gap:.5rem;padding:1rem 0}.typing-indicator span{width:8px;height:8px;background:#95a5a6;border-radius:50%;animation:typing 1.4s infinite}@keyframes typing{0%,60%,to{opacity:.3;transform:translateY(0)}30%{opacity:1;transform:translateY(-10px)}}.error-banner{background:#fee;color:#c0392b;padding:1rem;text-align:center;border-top:2px solid #e74c3c}.input-area{display:flex;gap:1rem;padding:1.5rem 2rem;background:#fff;border-top:1px solid #e1e8ed}.input-area input{flex:1;padding:.875rem 1.25rem;border:2px solid #e1e8ed;border-radius:24px;font-size:1rem;transition:border-color .3s}.input-area input:focus{outline:none;border-color:#3498db}.input-area input:disabled{background:#f5f7fa}.input-area button{padding:.875rem 2rem;background:#3498db;color:#fff;border:none;border-radius:24px;font-size:1rem;font-weight:600;cursor:pointer;transition:background .3s}.input-area button:hover:not(:disabled){background:#2980b9}.input-area button:disabled{background:#95a5a6;cursor:not-allowed}.processing-indicator{padding:1rem;text-align:center}.processing-label{font-weight:600;color:#3498db;margin-bottom:.5rem}.processing-step{font-size:.9rem;color:#666;margin-bottom:1rem;font-style:italic}.typing-indicator{display:flex;justify-content:center;align-items:center;gap:.5rem}.typing-indicator span{width:8px;height:8px;background-color:#3498db;border-radius:50%;animation:typing 1.4s infinite}.typing-indicator span:nth-child(2){animation-delay:.2s}.typing-indicator span:nth-child(3){animation-delay:.4s}@keyframes typing{0%,60%,to{transform:translateY(0);opacity:.7}30%{transform:translateY(-10px);opacity:1}}.ai-answer{background:linear-gradient(135deg,#667eea,#764ba2);padding:1.5rem;border-radius:12px;margin-bottom:1rem;box-shadow:0 4px 6px #667eea1a}.answer-label{font-size:.9rem;font-weight:700;color:#fff;margin-bottom:.75rem;text-transform:uppercase;letter-spacing:.5px}.answer-text{color:#fff;font-size:1.05rem;line-height:1.7;margin:0;font-weight:400}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background:#f5f7fa;color:#2c3e50;line-height:1.6}.container{max-width:1200px;margin:0 auto;padding:2rem}.navbar{background:#fff;border-bottom:1px solid #e1e8ed;padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 4px #0000001a}.navbar h1{font-size:1.5rem;color:#3498db;font-weight:700}.nav-actions{display:flex;gap:1rem;align-items:center}.btn-primary{background:#3498db;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:6px;cursor:pointer;font-size:1rem;font-weight:500;transition:background .3s}.btn-primary:hover{background:#2980b9}.btn-primary:disabled{background:#95a5a6;cursor:not-allowed}.btn-secondary{background:#ecf0f1;color:#2c3e50;border:none;padding:.75rem 1.5rem;border-radius:6px;cursor:pointer;font-size:1rem;font-weight:500;transition:background .3s}.btn-secondary:hover{background:#bdc3c7}.btn-danger{background:#e74c3c;color:#fff;border:none;padding:.5rem 1rem;border-radius:4px;cursor:pointer;font-size:.9rem;transition:background .3s}.btn-danger:hover{background:#c0392b}.error-message{background:#fee;color:#c0392b;padding:1rem;border-radius:6px;margin-bottom:1rem;border-left:4px solid #e74c3c}.loading{display:flex;justify-content:center;align-items:center;height:100vh;font-size:1.2rem;color:#7f8c8d}
