Spaces:
Runtime error
Runtime error
| <!DOCTYPE html> | |
| <html lang="es"> | |
| <head> | |
| <meta charset="UTF-8"> | |
| <meta name="viewport" content="width=device-width, initial-scale=1.0"> | |
| <title>Generador de Actividades Fonoaudiológicas</title> | |
| <link href="https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap" rel="stylesheet"> | |
| <style> | |
| :root { | |
| --primary: #4f46e5; | |
| --primary-hover: #4338ca; | |
| --secondary: #10b981; | |
| --dark: #1f2937; | |
| --light: #f9fafb; | |
| --gray: #6b7280; | |
| --gray-light: #e5e7eb; | |
| --danger: #ef4444; | |
| --success: #10b981; | |
| --border-radius: 12px; | |
| --shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06); | |
| --transition: all 0.3s ease; | |
| } | |
| * { | |
| margin: 0; | |
| padding: 0; | |
| box-sizing: border-box; | |
| } | |
| body { | |
| font-family: 'Inter', sans-serif; | |
| background-color: #f3f4f6; | |
| color: var(--dark); | |
| line-height: 1.6; | |
| } | |
| .container { | |
| max-width: 1200px; | |
| margin: 0 auto; | |
| padding: 20px; | |
| } | |
| header { | |
| text-align: center; | |
| margin-bottom: 40px; | |
| padding: 20px 0; | |
| } | |
| header h1 { | |
| font-size: 2.5rem; | |
| color: var(--primary); | |
| margin-bottom: 10px; | |
| } | |
| header p { | |
| color: var(--gray); | |
| font-size: 1.1rem; | |
| } | |
| .card { | |
| background: white; | |
| border-radius: var(--border-radius); | |
| box-shadow: var(--shadow); | |
| padding: 25px; | |
| margin-bottom: 25px; | |
| transition: var(--transition); | |
| } | |
| .card:hover { | |
| box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05); | |
| } | |
| .card-title { | |
| font-size: 1.25rem; | |
| font-weight: 600; | |
| margin-bottom: 20px; | |
| color: var(--dark); | |
| display: flex; | |
| align-items: center; | |
| gap: 10px; | |
| } | |
| .form-group { | |
| margin-bottom: 20px; | |
| } | |
| label { | |
| display: block; | |
| margin-bottom: 8px; | |
| font-weight: 500; | |
| color: var(--dark); | |
| } | |
| input, select, textarea { | |
| width: 100%; | |
| padding: 12px 15px; | |
| border: 1px solid var(--gray-light); | |
| border-radius: var(--border-radius); | |
| font-family: 'Inter', sans-serif; | |
| font-size: 1rem; | |
| transition: var(--transition); | |
| } | |
| input:focus, select:focus, textarea:focus { | |
| outline: none; | |
| border-color: var(--primary); | |
| box-shadow: 0 0 0 3px rgba(79, 70, 229, 0.2); | |
| } | |
| textarea { | |
| min-height: 120px; | |
| resize: vertical; | |
| } | |
| .checkbox-group { | |
| display: flex; | |
| align-items: center; | |
| gap: 10px; | |
| margin-bottom: 20px; | |
| } | |
| .checkbox-group input[type="checkbox"] { | |
| width: auto; | |
| transform: scale(1.2); | |
| } | |
| .btn { | |
| display: inline-flex; | |
| align-items: center; | |
| justify-content: center; | |
| gap: 8px; | |
| padding: 12px 24px; | |
| background-color: var(--primary); | |
| color: white; | |
| border: none; | |
| border-radius: var(--border-radius); | |
| font-size: 1rem; | |
| font-weight: 500; | |
| cursor: pointer; | |
| transition: var(--transition); | |
| } | |
| .btn:hover { | |
| background-color: var(--primary-hover); | |
| transform: translateY(-2px); | |
| } | |
| .btn-secondary { | |
| background-color: white; | |
| color: var(--primary); | |
| border: 1px solid var(--gray-light); | |
| } | |
| .btn-secondary:hover { | |
| background-color: #f9fafb; | |
| color: var(--primary-hover); | |
| } | |
| .btn-success { | |
| background-color: var(--success); | |
| } | |
| .btn-success:hover { | |
| background-color: #0da271; | |
| } | |
| .btn:disabled { | |
| opacity: 0.7; | |
| cursor: not-allowed; | |
| transform: none; | |
| } | |
| .advanced-toggle { | |
| display: flex; | |
| align-items: center; | |
| gap: 10px; | |
| margin-bottom: 20px; | |
| cursor: pointer; | |
| user-select: none; | |
| } | |
| .advanced-section { | |
| overflow: hidden; | |
| transition: max-height 0.3s ease; | |
| } | |
| .hidden { | |
| max-height: 0; | |
| overflow: hidden; | |
| } | |
| .upload-section { | |
| margin-bottom: 20px; | |
| } | |
| .drop-zone { | |
| border: 2px dashed var(--gray-light); | |
| border-radius: var(--border-radius); | |
| padding: 30px; | |
| text-align: center; | |
| transition: var(--transition); | |
| margin-bottom: 20px; | |
| } | |
| .drop-zone.highlight { | |
| border-color: var(--primary); | |
| background-color: rgba(79, 70, 229, 0.05); | |
| } | |
| .drop-zone p { | |
| margin-bottom: 15px; | |
| color: var(--gray); | |
| } | |
| .file-list { | |
| margin-top: 20px; | |
| } | |
| .file-item { | |
| display: flex; | |
| align-items: center; | |
| justify-content: space-between; | |
| padding: 12px 15px; | |
| background-color: #f9fafb; | |
| border-radius: var(--border-radius); | |
| margin-bottom: 10px; | |
| } | |
| .file-item div { | |
| display: flex; | |
| align-items: center; | |
| gap: 10px; | |
| } | |
| .remove-file { | |
| background: none; | |
| border: none; | |
| color: var(--danger); | |
| font-size: 1.2rem; | |
| cursor: pointer; | |
| padding: 0 5px; | |
| } | |
| .action-buttons { | |
| display: flex; | |
| gap: 15px; | |
| margin-top: 30px; | |
| } | |
| .result-container { | |
| display: none; | |
| } | |
| .result-content { | |
| line-height: 1.8; | |
| } | |
| .result-content h3 { | |
| margin: 25px 0 15px; | |
| color: var(--primary); | |
| font-weight: 600; | |
| } | |
| .result-content ul { | |
| padding-left: 25px; | |
| margin-bottom: 20px; | |
| } | |
| .result-content .step { | |
| background: #f8f9fa; | |
| padding: 15px; | |
| border-radius: var(--border-radius); | |
| margin-bottom: 15px; | |
| } | |
| .loading { | |
| text-align: center; | |
| padding: 40px 0; | |
| } | |
| .spinner { | |
| width: 50px; | |
| height: 50px; | |
| border: 5px solid rgba(79, 70, 229, 0.2); | |
| border-radius: 50%; | |
| border-top-color: var(--primary); | |
| animation: spin 1s ease-in-out infinite; | |
| margin: 0 auto 20px; | |
| } | |
| @keyframes spin { | |
| to { transform: rotate(360deg); } | |
| } | |
| .error-message { | |
| background-color: #fee2e2; | |
| color: var(--danger); | |
| padding: 15px; | |
| border-radius: var(--border-radius); | |
| margin-bottom: 20px; | |
| display: none; | |
| } | |
| .success-message { | |
| background-color: #d1fae5; | |
| color: |