.csv-upload{display:flex;justify-content:center;align-items:center;min-height:60vh}.upload-card{background:#fff;border-radius:12px;padding:2rem;box-shadow:0 4px 6px #0000001a;max-width:800px;width:100%}.upload-card h2{color:#333;margin-bottom:1.5rem;font-size:1.8rem}.upload-area{margin-bottom:2rem}.progress-section{margin-top:1.5rem;margin-bottom:1.5rem;animation:fadeIn .3s ease-in}.progress-bar-container{width:100%;height:8px;background:#e0e0e0;border-radius:10px;overflow:hidden;margin-bottom:.75rem;box-shadow:inset 0 2px 4px #0000001a}.progress-bar{height:100%;background:linear-gradient(90deg,#667eea,#764ba2,#667eea);background-size:200% 100%;border-radius:10px;transition:width .3s ease-out;animation:shimmer 2s infinite;box-shadow:0 2px 4px #667eea4d}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.progress-text{display:flex;justify-content:space-between;align-items:center;font-size:.9rem;color:#666}.progress-stage{font-weight:500;color:#667eea}.progress-percentage{font-weight:600;color:#764ba2;font-size:.95rem}.file-input{display:none}.file-label{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;border:2px dashed #667eea;border-radius:8px;cursor:pointer;transition:all .3s;background:#f8f9ff}.file-label:hover{border-color:#764ba2;background:#f0f2ff}.file-label svg{color:#667eea;margin-bottom:1rem}.file-label span{color:#667eea;font-weight:500;font-size:1.1rem}.preview-section{margin-top:2rem;margin-bottom:1.5rem}.preview-section h3{margin-bottom:1rem;color:#555}.preview-table{overflow-x:auto;border:1px solid #e0e0e0;border-radius:6px}.preview-table table{width:100%;border-collapse:collapse}.preview-table th,.preview-table td{padding:.75rem;text-align:left;border-bottom:1px solid #e0e0e0}.preview-table th{background:#f5f5f5;font-weight:600;color:#333}.preview-table td{font-size:.9rem;color:#666}.generate-button{width:100%;padding:1rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:transform .2s}.generate-button:hover:not(:disabled){transform:translateY(-2px)}.generate-button:disabled{opacity:.6;cursor:not-allowed}.error-message{margin-top:1rem;padding:1rem;background:#fee;color:#c33;border-radius:6px;border-left:4px solid #c33}.query-suggestions{width:100%}.suggestions-header{margin-bottom:1.5rem}.suggestions-header-below{margin:2rem 0 1.5rem}.suggestions-header-below h2{color:#111827;margin-bottom:.5rem;font-size:1.75rem;font-weight:600}.suggestions-header-below p{color:#6b7280;font-size:.95rem;margin:0}.suggestions-header h2{color:#333;margin-bottom:.5rem;font-size:2rem}.suggestions-header p{color:#666;font-size:1rem}.search-section{margin-bottom:2rem;background:#fff;padding:2rem;border-radius:12px;box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f;border:1px solid #e5e7eb}.ai-search-header{margin-bottom:1.5rem}.header-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.ai-search-header h3{color:#111827;margin:0;font-size:1.5rem;font-weight:600;letter-spacing:-.02em}.ai-badge{background:#f3f4f6;color:#374151;padding:.375rem .75rem;border-radius:6px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;border:1px solid #e5e7eb}.ai-description{color:#6b7280;margin:0;font-size:.95rem;line-height:1.6;max-width:100%}.features-list{display:flex;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.feature-item{display:flex;align-items:center;gap:.5rem;background:#f9fafb;padding:.625rem 1rem;border-radius:8px;font-size:.875rem;font-weight:500;color:#374151;border:1px solid #e5e7eb;transition:all .2s}.feature-item:hover{background:#f3f4f6;border-color:#d1d5db}.feature-icon-wrapper{display:flex;align-items:center;color:#667eea;flex-shrink:0}.feature-icon-wrapper svg{width:16px;height:16px}.columns-info{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;margin-bottom:1.5rem;overflow:hidden}.columns-dropdown-toggle{width:100%;background:transparent;border:none;padding:1.25rem 1.5rem;cursor:pointer;display:flex;justify-content:space-between;align-items:center;transition:background .2s;text-align:left}.columns-dropdown-toggle:hover{background:#f3f4f6}.dropdown-header-content{display:flex;justify-content:space-between;align-items:flex-start;flex:1;gap:1rem}.dropdown-header-content>div{flex:1}.columns-label{font-size:1rem;font-weight:600;color:#111827;display:block;margin-bottom:.25rem}.columns-subtitle{font-size:.875rem;color:#6b7280;margin:0;line-height:1.5}.columns-count{font-size:.75rem;color:#6b7280;background:#fff;padding:.375rem .75rem;border-radius:6px;border:1px solid #e5e7eb;font-weight:500;white-space:nowrap}.dropdown-arrow{color:#6b7280;transition:transform .3s;flex-shrink:0;margin-left:1rem}.dropdown-arrow.open{transform:rotate(180deg)}.columns-dropdown-content{border-top:1px solid #e5e7eb;background:#fff;max-height:400px;overflow-y:auto}.columns-dropdown-content::-webkit-scrollbar{width:8px}.columns-dropdown-content::-webkit-scrollbar-track{background:#f9fafb}.columns-dropdown-content::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:4px}.columns-dropdown-content::-webkit-scrollbar-thumb:hover{background:#9ca3af}.columns-loading{display:flex;align-items:center;gap:.75rem;padding:2rem;justify-content:center;color:#6b7280;font-size:.9rem}.spinner-small{width:16px;height:16px;border:2px solid #e5e7eb;border-top-color:#667eea;border-radius:50%;animation:spin .8s linear infinite}.columns-list{padding:0}.column-item{padding:1rem 1.5rem;border-bottom:1px solid #f3f4f6;transition:background .2s}.column-item:last-child{border-bottom:none}.column-item:hover{background:#f9fafb}.column-name{font-size:.8125rem;font-weight:600;color:#667eea;font-family:Monaco,Menlo,Courier New,monospace;margin-bottom:.5rem}.column-description{font-size:.875rem;color:#374151;line-height:1.6}.search-input-container{display:flex;gap:1rem;align-items:flex-start}.input-wrapper{flex:1;background:#fff;border-radius:8px;padding:0;border:1px solid #e5e7eb;overflow:hidden;box-shadow:0 1px 2px #0000000d}.input-label{display:flex;align-items:center;padding:.875rem 1.25rem;background:#f9fafb;border-bottom:1px solid #e5e7eb;font-weight:600;color:#374151;font-size:.875rem;text-transform:uppercase;letter-spacing:.05em}.ai-search-input{width:100%;padding:1rem;border:none;border-radius:0;font-size:.95rem;font-family:inherit;resize:none;min-height:120px;max-height:200px;color:#111827;background:#fff;transition:background .2s;line-height:1.6;overflow:hidden;-ms-overflow-style:none;scrollbar-width:none}.ai-search-input::-webkit-scrollbar{display:none}.ai-search-input::-moz-placeholder{color:#9ca3af;line-height:1.6}.ai-search-input::placeholder{color:#9ca3af;line-height:1.6}.ai-search-input:focus{outline:none;background:#fafafa}.ai-search-input:disabled{background:#f5f5f5;cursor:not-allowed;opacity:.7}.input-footer{padding:.75rem 1rem;border-top:1px solid #e5e7eb;display:flex;justify-content:flex-end;background:#f9fafb}.input-hint{font-size:.75rem;color:#6b7280;display:flex;align-items:center;gap:.25rem}.keyboard-shortcut{background:#fff;color:#374151;padding:.2rem .4rem;border-radius:4px;font-family:Monaco,Menlo,Courier New,monospace;font-size:.7rem;font-weight:600;border:1px solid #d1d5db;margin:0 .2rem;box-shadow:0 1px 2px #0000000d}.ai-search-button{padding:1rem 2rem;background:#667eea;color:#fff;border:none;border-radius:8px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap;display:flex;align-items:center;justify-content:center;gap:.5rem;box-shadow:0 1px 2px #0000000d;min-height:48px;align-self:flex-start}.ai-search-button:hover:not(:disabled){background:#5568d3;box-shadow:0 2px 4px #0000001a}.ai-search-button:active:not(:disabled){background:#4c5bc0}.ai-search-button:disabled{background:#d1d5db;color:#9ca3af;cursor:not-allowed;box-shadow:none}.button-icon{width:18px;height:18px;flex-shrink:0;display:flex;align-items:center}.spinner{width:16px;height:16px;border:2px solid rgba(102,126,234,.3);border-top-color:#667eea;border-radius:50%;animation:spin .8s linear infinite}.search-error{margin-top:1rem;padding:1rem;background:#fef2f2;color:#991b1b;border-radius:8px;border:1px solid #fecaca;font-size:.875rem;display:flex;align-items:center;gap:.75rem}.error-icon{width:20px;height:20px;flex-shrink:0;color:#dc2626}.error-icon svg{width:100%;height:100%}.queries-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(400px,1fr));gap:1.5rem}.query-card{background:#fff;border-radius:12px;padding:0;box-shadow:0 2px 8px #00000014;cursor:pointer;transition:all .3s ease;border:1px solid #e5e7eb;overflow:hidden;display:flex;flex-direction:column}.query-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px #0000001f;border-color:#667eea}.query-card-header{display:flex;align-items:center;gap:1rem;padding:1.25rem 1.5rem;background:linear-gradient(135deg,#f8f9ff,#fff);border-bottom:1px solid #e5e7eb}.query-number{width:32px;height:32px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:8px;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.9rem;flex-shrink:0}.query-card h3{color:#1f2937;margin:0;font-size:1.1rem;font-weight:600;line-height:1.4;flex:1}.query-description{color:#6b7280;margin:0;padding:1rem 1.5rem;line-height:1.6;font-size:.95rem}.query-preview{background:#f9fafb;padding:1rem 1.5rem;margin:0 1.5rem;border-radius:8px;border:1px solid #e5e7eb;flex:1}.query-preview-label{font-size:.75rem;font-weight:600;color:#667eea;text-transform:uppercase;letter-spacing:.5px;margin-bottom:.5rem}.query-preview code{font-size:.85rem;color:#374151;font-family:Monaco,Menlo,Ubuntu Mono,monospace;display:block;white-space:pre-wrap;word-break:break-word;line-height:1.5}.query-card-footer{padding:1rem 1.5rem;border-top:1px solid #e5e7eb;background:#fafafa}.view-details-btn{width:100%;padding:.75rem 1rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .3s;display:flex;align-items:center;justify-content:center;gap:.5rem}.view-details-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #667eea66}.view-details-btn:active{transform:translateY(0)}.view-details-btn .arrow{font-size:1.2rem;transition:transform .3s}.view-details-btn:hover .arrow{transform:translate(4px)}.no-queries{grid-column:1 / -1;text-align:center;padding:3rem;background:#fff;border-radius:10px;color:#666}.correlations-section,.join-queries-section,.table-queries-section{margin:2.5rem 0;padding:1.5rem;background:#f8f9fa;border-radius:12px;border:1px solid #e9ecef}.section-header{margin-bottom:1.5rem}.section-header h2{color:#111827;margin-bottom:.5rem;font-size:1.5rem;font-weight:600}.section-header p{color:#6b7280;font-size:.95rem;margin:0}.correlations-list{display:flex;flex-direction:column;gap:1rem}.correlation-card{background:#fff;padding:1.25rem;border-radius:8px;border:1px solid #e5e7eb;box-shadow:0 1px 3px #0000001a}.correlation-info{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.correlation-tables{font-weight:600;color:#111827;font-family:Monaco,Courier New,monospace;font-size:.9rem}.correlation-confidence{background:#dbeafe;color:#1e40af;padding:.25rem .75rem;border-radius:12px;font-size:.85rem;font-weight:600}.correlation-details{display:flex;gap:1rem;font-size:.85rem;color:#6b7280}.correlation-type{text-transform:capitalize;font-weight:500}.correlation-overlap{color:#059669}.join-query-card{border:2px solid #3b82f6;background:linear-gradient(to bottom,#fff,#f0f9ff)}.join-info{display:flex;gap:.75rem;margin:1rem 0;flex-wrap:wrap}.join-badge{background:#dbeafe;color:#1e40af;padding:.5rem 1rem;border-radius:6px;font-size:.85rem;font-family:Monaco,Courier New,monospace;font-weight:600}.join-type-badge{background:#3b82f6;color:#fff;padding:.5rem 1rem;border-radius:6px;font-size:.85rem;font-weight:600;text-transform:uppercase}.query-detail{width:100%}.detail-header{margin-bottom:2rem}.header-content{margin-top:1rem}.detail-header h2{color:#1f2937;margin-bottom:.5rem;font-size:2rem;font-weight:700}.detail-header p{color:#6b7280;font-size:1rem;line-height:1.6}.detail-content{display:grid;gap:1.5rem}.query-section,.dataset-input-section,.chart-suggestions-section{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #00000014;border:1px solid #e5e7eb}.section-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1.25rem;padding-bottom:1rem;border-bottom:2px solid #f3f4f6}.section-icon{font-size:1.5rem}.section-header h3{color:#1f2937;margin:0;font-size:1.25rem;font-weight:600}.query-code-wrapper{position:relative}.query-code{background:#1e1e1e;color:#d4d4d4;padding:1.25rem 1.25rem 4rem;border-radius:8px;overflow-x:auto;font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:.9rem;line-height:1.6;margin:0;white-space:pre-wrap;word-break:break-word}.query-actions{position:absolute;top:.75rem;right:.75rem;display:flex;gap:.5rem;align-items:center}.copy-query-btn{background:#ffffff1a;color:#d4d4d4;border:1px solid rgba(255,255,255,.2);padding:.5rem .75rem;border-radius:6px;cursor:pointer;font-size:.85rem;transition:all .3s;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);white-space:nowrap}.copy-query-btn:hover{background:#fff3;color:#fff}.try-devrev-btn{background:#10b98133;color:#10b981;border:1px solid rgba(16,185,129,.3);padding:.5rem .75rem;border-radius:6px;cursor:pointer;font-size:.85rem;transition:all .3s;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);text-decoration:none;display:inline-block;white-space:nowrap;font-weight:500}.try-devrev-btn:hover{background:#10b9814d;color:#059669;border-color:#10b98180;transform:translateY(-1px)}.loading-state{text-align:center;padding:3rem 2rem;color:#6b7280}.spinner-large{width:48px;height:48px;border:4px solid #e5e7eb;border-top-color:#667eea;border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 1rem}.spinner-small{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.error-message{background:#fee;color:#c33;padding:1rem;border-radius:8px;border-left:4px solid #c33;display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}.error-icon{font-size:1.25rem}.empty-state{text-align:center;padding:3rem 2rem;color:#9ca3af}.empty-icon{font-size:3rem;display:block;margin-bottom:1rem}.empty-state p{font-size:1rem;margin:0}.chart-suggestions-container{display:flex;flex-direction:column;gap:1.5rem}.segment-tabs{display:flex;gap:.5rem;border-bottom:2px solid #e5e7eb;padding-bottom:.5rem;flex-wrap:wrap}.segment-tab{padding:.75rem 1.5rem;background:transparent;border:none;border-bottom:3px solid transparent;cursor:pointer;font-size:.95rem;font-weight:500;color:#6b7280;transition:all .2s ease;display:flex;align-items:center;gap:.5rem}.segment-tab:hover{color:#374151;background:#f9fafb;border-radius:8px 8px 0 0}.segment-tab.active{color:#667eea;border-bottom-color:#667eea;background:#f5f7ff;border-radius:8px 8px 0 0}.chart-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem;margin-top:1rem}.chart-card{background:#f9fafb;border:1px solid #e5e7eb;border-radius:12px;padding:0;transition:all .3s;overflow:hidden;display:flex;flex-direction:column}.chart-card:hover{border-color:#667eea;transform:translateY(-2px);box-shadow:0 8px 24px #667eea26}.chart-card-header{display:flex;align-items:center;gap:1rem;padding:1.25rem;background:#fff;border-bottom:1px solid #e5e7eb}.chart-icon{font-size:2rem;flex-shrink:0}.chart-card h4{color:#1f2937;margin:0;font-size:1.1rem;font-weight:600}.chart-description{color:#6b7280;margin:0;padding:1rem 1.25rem;font-size:.9rem;line-height:1.6;flex:1}.validation-warning{background:#fff3cd;color:#856404;padding:.75rem 1.25rem;border-radius:6px;font-size:.85rem;margin:0 1.25rem 1rem;border-left:3px solid #ffc107;display:flex;align-items:center;gap:.5rem}.create-chart-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:.875rem 1.5rem;border-radius:0 0 12px 12px;cursor:pointer;font-weight:600;font-size:.95rem;transition:all .3s;display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;margin-top:auto}.create-chart-button:hover{background:linear-gradient(135deg,#5568d3,#6a3d8a)}.create-chart-button .arrow{font-size:1.1rem;transition:transform .3s}.create-chart-button:hover .arrow{transform:translate(4px)}.dataset-input-group{display:flex;flex-direction:column;gap:1rem}.dataset-input-group label{color:#374151;font-weight:600;font-size:.95rem;display:flex;flex-direction:column;gap:.25rem}.label-hint{font-weight:400;color:#6b7280;font-size:.85rem}.input-with-button{display:flex;gap:.75rem;align-items:stretch}.dataset-input{flex:1;padding:.875rem 1rem;border:2px solid #e5e7eb;border-radius:8px;font-size:1rem;transition:all .3s;font-family:inherit}.dataset-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.dataset-note{background:#fff3cd;color:#856404;padding:1rem;border-radius:8px;border-left:4px solid #ffc107;font-size:.9rem;line-height:1.6;display:flex;align-items:flex-start;gap:.75rem}.note-icon{font-size:1.25rem;flex-shrink:0}.dataset-note strong{display:block;margin-bottom:.25rem}.generate-charts-button{padding:.875rem 1.75rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s;display:flex;align-items:center;gap:.5rem;white-space:nowrap;flex-shrink:0}.generate-charts-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.generate-charts-button:active:not(:disabled){transform:translateY(0)}.generate-charts-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.chart-visualization{width:100%}.chart-header{margin-bottom:2rem}.chart-header h2{color:#333;font-size:2rem}.sql-query-section{background:#fff;border-radius:10px;padding:1.5rem;box-shadow:0 2px 8px #0000001a;margin-bottom:2rem}.sql-query-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.sql-query-header h3{color:#333;margin:0;font-size:1.3rem}.copy-button{background:#667eea;color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;cursor:pointer;font-size:.9rem;font-weight:600;transition:all .2s}.copy-button:hover{background:#5568d3;transform:translateY(-1px)}.copy-button:active{transform:translateY(0)}.sql-query-code{background:#1e1e1e;color:#d4d4d4;padding:1.5rem;border-radius:8px;overflow-x:auto;font-family:Courier New,monospace;font-size:.9rem;line-height:1.6;margin:0}.chart-container{background:#fff;border-radius:10px;padding:2rem;box-shadow:0 2px 8px #0000001a;margin-bottom:2rem}.chart-container h3{color:#333;margin-bottom:1.5rem;font-size:1.3rem}.table-wrapper{width:100%}.table-container{overflow-x:auto;max-height:600px;overflow-y:auto;margin:1rem 0}.data-table{width:100%;border-collapse:collapse}.data-table th,.data-table td{padding:.75rem;text-align:left;border-bottom:1px solid #e0e0e0}.data-table th{background:#f5f5f5;font-weight:600;color:#333;position:sticky;top:0}.data-table td{color:#666}.data-table tr:hover{background:#f8f9fa}.config-section{background:#fff;border-radius:10px;padding:1.5rem;box-shadow:0 2px 8px #0000001a}.config-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.config-section h3{color:#333;margin:0;font-size:1.3rem}.config-buttons{display:flex;gap:.75rem;align-items:center}.copy-json-button{background:#667eea;color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;cursor:pointer;font-size:.9rem;font-weight:600;transition:all .2s;white-space:nowrap}.copy-json-button:hover{background:#5568d3;transform:translateY(-1px)}.copy-json-button:active{transform:translateY(0)}.try-devrev-button{background:#10b981;color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;cursor:pointer;font-size:.9rem;font-weight:600;transition:all .2s;text-decoration:none;display:inline-block;white-space:nowrap}.try-devrev-button:hover{background:#059669;transform:translateY(-1px);color:#fff}.try-devrev-button:active{transform:translateY(0)}.config-json{background:#1e1e1e;color:#d4d4d4;padding:1.5rem;border-radius:8px;overflow-x:auto;font-family:Courier New,monospace;font-size:.85rem;line-height:1.6}.back-button{background:#6c757d;color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;cursor:pointer;margin-bottom:1rem;font-size:.9rem}.back-button:hover{background:#5a6268}.filters-section{background:#f8f9fa;border-radius:8px;padding:1rem;border:1px solid #e0e0e0;align-self:flex-start}.filters-section h3,.filters-section h4{color:#333;margin-bottom:.75rem;font-size:1rem;font-weight:600}.filters-grid{display:flex;flex-wrap:wrap;gap:1.5rem;align-items:flex-end}.filter-control{display:flex;flex-direction:column;gap:.5rem;min-width:200px}.filter-control label{font-weight:600;color:#555;font-size:.9rem}.filter-control select{padding:.6rem;border:1px solid #ddd;border-radius:6px;font-size:.9rem;background:#fff;color:#333;cursor:pointer;transition:border-color .2s}.filter-control select:hover{border-color:#667eea}.filter-control select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.no-data{text-align:center;padding:3rem;color:#999;font-size:1.1rem}.pagination-controls{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:#f8f9fa;border-radius:8px;margin-bottom:1rem;flex-wrap:wrap;gap:1rem}.pagination-controls:last-of-type{margin-bottom:0;margin-top:1rem}.pagination-info{display:flex;align-items:center;gap:1.5rem;flex-wrap:wrap}.pagination-info span{color:#666;font-size:.9rem}.items-per-page{display:flex;align-items:center;gap:.5rem}.items-per-page label{color:#666;font-size:.9rem;font-weight:500}.items-per-page select{padding:.4rem .6rem;border:1px solid #ddd;border-radius:4px;font-size:.9rem;background:#fff;color:#333;cursor:pointer;transition:border-color .2s}.items-per-page select:hover{border-color:#667eea}.items-per-page select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.pagination-buttons{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.pagination-btn{padding:.5rem .75rem;border:1px solid #ddd;border-radius:4px;background:#fff;color:#333;cursor:pointer;font-size:.9rem;font-weight:500;transition:all .2s;min-width:36px;text-align:center}.pagination-btn:hover:not(:disabled){background:#667eea;color:#fff;border-color:#667eea;transform:translateY(-1px)}.pagination-btn:active:not(:disabled){transform:translateY(0)}.pagination-btn:disabled{opacity:.5;cursor:not-allowed;background:#f5f5f5}.pagination-btn.active{background:#667eea;color:#fff;border-color:#667eea;font-weight:600}.page-numbers{display:flex;gap:.25rem;align-items:center}.app{min-height:100vh;display:flex;flex-direction:column}.app-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:2rem;text-align:center;box-shadow:0 2px 10px #0000001a}.app-header h1{font-size:2.5rem;margin-bottom:.5rem}.app-header p{font-size:1.1rem;opacity:.9}.app-main{flex:1;max-width:1200px;width:100%;margin:0 auto;padding:2rem}*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.visible{visibility:visible!important}.static{position:static!important}.fixed{position:fixed!important}.absolute{position:absolute!important}.relative{position:relative!important}.sticky{position:sticky!important}.inset-0{top:0!important;right:0!important;bottom:0!important;left:0!important}.bottom-6{bottom:1.5rem!important}.bottom-\[5vh\]{bottom:5vh!important}.left-0{left:0!important}.right-6{right:1.5rem!important}.right-\[5vw\]{right:5vw!important}.top-0{top:0!important}.z-\[1000\]{z-index:1000!important}.z-\[1001\]{z-index:1001!important}.m-0{margin:0!important}.mx-5{margin-left:1.25rem!important;margin-right:1.25rem!important}.my-3{margin-top:.75rem!important;margin-bottom:.75rem!important}.my-4{margin-top:1rem!important;margin-bottom:1rem!important}.mb-1{margin-bottom:.25rem!important}.mb-2{margin-bottom:.5rem!important}.mb-3{margin-bottom:.75rem!important}.mb-4{margin-bottom:1rem!important}.mb-6{margin-bottom:1.5rem!important}.mb-8{margin-bottom:2rem!important}.ml-auto{margin-left:auto!important}.mt-1{margin-top:.25rem!important}.mt-2{margin-top:.5rem!important}.mt-3{margin-top:.75rem!important}.mt-4{margin-top:1rem!important}.mt-6{margin-top:1.5rem!important}.mt-8{margin-top:2rem!important}.mt-auto{margin-top:auto!important}.block{display:block!important}.inline-block{display:inline-block!important}.flex{display:flex!important}.inline-flex{display:inline-flex!important}.table{display:table!important}.grid{display:grid!important}.h-10{height:2.5rem!important}.h-11{height:2.75rem!important}.h-12{height:3rem!important}.h-16{height:4rem!important}.h-2{height:.5rem!important}.h-20{height:5rem!important}.h-24{height:6rem!important}.h-3{height:.75rem!important}.h-4{height:1rem!important}.h-5{height:1.25rem!important}.h-6{height:1.5rem!important}.h-8{height:2rem!important}.h-9{height:2.25rem!important}.h-\[600px\]{height:600px!important}.h-\[90vh\]{height:90vh!important}.h-full{height:100%!important}.max-h-\[120px\]{max-height:120px!important}.max-h-\[600px\]{max-height:600px!important}.max-h-\[900px\]{max-height:900px!important}.min-h-\[320px\]{min-height:320px!important}.min-h-\[48px\]{min-height:48px!important}.min-h-\[70vh\]{min-height:70vh!important}.w-1\/3{width:33.333333%!important}.w-10{width:2.5rem!important}.w-11{width:2.75rem!important}.w-12{width:3rem!important}.w-16{width:4rem!important}.w-2{width:.5rem!important}.w-20{width:5rem!important}.w-24{width:6rem!important}.w-3{width:.75rem!important}.w-4{width:1rem!important}.w-5{width:1.25rem!important}.w-6{width:1.5rem!important}.w-8{width:2rem!important}.w-9{width:2.25rem!important}.w-\[400px\]{width:400px!important}.w-\[90vw\]{width:90vw!important}.w-full{width:100%!important}.min-w-\[180px\]{min-width:180px!important}.min-w-\[200px\]{min-width:200px!important}.min-w-\[36px\]{min-width:36px!important}.min-w-\[50px\]{min-width:50px!important}.min-w-\[60px\]{min-width:60px!important}.min-w-full{min-width:100%!important}.max-w-\[1200px\]{max-width:1200px!important}.max-w-\[75\%\]{max-width:75%!important}.max-w-\[80px\]{max-width:80px!important}.max-w-lg{max-width:32rem!important}.flex-1{flex:1 1 0%!important}.flex-shrink-0{flex-shrink:0!important}.border-collapse{border-collapse:collapse!important}.scale-105{--tw-scale-x: 1.05 !important;--tw-scale-y: 1.05 !important;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))!important}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))!important}@keyframes bounce-in{0%{transform:scale(0);opacity:0}50%{transform:scale(1.2)}to{transform:scale(1);opacity:1}}.animate-bounce-in{animation:bounce-in .5s ease-out!important}@keyframes gradient-x{0%,to{background-size:200% 200%;background-position:left center}50%{background-size:200% 200%;background-position:right center}}.animate-gradient-x{animation:gradient-x 3s ease infinite!important}@keyframes ping{75%,to{transform:scale(2);opacity:0}}.animate-ping{animation:ping 1s cubic-bezier(0,0,.2,1) infinite!important}@keyframes pulse{50%{opacity:.5}}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite!important}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.animate-shimmer{animation:shimmer 2s infinite!important}@keyframes slide-up{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.animate-slide-up{animation:slide-up .5s ease-out!important}@keyframes spin{to{transform:rotate(360deg)}}.animate-spin{animation:spin 1s linear infinite!important}.cursor-pointer{cursor:pointer!important}.resize-none{resize:none!important}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))!important}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))!important}.flex-row-reverse{flex-direction:row-reverse!important}.flex-col{flex-direction:column!important}.flex-wrap{flex-wrap:wrap!important}.items-start{align-items:flex-start!important}.items-end{align-items:flex-end!important}.items-center{align-items:center!important}.justify-center{justify-content:center!important}.justify-between{justify-content:space-between!important}.gap-1{gap:.25rem!important}.gap-1\.5{gap:.375rem!important}.gap-2{gap:.5rem!important}.gap-2\.5{gap:.625rem!important}.gap-3{gap:.75rem!important}.gap-4{gap:1rem!important}.gap-6{gap:1.5rem!important}.space-y-2>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0 !important;margin-top:calc(.5rem * calc(1 - var(--tw-space-y-reverse)))!important;margin-bottom:calc(.5rem * var(--tw-space-y-reverse))!important}.space-y-4>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0 !important;margin-top:calc(1rem * calc(1 - var(--tw-space-y-reverse)))!important;margin-bottom:calc(1rem * var(--tw-space-y-reverse))!important}.space-y-6>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0 !important;margin-top:calc(1.5rem * calc(1 - var(--tw-space-y-reverse)))!important;margin-bottom:calc(1.5rem * var(--tw-space-y-reverse))!important}.divide-y>:not([hidden])~:not([hidden]){--tw-divide-y-reverse: 0 !important;border-top-width:calc(1px * calc(1 - var(--tw-divide-y-reverse)))!important;border-bottom-width:calc(1px * var(--tw-divide-y-reverse))!important}.divide-gray-200>:not([hidden])~:not([hidden]){--tw-divide-opacity: 1 !important;border-color:rgb(229 231 235 / var(--tw-divide-opacity, 1))!important}.self-start{align-self:flex-start!important}.overflow-hidden{overflow:hidden!important}.overflow-x-auto{overflow-x:auto!important}.overflow-y-auto{overflow-y:auto!important}.truncate{overflow:hidden!important;text-overflow:ellipsis!important;white-space:nowrap!important}.whitespace-nowrap{white-space:nowrap!important}.whitespace-pre-wrap{white-space:pre-wrap!important}.break-words{overflow-wrap:break-word!important}.rounded{border-radius:.25rem!important}.rounded-2xl{border-radius:1rem!important}.rounded-3xl{border-radius:1.5rem!important}.rounded-full{border-radius:9999px!important}.rounded-lg{border-radius:.5rem!important}.rounded-md{border-radius:.375rem!important}.rounded-xl{border-radius:.75rem!important}.rounded-b-xl{border-bottom-right-radius:.75rem!important;border-bottom-left-radius:.75rem!important}.rounded-r-lg{border-top-right-radius:.5rem!important;border-bottom-right-radius:.5rem!important}.rounded-t-2xl{border-top-left-radius:1rem!important;border-top-right-radius:1rem!important}.rounded-t-lg{border-top-left-radius:.5rem!important;border-top-right-radius:.5rem!important}.rounded-bl-sm{border-bottom-left-radius:.125rem!important}.rounded-br-sm{border-bottom-right-radius:.125rem!important}.border{border-width:1px!important}.border-2{border-width:2px!important}.border-4{border-width:4px!important}.border-b{border-bottom-width:1px!important}.border-b-2{border-bottom-width:2px!important}.border-b-4{border-bottom-width:4px!important}.border-l-4{border-left-width:4px!important}.border-t{border-top-width:1px!important}.border-none{border-style:none!important}.border-gray-100{--tw-border-opacity: 1 !important;border-color:rgb(243 244 246 / var(--tw-border-opacity, 1))!important}.border-gray-200{--tw-border-opacity: 1 !important;border-color:rgb(229 231 235 / var(--tw-border-opacity, 1))!important}.border-gray-300{--tw-border-opacity: 1 !important;border-color:rgb(209 213 219 / var(--tw-border-opacity, 1))!important}.border-gray-700{--tw-border-opacity: 1 !important;border-color:rgb(55 65 81 / var(--tw-border-opacity, 1))!important}.border-indigo-500{--tw-border-opacity: 1 !important;border-color:rgb(99 102 241 / var(--tw-border-opacity, 1))!important}.border-primary-100{--tw-border-opacity: 1 !important;border-color:rgb(224 233 255 / var(--tw-border-opacity, 1))!important}.border-primary-200{--tw-border-opacity: 1 !important;border-color:rgb(199 210 254 / var(--tw-border-opacity, 1))!important}.border-primary-500{--tw-border-opacity: 1 !important;border-color:rgb(102 126 234 / var(--tw-border-opacity, 1))!important}.border-primary-600{--tw-border-opacity: 1 !important;border-color:rgb(90 103 216 / var(--tw-border-opacity, 1))!important}.border-transparent{border-color:transparent!important}.border-yellow-400{--tw-border-opacity: 1 !important;border-color:rgb(250 204 21 / var(--tw-border-opacity, 1))!important}.border-b-primary-400{--tw-border-opacity: 1 !important;border-bottom-color:rgb(129 140 248 / var(--tw-border-opacity, 1))!important}.border-l-primary-500{--tw-border-opacity: 1 !important;border-left-color:rgb(102 126 234 / var(--tw-border-opacity, 1))!important}.border-r-primary-600{--tw-border-opacity: 1 !important;border-right-color:rgb(90 103 216 / var(--tw-border-opacity, 1))!important}.border-t-primary-500{--tw-border-opacity: 1 !important;border-top-color:rgb(102 126 234 / var(--tw-border-opacity, 1))!important}.bg-gray-100{--tw-bg-opacity: 1 !important;background-color:rgb(243 244 246 / var(--tw-bg-opacity, 1))!important}.bg-gray-200{--tw-bg-opacity: 1 !important;background-color:rgb(229 231 235 / var(--tw-bg-opacity, 1))!important}.bg-gray-400{--tw-bg-opacity: 1 !important;background-color:rgb(156 163 175 / var(--tw-bg-opacity, 1))!important}.bg-gray-50{--tw-bg-opacity: 1 !important;background-color:rgb(249 250 251 / var(--tw-bg-opacity, 1))!important}.bg-gray-600{--tw-bg-opacity: 1 !important;background-color:rgb(75 85 99 / var(--tw-bg-opacity, 1))!important}.bg-gray-700{--tw-bg-opacity: 1 !important;background-color:rgb(55 65 81 / var(--tw-bg-opacity, 1))!important}.bg-gray-800{--tw-bg-opacity: 1 !important;background-color:rgb(31 41 55 / var(--tw-bg-opacity, 1))!important}.bg-gray-900{--tw-bg-opacity: 1 !important;background-color:rgb(17 24 39 / var(--tw-bg-opacity, 1))!important}.bg-green-500{--tw-bg-opacity: 1 !important;background-color:rgb(34 197 94 / var(--tw-bg-opacity, 1))!important}.bg-green-600{--tw-bg-opacity: 1 !important;background-color:rgb(22 163 74 / var(--tw-bg-opacity, 1))!important}.bg-indigo-100{--tw-bg-opacity: 1 !important;background-color:rgb(224 231 255 / var(--tw-bg-opacity, 1))!important}.bg-indigo-500{--tw-bg-opacity: 1 !important;background-color:rgb(99 102 241 / var(--tw-bg-opacity, 1))!important}.bg-primary-100{--tw-bg-opacity: 1 !important;background-color:rgb(224 233 255 / var(--tw-bg-opacity, 1))!important}.bg-primary-400{--tw-bg-opacity: 1 !important;background-color:rgb(129 140 248 / var(--tw-bg-opacity, 1))!important}.bg-primary-50{--tw-bg-opacity: 1 !important;background-color:rgb(240 244 255 / var(--tw-bg-opacity, 1))!important}.bg-primary-500{--tw-bg-opacity: 1 !important;background-color:rgb(102 126 234 / var(--tw-bg-opacity, 1))!important}.bg-red-300{--tw-bg-opacity: 1 !important;background-color:rgb(252 165 165 / var(--tw-bg-opacity, 1))!important}.bg-red-500{--tw-bg-opacity: 1 !important;background-color:rgb(239 68 68 / var(--tw-bg-opacity, 1))!important}.bg-red-600{--tw-bg-opacity: 1 !important;background-color:rgb(220 38 38 / var(--tw-bg-opacity, 1))!important}.bg-white{--tw-bg-opacity: 1 !important;background-color:rgb(255 255 255 / var(--tw-bg-opacity, 1))!important}.bg-white\/20{background-color:#fff3!important}.bg-yellow-50{--tw-bg-opacity: 1 !important;background-color:rgb(254 252 232 / var(--tw-bg-opacity, 1))!important}.bg-yellow-500{--tw-bg-opacity: 1 !important;background-color:rgb(234 179 8 / var(--tw-bg-opacity, 1))!important}.bg-gradient-to-br{background-image:linear-gradient(to bottom right,var(--tw-gradient-stops))!important}.bg-gradient-to-r{background-image:linear-gradient(to right,var(--tw-gradient-stops))!important}.from-blue-50{--tw-gradient-from: #eff6ff var(--tw-gradient-from-position) !important;--tw-gradient-to: rgb(239 246 255 / 0) var(--tw-gradient-to-position) !important;--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to) !important}.from-gray-50{--tw-gradient-from: #f9fafb var(--tw-gradient-from-position) !important;--tw-gradient-to: rgb(249 250 251 / 0) var(--tw-gradient-to-position) !important;--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to) !important}.from-primary-50{--tw-gradient-from: #f0f4ff var(--tw-gradient-from-position) !important;--tw-gradient-to: rgb(240 244 255 / 0) var(--tw-gradient-to-position) !important;--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to) !important}.from-primary-500{--tw-gradient-from: #667eea var(--tw-gradient-from-position) !important;--tw-gradient-to: rgb(102 126 234 / 0) var(--tw-gradient-to-position) !important;--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to) !important}.from-primary-600{--tw-gradient-from: #5a67d8 var(--tw-gradient-from-position) !important;--tw-gradient-to: rgb(90 103 216 / 0) var(--tw-gradient-to-position) !important;--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to) !important}.from-transparent{--tw-gradient-from: transparent var(--tw-gradient-from-position) !important;--tw-gradient-to: rgb(0 0 0 / 0) var(--tw-gradient-to-position) !important;--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to) !important}.via-primary-400{--tw-gradient-to: rgb(129 140 248 / 0) var(--tw-gradient-to-position) !important;--tw-gradient-stops: var(--tw-gradient-from), #818cf8 var(--tw-gradient-via-position), var(--tw-gradient-to) !important}.via-primary-500{--tw-gradient-to: rgb(102 126 234 / 0) var(--tw-gradient-to-position) !important;--tw-gradient-stops: var(--tw-gradient-from), #667eea var(--tw-gradient-via-position), var(--tw-gradient-to) !important}.via-white{--tw-gradient-to: rgb(255 255 255 / 0) var(--tw-gradient-to-position) !important;--tw-gradient-stops: var(--tw-gradient-from), #fff var(--tw-gradient-via-position), var(--tw-gradient-to) !important}.via-white\/30{--tw-gradient-to: rgb(255 255 255 / 0) var(--tw-gradient-to-position) !important;--tw-gradient-stops: var(--tw-gradient-from), rgb(255 255 255 / .3) var(--tw-gradient-via-position), var(--tw-gradient-to) !important}.to-gray-100{--tw-gradient-to: #f3f4f6 var(--tw-gradient-to-position) !important}.to-indigo-50{--tw-gradient-to: #eef2ff var(--tw-gradient-to-position) !important}.to-primary-100\/50{--tw-gradient-to: rgb(224 233 255 / .5) var(--tw-gradient-to-position) !important}.to-primary-50\/30{--tw-gradient-to: rgb(240 244 255 / .3) var(--tw-gradient-to-position) !important}.to-primary-600{--tw-gradient-to: #5a67d8 var(--tw-gradient-to-position) !important}.to-transparent{--tw-gradient-to: transparent var(--tw-gradient-to-position) !important}.to-white{--tw-gradient-to: #fff var(--tw-gradient-to-position) !important}.bg-clip-text{-webkit-background-clip:text!important;background-clip:text!important}.p-2{padding:.5rem!important}.p-3{padding:.75rem!important}.p-4{padding:1rem!important}.p-5{padding:1.25rem!important}.p-6{padding:1.5rem!important}.p-8{padding:2rem!important}.px-2{padding-left:.5rem!important;padding-right:.5rem!important}.px-2\.5{padding-left:.625rem!important;padding-right:.625rem!important}.px-3{padding-left:.75rem!important;padding-right:.75rem!important}.px-4{padding-left:1rem!important;padding-right:1rem!important}.px-6{padding-left:1.5rem!important;padding-right:1.5rem!important}.py-0\.5{padding-top:.125rem!important;padding-bottom:.125rem!important}.py-1{padding-top:.25rem!important;padding-bottom:.25rem!important}.py-1\.5{padding-top:.375rem!important;padding-bottom:.375rem!important}.py-12{padding-top:3rem!important;padding-bottom:3rem!important}.py-2{padding-top:.5rem!important;padding-bottom:.5rem!important}.py-2\.5{padding-top:.625rem!important;padding-bottom:.625rem!important}.py-3{padding-top:.75rem!important;padding-bottom:.75rem!important}.py-3\.5{padding-top:.875rem!important;padding-bottom:.875rem!important}.py-4{padding-top:1rem!important;padding-bottom:1rem!important}.py-8{padding-top:2rem!important;padding-bottom:2rem!important}.pb-2{padding-bottom:.5rem!important}.pr-3{padding-right:.75rem!important}.pr-4{padding-right:1rem!important}.pt-3{padding-top:.75rem!important}.text-left{text-align:left!important}.text-center{text-align:center!important}.text-right{text-align:right!important}.font-mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace!important}.font-sans{font-family:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji"!important}.text-2xl{font-size:1.5rem!important;line-height:2rem!important}.text-3xl{font-size:1.875rem!important;line-height:2.25rem!important}.text-base{font-size:1rem!important;line-height:1.5rem!important}.text-lg{font-size:1.125rem!important;line-height:1.75rem!important}.text-sm{font-size:.875rem!important;line-height:1.25rem!important}.text-xl{font-size:1.25rem!important;line-height:1.75rem!important}.text-xs{font-size:.75rem!important;line-height:1rem!important}.font-bold{font-weight:700!important}.font-medium{font-weight:500!important}.font-semibold{font-weight:600!important}.uppercase{text-transform:uppercase!important}.lowercase{text-transform:lowercase!important}.leading-relaxed{line-height:1.625!important}.tracking-wide{letter-spacing:.025em!important}.tracking-wider{letter-spacing:.05em!important}.text-gray-100{--tw-text-opacity: 1 !important;color:rgb(243 244 246 / var(--tw-text-opacity, 1))!important}.text-gray-300{--tw-text-opacity: 1 !important;color:rgb(209 213 219 / var(--tw-text-opacity, 1))!important}.text-gray-400{--tw-text-opacity: 1 !important;color:rgb(156 163 175 / var(--tw-text-opacity, 1))!important}.text-gray-500{--tw-text-opacity: 1 !important;color:rgb(107 114 128 / var(--tw-text-opacity, 1))!important}.text-gray-600{--tw-text-opacity: 1 !important;color:rgb(75 85 99 / var(--tw-text-opacity, 1))!important}.text-gray-700{--tw-text-opacity: 1 !important;color:rgb(55 65 81 / var(--tw-text-opacity, 1))!important}.text-gray-800{--tw-text-opacity: 1 !important;color:rgb(31 41 55 / var(--tw-text-opacity, 1))!important}.text-gray-900{--tw-text-opacity: 1 !important;color:rgb(17 24 39 / var(--tw-text-opacity, 1))!important}.text-indigo-800{--tw-text-opacity: 1 !important;color:rgb(55 48 163 / var(--tw-text-opacity, 1))!important}.text-primary-500{--tw-text-opacity: 1 !important;color:rgb(102 126 234 / var(--tw-text-opacity, 1))!important}.text-primary-600{--tw-text-opacity: 1 !important;color:rgb(90 103 216 / var(--tw-text-opacity, 1))!important}.text-primary-800{--tw-text-opacity: 1 !important;color:rgb(67 65 144 / var(--tw-text-opacity, 1))!important}.text-transparent{color:transparent!important}.text-white{--tw-text-opacity: 1 !important;color:rgb(255 255 255 / var(--tw-text-opacity, 1))!important}.text-yellow-800{--tw-text-opacity: 1 !important;color:rgb(133 77 14 / var(--tw-text-opacity, 1))!important}.opacity-20{opacity:.2!important}.opacity-50{opacity:.5!important}.opacity-60{opacity:.6!important}.opacity-90{opacity:.9!important}.shadow-2xl{--tw-shadow: 0 25px 50px -12px rgb(0 0 0 / .25) !important;--tw-shadow-colored: 0 25px 50px -12px var(--tw-shadow-color) !important;box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)!important}.shadow-inner{--tw-shadow: inset 0 2px 4px 0 rgb(0 0 0 / .05) !important;--tw-shadow-colored: inset 0 2px 4px 0 var(--tw-shadow-color) !important;box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)!important}.shadow-lg{--tw-shadow: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1) !important;--tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color) !important;box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)!important}.shadow-md{--tw-shadow: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1) !important;--tw-shadow-colored: 0 4px 6px -1px var(--tw-shadow-color), 0 2px 4px -2px var(--tw-shadow-color) !important;box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)!important}.shadow-sm{--tw-shadow: 0 1px 2px 0 rgb(0 0 0 / .05) !important;--tw-shadow-colored: 0 1px 2px 0 var(--tw-shadow-color) !important;box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)!important}.shadow-primary-500\/40{--tw-shadow-color: rgb(102 126 234 / .4) !important;--tw-shadow: var(--tw-shadow-colored) !important}.shadow-primary-500\/50{--tw-shadow-color: rgb(102 126 234 / .5) !important;--tw-shadow: var(--tw-shadow-colored) !important}.blur-sm{--tw-blur: blur(4px) !important;filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)!important}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)!important}.transition-all{transition-property:all!important;transition-timing-function:cubic-bezier(.4,0,.2,1)!important;transition-duration:.15s!important}.transition-colors{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke!important;transition-timing-function:cubic-bezier(.4,0,.2,1)!important;transition-duration:.15s!important}.transition-shadow{transition-property:box-shadow!important;transition-timing-function:cubic-bezier(.4,0,.2,1)!important;transition-duration:.15s!important}.transition-transform{transition-property:transform!important;transition-timing-function:cubic-bezier(.4,0,.2,1)!important;transition-duration:.15s!important}.duration-200{transition-duration:.2s!important}.duration-300{transition-duration:.3s!important}.duration-500{transition-duration:.5s!important}.ease-out{transition-timing-function:cubic-bezier(0,0,.2,1)!important}.\[animation-delay\:0\.2s\]{animation-delay:.2s!important}.\[animation-delay\:0\.4s\]{animation-delay:.4s!important}*{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}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}#root{min-height:100vh}.last\:mb-0:last-child{margin-bottom:0!important}.hover\:-translate-y-0\.5:hover{--tw-translate-y: -.125rem !important;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))!important}.hover\:-translate-y-1:hover{--tw-translate-y: -.25rem !important;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))!important}.hover\:scale-105:hover{--tw-scale-x: 1.05 !important;--tw-scale-y: 1.05 !important;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))!important}.hover\:scale-110:hover{--tw-scale-x: 1.1 !important;--tw-scale-y: 1.1 !important;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))!important}.hover\:border-gray-300:hover{--tw-border-opacity: 1 !important;border-color:rgb(209 213 219 / var(--tw-border-opacity, 1))!important}.hover\:border-indigo-500:hover{--tw-border-opacity: 1 !important;border-color:rgb(99 102 241 / var(--tw-border-opacity, 1))!important}.hover\:border-primary-500:hover{--tw-border-opacity: 1 !important;border-color:rgb(102 126 234 / var(--tw-border-opacity, 1))!important}.hover\:bg-gray-300:hover{--tw-bg-opacity: 1 !important;background-color:rgb(209 213 219 / var(--tw-bg-opacity, 1))!important}.hover\:bg-gray-50:hover{--tw-bg-opacity: 1 !important;background-color:rgb(249 250 251 / var(--tw-bg-opacity, 1))!important}.hover\:bg-gray-600:hover{--tw-bg-opacity: 1 !important;background-color:rgb(75 85 99 / var(--tw-bg-opacity, 1))!important}.hover\:bg-gray-700:hover{--tw-bg-opacity: 1 !important;background-color:rgb(55 65 81 / var(--tw-bg-opacity, 1))!important}.hover\:bg-green-700:hover{--tw-bg-opacity: 1 !important;background-color:rgb(21 128 61 / var(--tw-bg-opacity, 1))!important}.hover\:bg-indigo-500:hover{--tw-bg-opacity: 1 !important;background-color:rgb(99 102 241 / var(--tw-bg-opacity, 1))!important}.hover\:bg-primary-600:hover{--tw-bg-opacity: 1 !important;background-color:rgb(90 103 216 / var(--tw-bg-opacity, 1))!important}.hover\:bg-white\/30:hover{background-color:#ffffff4d!important}.hover\:from-primary-600:hover{--tw-gradient-from: #5a67d8 var(--tw-gradient-from-position) !important;--tw-gradient-to: rgb(90 103 216 / 0) var(--tw-gradient-to-position) !important;--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to) !important}.hover\:to-primary-700:hover{--tw-gradient-to: #4c51bf var(--tw-gradient-to-position) !important}.hover\:text-gray-800:hover{--tw-text-opacity: 1 !important;color:rgb(31 41 55 / var(--tw-text-opacity, 1))!important}.hover\:text-white:hover{--tw-text-opacity: 1 !important;color:rgb(255 255 255 / var(--tw-text-opacity, 1))!important}.hover\:shadow-lg:hover{--tw-shadow: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1) !important;--tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color) !important;box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)!important}.hover\:shadow-xl:hover{--tw-shadow: 0 20px 25px -5px rgb(0 0 0 / .1), 0 8px 10px -6px rgb(0 0 0 / .1) !important;--tw-shadow-colored: 0 20px 25px -5px var(--tw-shadow-color), 0 8px 10px -6px var(--tw-shadow-color) !important;box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)!important}.hover\:shadow-primary-500\/40:hover{--tw-shadow-color: rgb(102 126 234 / .4) !important;--tw-shadow: var(--tw-shadow-colored) !important}.hover\:shadow-primary-500\/50:hover{--tw-shadow-color: rgb(102 126 234 / .5) !important;--tw-shadow: var(--tw-shadow-colored) !important}.focus\:border-indigo-500:focus{--tw-border-opacity: 1 !important;border-color:rgb(99 102 241 / var(--tw-border-opacity, 1))!important}.focus\:border-primary-500:focus{--tw-border-opacity: 1 !important;border-color:rgb(102 126 234 / var(--tw-border-opacity, 1))!important}.focus\:outline-none:focus{outline:2px solid transparent!important;outline-offset:2px!important}.focus\:ring-2:focus{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color) !important;--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color) !important;box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)!important}.focus\:ring-4:focus{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color) !important;--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(4px + var(--tw-ring-offset-width)) var(--tw-ring-color) !important;box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)!important}.focus\:ring-indigo-200:focus{--tw-ring-opacity: 1 !important;--tw-ring-color: rgb(199 210 254 / var(--tw-ring-opacity, 1)) !important}.focus\:ring-primary-500\/10:focus{--tw-ring-color: rgb(102 126 234 / .1) !important}.active\:translate-y-0:active{--tw-translate-y: 0px !important;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))!important}.active\:scale-95:active{--tw-scale-x: .95 !important;--tw-scale-y: .95 !important;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))!important}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed!important}.disabled\:bg-gray-100:disabled{--tw-bg-opacity: 1 !important;background-color:rgb(243 244 246 / var(--tw-bg-opacity, 1))!important}.disabled\:opacity-50:disabled{opacity:.5!important}.disabled\:hover\:translate-y-0:hover:disabled{--tw-translate-y: 0px !important;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))!important}.disabled\:hover\:border-gray-300:hover:disabled{--tw-border-opacity: 1 !important;border-color:rgb(209 213 219 / var(--tw-border-opacity, 1))!important}.disabled\:hover\:bg-gray-100:hover:disabled{--tw-bg-opacity: 1 !important;background-color:rgb(243 244 246 / var(--tw-bg-opacity, 1))!important}.disabled\:hover\:text-gray-800:hover:disabled{--tw-text-opacity: 1 !important;color:rgb(31 41 55 / var(--tw-text-opacity, 1))!important}.group:hover .group-hover\:translate-x-1{--tw-translate-x: .25rem !important;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))!important}@media (min-width: 768px){.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))!important}.md\:p-12{padding:3rem!important}.md\:text-4xl{font-size:2.25rem!important;line-height:2.5rem!important}.md\:text-lg{font-size:1.125rem!important;line-height:1.75rem!important}}@media (min-width: 1024px){.lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))!important}}@media (prefers-color-scheme: dark){.dark\:border-gray-700{--tw-border-opacity: 1 !important;border-color:rgb(55 65 81 / var(--tw-border-opacity, 1))!important}.dark\:bg-gray-700{--tw-bg-opacity: 1 !important;background-color:rgb(55 65 81 / var(--tw-bg-opacity, 1))!important}.dark\:bg-gray-800{--tw-bg-opacity: 1 !important;background-color:rgb(31 41 55 / var(--tw-bg-opacity, 1))!important}.dark\:text-gray-300{--tw-text-opacity: 1 !important;color:rgb(209 213 219 / var(--tw-text-opacity, 1))!important}.dark\:text-gray-400{--tw-text-opacity: 1 !important;color:rgb(156 163 175 / var(--tw-text-opacity, 1))!important}.dark\:hover\:bg-gray-600:hover{--tw-bg-opacity: 1 !important;background-color:rgb(75 85 99 / var(--tw-bg-opacity, 1))!important}}
