.dashboard{flex:1;padding:2rem;max-width:1400px;margin:0 auto;width:100%}.dashboard-header{margin-bottom:2rem;border-bottom:2px solid var(--primary-color);padding-bottom:1rem}.dashboard-header h1{font-size:2rem;color:var(--text-primary);margin-bottom:.25rem}.subtitle{color:var(--text-secondary);font-size:1.1rem}.dashboard-content{display:grid;grid-template-columns:1fr;gap:2rem}.query-section{background-color:#fff;border:1px solid var(--border-color);border-radius:8px;padding:2rem;box-shadow:0 1px 3px #0000001a}.query-form h2{margin-bottom:1.5rem;color:var(--text-primary);font-size:1.3rem}.loading-spinner-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 2rem;background-color:#fff;border:1px solid var(--border-color);border-radius:8px;box-shadow:0 1px 3px #0000001a}.spinner{width:50px;height:50px;border:4px solid var(--secondary-color);border-top-color:var(--primary-color);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}@keyframes spin{to{transform:rotate(360deg)}}.loading-spinner-container h3{margin-bottom:.5rem;font-size:1.1rem}.elapsed-time{font-size:1.3rem;font-weight:700;color:var(--primary-color);margin:.5rem 0}.estimate{color:var(--text-secondary);font-size:.95rem}.results-section{background-color:#fff;border:1px solid var(--border-color);border-radius:8px;padding:2rem;box-shadow:0 1px 3px #0000001a}.results-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--border-color)}.results-header h2{margin:0;font-size:1.3rem}.table-container{overflow-x:auto;border-radius:4px;border:1px solid var(--border-color)}.data-table{width:100%;border-collapse:collapse;font-size:.95rem}.data-table thead{background-color:var(--secondary-color);border-bottom:2px solid var(--border-color)}.data-table th{padding:1rem;text-align:left;font-weight:600;color:var(--text-primary);-webkit-user-select:none;user-select:none}.sortable-header{cursor:pointer;transition:background-color .2s}.sortable-header:hover{background-color:#e0e0e0}.header-content{display:flex;align-items:center;gap:.5rem}.sort-indicator{font-size:.8rem;color:var(--primary-color);font-weight:700}.data-table td{padding:.75rem 1rem;border-bottom:1px solid var(--border-color);word-break:break-word;max-width:300px}.table-cell{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.data-table tbody tr{transition:background-color .1s}.data-table tbody tr:hover{background-color:#f5f5f5}.row-odd{background-color:#fff}.row-even{background-color:#fafafa}.row-nodata{background-color:#ffebee}.row-nodata td{color:var(--error-color);font-weight:500}.row-warning{background-color:#fff9c4}.row-warning td{color:#9c8700}@media (max-width: 1024px){.dashboard{padding:1rem}.table-container{font-size:.85rem}.data-table th,.data-table td{padding:.5rem}}@media (max-width: 768px){.dashboard{padding:1rem}.dashboard-header h1{font-size:1.5rem}.query-section,.results-section{padding:1rem}.results-header{flex-direction:column;align-items:flex-start;gap:1rem}.btn-secondary{width:100%}.table-container{font-size:.8rem;overflow-x:auto}.data-table th,.data-table td{padding:.5rem}.table-cell{max-width:150px}}.app-container{flex:1;min-height:100vh;display:flex;flex-direction:column}.login-screen{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;text-align:center}.login-screen h1{margin:0;font-size:28px}.login-screen p{margin:0 0 16px;color:#888}.app-footer{margin-top:auto;display:flex;align-items:center;justify-content:flex-end;gap:16px;padding:12px 24px;border-top:1px solid #eee;font-size:13px;color:#666}.btn-logout{background:none;border:1px solid #ddd;border-radius:6px;padding:6px 14px;font-size:13px;cursor:pointer;color:#555}.btn-logout:hover{background:#f5f5f5}:root{--primary-color: #0066cc;--secondary-color: #f5f5f5;--error-color: #d32f2f;--warning-color: #fbc02d;--success-color: #388e3c;--text-primary: #212121;--text-secondary: #757575;--border-color: #bdbdbd;--background: #fafafa}*{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:var(--background);color:var(--text-primary)}#root{min-height:100vh}.app-container{display:flex;flex-direction:column;min-height:100vh}.app-footer{background-color:#f5f5f5;border-top:1px solid var(--border-color);padding:1rem;text-align:center;margin-top:auto;display:flex;justify-content:center;gap:1rem;align-items:center}.btn-logout{padding:.5rem 1rem;background-color:var(--error-color);color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.9rem;transition:background-color .2s}.btn-logout:hover{background-color:#c62828}.btn-primary,.btn-secondary{padding:.75rem 1.5rem;border:none;border-radius:4px;font-size:1rem;cursor:pointer;transition:all .2s;font-weight:500}.btn-primary{background-color:var(--primary-color);color:#fff}.btn-primary:hover:not(:disabled){background-color:#0052a3;transform:translateY(-2px);box-shadow:0 2px 8px #0066cc4d}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-secondary{background-color:var(--secondary-color);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover:not(:disabled){background-color:#eee}.form-group{margin-bottom:1.5rem}label{display:block;margin-bottom:.5rem;font-weight:600;color:var(--text-primary)}.form-input,.form-textarea{width:100%;padding:.75rem;border:1px solid var(--border-color);border-radius:4px;font-family:inherit;font-size:1rem;transition:border-color .2s}.form-input:focus,.form-textarea:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #0066cc1a}.form-input:disabled,.form-textarea:disabled{background-color:#f5f5f5;cursor:not-allowed}.form-textarea{resize:vertical;min-height:100px}small{display:block;margin-top:.25rem;color:var(--text-secondary);font-size:.875rem}.error-message{background-color:#ffebee;border-left:4px solid var(--error-color);padding:1rem;margin:1rem 0;border-radius:4px;color:var(--error-color)}.no-data-message{text-align:center;color:var(--text-secondary);padding:2rem;font-size:1.1rem}
