*{margin:0;padding:0;box-sizing:border-box}body{font-family:Arial,sans-serif;line-height:1.6;color:#333;background-color:#f4f4f4}.header{background-color:#772c49;color:#fff;padding:1rem 0;position:fixed;width:100%;top:0;z-index:1000;box-shadow:0 2px 5px #0000001a}.nav-container{max-width:1200px;margin:0 auto;display:flex;justify-content:center;align-items:center;padding:0 2rem}.logo{font-size:1.5rem;font-weight:700}.flex .auth-btn{flex:1 1 0;min-width:0;margin-left:.5rem;margin-right:.5rem}.auth-btn{font-size:1rem;min-width:130px;text-align:center;display:inline-block;box-sizing:border-box;padding:.75rem 1.25rem;border:none;border-radius:6px;cursor:pointer;text-decoration:none;transition:all .3s ease;font-weight:500;height:44px;line-height:1.2;vertical-align:middle}.login-btn{background-color:#a4813f;color:#fff}.login-btn:hover{background-color:#2980b9;transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.logout-btn{background-color:#916b67;color:#fff}.logout-btn:hover{background-color:#c0392b;transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.login-btn.show{display:inline-block}.main-content{margin-top:140px;padding:2rem;min-height:calc(100vh - 80px);display:flex;flex-direction:column;align-items:center;justify-content:center}.form-container{background:white;padding:2rem;border-radius:10px;box-shadow:0 0 20px #0000001a;width:100%;max-width:800px}.form-title{text-align:center;margin-bottom:2rem;color:#772c49;font-size:1.8rem}.form-group{margin-bottom:1rem}.form-grid{display:grid;grid-template-columns:1fr;gap:1rem;margin-bottom:2rem}@media (min-width: 768px){.form-grid{grid-template-columns:1fr 1fr}.form-group-full{grid-column:1 / -1}}@media (min-width: 1024px){.form-grid{grid-template-columns:1fr 1fr 1fr}.form-group-full{grid-column:1 / -1}.form-group-span-2{grid-column:2 / 4}}.form-group label{display:block;margin-bottom:.5rem;color:#555;font-weight:700}.form-group input,.form-group select,.form-group textarea{width:100%;padding:.8rem;border:1px solid #ddd;border-radius:5px;font-size:1rem;transition:border-color .3s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#a4813f}.form-group textarea{min-height:100px;resize:vertical}.btn-primary{background-color:#772c49;color:#fff;padding:.8rem 2rem;border:none;border-radius:5px;cursor:pointer;font-size:1rem;width:100%;transition:background-color .3s}.btn-primary:hover{background-color:#5f2239}.btn-secondary{background-color:#95a5a6;color:#fff;padding:.8rem 2rem;border:none;border-radius:5px;cursor:pointer;font-size:1rem;width:100%;margin-top:.5rem;transition:background-color .3s}.btn-secondary:hover{background-color:#7f8c8d}.hoverable-avatar:hover{box-shadow:0 0 0 4px #b3d7ff}.avatar-container{display:flex;flex-direction:column;align-items:center;justify-content:center;margin-bottom:1.5rem}.avatar-container>*{width:100%;max-width:220px;margin-bottom:.5rem;display:block}.avatar-container label{text-align:center}.avatar-box{position:relative;width:160px;height:160px;margin:0 auto;cursor:pointer;transition:box-shadow .2s;border-radius:50%;box-shadow:0 2px 8px #00000012;background:#f5f5f5;overflow:hidden}.avatar-box:hover{box-shadow:0 4px 16px #00000021}.avatar-img{width:100%;height:100%;object-fit:cover;border-radius:50%;display:block;background:#e9e9e9}.avatar-error{margin-top:.5rem;color:#d32f2f;font-size:.95em;display:none;text-align:center}.avatar-error.active{display:block}.firma-section{margin:2rem 0 1rem;text-align:center}.firma-label{font-weight:600;margin-bottom:.5rem;display:block}.firma-canvas-wrapper{display:flex;justify-content:center;margin-bottom:.5rem}.firma-clear-btn{margin-bottom:.5rem;background:#e74c3c;color:#fff;border:none;padding:.4rem 1.2rem;border-radius:4px;cursor:pointer;font-size:1rem}.firma-clear-btn:hover{background:#c0392b}@media (max-width: 768px){.nav-container{padding:0 1rem}.main-content{padding:1rem}.form-container{padding:1.5rem;max-width:100%}.clases-container{grid-template-columns:1fr;max-height:350px;padding-right:.5rem}.clases-container::-webkit-scrollbar{width:6px}.clases-container::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.clases-container::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:3px}.clase-card{margin-bottom:.5rem}.clase-header,.clase-body{padding:.75rem}.clase-observaciones{min-height:60px}}.is-invalid{border-color:#dc3545!important;background-color:#fff5f5}.invalid-feedback{display:block;width:100%;margin-top:.25rem;font-size:.875rem;color:#dc3545}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.form-group{position:relative}.form-section-title{font-size:1.2rem;font-weight:700;color:#772c49;margin-bottom:.5rem;display:block}.form-section-subtitle{font-size:.9rem;color:#666;margin-bottom:1rem}.search-container{position:relative;margin-bottom:1rem}.search-input{width:100%;padding:.8rem 2.5rem .8rem 1rem;border:1px solid #ddd;border-radius:5px;font-size:1rem;transition:border-color .3s}.search-input:focus{outline:none;border-color:#a4813f}.search-icon{position:absolute;right:1rem;top:50%;transform:translateY(-50%);color:#666;pointer-events:none}.clases-container{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1rem;margin-bottom:1rem;max-height:500px;overflow-y:auto;padding:1rem;border:1px solid #e0e0e0;border-radius:8px;background-color:#fafafa}.clases-container::-webkit-scrollbar{width:8px}.clases-container::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.clases-container::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:4px}.clases-container::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.clase-card{border:1px solid #ddd;border-radius:8px;background:#fff;box-shadow:0 2px 4px #0000001a;transition:all .3s ease}.clase-card:hover{box-shadow:0 4px 8px #00000026;transform:translateY(-2px)}.clase-card.hidden{display:none}.clase-header{background:#f8f9fa;padding:1rem;border-bottom:1px solid #ddd;border-radius:8px 8px 0 0}.clase-title{margin:0;font-size:1.1rem;color:#772c49;font-weight:600}.clase-body{padding:1rem}.clase-body label{display:block;margin-bottom:.5rem;font-weight:500;color:#555}.no-clases{text-align:center;padding:2rem;color:#666;font-style:italic}@media (min-width: 769px) and (max-width: 1024px){.form-container{max-width:700px}.clases-container{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));max-height:450px}}@media (min-width: 1200px){.form-container{max-width:900px}.main-content{padding:3rem}.clases-container{grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:1.5rem;max-height:600px}}.terms-conditions{margin:1.5rem 0;text-align:center}.form-check{display:inline-flex;align-items:center;gap:.5rem;font-size:.95rem;color:#555}.form-check-input{width:18px!important;height:18px;margin:0;cursor:pointer;accent-color:#a4813f;flex-shrink:0}.form-check-label{margin:0;cursor:pointer;line-height:1.4}.terms-link{color:#a4813f;text-decoration:underline;font-weight:500;transition:color .3s ease}.terms-link:hover{color:#2980b9;text-decoration:underline}.horarios-label{font-weight:700;color:#555;margin-bottom:.8rem;display:block}.horarios-container{display:flex;flex-direction:column;gap:.8rem;padding:.5rem 0}.horario-checkbox{display:flex;align-items:flex-start;gap:.6rem;padding:.8rem;border:1px solid #e0e0e0;border-radius:8px;transition:all .3s ease;cursor:pointer;background-color:#fafafa}.horario-checkbox:hover{border-color:#a4813f;background-color:#f0f8ff;transform:translateY(-1px);box-shadow:0 2px 5px #3498db1a}.horario-checkbox-input{width:18px!important;height:18px;margin:2px 0 0!important;cursor:pointer;accent-color:#a4813f;flex-shrink:0}.horario-checkbox-input:checked+.horario-checkbox-label{color:#a4813f;font-weight:600}.horario-checkbox:has(.horario-checkbox-input:checked){border-color:#a4813f;background-color:#e8f4fd;box-shadow:0 2px 8px #3498db26}.horario-checkbox-label{flex:1;cursor:pointer;line-height:1.4;color:#555;transition:color .3s ease;margin:0!important}.horario-time{color:#666;font-size:.9rem;font-weight:400}.no-horarios{text-align:center;color:#999;font-style:italic;padding:1rem;background-color:#f8f9fa;border-radius:8px;margin:.5rem 0}@media (max-width: 768px){.horarios-container{gap:.6rem}.horario-checkbox{padding:.6rem}.horario-checkbox-label{font-size:.9rem}}@media (max-width: 768px){.clases-container{grid-template-columns:1fr;overflow-x:hidden!important;width:100%;max-width:100%;box-sizing:border-box;margin-left:0;padding-left:.5rem;padding-right:.5rem}.clase-card,.clase-header,.clase-body{width:100%;max-width:100%;box-sizing:border-box;overflow-wrap:break-word;word-break:break-word}.clase-title{font-size:1rem;word-break:break-word}}.text-danger{color:#e74c3c;font-weight:700}.grupo-selector{margin-bottom:1.5rem}.selector-row{display:flex;gap:1rem;align-items:center}.form-select{flex:1;padding:.8rem;border:1px solid #ddd;border-radius:5px;font-size:1rem;background-color:#fff;transition:border-color .3s}.form-select:focus{outline:none;border-color:#a4813f}.btn-add-grupo{background-color:#a4813f;color:#fff;border:none;padding:.8rem 1.5rem;border-radius:5px;font-size:1rem;cursor:pointer;white-space:nowrap;transition:background-color .3s}.btn-add-grupo:hover{background-color:#6b5325}.btn-add-grupo:disabled{background-color:#bdc3c7;cursor:not-allowed}.grupos-seleccionados{margin-top:1rem}.grupo-item{background-color:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:1rem;margin-bottom:1rem;box-shadow:0 2px 4px #0000001a;transition:box-shadow .3s}.grupo-item:hover{box-shadow:0 4px 8px #00000026}.grupo-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.grupo-item-title{font-size:1.1rem;font-weight:600;color:#2c3e50;margin:0}.btn-remove-grupo{background-color:#916b67;color:#fff;border:none;padding:.4rem .8rem;border-radius:4px;font-size:.9rem;cursor:pointer;transition:background-color .3s}.btn-remove-grupo:hover{background-color:#332726}.clase-item-body label{display:block;margin-bottom:.5rem;font-weight:500;color:#555}.clase-observaciones{width:100%;padding:.8rem;border:1px solid #ddd;border-radius:5px;font-size:.9rem;resize:vertical;min-height:80px;transition:border-color .3s}.clase-observaciones:focus{outline:none;border-color:#a4813f}.clase-observaciones.filled{background-color:#f0f8ff;border-color:#a4813f}.no-grupos-seleccionados{text-align:center;padding:2rem;color:#666;font-style:italic;background-color:#f8f9fa;border-radius:8px;border:2px dashed #ddd}@media (max-width: 768px){.selector-row{flex-direction:column;gap:.8rem}.btn-add-grupo{width:100%}}
