body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;background-color:#fff;color:#111;line-height:1.5}.landing-container{display:flex;flex-direction:column;min-height:100vh}.landing-header{display:flex;justify-content:space-between;padding:1rem 2rem;border-bottom:1px solid #eee;align-items:center;max-width:1200px;margin:0 auto;width:100%;box-sizing:border-box}.logo-container{display:flex;align-items:center;gap:.5rem}.logo-circle{background-color:#22c55e;color:#fff;width:2rem;height:2rem;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700}.logo-text{font-size:1.2rem;font-weight:700}.auth-buttons{display:flex;gap:1rem;align-items:center}.login-btn{text-decoration:none;color:#111;font-weight:500}.signup-btn{padding:.5rem 1rem;background-color:#22c55e;color:#fff;border-radius:6px;font-weight:500;text-decoration:none}.landing-main{display:flex;justify-content:space-between;align-items:center;padding:4rem 2rem;max-width:1200px;margin:0 auto;width:100%;box-sizing:border-box;gap:4rem}.text-section{flex:1;max-width:600px}.text-section h1{font-size:3.5rem;margin-bottom:1rem;line-height:1.1;font-weight:700}.text-section p{color:#555;font-size:1.1rem;margin-bottom:2rem;max-width:500px}.buttons{display:flex;gap:1rem;flex-wrap:wrap}.btn-green{background-color:#22c55e;color:#fff;padding:.8rem 1.5rem;border-radius:8px;text-decoration:none;font-weight:500;display:inline-block;transition:background-color .2s}.btn-green:hover{background-color:#1ea550}.arrow{margin-left:4px}.btn-white{padding:.8rem 1.5rem;border:1px solid #ddd;border-radius:8px;text-decoration:none;color:#111;font-weight:500;display:inline-block;transition:background-color .2s}.btn-white:hover{background-color:#f5f5f5}.chat-bubble{flex:1;max-width:450px;background:#fff;border:1px solid #e1f7eb;border-radius:12px;padding:1.5rem;box-shadow:0 8px 30px #0000000f}.chat-header{display:flex;align-items:center;gap:.5rem;margin-bottom:1rem}.chat-avatar{display:flex;align-items:center;justify-content:center}.avatar-circle{background-color:#22c55e;color:#fff;width:1.8rem;height:1.8rem;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.8rem}.bubble-container{display:flex;flex-direction:column;gap:.8rem}.bubble{padding:.8rem 1rem;border-radius:8px;max-width:90%;font-size:.95rem}.bubble.assistant{background:#f5f5f5;align-self:flex-start}.bubble.user{background:#e6f7ee;align-self:flex-end}.features{background-color:#f7f7f7;padding:5rem 2rem;text-align:center}.features h2{font-size:2.5rem;margin-bottom:.5rem;font-weight:700}.features-subtitle{color:#555;margin-bottom:3rem;font-size:1.1rem;max-width:700px;margin-left:auto;margin-right:auto}.feature-list{display:flex;justify-content:center;gap:2rem;flex-wrap:wrap;max-width:1200px;margin:0 auto}.feature-box{background:#fff;padding:2rem;border-radius:10px;width:300px;box-shadow:0 6px 12px #0000000d;text-align:center;display:flex;flex-direction:column;align-items:center}.feature-icon{width:3rem;height:3rem;border-radius:50%;background-color:#e6f7ee;margin-bottom:1.5rem;display:flex;align-items:center;justify-content:center;color:#22c55e}.feature-box h3{margin-bottom:.8rem;font-weight:600}.feature-box p{color:#555;font-size:.95rem;line-height:1.5}.landing-footer{padding:2rem;text-align:center;font-size:.9rem;color:#666;margin-top:auto;border-top:1px solid #eee}.footer-links{margin-top:.5rem}.landing-footer a{color:#666;text-decoration:none}@media (max-width: 1024px){.landing-main{flex-direction:column;padding:3rem 2rem;text-align:center}.text-section{max-width:100%}.text-section p{margin-left:auto;margin-right:auto}.buttons{justify-content:center}.chat-bubble{max-width:100%}}@media (max-width: 768px){.landing-header{padding:1rem}.text-section h1{font-size:2.5rem}.feature-list{gap:1.5rem}.feature-box{width:100%;max-width:350px}}.password-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.forgot-link{font-size:.85rem;color:#22c55e;text-decoration:none}.auth-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background-color:#f2fdf6;padding:1rem}.auth-form{background-color:#fff;padding:2.5rem;border-radius:12px;width:100%;max-width:400px;box-shadow:0 0 20px #0000000d}.auth-logo{background-color:#22c55e;color:#fff;width:3rem;height:3rem;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;margin:0 auto 1.5rem;font-size:1.2rem}.auth-form h2{text-align:center;font-size:1.5rem;margin-bottom:.5rem;font-weight:600}.auth-subtitle{text-align:center;color:#666;margin-bottom:2rem;font-size:.95rem}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;font-size:.95rem;color:#333}.auth-form input{width:100%;padding:.8rem;border:1px solid #ddd;border-radius:6px;font-size:.95rem;box-sizing:border-box}.auth-form input:focus{outline:none;border-color:#22c55e;box-shadow:0 0 0 2px #22c55e1a}.auth-button{background-color:#22c55e;color:#fff;border:none;width:100%;padding:.9rem;border-radius:6px;font-weight:500;cursor:pointer;margin-top:1rem;font-size:1rem;transition:background-color .2s}.auth-button:hover{background-color:#1ea550}.divider{text-align:center;margin:1.5rem 0;color:#888;font-size:.8rem;position:relative}.divider:before,.divider:after{content:"";position:absolute;top:50%;width:35%;height:1px;background-color:#ddd}.divider:before{left:0}.divider:after{right:0}.social-buttons{display:flex;gap:1rem;margin-bottom:1.5rem}.social{flex:1;padding:.8rem;border:1px solid #ddd;background:#fff;border-radius:6px;cursor:pointer;display:flex;justify-content:center;align-items:center;gap:.5rem;transition:background-color .2s}.social:hover{background-color:#f5f5f5}.toggle-link{text-align:center;font-size:.9rem;color:#555;margin-top:.5rem}.toggle-link a{color:#22c55e;text-decoration:none;font-weight:500}.toggle-link a:hover{text-decoration:underline}.field-editor{max-width:1200px;margin:0 auto;padding:20px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.field-editor-header{margin-bottom:30px;text-align:center}.field-editor-header h2{color:#1a202c;font-size:2rem;font-weight:600;margin-bottom:8px}.field-editor-header p{color:#718096;font-size:1.1rem}.error-message{background-color:#fed7d7;border:1px solid #feb2b2;color:#c53030;padding:12px 16px;border-radius:8px;margin-bottom:20px;display:flex;align-items:center;gap:8px}.saving-indicator{background-color:#bee3f8;border:1px solid #90cdf4;color:#2b6cb0;padding:12px 16px;border-radius:8px;margin-bottom:20px;display:flex;align-items:center;gap:8px;font-weight:500}.field-editor-controls{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:30px}.control-group{background:#f7fafc;padding:20px;border-radius:12px;border:1px solid #e2e8f0}.control-group label{display:block;font-weight:600;color:#2d3748;margin-bottom:4px;font-size:1.1rem}.control-group p{color:#718096;font-size:.9rem;margin-bottom:12px}.control-group select{width:100%;padding:12px 16px;border:2px solid #e2e8f0;border-radius:8px;font-size:1rem;background-color:#fff;transition:border-color .2s}.control-group select:focus{outline:none;border-color:#4299e1;box-shadow:0 0 0 3px #4299e11a}.control-group select:disabled{background-color:#f7fafc;cursor:not-allowed}.debug-info{color:#48bb78;font-size:.85rem;margin-top:8px;font-weight:500}.table-data-section{background:#fff;border-radius:12px;border:1px solid #e2e8f0;overflow:hidden;box-shadow:0 1px 3px #0000001a}.table-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;background:#f7fafc;border-bottom:1px solid #e2e8f0}.table-header h3{color:#2d3748;font-size:1.3rem;font-weight:600;margin:0}.loading{text-align:center;padding:40px;color:#718096;font-size:1.1rem}.excel-table-container{overflow-x:auto;max-height:600px;overflow-y:auto}.excel-table{width:100%;border-collapse:collapse;font-size:.9rem;background:#fff}.excel-table th{background:#edf2f7;color:#2d3748;font-weight:600;padding:12px 16px;text-align:left;border-bottom:2px solid #e2e8f0;border-right:1px solid #e2e8f0;position:sticky;top:0;z-index:10}.excel-table th:last-child{border-right:none}.excel-table th.actions-column{width:80px;text-align:center}.excel-table tbody tr{transition:background-color .1s}.excel-table tbody tr:hover{background-color:#f7fafc}.excel-table tbody tr:nth-child(2n){background-color:#fafafa}.excel-table tbody tr:nth-child(2n):hover{background-color:#f1f5f9}.excel-table td{border-bottom:1px solid #e2e8f0;border-right:1px solid #e2e8f0;padding:0;position:relative}.excel-table td:last-child{border-right:none}.excel-cell-container{min-width:120px}.excel-cell{padding:12px 16px;min-height:20px;cursor:pointer;transition:background-color .1s;border:2px solid transparent;word-break:break-word;white-space:pre-wrap}.excel-cell:hover{background-color:#f0f9ff;border-color:#bae6fd}.excel-cell-input{width:100%;padding:12px 16px;border:2px solid #4299e1;background-color:#e3f2fd;font-size:.9rem;font-family:inherit;outline:none;border-radius:0;min-height:20px;box-sizing:border-box}.excel-cell-input:focus{background-color:#e3f2fd;border-color:#2b6cb0;box-shadow:0 0 0 1px #2b6cb0}.actions-cell{text-align:center;padding:8px;width:80px}.delete-btn{background:none;border:none;padding:6px 8px;border-radius:4px;cursor:pointer;font-size:1.1rem;transition:background-color .2s;color:#e53e3e}.delete-btn:hover:not(:disabled){background:#fed7d7}.delete-btn:disabled{opacity:.5;cursor:not-allowed}.add-record-section{padding:20px;text-align:center;background:#f7fafc;border-top:1px solid #e2e8f0}.add-record-btn-bottom{background:#48bb78;color:#fff;border:none;padding:12px 24px;border-radius:8px;font-weight:500;cursor:pointer;transition:background-color .2s;display:inline-flex;align-items:center;gap:8px;font-size:1rem}.add-record-btn-bottom:hover:not(:disabled){background:#38a169;transform:translateY(-1px)}.add-record-btn-bottom:disabled{background:#a0aec0;cursor:not-allowed;transform:none}.add-record-btn{background:#48bb78;color:#fff;border:none;padding:10px 20px;border-radius:8px;font-weight:500;cursor:pointer;transition:background-color .2s;display:flex;align-items:center;gap:8px}.add-record-btn:hover:not(:disabled){background:#38a169}.add-record-btn:disabled{background:#a0aec0;cursor:not-allowed}.no-data{text-align:center;padding:60px 20px;color:#718096}.no-data p{font-size:1.1rem;margin-bottom:20px}@media (max-width: 768px){.field-editor{padding:15px}.field-editor-controls{grid-template-columns:1fr;gap:15px}.table-header{flex-direction:column;gap:15px;align-items:stretch}.excel-table{font-size:.8rem}.excel-table th,.excel-cell,.excel-cell-input{padding:8px 12px}.excel-cell-container{min-width:100px}}.excel-table.loading{opacity:.6;pointer-events:none}.database-optimization{padding:20px;max-width:1400px;margin:0 auto;background-color:#f9fafb;min-height:100vh}.optimization-tabs{display:flex;gap:8px;margin-bottom:24px;border-bottom:1px solid #e5e7eb;padding-bottom:0}.tab{display:inline-flex;align-items:center;padding:.75rem 1rem;border-bottom:2px solid transparent;font-weight:500;font-size:.875rem;color:#6b7280;background:none;border:none;cursor:pointer;transition:all .2s ease;margin-right:2rem}.tab:hover{color:#374151;border-bottom-color:#d1d5db}.tab.active{color:#059669;border-bottom-color:#059669}.tab-icon{margin-right:.5rem;font-size:1rem}.tab-content{background:#fff;border-radius:0 8px 8px;min-height:400px}.existing-databases-tab{padding:40px;text-align:center}.coming-soon{max-width:600px;margin:0 auto;text-align:center;padding:4rem 2rem;background-color:#f9fafb;border-radius:.5rem}.coming-soon-icon{font-size:4rem;margin-bottom:1rem}.coming-soon h3{font-size:1.5rem;font-weight:600;color:#111827;margin-bottom:.5rem}.coming-soon p{color:#6b7280;margin-bottom:.5rem}.coming-soon small{color:#9ca3af;font-size:.875rem}.features-preview{background:#f8f9fa;padding:24px;border-radius:8px;text-align:left;margin-top:30px}.features-preview h4{color:#495057;margin-bottom:16px;font-size:18px}.features-preview ul{list-style:none;padding:0;margin:0}.features-preview li{padding:8px 0;color:#6c757d;font-size:14px}.schema-upload-optimization{padding:0}.optimization-header{padding:30px 40px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;margin:0;margin-bottom:2rem}.optimization-header h1{margin:0 0 8px;font-size:2rem;font-weight:700;color:#111827;margin-bottom:.5rem}.optimization-header p{margin:0;opacity:.9;font-size:16px;color:#6b7280}.alert{display:flex;align-items:flex-start;gap:12px;padding:16px 40px;margin:0;font-size:14px;font-weight:500;background-color:#fef2f2;border:1px solid #fecaca;border-radius:.5rem;margin-bottom:1.5rem}.alert-error{background-color:#fef2f2;color:#991b1b;border:1px solid #fecaca}.alert-success{background-color:#f0fdf4;color:#166534;border:1px solid #bbf7d0}.alert-icon{font-size:16px;margin-right:.75rem}.alert h3{font-weight:500;font-size:.875rem;margin-bottom:.5rem}.alert-error h3{color:#991b1b}.alert-success h3{color:#166534}.alert-error div{color:#b91c1c;font-size:.875rem}.alert-success div{color:#15803d;font-size:.875rem}.optimization-content{display:grid;grid-template-columns:400px 1fr;min-height:600px;gap:2rem}.schemas-panel{background:#f8f9fa;border-right:1px solid #e9ecef;display:flex;flex-direction:column;background-color:#fff;border-radius:.5rem;border:1px solid #e5e7eb;overflow:hidden}.panel-header{display:flex;justify-content:between;align-items:center;padding:20px;border-bottom:1px solid #e9ecef;background:#fff;padding:1.5rem;border-bottom:1px solid #e5e7eb;background-color:#f9fafb}.panel-header h3{font-size:18px;flex:1;font-size:1.125rem;font-weight:600;color:#111827;margin:0}.upload-zone{margin:20px;border:2px dashed #dee2e6;border-radius:8px;padding:30px 20px;transition:all .3s ease;cursor:pointer;background:#fff;border:2px dashed #d1d5db;border-radius:.5rem;padding:2rem;text-align:center;transition:all .2s ease;margin-bottom:1rem}.upload-zone:hover{border-color:#007bff;background:#f8f9ff;border-color:#9ca3af}.upload-zone.drag-active{border-color:#007bff;background:#e3f2fd;transform:scale(1.02);border-color:#059669;background-color:#f0fdf4}.upload-zone.uploading{border-color:#28a745;background:#f0fff4;opacity:.6;pointer-events:none}.upload-content{gap:12px;display:flex;flex-direction:column;align-items:center}.upload-icon{font-size:48px;opacity:.6;font-size:3rem;margin-bottom:1rem}.upload-text p{margin:4px 0;margin:.5rem 0;color:#374151}.upload-text strong{color:#007bff;font-weight:600}.upload-info{margin-top:8px;margin-top:1rem}.upload-info small{color:#6c757d;font-size:12px;color:#6b7280;font-size:.75rem}.schemas-list{flex:1;padding:0 20px 20px;padding:1rem;max-height:400px;overflow-y:auto}.loading-state,.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;color:#6c757d;text-align:center;padding:3rem 1rem}.empty-icon{font-size:48px;margin-bottom:16px;font-size:4rem;margin-bottom:1rem;opacity:.6}.empty-state p{margin:8px 0 4px;font-weight:500;color:#495057;color:#6b7280}.empty-state small{font-size:12px;color:#9ca3af;font-size:.875rem}.schema-item{background:#fff;border:1px solid #e9ecef;border-radius:8px;padding:16px;margin-bottom:12px;display:flex;justify-content:space-between;align-items:flex-start;padding:1rem;border:1px solid #e5e7eb;border-radius:.5rem;margin-bottom:.75rem;cursor:pointer;transition:all .2s ease;background-color:#fff}.schema-item:hover{border-color:#007bff;box-shadow:0 2px 8px #007bff1a;border-color:#d1d5db;background-color:#f9fafb}.schema-item.selected{border-color:#007bff;background:#f8f9ff;box-shadow:0 2px 8px #007bff26;border-color:#059669;background-color:#f0fdf4}.schema-info{flex:1}.schema-name{margin-bottom:8px;font-size:14px;font-weight:600;color:#111827;margin-bottom:.5rem}.schema-meta{gap:12px;margin-bottom:8px;display:flex;gap:1rem;margin-bottom:.5rem}.schema-type,.schema-date{font-size:12px;color:#6c757d;font-size:.75rem;color:#6b7280}.schema-status{display:flex;gap:8px;flex-wrap:wrap}.status-badge{font-size:11px;padding:2px 6px;display:inline-block;padding:.25rem .5rem;border-radius:9999px;font-size:.75rem;font-weight:500}.status-uploaded{background:#e3f2fd;color:#1976d2;background-color:#dbeafe;color:#1e40af}.status-analyzed{background:#fff3e0;color:#f57c00;background-color:#fef3c7;color:#d97706}.status-modified{background:#e8f5e8;color:#2e7d32;background-color:#d1fae5;color:#065f46}.status-active{background-color:#d1fae5;color:#065f46}.modification-badge{background:#f3e5f5;color:#7b1fa2;font-size:11px;padding:2px 6px;background-color:#fed7aa;color:#ea580c;padding:.25rem .5rem;border-radius:9999px;font-size:.75rem;font-weight:500;margin-left:.5rem}.schema-actions{gap:4px;display:flex;align-items:center;gap:.5rem}.btn-icon{padding:4px;border-radius:4px;font-size:14px;transition:all .2s ease;background:none;border:none;padding:.5rem;border-radius:.25rem;cursor:pointer;transition:background-color .2s ease}.btn-icon:hover{background:#f8f9fa;background-color:#f3f4f6}.btn-icon.btn-danger:hover{background:#f8d7da;background-color:#fef2f2;color:#dc2626}.analysis-panel{background:#fff;display:flex;flex-direction:column;background-color:#fff;border-radius:.5rem;border:1px solid #e5e7eb;overflow:hidden}.no-selection{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:#6c757d;padding:40px;text-align:center;padding:3rem 1rem}.no-selection-icon{font-size:64px;margin-bottom:20px;font-size:4rem;margin-bottom:1rem;opacity:.6}.no-selection h3{margin-bottom:12px;color:#111827;margin-bottom:.5rem}.no-selection p{max-width:400px;line-height:1.5;color:#6b7280}.analysis-actions{gap:12px;display:flex;gap:.5rem;align-items:center}.analysis-meta{gap:8px;display:flex;gap:.5rem;align-items:center}.analysis-content{flex:1;padding:20px;overflow-y:auto}.analysis-summary{margin-bottom:30px;margin-bottom:2rem}.summary-card{background:#f8f9fa;border-radius:8px;padding:24px;background-color:#fff;border:1px solid #e5e7eb;border-radius:.5rem;padding:1.5rem}.summary-card h4{margin:0 0 20px;font-size:18px;font-size:1.125rem;font-weight:600;color:#111827;margin-bottom:1rem}.summary-stats{grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:20px;display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}.stat{text-align:center;padding:1rem;border-radius:.5rem}.stat:nth-child(1){background-color:#eff6ff}.stat:nth-child(2){background-color:#fffbeb}.stat:nth-child(3){background-color:#f0fdf4}.stat-value{font-size:32px;color:#007bff;margin-bottom:4px;display:block;font-size:2rem;font-weight:700;margin-bottom:.25rem}.stat:nth-child(1) .stat-value{color:#2563eb}.stat:nth-child(2) .stat-value{color:#d97706}.stat:nth-child(3) .stat-value{color:#059669}.stat-label{font-size:12px;color:#6c757d;font-size:.875rem;color:#6b7280}.recommendations-section h4{margin-bottom:12px;font-size:24px;margin-bottom:.5rem;font-size:1.125rem;font-weight:600;color:#111827;margin:0;padding:1.5rem;border-bottom:1px solid #e5e7eb;background-color:#f9fafb}.no-recommendations{padding:40px;color:#6c757d;text-align:center;padding:3rem}.no-recommendations-icon{font-size:64px;margin-bottom:20px;font-size:4rem;margin-bottom:1rem}.no-recommendations h5{color:#28a745;margin-bottom:8px;font-size:1.25rem;font-weight:600;color:#111827;margin-bottom:.5rem}.no-recommendations p{max-width:400px;line-height:1.5;color:#6b7280}.recommendations-list{display:flex;flex-direction:column;gap:16px;divide-y:1px solid #e5e7eb}.recommendation-card{border:1px solid #e9ecef;border-radius:8px;overflow:hidden;transition:all .2s ease;padding:1.5rem;transition:background-color .2s ease}.recommendation-card:hover{box-shadow:0 2px 8px #0000001a;background-color:#f9fafb}.recommendation-card.applied{border-color:#28a745;background:#f8fff9;background-color:#f0fdf4;border-left:4px solid #10b981}.recommendation-header{align-items:center;padding:20px;background:#fff;border-bottom:1px solid #e9ecef;margin-bottom:1rem;display:flex;justify-content:space-between;align-items:flex-start;gap:1rem}.recommendation-title{gap:8px;display:flex;align-items:center;flex:1;flex-direction:column;align-items:flex-start;gap:.5rem}.type-icon{font-size:16px;font-size:1.5rem}.title{font-size:16px;font-weight:600;color:#111827;font-size:1.125rem}.priority-badge{padding:4px 8px;font-size:11px;padding:.25rem .5rem;border-radius:9999px;font-size:.75rem;font-weight:500;color:#fff;text-transform:uppercase}.applied-badge{background:#28a745;color:#fff;padding:6px 12px;font-size:12px;background-color:#d1fae5;color:#065f46;padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:500}.recommendation-content{padding:20px;color:#374151}.description{margin:0 0 16px;color:#495057;margin-bottom:1rem;line-height:1.6}.benefits{margin-bottom:16px;margin-bottom:1rem}.benefits strong{display:block;margin-bottom:8px;color:#111827;font-weight:600}.benefits ul{margin:0;padding-left:20px;margin-top:.5rem;margin-left:1rem}.benefits li{color:#6c757d;margin-bottom:4px;font-size:14px;margin-bottom:.25rem;color:#6b7280}.sql-code{margin-bottom:16px;margin-bottom:1rem}.sql-code strong{display:block;margin-bottom:8px;color:#111827;font-weight:600}.sql-code pre{background:#f8f9fa;border:1px solid #e9ecef;border-radius:4px;padding:12px;margin:0;font-size:13px;margin-top:.5rem;background-color:#f3f4f6;padding:1rem;border-radius:.375rem;overflow-x:auto;font-size:.875rem;border:1px solid #e5e7eb}.sql-code code{color:#374151;font-family:Monaco,Menlo,Ubuntu Mono,monospace}.recommendation-meta{gap:20px;display:flex;gap:1rem;flex-wrap:wrap;margin-top:1rem;padding-top:1rem;border-top:1px solid #e5e7eb}.meta-item{font-size:12px;color:#6c757d;font-size:.875rem;color:#6b7280}.meta-item strong{color:#374151}.no-analysis{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:#6c757d;padding:40px;text-align:center;padding:3rem 1rem}.no-analysis-icon{font-size:64px;margin-bottom:20px;font-size:4rem;margin-bottom:1rem;opacity:.6}.no-analysis h4{margin-bottom:12px;color:#111827;margin-bottom:.5rem}.no-analysis p{max-width:400px;line-height:1.5;color:#6b7280}.btn{gap:8px;padding:8px 16px;border:1px solid transparent;border-radius:6px;font-size:14px;background:none;display:inline-flex;align-items:center;justify-content:center;padding:.5rem 1rem;border-radius:.375rem;font-weight:500;font-size:.875rem;transition:all .2s ease;cursor:pointer;border:none;text-decoration:none}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:#007bff;border-color:#007bff;background-color:#059669;color:#fff}.btn-primary:hover:not(:disabled){background:#0056b3;border-color:#0056b3;background-color:#047857}.btn-success{background:#28a745;border-color:#28a745;background-color:#10b981;color:#fff}.btn-success:hover:not(:disabled){background:#1e7e34;border-color:#1e7e34;background-color:#059669}.btn-outline{background:#fff;color:#007bff;border-color:#007bff;background-color:transparent;color:#374151;border:1px solid #d1d5db}.btn-outline:hover:not(:disabled){background:#007bff;color:#fff;background-color:#f9fafb;border-color:#9ca3af}.btn-sm{padding:6px 12px;font-size:12px;padding:.375rem .75rem;font-size:.75rem}.spinner{width:20px;height:20px;border:2px solid #f3f3f3;border-top:2px solid #007bff;display:inline-block;width:2rem;height:2rem;border:3px solid #f3f4f6;border-top:3px solid #059669;border-radius:50%;animation:spin 1s linear infinite}.spinner-sm{width:16px;height:16px;border:2px solid #f3f3f3;border-top:2px solid #ffffff;border-radius:50%;width:1rem;height:1rem;border-width:2px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (max-width: 1024px){.optimization-content{grid-template-columns:1fr;gap:1rem}.schemas-panel{border-right:none;border-bottom:1px solid #e9ecef}.summary-stats{grid-template-columns:1fr}.recommendation-header{flex-direction:column;align-items:flex-start;gap:1rem}.recommendation-title{flex-direction:column;align-items:flex-start;gap:.5rem}.analysis-actions,.analysis-meta{flex-direction:column;width:100%}.tab{margin-right:1rem;padding:.5rem .75rem}}@media (max-width: 768px){.database-optimization{padding:10px}.optimization-header{padding:20px}.optimization-header h2{font-size:24px}.alert{padding:12px 20px}.analysis-content{padding:20px}.summary-stats{grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:16px}.recommendation-meta{flex-direction:column;gap:8px}.analysis-actions{flex-direction:column;align-items:stretch}.analysis-meta{flex-direction:column;gap:8px}}@media (max-width: 640px){.optimization-header h1{font-size:1.5rem}.upload-zone{padding:1.5rem}.upload-icon{font-size:2rem}.panel-header,.recommendation-card,.summary-card{padding:1rem}}.schema-based-creation{max-width:1200px;margin:0 auto;padding:0}.schema-header{margin-bottom:2rem}.schema-title{font-size:2rem;font-weight:700;color:#1f2937;margin-bottom:.5rem}.schema-subtitle{color:#6b7280;font-size:1rem;line-height:1.5}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:2rem}.stat-card{background:#fff;border:1px solid #e5e7eb;border-radius:.5rem;padding:1.5rem;text-align:center;transition:all .2s ease}.stat-card:hover{border-color:#10b981;box-shadow:0 4px 6px -1px #0000001a}.stat-number{font-size:2rem;font-weight:700;color:#10b981;margin-bottom:.5rem}.stat-label{color:#6b7280;font-size:.875rem;font-weight:500}.upload-section{background:#fff;border:1px solid #e5e7eb;border-radius:.75rem;padding:2rem;margin-bottom:2rem}.upload-area{border:2px dashed #d1d5db;border-radius:.75rem;padding:3rem 2rem;text-align:center;cursor:pointer;transition:all .3s ease;background:#fafafa}.upload-area:hover{border-color:#10b981;background:#f0fdf4}.upload-area.drag-active{border-color:#10b981;background:#f0fdf4;transform:scale(1.02)}.upload-area.file-selected{border-color:#10b981;background:#f0fdf4}.upload-placeholder{display:flex;flex-direction:column;align-items:center;gap:1rem}.upload-icon{color:#9ca3af}.upload-text{text-align:center}.upload-primary{font-size:1.125rem;font-weight:600;color:#374151;margin-bottom:.5rem}.upload-secondary{color:#6b7280;margin-bottom:.5rem}.upload-formats{font-size:.875rem;color:#9ca3af}.file-info{display:flex;align-items:center;gap:1rem;padding:1rem;background:#fff;border-radius:.5rem;border:1px solid #e5e7eb}.file-icon{color:#10b981;flex-shrink:0}.file-details{flex:1}.file-name{font-weight:600;color:#374151;margin-bottom:.25rem}.file-size{font-size:.875rem;color:#6b7280}.remove-file{background:#fee2e2;color:#dc2626;border:none;border-radius:.375rem;padding:.5rem;cursor:pointer;transition:all .2s ease;flex-shrink:0}.remove-file:hover{background:#fecaca}.project-name-section{margin:1.5rem 0}.project-label{display:block;font-weight:600;color:#374151;margin-bottom:.5rem}.project-input{width:100%;padding:.75rem;border:1px solid #d1d5db;border-radius:.5rem;font-size:1rem;transition:all .2s ease}.project-input:focus{outline:none;border-color:#10b981;box-shadow:0 0 0 3px #10b9811a}.project-input:disabled{background:#f9fafb;color:#9ca3af}.upload-button{width:100%;background:#10b981;color:#fff;border:none;border-radius:.5rem;padding:.875rem 1.5rem;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:.5rem}.upload-button:hover:not(:disabled){background:#059669;transform:translateY(-1px);box-shadow:0 4px 6px -1px #0000001a}.upload-button:disabled{background:#d1d5db;color:#9ca3af;cursor:not-allowed;transform:none;box-shadow:none}.spinner{width:1rem;height:1rem;border:2px solid transparent;border-top:2px solid currentColor;border-radius:50%;animation:spin 1s linear infinite}.progress-section{margin-top:1rem;display:flex;align-items:center;gap:1rem}.progress-bar{flex:1;height:.5rem;background:#e5e7eb;border-radius:.25rem;overflow:hidden}.progress-fill{height:100%;background:#10b981;transition:width .3s ease}.progress-text{font-size:.875rem;font-weight:600;color:#10b981;min-width:3rem;text-align:right}.message{display:flex;align-items:center;gap:.5rem;padding:.875rem 1rem;border-radius:.5rem;margin-top:1rem;font-weight:500}.error-message{background:#fef2f2;color:#dc2626;border:1px solid #fecaca}.success-message{background:#f0fdf4;color:#059669;border:1px solid #bbf7d0}.current-process{background:#fff;border:1px solid #e5e7eb;border-radius:.75rem;padding:2rem;margin-bottom:2rem}.process-title{font-size:1.25rem;font-weight:700;color:#1f2937;margin-bottom:1rem}.process-card{border:1px solid #e5e7eb;border-radius:.5rem;padding:1.5rem;background:#fafafa}.process-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.process-name{font-size:1.125rem;font-weight:600;color:#374151}.process-status{display:flex;align-items:center;gap:.5rem;font-weight:600;font-size:.875rem}.status-spinner{width:1rem;height:1rem;border:2px solid transparent;border-top:2px solid currentColor;border-radius:50%;animation:spin 1s linear infinite}.process-details{display:flex;flex-direction:column;gap:.75rem}.process-info{display:flex;gap:.5rem}.info-label{font-weight:600;color:#6b7280;min-width:120px}.info-value{color:#374151}.database-type{background:#dbeafe;color:#1e40af;padding:.25rem .5rem;border-radius:.25rem;font-size:.875rem;font-weight:600}.process-reasoning{display:flex;flex-direction:column;gap:.5rem}.reasoning-text{background:#fff;padding:1rem;border-radius:.375rem;border:1px solid #e5e7eb;color:#374151;line-height:1.5}.process-error{display:flex;flex-direction:column;gap:.5rem}.error-text{background:#fef2f2;color:#dc2626;padding:1rem;border-radius:.375rem;border:1px solid #fecaca;line-height:1.5}.process-actions{margin-top:1rem;padding-top:1rem;border-top:1px solid #e5e7eb}.action-button{background:#10b981;color:#fff;border:none;border-radius:.375rem;padding:.5rem 1rem;font-weight:600;cursor:pointer;transition:all .2s ease}.action-button:hover{background:#059669}.action-button.primary{background:#3b82f6}.action-button.primary:hover{background:#2563eb}.processes-history{background:#fff;border:1px solid #e5e7eb;border-radius:.75rem;padding:2rem}.history-title{font-size:1.25rem;font-weight:700;color:#1f2937;margin-bottom:1rem}.processes-list{display:flex;flex-direction:column;gap:1rem}.process-item{border:1px solid #e5e7eb;border-radius:.5rem;padding:1rem;background:#fafafa;transition:all .2s ease}.process-item:hover{border-color:#10b981;background:#f0fdf4}.process-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.process-item-name{font-weight:600;color:#374151}.process-item-status{font-size:.875rem;font-weight:600}.process-item-details{display:flex;justify-content:space-between;align-items:center;font-size:.875rem;color:#6b7280;margin-bottom:.5rem}.process-item-file{font-weight:500}.process-item-database{display:flex;justify-content:flex-end}.database-badge{background:#dbeafe;color:#1e40af;padding:.25rem .5rem;border-radius:.25rem;font-size:.75rem;font-weight:600}@media (max-width: 768px){.schema-based-creation{padding:0 1rem}.upload-area{padding:2rem 1rem}.stats-grid{grid-template-columns:repeat(2,1fr)}.process-header{flex-direction:column;align-items:flex-start;gap:.5rem}.process-item-header,.process-item-details{flex-direction:column;align-items:flex-start;gap:.25rem}}@media (max-width: 480px){.stats-grid{grid-template-columns:1fr}.upload-section,.current-process,.processes-history{padding:1rem}}.schema-export-container{display:flex;flex-direction:column;height:100%;width:100%}.schema-export-header{margin-bottom:1.5rem}.schema-export-title{font-size:1.5rem;font-weight:700;color:#1f2937;margin-bottom:.5rem}.schema-export-description{color:#6b7280;font-size:.875rem}.schema-export-content{display:flex;flex:1;gap:1.5rem;height:calc(100vh - 14rem)}.schema-export-databases-panel{width:40%;display:flex;flex-direction:column;border:1px solid #e5e7eb;border-radius:.5rem;background-color:#fff;overflow:hidden}.schema-export-search{padding:1rem;border-bottom:1px solid #e5e7eb}.schema-export-search-input{width:100%;padding:.5rem .75rem;border:1px solid #d1d5db;border-radius:.375rem;font-size:.875rem}.schema-export-search-input:focus{outline:none;border-color:#10b981;box-shadow:0 0 0 1px #10b98133}.schema-export-table-header{display:flex;padding:.75rem 1rem;background-color:#f9fafb;border-bottom:1px solid #e5e7eb;font-weight:600;font-size:.75rem;text-transform:uppercase;color:#6b7280}.schema-export-table-header-cell{cursor:pointer;display:flex;align-items:center}.schema-export-table-header-cell:hover{color:#10b981}.schema-export-table-header-cell:nth-child(1){flex:2}.schema-export-table-header-cell:nth-child(2){flex:1}.schema-export-table-header-cell:nth-child(3){flex:1}.sort-icon{margin-left:.25rem}.schema-export-databases-list{flex:1;overflow-y:auto}.schema-export-database-item{display:flex;padding:.75rem 1rem;border-bottom:1px solid #e5e7eb;cursor:pointer;transition:background-color .2s}.schema-export-database-item:hover{background-color:#f9fafb}.schema-export-database-item.selected{background-color:#ecfdf5;border-left:3px solid #10b981}.schema-export-database-name{flex:2;font-weight:500;color:#1f2937}.schema-export-database-engine{flex:1;color:#6b7280;font-size:.875rem}.schema-export-database-date{flex:1;color:#6b7280;font-size:.75rem}.schema-export-preview-panel{flex:1;display:flex;flex-direction:column;border:1px solid #e5e7eb;border-radius:.5rem;background-color:#fff;overflow:hidden}.schema-export-preview-header{display:flex;justify-content:space-between;align-items:center;padding:1rem;border-bottom:1px solid #e5e7eb}.schema-export-preview-header h2{font-size:1.125rem;font-weight:600;color:#1f2937;margin:0}.schema-export-format-selector{display:flex;align-items:center;gap:.5rem}.schema-export-format-selector label{font-size:.875rem;color:#6b7280}.schema-export-format-options{display:flex;gap:.25rem}.schema-export-format-button{padding:.25rem .5rem;border:1px solid #d1d5db;border-radius:.25rem;background-color:#fff;font-size:.75rem;font-weight:500;color:#6b7280;cursor:pointer;transition:all .2s}.schema-export-format-button:hover{border-color:#10b981;color:#10b981}.schema-export-format-button.active{background-color:#10b981;border-color:#10b981;color:#fff}.schema-export-preview-content{flex:1;overflow-y:auto;padding:1rem;background-color:#f9fafb}.schema-export-code-preview{margin:0;padding:1rem;background-color:#1f2937;color:#f3f4f6;border-radius:.375rem;font-family:monospace;font-size:.875rem;line-height:1.5;overflow-x:auto;white-space:pre-wrap;height:100%}.schema-export-actions{display:flex;justify-content:flex-end;padding:1rem;border-top:1px solid #e5e7eb}.schema-export-download-button{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background-color:#10b981;color:#fff;border:none;border-radius:.375rem;font-weight:500;cursor:pointer;transition:background-color .2s}.schema-export-download-button:hover{background-color:#059669}.schema-export-download-button:disabled{background-color:#d1d5db;cursor:not-allowed}.schema-export-icon{width:1.25rem;height:1.25rem}.schema-export-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:#6b7280}.schema-export-spinner{width:2rem;height:2rem;border:3px solid #e5e7eb;border-top-color:#10b981;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}.schema-export-error{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;padding:1rem;color:#ef4444;text-align:center}.schema-export-retry-button{margin-top:1rem;padding:.5rem 1rem;background-color:#ef4444;color:#fff;border:none;border-radius:.375rem;font-weight:500;cursor:pointer;transition:background-color .2s}.schema-export-retry-button:hover{background-color:#dc2626}.schema-export-empty,.schema-export-no-selection{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:#6b7280}.schema-export-icon-large{width:4rem;height:4rem;color:#d1d5db;margin-bottom:1rem}@media (max-width: 768px){.schema-export-content{flex-direction:column;height:auto}.schema-export-databases-panel{width:100%;height:300px}.schema-export-preview-panel{margin-top:1rem;height:400px}}*,: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}.container{width:100%}@media (min-width: 640px){.container{max-width:640px}}@media (min-width: 768px){.container{max-width:768px}}@media (min-width: 1024px){.container{max-width:1024px}}@media (min-width: 1280px){.container{max-width:1280px}}@media (min-width: 1536px){.container{max-width:1536px}}.pointer-events-none{pointer-events:none}.absolute{position:absolute}.relative{position:relative}.right-2{right:.5rem}.top-1\/2{top:50%}.float-right{float:right}.mx-auto{margin-left:auto;margin-right:auto}.-mb-px{margin-bottom:-1px}.-ml-1{margin-left:-.25rem}.mb-1{margin-bottom:.25rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.mb-8{margin-bottom:2rem}.ml-1{margin-left:.25rem}.ml-2{margin-left:.5rem}.ml-3{margin-left:.75rem}.ml-4{margin-left:1rem}.ml-auto{margin-left:auto}.mr-2{margin-right:.5rem}.mr-3{margin-right:.75rem}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.mt-4{margin-top:1rem}.mt-6{margin-top:1.5rem}.block{display:block}.inline-block{display:inline-block}.inline{display:inline}.flex{display:flex}.inline-flex{display:inline-flex}.table{display:table}.grid{display:grid}.hidden{display:none}.h-12{height:3rem}.h-14{height:3.5rem}.h-16{height:4rem}.h-2\.5{height:.625rem}.h-3{height:.75rem}.h-4{height:1rem}.h-5{height:1.25rem}.h-6{height:1.5rem}.h-64{height:16rem}.h-8{height:2rem}.h-80{height:20rem}.h-full{height:100%}.h-screen{height:100vh}.max-h-48{max-height:12rem}.max-h-60{max-height:15rem}.max-h-96{max-height:24rem}.min-h-\[200px\]{min-height:200px}.min-h-\[32px\]{min-height:32px}.min-h-screen{min-height:100vh}.w-12{width:3rem}.w-16{width:4rem}.w-3{width:.75rem}.w-4{width:1rem}.w-5{width:1.25rem}.w-56{width:14rem}.w-6{width:1.5rem}.w-8{width:2rem}.w-full{width:100%}.min-w-full{min-width:100%}.max-w-4xl{max-width:56rem}.max-w-7xl{max-width:80rem}.max-w-\[80\%\]{max-width:80%}.max-w-md{max-width:28rem}.flex-1{flex:1 1 0%}.flex-shrink-0{flex-shrink:0}.-translate-y-1\/2{--tw-translate-y: -50%;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))}.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))}@keyframes spin{to{transform:rotate(360deg)}}.animate-spin{animation:spin 1s linear infinite}.cursor-pointer{cursor:pointer}.list-inside{list-style-position:inside}.list-disc{list-style-type:disc}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-start{align-items:flex-start}.items-center{align-items:center}.items-stretch{align-items:stretch}.justify-start{justify-content:flex-start}.justify-end{justify-content:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1{gap:.25rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-6{gap:1.5rem}.space-x-1>:not([hidden])~:not([hidden]){--tw-space-x-reverse: 0;margin-right:calc(.25rem * var(--tw-space-x-reverse));margin-left:calc(.25rem * calc(1 - var(--tw-space-x-reverse)))}.space-x-2>:not([hidden])~:not([hidden]){--tw-space-x-reverse: 0;margin-right:calc(.5rem * var(--tw-space-x-reverse));margin-left:calc(.5rem * calc(1 - var(--tw-space-x-reverse)))}.space-x-3>:not([hidden])~:not([hidden]){--tw-space-x-reverse: 0;margin-right:calc(.75rem * var(--tw-space-x-reverse));margin-left:calc(.75rem * calc(1 - var(--tw-space-x-reverse)))}.space-x-4>:not([hidden])~:not([hidden]){--tw-space-x-reverse: 0;margin-right:calc(1rem * var(--tw-space-x-reverse));margin-left:calc(1rem * calc(1 - var(--tw-space-x-reverse)))}.space-x-8>:not([hidden])~:not([hidden]){--tw-space-x-reverse: 0;margin-right:calc(2rem * var(--tw-space-x-reverse));margin-left:calc(2rem * calc(1 - var(--tw-space-x-reverse)))}.space-y-1>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.25rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.25rem * var(--tw-space-y-reverse))}.space-y-2>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.5rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.5rem * var(--tw-space-y-reverse))}.space-y-3>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.75rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.75rem * var(--tw-space-y-reverse))}.space-y-6>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(1.5rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1.5rem * var(--tw-space-y-reverse))}.divide-y>:not([hidden])~:not([hidden]){--tw-divide-y-reverse: 0;border-top-width:calc(1px * calc(1 - var(--tw-divide-y-reverse)));border-bottom-width:calc(1px * var(--tw-divide-y-reverse))}.divide-gray-200>:not([hidden])~:not([hidden]){--tw-divide-opacity: 1;border-color:rgb(229 231 235 / var(--tw-divide-opacity, 1))}.overflow-auto{overflow:auto}.overflow-hidden{overflow:hidden}.overflow-x-auto{overflow-x:auto}.overflow-y-auto{overflow-y:auto}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.whitespace-nowrap{white-space:nowrap}.whitespace-pre-wrap{white-space:pre-wrap}.rounded{border-radius:.25rem}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:.5rem}.rounded-md{border-radius:.375rem}.rounded-l-lg{border-top-left-radius:.5rem;border-bottom-left-radius:.5rem}.rounded-r-lg{border-top-right-radius:.5rem;border-bottom-right-radius:.5rem}.border{border-width:1px}.border-2{border-width:2px}.border-b{border-bottom-width:1px}.border-b-2{border-bottom-width:2px}.border-r{border-right-width:1px}.border-t{border-top-width:1px}.border-t-2{border-top-width:2px}.border-dashed{border-style:dashed}.border-blue-200{--tw-border-opacity: 1;border-color:rgb(191 219 254 / var(--tw-border-opacity, 1))}.border-blue-400{--tw-border-opacity: 1;border-color:rgb(96 165 250 / var(--tw-border-opacity, 1))}.border-blue-500{--tw-border-opacity: 1;border-color:rgb(59 130 246 / var(--tw-border-opacity, 1))}.border-blue-600{--tw-border-opacity: 1;border-color:rgb(37 99 235 / var(--tw-border-opacity, 1))}.border-gray-200{--tw-border-opacity: 1;border-color:rgb(229 231 235 / var(--tw-border-opacity, 1))}.border-gray-300{--tw-border-opacity: 1;border-color:rgb(209 213 219 / var(--tw-border-opacity, 1))}.border-green-200{--tw-border-opacity: 1;border-color:rgb(187 247 208 / var(--tw-border-opacity, 1))}.border-green-500{--tw-border-opacity: 1;border-color:rgb(34 197 94 / var(--tw-border-opacity, 1))}.border-green-600{--tw-border-opacity: 1;border-color:rgb(22 163 74 / var(--tw-border-opacity, 1))}.border-red-200{--tw-border-opacity: 1;border-color:rgb(254 202 202 / var(--tw-border-opacity, 1))}.border-red-300{--tw-border-opacity: 1;border-color:rgb(252 165 165 / var(--tw-border-opacity, 1))}.border-red-400{--tw-border-opacity: 1;border-color:rgb(248 113 113 / var(--tw-border-opacity, 1))}.border-transparent{border-color:transparent}.border-white{--tw-border-opacity: 1;border-color:rgb(255 255 255 / var(--tw-border-opacity, 1))}.bg-blue-100{--tw-bg-opacity: 1;background-color:rgb(219 234 254 / var(--tw-bg-opacity, 1))}.bg-blue-50{--tw-bg-opacity: 1;background-color:rgb(239 246 255 / var(--tw-bg-opacity, 1))}.bg-blue-500{--tw-bg-opacity: 1;background-color:rgb(59 130 246 / var(--tw-bg-opacity, 1))}.bg-blue-600{--tw-bg-opacity: 1;background-color:rgb(37 99 235 / var(--tw-bg-opacity, 1))}.bg-gray-100{--tw-bg-opacity: 1;background-color:rgb(243 244 246 / var(--tw-bg-opacity, 1))}.bg-gray-200{--tw-bg-opacity: 1;background-color:rgb(229 231 235 / var(--tw-bg-opacity, 1))}.bg-gray-400{--tw-bg-opacity: 1;background-color:rgb(156 163 175 / var(--tw-bg-opacity, 1))}.bg-gray-50{--tw-bg-opacity: 1;background-color:rgb(249 250 251 / var(--tw-bg-opacity, 1))}.bg-gray-600{--tw-bg-opacity: 1;background-color:rgb(75 85 99 / var(--tw-bg-opacity, 1))}.bg-green-100{--tw-bg-opacity: 1;background-color:rgb(220 252 231 / var(--tw-bg-opacity, 1))}.bg-green-50{--tw-bg-opacity: 1;background-color:rgb(240 253 244 / var(--tw-bg-opacity, 1))}.bg-green-500{--tw-bg-opacity: 1;background-color:rgb(34 197 94 / var(--tw-bg-opacity, 1))}.bg-green-600{--tw-bg-opacity: 1;background-color:rgb(22 163 74 / var(--tw-bg-opacity, 1))}.bg-orange-100{--tw-bg-opacity: 1;background-color:rgb(255 237 213 / var(--tw-bg-opacity, 1))}.bg-red-100{--tw-bg-opacity: 1;background-color:rgb(254 226 226 / var(--tw-bg-opacity, 1))}.bg-red-50{--tw-bg-opacity: 1;background-color:rgb(254 242 242 / var(--tw-bg-opacity, 1))}.bg-red-600{--tw-bg-opacity: 1;background-color:rgb(220 38 38 / var(--tw-bg-opacity, 1))}.bg-white{--tw-bg-opacity: 1;background-color:rgb(255 255 255 / var(--tw-bg-opacity, 1))}.bg-yellow-100{--tw-bg-opacity: 1;background-color:rgb(254 249 195 / var(--tw-bg-opacity, 1))}.bg-yellow-50{--tw-bg-opacity: 1;background-color:rgb(254 252 232 / var(--tw-bg-opacity, 1))}.p-1{padding:.25rem}.p-2{padding:.5rem}.p-3{padding:.75rem}.p-4{padding:1rem}.p-6{padding:1.5rem}.p-8{padding:2rem}.px-1{padding-left:.25rem;padding-right:.25rem}.px-2{padding-left:.5rem;padding-right:.5rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.py-0\.5{padding-top:.125rem;padding-bottom:.125rem}.py-1{padding-top:.25rem;padding-bottom:.25rem}.py-16{padding-top:4rem;padding-bottom:4rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.py-4{padding-top:1rem;padding-bottom:1rem}.py-8{padding-top:2rem;padding-bottom:2rem}.pb-2{padding-bottom:.5rem}.pl-5{padding-left:1.25rem}.pr-12{padding-right:3rem}.pr-2{padding-right:.5rem}.pt-4{padding-top:1rem}.text-left{text-align:left}.text-center{text-align:center}.text-2xl{font-size:1.5rem;line-height:2rem}.text-3xl{font-size:1.875rem;line-height:2.25rem}.text-4xl{font-size:2.25rem;line-height:2.5rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.text-xs{font-size:.75rem;line-height:1rem}.font-bold{font-weight:700}.font-medium{font-weight:500}.font-semibold{font-weight:600}.uppercase{text-transform:uppercase}.capitalize{text-transform:capitalize}.leading-6{line-height:1.5rem}.tracking-wider{letter-spacing:.05em}.text-blue-500{--tw-text-opacity: 1;color:rgb(59 130 246 / var(--tw-text-opacity, 1))}.text-blue-600{--tw-text-opacity: 1;color:rgb(37 99 235 / var(--tw-text-opacity, 1))}.text-blue-700{--tw-text-opacity: 1;color:rgb(29 78 216 / var(--tw-text-opacity, 1))}.text-blue-800{--tw-text-opacity: 1;color:rgb(30 64 175 / var(--tw-text-opacity, 1))}.text-blue-900{--tw-text-opacity: 1;color:rgb(30 58 138 / var(--tw-text-opacity, 1))}.text-gray-400{--tw-text-opacity: 1;color:rgb(156 163 175 / var(--tw-text-opacity, 1))}.text-gray-500{--tw-text-opacity: 1;color:rgb(107 114 128 / var(--tw-text-opacity, 1))}.text-gray-600{--tw-text-opacity: 1;color:rgb(75 85 99 / var(--tw-text-opacity, 1))}.text-gray-700{--tw-text-opacity: 1;color:rgb(55 65 81 / var(--tw-text-opacity, 1))}.text-gray-800{--tw-text-opacity: 1;color:rgb(31 41 55 / var(--tw-text-opacity, 1))}.text-gray-900{--tw-text-opacity: 1;color:rgb(17 24 39 / var(--tw-text-opacity, 1))}.text-green-400{--tw-text-opacity: 1;color:rgb(74 222 128 / var(--tw-text-opacity, 1))}.text-green-600{--tw-text-opacity: 1;color:rgb(22 163 74 / var(--tw-text-opacity, 1))}.text-green-700{--tw-text-opacity: 1;color:rgb(21 128 61 / var(--tw-text-opacity, 1))}.text-green-800{--tw-text-opacity: 1;color:rgb(22 101 52 / var(--tw-text-opacity, 1))}.text-green-900{--tw-text-opacity: 1;color:rgb(20 83 45 / var(--tw-text-opacity, 1))}.text-orange-600{--tw-text-opacity: 1;color:rgb(234 88 12 / var(--tw-text-opacity, 1))}.text-orange-800{--tw-text-opacity: 1;color:rgb(154 52 18 / var(--tw-text-opacity, 1))}.text-purple-600{--tw-text-opacity: 1;color:rgb(147 51 234 / var(--tw-text-opacity, 1))}.text-red-400{--tw-text-opacity: 1;color:rgb(248 113 113 / var(--tw-text-opacity, 1))}.text-red-500{--tw-text-opacity: 1;color:rgb(239 68 68 / var(--tw-text-opacity, 1))}.text-red-600{--tw-text-opacity: 1;color:rgb(220 38 38 / var(--tw-text-opacity, 1))}.text-red-700{--tw-text-opacity: 1;color:rgb(185 28 28 / var(--tw-text-opacity, 1))}.text-red-800{--tw-text-opacity: 1;color:rgb(153 27 27 / var(--tw-text-opacity, 1))}.text-white{--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.text-yellow-600{--tw-text-opacity: 1;color:rgb(202 138 4 / var(--tw-text-opacity, 1))}.text-yellow-800{--tw-text-opacity: 1;color:rgb(133 77 14 / var(--tw-text-opacity, 1))}.opacity-25{opacity:.25}.opacity-50{opacity:.5}.opacity-75{opacity:.75}.shadow{--tw-shadow: 0 1px 3px 0 rgb(0 0 0 / .1), 0 1px 2px -1px rgb(0 0 0 / .1);--tw-shadow-colored: 0 1px 3px 0 var(--tw-shadow-color), 0 1px 2px -1px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-md{--tw-shadow: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--tw-shadow-colored: 0 4px 6px -1px var(--tw-shadow-color), 0 2px 4px -2px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-sm{--tw-shadow: 0 1px 2px 0 rgb(0 0 0 / .05);--tw-shadow-colored: 0 1px 2px 0 var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.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)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,-webkit-backdrop-filter;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter,-webkit-backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-all{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-colors{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-shadow{transition-property:box-shadow;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-transform{transition-property:transform;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.duration-300{transition-duration:.3s}.ease-in-out{transition-timing-function:cubic-bezier(.4,0,.2,1)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;background-color:#fff;color:#111;line-height:1.5}a{text-decoration:none;color:inherit}button{font-family:inherit}.error-message{background-color:#fee2e2;color:#b91c1c;padding:.75rem;border-radius:.375rem;margin-bottom:1rem;font-size:.875rem}.success-message{background-color:#dcfce7;color:#166534;padding:.75rem;border-radius:.375rem;margin-bottom:1rem;font-size:.875rem}.connection-status{padding:.75rem;border-radius:.375rem;margin-bottom:1rem;font-size:.875rem;text-align:center}.connection-status.error{background-color:#fee2e2;color:#b91c1c;border:1px solid #f87171}.connection-status.success{background-color:#dcfce7;color:#166534;border:1px solid #4ade80}.connection-status .small{font-size:.75rem;margin-top:.25rem}button:disabled{opacity:.6;cursor:not-allowed}.hover\:border-gray-300:hover{--tw-border-opacity: 1;border-color:rgb(209 213 219 / var(--tw-border-opacity, 1))}.hover\:border-gray-400:hover{--tw-border-opacity: 1;border-color:rgb(156 163 175 / var(--tw-border-opacity, 1))}.hover\:border-green-300:hover{--tw-border-opacity: 1;border-color:rgb(134 239 172 / var(--tw-border-opacity, 1))}.hover\:border-green-400:hover{--tw-border-opacity: 1;border-color:rgb(74 222 128 / var(--tw-border-opacity, 1))}.hover\:bg-blue-600:hover{--tw-bg-opacity: 1;background-color:rgb(37 99 235 / var(--tw-bg-opacity, 1))}.hover\:bg-blue-700:hover{--tw-bg-opacity: 1;background-color:rgb(29 78 216 / var(--tw-bg-opacity, 1))}.hover\:bg-gray-100:hover{--tw-bg-opacity: 1;background-color:rgb(243 244 246 / var(--tw-bg-opacity, 1))}.hover\:bg-gray-200:hover{--tw-bg-opacity: 1;background-color:rgb(229 231 235 / var(--tw-bg-opacity, 1))}.hover\:bg-gray-50:hover{--tw-bg-opacity: 1;background-color:rgb(249 250 251 / var(--tw-bg-opacity, 1))}.hover\:bg-gray-700:hover{--tw-bg-opacity: 1;background-color:rgb(55 65 81 / var(--tw-bg-opacity, 1))}.hover\:bg-green-100:hover{--tw-bg-opacity: 1;background-color:rgb(220 252 231 / var(--tw-bg-opacity, 1))}.hover\:bg-green-50:hover{--tw-bg-opacity: 1;background-color:rgb(240 253 244 / var(--tw-bg-opacity, 1))}.hover\:bg-green-50\/50:hover{background-color:#f0fdf480}.hover\:bg-green-600:hover{--tw-bg-opacity: 1;background-color:rgb(22 163 74 / var(--tw-bg-opacity, 1))}.hover\:bg-green-700:hover{--tw-bg-opacity: 1;background-color:rgb(21 128 61 / var(--tw-bg-opacity, 1))}.hover\:bg-red-700:hover{--tw-bg-opacity: 1;background-color:rgb(185 28 28 / var(--tw-bg-opacity, 1))}.hover\:text-blue-500:hover{--tw-text-opacity: 1;color:rgb(59 130 246 / var(--tw-text-opacity, 1))}.hover\:text-blue-800:hover{--tw-text-opacity: 1;color:rgb(30 64 175 / var(--tw-text-opacity, 1))}.hover\:text-gray-600:hover{--tw-text-opacity: 1;color:rgb(75 85 99 / var(--tw-text-opacity, 1))}.hover\:text-gray-700:hover{--tw-text-opacity: 1;color:rgb(55 65 81 / var(--tw-text-opacity, 1))}.hover\:text-gray-800:hover{--tw-text-opacity: 1;color:rgb(31 41 55 / var(--tw-text-opacity, 1))}.hover\:text-gray-900:hover{--tw-text-opacity: 1;color:rgb(17 24 39 / var(--tw-text-opacity, 1))}.hover\:text-green-700:hover{--tw-text-opacity: 1;color:rgb(21 128 61 / var(--tw-text-opacity, 1))}.hover\:text-red-500:hover{--tw-text-opacity: 1;color:rgb(239 68 68 / var(--tw-text-opacity, 1))}.hover\:text-red-600:hover{--tw-text-opacity: 1;color:rgb(220 38 38 / var(--tw-text-opacity, 1))}.hover\:text-red-700:hover{--tw-text-opacity: 1;color:rgb(185 28 28 / var(--tw-text-opacity, 1))}.hover\:shadow-md:hover{--tw-shadow: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--tw-shadow-colored: 0 4px 6px -1px var(--tw-shadow-color), 0 2px 4px -2px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.focus\:border-blue-500:focus{--tw-border-opacity: 1;border-color:rgb(59 130 246 / var(--tw-border-opacity, 1))}.focus\:border-green-500:focus{--tw-border-opacity: 1;border-color:rgb(34 197 94 / var(--tw-border-opacity, 1))}.focus\:border-transparent:focus{border-color:transparent}.focus\:outline-none:focus{outline:2px solid transparent;outline-offset:2px}.focus\:ring-1:focus{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.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);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.focus\:ring-blue-500:focus{--tw-ring-opacity: 1;--tw-ring-color: rgb(59 130 246 / var(--tw-ring-opacity, 1))}.focus\:ring-green-500:focus{--tw-ring-opacity: 1;--tw-ring-color: rgb(34 197 94 / var(--tw-ring-opacity, 1))}.focus\:ring-offset-2:focus{--tw-ring-offset-width: 2px}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:opacity-50:disabled{opacity:.5}.group[open] .group-open\:rotate-180{--tw-rotate: 180deg;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))}.group:hover .group-hover\:text-green-600{--tw-text-opacity: 1;color:rgb(22 163 74 / var(--tw-text-opacity, 1))}@media (min-width: 768px){.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.md\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}}@media (min-width: 1024px){.lg\:col-span-2{grid-column:span 2 / span 2}.lg\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}}@media (min-width: 1280px){.xl\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}}
