

/* Colores
- black: #060612
- segundo oscuro: #2b3249
- medio: #626994
- medio claro: #a4a1e0
- Claro: #e8d1ea*/
html {
  height: 100%;
  margin: 0;
  box-shadow: inset 0 0 0 20px #000;

}
html body:not(.inicio) {
 box-shadow: none !important;
}
body.inicio{
  background-image: url("../imagenes/fondo_inicio.png");
  background-size: contain;
  background-repeat: no-repeat;
  background-size: 100%;
  background-color: black;

}


body.login {
  background-image: url("../imagenes/fondo_login.png");
  background-size: contain;
  background-repeat: no-repeat;
  background-size: 100%;
  background-color: black;
}
body.registro {
  background-image: url("../imagenes/fondo_registro.png");
  background-size: cover;   
  background-repeat: no-repeat;
  background-color: black;
}

body.misclases-alum {
  background-image: url("../imagenes/fondo_misclases.png");
background-size: contain;
background-repeat: no-repeat;
background-size: 100%;
  background-color: black;
}

body.notificaciones {
  background-image: url("../imagenes/fondo_notificaciones.png");
  background-size: cover;
  background-repeat: no-repeat;
  background-color: black;
}

body.perfil {
  background-image: url("../imagenes/fondo_perfil.png");
  background-size: cover;
  background-repeat: no-repeat;
  background-color: black;
  background-size: 100%;
}

body.grupos {
  background-image: url("../imagenes/fondo_grupos.png"); 
  background-size: cover;
  background-repeat: no-repeat;
  background-color: black;
  background-size: 100%;
}

body.admin_usu{
  background-image: url("../imagenes/fondo_adminusu.png"); 
  background-size: cover;
  background-repeat: no-repeat;
  background-color: black;
  background-size: 100%;
  display: flex;
  gap: 10px;
  padding: 20px;
}

body.materiales {
  background-image: url("../imagenes/fondo_materiales.png"); 
  background-size: contain;
  background-repeat: no-repeat;
  background-size: 100%;
  background-color: black;
  display: flex;
  gap: 10px;
  padding: 20px;
}

body.notas {
  background-image: url("../imagenes/fondo_notas.png"); 
  background-size: contain;
  background-repeat: no-repeat;
  background-size: 100%;
    background-color: black;
  display: flex;
  gap: 10px;
  padding: 20px;
}
body.adminclases {
  background-image: url("../imagenes/fondo_adminclases.png"); 
  background-size: cover;
  background-repeat: no-repeat;
  background-color: black;
  background-size: 100%;
  display: flex;
  gap: 10px;
  padding: 20px;
}

.bigform {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
.bigform2 {
  position: absolute;
  top: 50%;
  left: 30%;
  transform: translate(-50%, -50%);
}

.form-noti {
  position: absolute;
  margin-top: 16rem;
  margin-left: 3rem;
  width: 30%;
  height: min-content;
  background-image: linear-gradient(to bottom, #a4a1e0, #a8afda);
  align-items: left;
  flex-direction: column;
  border-radius: 0.5rem;
}
.form-material {
  position: absolute;
  margin-top: 40rem;
  margin-left: 5rem;
  width: 30%;
  height: min-content;
  background-image: linear-gradient(to bottom, #a4a1e0, #a8afda);
  align-items: left;
  flex-direction: column;
  border-radius: 0.5rem;
}


::selection {
  background-color: #e8d1ea;
}



.form1 {
  margin-top: 3rem;
  width: 50rem;
  height: 50rem;
  background-image: linear-gradient(to bottom, #a4a1e0, #626994);
  display: flex;
  align-items: center;
  flex-direction: column;
  border-radius: 0.5rem;
}

.form2 {
  margin-top: 3rem;
  margin-left: 50rem;
  float: right;
  width: 50rem;
  height: 50rem;
  background-image: linear-gradient(to bottom, #a4a1e0, #a2aadd);
  display: flex;
  align-items: center;
  flex-direction: column;
  border-radius: 0.5rem;
}

.title {

  color: #2b3249;
  margin-top: 3rem;
  margin-left: 6rem;
  margin-bottom: 1.5rem ;
  font-size: 4rem;
  font-family: "Tinos", serif;
  font-weight: 400;
  font-style: normal;
  font-weight: bold;
  text-align: left;   
  width: 100%; 

}

.title2 {

  color: #2b3249;
  margin-top: 3rem;
  margin-left: 6rem;
  margin-bottom: 1.5rem ;
  font-size: 3rem;
  font-family: "Tinos", serif;
  font-weight: 400;
  font-style: normal;
  font-weight: bold;
  text-align: left;   
  width: 100%; 

}

.title3 {
  color: #626994;
  font-size: 3.5rem;
  font-family: "Tinos", serif;
  font-weight: 300;
  font-style: normal;
  font-weight: bold;
  text-align: center;  
  margin: 0px; 
  width: 100%; 

}
.title4 {

  color: #2b3249;
  margin-top: 2.5rem;
  margin-left: 2rem;
  font-size: 2.5rem;
  font-family: "Tinos", serif;
  font-weight: 400;
  font-style: normal;
  font-weight: bold;
  text-align: left;   
  width: 100%; 

}
.text1{

  color: #2b3249;
  text-align: left;   
  width: 100%; 
  font-size: 1.5rem;
  margin-left: 6rem;
  font-family: "Tinos", serif;
  font-weight: 500;
  font-style: normal;

}
.text2{

  color: #2b3249;
  text-align: center;   
  width: 100%; 
  font-size: 1.5rem;
  font-family: "Tinos", serif;
  font-weight: 500;
  font-style: normal;

}
.text3{

  color: #fff;
  text-align: left;   
  width: 100%; 
  font-size: 1.5rem;
  margin-left: 2rem;
  font-family: "Tinos", serif;
  font-weight: 500;
  font-style: normal;

}
.text6{
  margin: 0;
  color: #2b3249;
  text-align: left;   
  width: 25%; 
  font-size: 1.5rem;
  margin-left: 1rem;
  font-family: "Tinos", serif;
  font-weight: 500;
  font-style: normal;

}

.link1{
    color: #be95ef;
  text-align: left;   
  width: 100%; 
  font-size: 1.5rem;
  font-family: "Tinos", serif;
  font-weight: 500;
  font-style: normal;
}
.link2{
  float: right;
  color: #332cbf;
  text-align: right;   
    margin-right: 50px;
  width: 100%; 
  font-size: 1.5rem;
  font-family: "Tinos", serif;
  font-weight: 500;
  font-style: normal;
}

.link3{

  color: #332cbf;
  text-align: right;   
  margin-right: 50px;
  margin-top: 50rem;
  margin-left: 50rem;
  width: 100%; 
  font-size: 1.5rem;
  font-family: "Tinos", serif;
  font-weight: 500;
  font-style: normal;
}
.input {

  margin-right: 6rem;
  padding: 1rem;

  text-align: left;   
  width: 70%;
  opacity: 0.3;
  border-radius: 0.5rem;
  color: #2b3249;
  border: none;
  outline: none;
  border-bottom: 3px solid #2b3249;
  transition: all 400ms;
  font-size: 1.5rem;
  font-family: "Tinos", serif;
  font-weight: 400;
  font-style: normal;
}
.input:hover {
  background-color: #d9d1ea;
  border: none;
  border-radius: 0.5rem;
  border-bottom: 2px solid #2b3249;
}

.passwords-container {
  display: flex;
  gap: 1rem;  
  margin-right: 4rem;
  
 
}

.passwordres {
  margin-right: 0;
  padding: 1rem;
  text-align: left;   
  width: 40%;
  opacity: 0.3;
  border-radius: 0.5rem;
  color: #2b3249;
  border: none;
  outline: none;
  border-bottom: 3px solid ;
  transition: all 400ms;
  font-size: 1.5rem;
  font-family: "Tinos", serif;
  font-weight: 400;
  font-style: normal;
}
.passwordres:hover {
  background-color: #d9d1ea;
  border: none;
  border-radius: 0.5rem;
  border-bottom: 2px solid #2b3249;
}

.select-inputs {
  position: relative;
  display: flex;
  flex-wrap: wrap;
  border: 2px solid #d9d1ea;
  border-radius: 0.5rem;
  box-sizing: border-box;
  box-shadow: 0 0 0px 1px rgba(0, 0, 0, 0.06);
  padding: 0.25rem;
  width: 80%;
  font-size: 1.5rem;
  font-family: "Tinos", serif;
  font-style: normal;
  font-weight: 500;

}

.select-inputs .select {
  flex: 1 1 auto;
  text-align: center;
  position: relative;
  border-right: 2px solid #d9d1ea;
}

.select-inputs .select input {
  position: absolute;
  opacity: 0;
  pointer-events: auto;
}

.select-inputs .select .name {
  display: flex;
  cursor: pointer;
  align-items: center;
  justify-content: center;
  border-radius: 0.5rem;
  border: none;
  padding: .5rem 0;
  color: #d9d1ea;
  transition: all .15s ease-in-out;
}

.select-inputs .select input:checked + .name {
  color: #626994; 
  background-color: #d9d1ea;
  font-weight: 600;
}


.boton {
  align-self: flex-end;
  margin-top: auto;
  margin-right: 32px;
  margin-bottom: 32px;
  --primary-color: #fff;
  --secondary-color: #626994;
  --hover-color: #111;
  --arrow-width: 10px;
  --arrow-stroke: 2px;
  box-sizing: border-box;
  border: 0;
  border-radius: 20px;
  color: var(--secondary-color);
  padding: 0.8em 1em;
  background: var(--primary-color);
  display: flex;
  transition: 0.2s background;
  align-items: center;
  gap: 0.6em;
  font-size: 1.5rem;
  font-family: "Tinos", serif;
  font-weight: bold;
  font-style: normal;
  
}

.boton .arrow-wrapper {
  display: flex;
  justify-content: center;
  align-items: center;
}

.boton .arrow {
  margin-top: 1px;
  width: var(--arrow-width);
  background: var(--primary-color);
  height: var(--arrow-stroke);
  position: relative;
  transition: 0.2s;
}

.boton .arrow::before {
  content: "";
  box-sizing: border-box;
  position: absolute;
  border: solid var(--secondary-color);
  border-width: 0 var(--arrow-stroke) var(--arrow-stroke) 0;
  display: inline-block;
  top: -3px;
  right: 3px;
  transition: 0.2s;
  padding: 3px;
  transform: rotate(-45deg);
}

.boton:hover {
  background-color: var(--hover-color);
}

.boton:hover .arrow {
  background: var(--secondary-color);
}

.boton:hover .arrow:before {
  right: 0;
}

.boton2 {
  float: right;
  margin-right: 1rem;
  margin-bottom: 1rem;
  --primary-color: #fff;
  --secondary-color: #626994;
  --hover-color: #111;
  --arrow-width: 10px;
  --arrow-stroke: 2px;
  box-sizing: border-box;
  border: 0;
  border-radius: 20px;
  color: var(--secondary-color);
  padding: 0.8em 1em;
  background: var(--primary-color);
  display: flex;
  transition: 0.2s background;
  align-items: center;
  gap: 0.6em;
  font-size: 1rem;
  font-family: "Tinos", serif;
  font-weight: bold;
  font-style: normal;
  
}

.boton2 .arrow-wrapper {
  display: flex;
  justify-content: center;
  align-items: center;
}

.boton2 .arrow {
  margin-top: 1px;
  width: var(--arrow-width);
  background: var(--primary-color);
  height: var(--arrow-stroke);
  position: relative;
  transition: 0.2s;
}

.boton2 .arrow::before {
  content: "";
  box-sizing: border-box;
  position: absolute;
  border: solid var(--secondary-color);
  border-width: 0 var(--arrow-stroke) var(--arrow-stroke) 0;
  display: inline-block;
  top: -3px;
  right: 3px;
  transition: 0.2s;
  padding: 3px;
  transform: rotate(-45deg);
}

.boton2:hover {
  background-color: var(--hover-color);
}

.boton2:hover .arrow {
  background: var(--secondary-color);
}

.boton2:hover .arrow:before {
  right: 0;
}

/*Menu*/

.menu-wrapper {
  position: absolute;
  z-index: 9999;
  pointer-events: auto;
  margin-left: 15px;
}
.button-menu.alumno {
  background-image: url("../imagenes/perfil_alum.png");
}

.button-menu.profesor {
  background-image: url("../imagenes/perfil_prof.png");
}

.button-menu.administrador {
  background-image: url("../imagenes/perfil_admin.png");
}
.button-menu.visitante {
  background-image: url("../imagenes/perfil_visi.png");
}

.button-menu {
  cursor: pointer;
  background-size: cover;
  z-index: 999;
  font-size: 30px;
  font-weight: 700;
  width: 100px;
  height: 100px;
  border-radius: 50%;
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: center;
  -webkit-box-shadow: 0px 3px 10px 0px rgba(16, 16, 16, 0.5);
  -moz-box-shadow: 0px 3px 10px 0px rgba(16, 16, 16, 0.5);
  box-shadow: 0px 3px 10px 0px rgba(16, 16, 16, 0.5);
  
}



.checkbox {
  position: absolute;
  width: 100px;
  height: 100px;
  opacity: 0;
  z-index: 999;
  cursor: pointer;
  color: transparent;
}



.checkbox:checked {
  width: 300px;
  height: 300px;
  transform: translate(-80px, -70px);
  transition: all 0.3s ease;
}
.checkbox:checked ~ .button-menu {
  width: 325px;
  height: 325px;
  transform: translate(-80px, -70px);
  transition: all 0.3s ease;
    color: transparent;
}


.option {
  position: absolute;
  z-index: 998;
  width: 0px;
  border: 0px;
  background-color: transparent;
  height: 0px;
  cursor: pointer;
  font-size: 0px;
  font-weight: 0;
  font-family: "Tinos", serif;
  font-style: normal;
  transition: all 0.3s;
  color: transparent;
}

.option a{
  text-decoration: none; /* quita la línea */
  color: inherit; 
}

.option ~ form {
  position: absolute;
  z-index: 998;
  width: 0px;
  height: 0px;
  cursor: pointer;
  font-size: 0px;
  font-weight: 0;
  transition: all 0.3s;
    color: transparent;


}

.checkbox:checked ~ .nombre {
  font-size: 30px;
  margin-left: 30px;
  transition-delay: 0.3s;
  transform: translateX(250px) translateY(-325px);
  color: #2b3249;
  box-shadow: 0px 0px 0px 0px rgba(16, 16, 16, 0.5);
  width: 250px;
  height: 55px;
  font-weight: 700;

}



.checkbox:checked ~ .option-a {
  font-size: 23px;
  margin-left: 15px;
  transition-delay: 0.1s;
  transform: translateY(0px);
  background-color: #f2eff8;
  color: #2b3249;
  border: 0px;
  border-radius: 0 20px 20px 0;
  width: 250px;
  height: 55px;

}
.checkbox:checked ~ form .option-a-form {
  font-size: 23px;
  margin-left: 15px;
  transition-delay: 0.1s;
  transform: translateY(0px);
  background-color: #626994;
  color: #fff;
  border: 0px;
  border-radius: 0 20px 20px 0;
  width: 150px;
  height: 55px;
}

.checkbox:checked ~ .option-b {
  font-size: 23px;
  margin-left: 15px;
  transition-delay: 0.2s;
  transform: translateY(75px);
  background-color: #f2eff8;
  color: #2b3249;
  border: 0px;
  border-radius: 0 20px 20px 0;
  width: 170px;
  height: 55px;
}


.checkbox:checked ~ .option-b-ad {
  font-size: 23px;
  margin-left: 15px;
  transition-delay: 0.2s;
  transform: translateY(75px);
  background-color: #f2eff8;
  color: #2b3249;
  border: 0px;
  border-radius: 0 20px 20px 0;
  width: 280px;
  height: 55px;
}

.checkbox:checked ~ .option-c {
  font-size: 23px;
  margin-left: 15px;
  transition-delay: 0.3s;
  transform: translateY(150px);
  background-color: #f2eff8;
  color: #2b3249;
  border: 0px;
  border-radius: 0 20px 20px 0;
  width: 120px;
  height: 55px;
}
.checkbox:checked ~ .option-c-ad {
  font-size: 23px;
  margin-left: 15px;
  transition-delay: 0.3s;
  transform: translateY(150px);
  background-color: #f2eff8;
  color: #2b3249;
  border: 0px;
  border-radius: 0 20px 20px 0;
  width: 250px;
  height: 55px;
}
.checkbox:checked ~ .option-c-prof {
    font-size: 23px;
    margin-left: 15px;
    transition-delay: 0.3s;
    transform: translateY(150px);
    background-color: #f2eff8;
    color: #2b3249;
    border: 0px;
    border-radius: 0 20px 20px 0;
    width: 170px;
    height: 55px;
  }
.checkbox:checked ~ .option-perf {
  font-size: 23px;
  margin-left: 15px;
  transition-delay: 0.3s;
  transform: translateY(220px);
  background-color: #f2eff8;
  color: #2b3249;
  border: 0px;
  border-radius: 0 20px 20px 0;
  width: 120px;
  height: 55px;
}
.checkbox:checked ~ form .option-d {
  font-weight: 500;
  font-size: 23px;
  margin-left: 15px;
  transition-delay: 0.4s;
  transform: translateY(250px);
  background-color: #626994;
  color: #fff;
  border: 0px;
  border-radius: 0 20px 20px 0;
  width: 150px;
  height: 55px;
}
.checkbox:checked ~ .option-d-prof {
  font-size: 23px;
  margin-left: 15px;
  transition-delay: 0.3s;
  transform: translateY(220px);
  background-color: #f2eff8;
  color: #2b3249;
  border: 0px;
  border-radius: 0 20px 20px 0;
  width: 120px;
  height: 55px;
}
.checkbox:checked ~ form .option-d-logoff {
  font-weight: 500;
  font-size: 23px;
  margin-left: 15px;
  transition-delay: 0.4s;
  transform: translateY(290px);
  background-color: #626994;
  color: #fff;
  border: 0px;
  border-radius: 0 20px 20px 0;
  width: 150px;
  height: 55px;
}


/*mis clases  clases*/

.title-wrapper {
  margin: 0px;
}

.slider-clases {
  display: flex;
  overflow-x: auto;
  padding: 20px;
  padding-bottom: 50px; /* separación de la barra */
  scroll-snap-type: x mandatory;
  margin-left: 50px;
  margin-right: 50px;
  margin-top: 50px;
}

.slider-clases::-webkit-scrollbar-track {
  background: #d9d1ea81; 
  height: 2px;  
  border-radius: 6px; 
    
}


.slider-clases::-webkit-scrollbar-thumb {
  background: #626994;       
  border-radius:30%;      
  height: 8px;             
  width: 3px;
}

/* scrollbar general */
.slider-clases::-webkit-scrollbar {
  height: 8px; 
            
}

/* CONTENEDOR */
.contenedor-clases {
  display: flex;
  flex-wrap: wrap;
}

/* CARD */
.contenedor-clases .card {
  margin-right: 250px;
  flex: 0 0 500px;
  scroll-snap-align: start;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  border-radius: 0.75rem;
  background-color: #f9f6fd;
  height: 560px;
  box-shadow: 0 4px 6px -1px rgba(0,0,0,.1),
              0 2px 4px -2px rgba(0,0,0,.1);
}

/* HEADER */
.contenedor-clases .header {
  margin: 1rem 1rem 0;
  border-radius: 0.75rem;
  background-color: #626994;
  height: 6rem;
  margin-bottom: 0px;
  font-family: "Tinos", serif;
  font-style: normal;
}

/* INFO */
.contenedor-clases .info {

  margin-left: 30px;
  font-size: 1.1rem;
  margin-bottom: 150px;
  font-family: "Tinos", serif;
  font-style: normal;
}
.contenedor-clases .info p {
  margin: 5px 0;
}
.contenedor-clases .info .campo {
  display: flex;
  gap: 0px;
  margin-bottom: 4px;
}
.text4{

  color: #2b3249;
  text-align: left;   
  font-size: 1.5rem;
  font-family: "Tinos", serif;
  font-weight: 500;
  font-style: normal;

}
.text5{

  color: #534c79;
  text-align: left;    
  font-size: 1.5rem;
  font-family: "Tinos", serif;
  font-weight: 500;
  font-style: normal;

}
.text-notificaciones{
  margin-left: 2rem;
  color: #2b3249;
  text-align: left;   
  font-size: 1.5rem;
  font-family: "Tinos", serif;
  font-weight: 500;
  font-style: normal;
}

/* TÍTULO */
.contenedor-clases .titulo-clase {
  font-size: 2rem;
  font-weight: 600;
  margin-left: 20px;
  background-color: #626994;
  font-family: "Tinos", serif;
  font-style: normal;
  color: #2b3249;
}

/* FOOTER */
.contenedor-clases .footer {

  padding: 1.25rem;
  display: flex;
  justify-content: space-between;
  background-color: #626994;
  border-radius: 0.75rem;
  border-top-left-radius: 0rem;
  border-top-right-radius: 0rem;
}

/* BOTÓN */
.contenedor-clases .action {
  border: none;
  background: #d9d1ea;
  padding: 1rem 2rem;
  border-radius: 2rem;
  font-weight: 700;
  font-size: 1.5rem;
  font-family: "Tinos", serif;
  font-style: normal;
  color: #626994;

}
.contenedor-clases .action a {
  text-decoration: none; /* quita la línea */
  color: inherit;        /* mantiene el color del botón */
}

.volver-inicio {
  margin-left: 50px;
  justify-content: right;
  font-family: "Tinos", serif;
  font-style: normal;
}

/*------------ Notificaciones----------------------*/
.radio-inputs {
  position: relative;
  display: flex;
  float: right;
  margin-right: 100px;
  margin-top: 5rem;
  border-top-left-radius: 0.5rem;
  border-top-right-radius: 0.5rem;
  background-color: transparent;
  font-size: 14px;
  width: 55%;
  padding: 0.5rem 1.5rem 0 1.5rem;
}

.radio-inputs .radio input {
  background-color: rgb(83, 76, 121);
  display: none;
}

.radio-inputs .radio .name {
  display: flex;
  cursor: pointer;
  background-color: #2b3249;
  color: white;
  font-size: 1.5rem;
  font-family: "Tinos", serif;
  font-weight: 400;
  font-style: normal;
  align-items: center;
  justify-content: center;
  border: none;
  transition: all 0.15s ease-in-out;
  position: relative;
  border-top-left-radius: 0.5rem;
  border-top-right-radius: 0.5rem;
}

.radio-inputs .radio input + .name:hover {
  color: #fff;
}

.radio-inputs .radio input + .name .pre-name,
.radio-inputs .radio input + .name .pos-name {
  content: "";
  position: absolute;
  width: 10px;
  height: 10px;
  background-color: transparent;
  bottom: 0;
  opacity: 0;
}

.radio-inputs .radio input + .name .pre-name {
  right: -10px;
  border-bottom-left-radius: 300px;
  box-shadow: -3px 3px 0px 3px rgb(83, 76, 121);
}

.radio-inputs .radio input + .name .pos-name {
  left: -10px;
  border-bottom-right-radius: 300px;
  box-shadow: 3px 3px 0px 3px rgb(83, 76, 121);
}

.radio-inputs .radio input:checked + .name {
  animation: name-activated;
  animation-duration: 0.1s;
  animation-fill-mode: forwards;
}

@keyframes name-activated {
  from {
    background-color: rgb(83, 76, 121);
    font-weight: 300;
    cursor: pointer;
    color: white;
  }

  to {
    background-color: #e8e8e8;
    font-weight: 600;
    font-size: 1.5rem;
    cursor: default;
    color: #2b3249;
  }
}

.radio-inputs .radio input:checked + .name .pre-name,
.radio-inputs .radio input:checked + .name .pos-name {
  animation: name-border-activated;
  animation-duration: 0.1s;
  animation-fill-mode: forwards;
  z-index: 0;
}

@keyframes name-border-activated {
  from {
    opacity: 0;
  }

  to {
    opacity: 1;
  }
}

.radio-inputs .radio .name span:last-child {
  z-index: 1;
  padding: 0.5rem 0.8rem;
  border-top-left-radius: 0.5rem;
  border-top-right-radius: 0.5rem;
}

.radio-inputs .radio input:checked + .name span:last-child {
  animation: name-text-activated;
  animation-duration: 0.1s;
  animation-fill-mode: forwards;
}

@keyframes name-text-activated {
  from {
    background-color: transparent;
  }

  to {
    background-color: #e8e8e8;
  }
}

.radio-inputs > .radio > .content {
  display: none;
}

.content table{
  width: 100%;
  text-align: left;
  border-collapse: collapse;
}

.content th {
  padding: 10px;
  color: #2b3249;
  text-align: left;   
  font-size: 1.5rem;
  font-family: "Tinos", serif;
  font-weight: 600;
  font-style: normal;

}
.content td{
  padding-left: 30px;
  border-bottom: 2px solid #626994;
  padding-bottom: 10px;
  padding-top: 10px;
  color: #626994;
  font-family: "Tinos", serif;
  font-weight: 500;
  font-style: normal;
}
.boton-leer {
  padding: 0px;
  margin: 0px;
  width: 10%;
  text-align: right;
}

.estado {
  width: 10%;
  text-align: center;

}
.radio-inputs > label.radio > input:checked ~ div.content {
  display: block;
}

.radio-inputs > label.radio > input:checked ~ div.content div * {
  animation: content-activated;
  animation-duration: 1s;
  animation-fill-mode: forwards;
}

.content {
  background-color: transparent;
  position: absolute;
  left: 0px;
  right: 0px;
  border-bottom-left-radius: 0.5rem;
  border-bottom-right-radius: 0.5rem;
}

.content > div {
  background-color: #e8e8e8;
  border-radius: 0.5rem;
  padding: 1rem;
  padding-bottom: 1.2rem;
  border: 4px solid transparent;
  border-top-width: 0px;
}

@keyframes content-activated {
  from {
    opacity: 0;
  }

  to {
    opacity: 1;
  }
}

.Btn {
  width: 30px;
  height: 30px;
  border: none;
  border-radius: 50%;
  float: right;
  background-color: #626994;
  display: flex;
  margin-right: 30px;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  position: relative;
  transition-duration: .3s;
  box-shadow: 2px 2px 10px rgba(0, 0, 0, 0.11);
}

.svgIcon {
  fill: rgb(214, 178, 255);
}


.tooltip {
  position: absolute;
  right: -105px;
  opacity: 0;
  background-color: white;
  color: white;
  padding: 5px 10px;
  border-radius: 5px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition-duration: .2s;
  pointer-events: none;
  letter-spacing: 0.5px;
}

.tooltip::before {
  position: absolute;
  content: "";
  width: 10px;
  height: 10px;
  background-color: white;
  background-size: 1000%;
  background-position: center;
  transform: rotate(45deg);
  left: -5%;
  transition-duration: .3s;
}

.Btn:hover .tooltip {
  opacity: 1;
  transition-duration: .3s;
}

.Btn:hover {
  background-color: #a9afdb;
  transition-duration: .3s;
}

.Btn:hover .svgIcon {
  fill: rgb(255, 255, 255);
  animation: slide-in-top 0.6s cubic-bezier(0.250, 0.460, 0.450, 0.940) both;
}

.Btn2 {
  width: 30px;
  height: 30px;
  border: none;
  border-radius: 50%;
  background-color: #626994;
  display: flex;
  margin-right: 30px;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  position: relative;
  transition-duration: .3s;
  box-shadow: 2px 2px 10px rgba(0, 0, 0, 0.11);
}

.svgIcon {
  fill: rgb(214, 178, 255);
}


.tooltip {
  position: absolute;
  right: -105px;
  opacity: 0;
  background-color: white;
  color: white;
  padding: 5px 10px;
  border-radius: 5px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition-duration: .2s;
  pointer-events: none;
  letter-spacing: 0.5px;
}

.tooltip::before {
  position: absolute;
  content: "";
  width: 10px;
  height: 10px;
  background-color: white;
  background-size: 1000%;
  background-position: center;
  transform: rotate(45deg);
  left: -5%;
  transition-duration: .3s;
}

.Btn2:hover .tooltip {
  opacity: 1;
  transition-duration: .3s;
}

.Btn2:hover {
  background-color: #a9afdb;
  transition-duration: .3s;
}

.Btn2:hover .svgIcon {
  fill: rgb(255, 255, 255);
  animation: slide-in-top 0.6s cubic-bezier(0.250, 0.460, 0.450, 0.940) both;
}
@keyframes slide-in-top {
  0% {
    transform: translateY(-10px);
    opacity: 0;
  }

  100% {
    transform: translateY(0px);
    opacity: 1;
  }
}

.slider-noti {
  display: flex;
  flex-direction: column;
  overflow-y: auto;
  overflow-x: hidden;
  scroll-snap-type: y mandatory;
  padding: 20px;
  padding-bottom: 10px;
  margin-top: 50px;
  max-height: 400px; /* altura del slider */
}

.slider-noti::-webkit-scrollbar {
  width: 8px;
}

.slider-noti::-webkit-scrollbar-track {
  background: #f0f0f0;
  border-radius: 30%;
}

.slider-noti::-webkit-scrollbar-thumb {
  background: #626994;
  border-radius: 30%;
}


/*--------------- Card de grupos---------------------*/

.card-clase {
  background-color: #a2aadd;
  border-radius: 1rem;
  width: 30%;
  display: flex;
  flex-direction: column;
  scroll-snap-align: start;
  justify-content: space-between;
  float: center;
  border-bottom: #2b3249 4px solid;
  margin-bottom: 2rem;
}

.contenedor-grupos {
  display: flex;
  gap: 1.5rem;
  margin: 5rem;
  flex-wrap: wrap;          /* permite varias filas */
  justify-content: flex-start;
  align-items: flex-start;
  float: center;
}

.text-grupos {
  color: #2b3249;
  float: left;
  margin-left: 1rem;
  font-size: 2rem;
  font-family: "Tinos", serif;
  font-weight: 600;
  font-style: normal;
}

.radio-inputs2 {

  position: relative;
  display: flex;
  border-top-left-radius: 0.5rem;
  border-top-right-radius: 0.5rem;
  background-color: transparent;
  font-size: 14px;
}


.radio-inputs2 .grupo-align .radio input {

  display: none;
}

.radio-inputs2 .grupo-align .radio .name {
  display: flex;
  cursor: pointer;
  background-color: #2b3249;
  color: white;
  font-size: 1.2rem;
  font-family: "Tinos", serif;
  font-weight: 400;
  font-style: normal;
  border: none;
  transition: all 0.15s ease-in-out;
  position: relative;
  margin-left: 20%;
  bottom: 0;
  border-top-left-radius: 0.5rem;
  border-top-right-radius: 0.5rem;
  width: max-content;
  margin-right: 8px;
}

.radio-inputs2 .grupo-align .radio input + .name:hover {
  color: #fff;
}

.radio-inputs2 .grupo-align .radio input + .name .pre-name,
.radio-inputs2 .grupo-align .radio input + .name .pos-name {
  content: "";
  position: absolute;
  width: 10px;
  height: 10px;
  background-color: transparent;
  bottom: 0;
  opacity: 0;
}

.radio-inputs2 .grupo-align .radio input + .name .pre-name {
  right: -10px;
  border-bottom-left-radius: 300px;
  box-shadow: -3px 3px 0px 3px #626994;
}

.radio-inputs2 .grupo-align .radio input + .name .pos-name {
  left: -10px;
  border-bottom-right-radius: 300px;
  box-shadow: 3px 3px 0px 3px #626994;
}

.radio-inputs2 .grupo-align .radio input:checked + .name {
  animation: name-activated;
  animation-duration: 0.1s;
  animation-fill-mode: forwards;
}

@keyframes name-activated {
  from {
    background-color: #626994;
    font-weight: 300;
    cursor: pointer;
    color: white;
  }

  to {
    background-color: #626994;
    font-weight: 600;
    font-size: 1.5rem;
    cursor: default;
    color: #2b3249;
  }
}

.radio-inputs2 .grupo-align .radio input:checked + .name .pre-name,
.radio-inputs2 .grupo-align .radio input:checked + .name .pos-name {
  animation: name-border-activated;
  animation-duration: 0.1s;
  animation-fill-mode: forwards;
  z-index: 0;
}

@keyframes name-border-activated {
  from {
    opacity: 0;
  }

  to {
    opacity: 1;
  }
}

.radio-inputs2 .grupo-align .radio .name span:last-child {
  width: 30%;
  z-index: 1;
  padding: 0.5rem 0.8rem;
  border-top-left-radius: 0.5rem;
  border-top-right-radius: 0.5rem;
}

.radio-inputs2 .grupo-align .radio input:checked + .name span:last-child {
  animation: name-text-activated;
  animation-duration: 0.1s;
  animation-fill-mode: forwards;
}

@keyframes name-text-activated {
  from {
    background-color: transparent;
  }

  to {
    background-color: #e8e8e8;
  }
}

.radio-inputs2 > .grupo-align > .radio > .content {
  display: none;
}

.radio-inputs2 > .grupo-align > label.radio > input:checked ~ div.content {
  display: block;
}

.radio-inputs2 > .grupo-align > label.radio > input:checked ~ div.content div * {
  animation: content-activated;
  animation-duration: 1s;
  animation-fill-mode: forwards;
}
.radio-inputs2 .radio .content {
  display: none;
}

.radio-inputs2 .radio input:checked ~ .content {
  display: block;
}
.content {
  background-color: transparent;
  position: absolute;
  left: 0px;
  right: 0px;
  border-bottom-left-radius: 0.5rem;
  border-bottom-right-radius: 0.5rem;
}

.content > div {
  border: rgb(83, 76, 121) solid 5px;
  background-color: #ffffffda;
  border-bottom-left-radius: 0.5rem;
  border-bottom-right-radius: 0.5rem;
  padding: 1rem;
  padding-bottom: 1.2rem;

}

@keyframes content-activated {
  from {
    opacity: 0;
  }

  to {
    opacity: 1;
  }
}


.boton3 {
  width: 25%;
  float: right;
  margin-left: 80%;
  margin-bottom: 1.5rem;
  --primary-color: #fff;
  --secondary-color: #626994;
  --hover-color: #111;
  --arrow-width: 10px;
  --arrow-stroke: 2px;
  box-sizing: border-box;
  border: 0;
  border-radius: 20px;
  color: var(--secondary-color);
  padding: 0.8em 1em;
  background: var(--primary-color);
  display: flex;
  transition: 0.2s background;
  align-items: center;
  gap: 0.6em;
  font-size: 1rem;
  font-family: "Tinos", serif;
  font-weight: bold;
  font-style: normal;
  
}

.boton3 .arrow-wrapper {
  display: flex;
  justify-content: center;
  align-items: center;
}

.boton3 .arrow {
  margin-top: 1px;
  width: var(--arrow-width);
  background: var(--primary-color);
  height: var(--arrow-stroke);
  position: relative;
  transition: 0.2s;
}

.boton3 .arrow::before {
  content: "";
  box-sizing: border-box;
  position: absolute;
  border: solid var(--secondary-color);
  border-width: 0 var(--arrow-stroke) var(--arrow-stroke) 0;
  display: inline-block;
  top: -3px;
  right: 3px;
  transition: 0.2s;
  padding: 3px;
  transform: rotate(-45deg);
}

.boton3:hover {
  background-color: var(--hover-color);
}

.boton3:hover .arrow {
  background: var(--secondary-color);
}

.boton3:hover .arrow:before {
  right: 0;
}
.boton4 {
  position: fixed;
  bottom: 20px;   /* distancia desde abajo */
  right: 20px;    /* distancia desde la derecha */

  width: 25%;
  margin: 0;

  --primary-color: #fff;
  --secondary-color: #626994;
  --hover-color: #111;
  --arrow-width: 10px;
  --arrow-stroke: 2px;

  box-sizing: border-box;
  border: 0;
  border-radius: 20px;
  color: var(--secondary-color);
  padding: 0.8em 1em;
  background: var(--primary-color);
  display: flex;
  align-items: center;
  gap: 0.6em;

  font-size: 1rem;
  font-family: "Tinos", serif;
  font-weight: bold;

  transition: 0.2s background;
  z-index: 1000; /* para que quede por encima de todo */
}


.boton4 .arrow-wrapper {
  display: flex;
  justify-content: center;
  align-items: center;
}

.boton4 .arrow {
  margin-top: 1px;
  width: var(--arrow-width);
  background: var(--primary-color);
  height: var(--arrow-stroke);
  position: relative;
  transition: 0.2s;
}

.boton4 .arrow::before {
  content: "";
  box-sizing: border-box;
  position: absolute;
  border: solid var(--secondary-color);
  border-width: 0 var(--arrow-stroke) var(--arrow-stroke) 0;
  display: inline-block;
  top: -3px;
  right: 3px;
  transition: 0.2s;
  padding: 3px;
  transform: rotate(-45deg);
}

.boton4:hover {
  background-color: var(--hover-color);
}

.boton4:hover .arrow {
  background: var(--secondary-color);
}

.boton4:hover .arrow:before {
  right: 0;
}

.boton5 {
  width: 25%;
  float: left;
  margin-bottom: 1.5rem;
  --primary-color: #fff;
  --secondary-color: #626994;
  --hover-color: #111;
  --arrow-width: 10px;
  --arrow-stroke: 2px;
  box-sizing: border-box;
  border: 0;
  border-radius: 20px;
  color: var(--secondary-color);
  padding: 0.8em 1em;
  background: var(--primary-color);
  display: flex;
  transition: 0.2s background;
  align-items: center;
  gap: 0.6em;
  font-size: 1rem;
  font-family: "Tinos", serif;
  font-weight: bold;
  font-style: normal;
  
}


.boton5 .arrow-wrapper {
  display: flex;
  justify-content: center;
  align-items: center;
}

.boton5 .arrow {
  margin-top: 1px;
  width: var(--arrow-width);
  background: var(--primary-color);
  height: var(--arrow-stroke);
  position: relative;
  transition: 0.2s;
}

.boton5 .arrow::before {
  content: "";
  box-sizing: border-box;
  position: absolute;
  border: solid var(--secondary-color);
  border-width: 0 var(--arrow-stroke) var(--arrow-stroke) 0;
  display: inline-block;
  top: -3px;
  right: 3px;
  transition: 0.2s;
  padding: 3px;
  transform: rotate(-45deg);
}

.boton5:hover {
  background-color: var(--hover-color);
}

.boton5:hover .arrow {
  background: var(--secondary-color);
}

.boton5:hover .arrow:before {
  right: 0;
}

/*------------Admin_usu.php------------------------*/
/* CONTENEDOR GENERAL */
.columna {
  flex: 1;              /* ambas columnas mismo ancho */
}

.button3 {
  width: 50px;
  height: 50px;
  border-radius: 50%;
  background-color: #626994;
  border: none;
  font-weight: 600;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  box-shadow: 0px 0px 20px rgba(0, 0, 0, 0.164);
  cursor: pointer;
  transition-duration: 0.3s;
  overflow: hidden;
  position: relative;
  gap: 2px;
}

.svgIcon2 {
  width: 12px;
  transition-duration: 0.3s;
}

.svgIcon2 path {
  fill: white;
}

.button3:hover {
  transition-duration: 0.3s;
  background-color: #aaa0d3;
  align-items: center;
  gap: 0;
}

.bin-top1 {
  transform-origin: bottom right;
}
.button3:hover .bin-top1 {
  transition-duration: 0.5s;
  transform: rotate(160deg);
}
.adminusu-wrapper {
  border-radius: 5%;
  padding: 30px;
  background-color: #fff;
  opacity: 0.9;
  border-collapse: collapse;
  align-items: center;
  width: 80%;
  margin-left: 5%;
  height: 70%;

}
.title-adminusu {
  margin-left: 5%;
  margin-top: 10%;
  margin-bottom: 5px;
  font-size: 2.5rem;
  font-family: "Tinos", serif;
  font-weight: 600;
  font-style: normal;
  color: #2b3249;
}

.title-adminusu2 {
  margin-left: 0;
  margin-top: 53%;
  margin-bottom: 5px;
  font-size: 2.5rem;
  font-family: "Tinos", serif;
  font-weight: 600;
  font-style: normal;
  color: #2b3249;

}
.title5 {

  color: #2b3249;
  margin-top: 1.5rem;
  margin-left: 2rem;
  font-size: 2rem;
  font-family: "Tinos", serif;
  font-weight: 400;
  font-style: normal;
  font-weight: bold;
  text-align: left;   
  width: 100%; 
}
.formularios {
  margin-bottom: 50%;
}
.formularios-grupos {
  position: fixed;
  bottom: 30%;   /* distancia desde abajo */
  left: 3%;  
  width: 40%;
}
.newadminusu-wrapper {
  border-radius: 5%;
  padding: 30px;
  background-color: #fff;
  opacity: 0.9;
  border-collapse: collapse;
  align-items: center;
  width: 90%;
  margin-left: 0;
  height: 25%;
}

.tabla-adminusu{
  width: 100%;
}

.tabla-adminusu th {

  padding: 10px;
  color: #2b3249;
  text-align: left;   
  font-size: 1.5rem;
  font-family: "Tinos", serif;
  font-weight: 600;
  font-style: normal;
  

}
.tabla-adminusu td{
  padding-left: 30px;
  border-bottom: 2px solid #626994;
  padding-bottom: 10px;
  padding-top: 10px;
  color: #626994;
  font-family: "Tinos", serif;
  font-weight: 500;
  font-style: normal;

}

.input-usu {
  margin-left: 3rem;
  padding: 0.6rem;
  text-align: left;
  width: 55%;
  opacity: 0.4;
  border-radius: 0.4rem;
  color: #2b3249;
  border: none;
  outline: none;
  border-bottom: 2px solid #2b3249;
  transition: all 400ms;
  font-size: 1.2rem;
  font-family: "Tinos", serif;
  font-weight: 400;
  font-style: normal;
}

.input-usu:hover {
  background-color: #d9d1ea;
  border-radius: 0.4rem;
  border-bottom: 2px solid #2b3249;
}

/* ---------------- RADIO INPUTS ---------------- */

.radio-inputs-usu {
  position: relative;
  display: flex;

  margin-left: 0;
  margin-right: 60px;
  margin-top: 2rem;
  border-top-left-radius: 0.4rem;
  border-top-right-radius: 0.4rem;
  background-color: transparent;
  font-size: 0.8rem;
  width: 75%;
  padding: 0.4rem 1rem 0 1rem;
}

.radio-inputs-usu > .radio > input[type="radio"] {
  display: none;
}

.radio-inputs-usu .radio .name {
  display: flex;
  cursor: pointer;
  background-color: #2b3249;
  color: #d9d1ea8f;
  font-size: 1.3rem;
  font-family: "Tinos", serif;
  align-items: center;
  justify-content: center;
  transition: all 0.15s ease-in-out;
  position: relative;
  border-top-left-radius: 0.4rem;
  border-top-right-radius: 0.4rem;
}

.radio-inputs-usu .radio input + .name:hover {
  color: #fff;
}

.radio-inputs-usu .radio input + .name .pre-name,
.radio-inputs-usu .radio input + .name .pos-name {
  content: "";
  position: absolute;
  width: 8px;
  height: 8px;
  background-color: transparent;
  bottom: 0;
  opacity: 0;
}

.radio-inputs-usu .radio input + .name .pre-name {
  right: -8px;
  border-bottom-left-radius: 300px;
  box-shadow: -3px 3px 0px 3px #534c79;
}

.radio-inputs-usu .radio input + .name .pos-name {
  left: -8px;
  border-bottom-right-radius: 300px;
  box-shadow: 3px 3px 0px 3px #534c79;
}

/* ---------------- ACTIVADO ---------------- */

.radio-inputs-usu .radio input:checked + .name {
  animation: name-activated;
  animation-duration: 0.1s;
  animation-fill-mode: forwards;
}

@keyframes name-activated {
  from {
    background-color: #534c79;
    font-weight: 300;
    color: #534c79;
  }
  to {
    background-color: #534c79;
    font-weight: 500;
    font-size: 1.6rem;
    color: #e8e8e8;
  }
}

.radio-inputs-usu .radio input:checked + .name .pre-name,
.radio-inputs-usu .radio input:checked + .name .pos-name {
  animation: name-border-activated;
  animation-duration: 0.1s;
  animation-fill-mode: forwards;
  z-index: 0;
}

@keyframes name-border-activated {
  from { opacity: 0; }
  to { opacity: 1; }
}

.radio-inputs-usu .radio .name span:last-child {
  z-index: 1;
  padding: 0.4rem 0.6rem;
  border-top-left-radius: 0.4rem;
  border-top-right-radius: 0.4rem;
}

.radio-inputs-usu .radio input:checked + .name span:last-child {
  animation: name-text-activated;
  animation-duration: 0.1s;
  animation-fill-mode: forwards;
}

@keyframes name-text-activated {
  from { background-color: transparent; }
  to { background-color: #534c79; }
}

/* ---------------- CONTENT ---------------- */

.radio-inputs-usu > .radio > .content-usu {
  display: none;
}

.content-usu form {
  background-color: #d9d1ea;
  position: absolute;
  left: 0;
  right: 0;
  border-radius: 0.6rem;
  border: 5px solid #534c79;
  padding: 12px;
}

.input2 {

  margin-left: 2rem;
  padding: 1rem;

  text-align: left;   
  width: 70%;
  opacity: 0.3;
  border-radius: 0.5rem;
  color: #2b3249;
  border: none;
  outline: none;
  border-bottom: 3px solid #2b3249;
  transition: all 400ms;
  font-size: 1.5rem;
  font-family: "Tinos", serif;
  font-weight: 400;
  font-style: normal;
}
.input2:hover {
  background-color: #d9d1ea;
  border: none;
  border-radius: 0.5rem;
  border-bottom: 2px solid #2b3249;
}
.radio-inputs-usu form .input3 {
  margin-left: 2.5rem;
  background-color: #ece9f3b7;
  padding: 0.5rem;
  width: 40%;
  opacity: 0.4;
  border-radius: 0.4rem;
  color: #2b3249;
  border: none;
  outline: none;
  border-bottom: 2px solid #2b32498e;
  transition: all 400ms;
  font-size: 0.9rem;
  font-family: "Tinos", serif;
}

.radio-inputs-usu form .input3:hover {
  background-color: #f3f3f3d7;
  opacity: 0.8;
  border-bottom: 2px solid #2b3249;
}

/* ---------------- CAJA INTERNA ---------------- */

.content-usu > div {
  background-color: #534c79;
  width: 25%;
  height: max-content;
  border-radius: 0.4rem;
  padding: 0.7rem;
  padding-bottom: 0.9rem;
}

.radio-inputs-usu > label.radio > input:checked ~ div.content-usu {
  display: block;
}

.radio-inputs-usu > label.radio > input:checked ~ div.content-usu div * {
  animation: content-activated;
  animation-duration: 0.8s;
  animation-fill-mode: forwards;
}

.content-usu {
  background-color: #534c79;
  border-radius: 0.6rem;
  position: absolute;
  left: 0;
  right: 0;
  border-bottom-left-radius: 0.4rem;
  border-bottom-right-radius: 0.4rem;
}

@keyframes content-activated {
  from { opacity: 0; }
  to { opacity: 1; }
}

.boton4 {
  width: auto;
  float: center;
  margin-right: 10px;
  margin-left: 40%;
  margin-bottom: 1.5rem;
  --primary-color: #fff;
  --secondary-color: #626994;
  --hover-color: #111;
  --arrow-width: 10px;
  --arrow-stroke: 2px;
  box-sizing: border-box;
  border: 0;
  border-radius: 25px;
  color: var(--secondary-color);
  padding: 0.8em 1em;
  background: var(--primary-color);
  display: flex;
  transition: 0.2s background;
  align-items: center;
  gap: 0.6em;
  font-size: 1.2rem;
  font-family: "Tinos", serif;
  font-weight: bold;
  font-style: normal;
  
}

.boton4 .arrow-wrapper {
  display: flex;
  justify-content: center;
  align-items: center;
}

.boton4 .arrow {
  margin-top: 1px;
  width: var(--arrow-width);
  background: var(--primary-color);
  height: var(--arrow-stroke);
  position: relative;
  transition: 0.2s;
}

.boton4 .arrow::before {
  content: "";
  box-sizing: border-box;
  position: absolute;
  border: solid var(--secondary-color);
  border-width: 0 var(--arrow-stroke) var(--arrow-stroke) 0;
  display: inline-block;
  top: -3px;
  right: 3px;
  transition: 0.2s;
  padding: 3px;
  transform: rotate(-45deg);
}

.boton4:hover {
  background-color: var(--hover-color);
}

.boton4:hover .arrow {
  background: var(--secondary-color);
}

.boton4:hover .arrow:before {
  right: 0;
}

.select-inputs2 {
  position: relative;
  display: flex;
  flex-wrap: wrap;
  border: 2px solid #626994;
  border-radius: 0.5rem;
  box-sizing: border-box;
  box-shadow: 0 0 0px 1px rgba(0, 0, 0, 0.06);
  padding: 0.25rem;
  width: 70%;
  font-size: 1.5rem;
  font-family: "Tinos", serif;
  font-style: normal;
  font-weight: 500;
  top: 50%;
  left: 15%;

}

.select-inputs2 .select {
  flex: 1 1 auto;
  text-align: center;
  position: relative;
  border-right: 2px solid #e8e5f0;
  
}

.select-inputs2 .select input {

  position: absolute;
  opacity: 0;
  pointer-events: auto;
  display: none;
}

.select-inputs2 .select .name {
  display: flex;
  cursor: pointer;
  align-items: center;
  justify-content: center;
  border-radius: 0.5rem;
  border: none;
  padding: .5rem 0;
  color: #626994;
  background-color: transparent;
  transition: all .15s ease-in-out;
  
}

.select-inputs2 .select input:checked + .name {
  color: #626994; 
  background-color: #e8e5f0;
  font-weight: 600;
}

.select-clase {
  margin-left: 30px;
  width: 100%;
  max-width: 300px;
  padding: 10px 40px 10px 12px;
  font-size: 16px;
  border: 1px solid #ccc;
  border-radius: 8px;
  background-color: #fff;
  color: #2b3249;
  appearance: none; /* Quita el estilo nativo */
  -webkit-appearance: none;
  -moz-appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg fill='none' stroke='%23666' stroke-width='2' viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M19 9l-7 7-7-7'%3E%3C/path%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 12px center;
  background-size: 18px;
  cursor: pointer;
  transition: border-color 0.3s, box-shadow 0.3s;
}

.select-clase:focus {
  outline: none;
  border-color: #626994;
  box-shadow: 0 0 0 3px rgba(79, 70, 229, 0.2);
}

.select-clase option {
  padding: 10px;
}

/* =======================
   WRAPPER
======================= */
.inicards-wrapper {
  display: flex;
  gap: 40px;
  justify-content: center;
  flex-wrap: wrap;
}

/* =======================
   CARD BASE
======================= */
.cardini1 {
  --main-color: #000;
  --submain-color: #78858F;
  --bg-color: #fff;

  font-family: system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI',
    Roboto, Oxygen, Ubuntu, Cantarell, 'Open Sans', 'Helvetica Neue', sans-serif;

  position: relative;
  width: 380px;
  height: 480px;
  display: flex;
  flex-direction: column;
  align-items: center;
  border-radius: 30px;
  background: var(--bg-color);
}

/* =======================
   IMAGEN SUPERIOR
======================= */
.card__img1 {
  height: 240px;
  width: 100%;
  background-image: url("../imagenes/fondo_card.png");
  background-size: cover;
  background-position: center;
  border-radius: 30px 30px 0 0;
}

.card__img2 {
  height: 240px;
  width: 100%;
  background-image: url("../imagenes/fondo_card2.png");
  background-size: cover;
  background-position: center;
  border-radius: 30px 30px 0 0;
}

.card__img3 {
  height: 240px;
  width: 100%;
  background-image: url("../imagenes/fondo_card3.png");
  background-size: cover;
  background-position: center;
  border-radius: 30px 30px 0 0;
}

.card__img4 {
  height: 240px;
  width: 100%;
  background-image: url("../imagenes/fondo_card4.png");
  background-size: cover;
  background-position: center;
  border-radius: 30px 30px 0 0;
}

/* =======================
   AVATARES
======================= */
.card__avatar1,
.card__avatar2,
.card__avatar3,
.card__avatar4 {
  position: absolute;
  width: 140px;
  height: 140px;
  border-radius: 50%;
  display: flex;
  justify-content: center;
  align-items: center;
  top: calc(50% - 70px);
  border: 8px solid var(--bg-color);
}

.card__avatar1 { background: #bec2dc; }
.card__avatar2 { background: #888fbc; }
.card__avatar3 { background: #413385; }
.card__avatar4 { background: #201355; }

/* =======================
   TEXTOS
======================= */
.card__title {
  margin-top: 80px;
  font-weight: 600;
  font-size: 20px;
  color: var(--main-color);
}

.card__subtitle {
  margin-top: 12px;
  font-weight: 400;
  font-size: 17px;
  color: var(--submain-color);
}


.clases-section{
  margin-top: 55%;
}

.tituloinicio {
  font-size: 6rem;
  font-family: "Tinos", serif;
  font-weight: 600;
  font-style: normal;
  color: #2b3249;
  float: left;
  margin-top: 20%;
  margin-left: 50px;
  margin-bottom: 20px;
}
.contacto-section{
  margin-top:10%;
  margin-bottom: 40%;
  margin-right: 10%;
  float: right;

  position: relative;
}

.card-ini {
 width: 100%;
 height: 40%;
 background: white;
 border-radius: 10px;
 transition: border-radius 0.5s cubic-bezier(0.175, 0.885, 0.32, 1.275);
  padding: 10px;
  font-family: "Tinos", serif;
  font-weight: 400;
  font-style: normal;
    margin-bottom: 40%;

}

.shadow {
 box-shadow: inset 0 -3em 3em rgba(0,0,0,0.1),
             0 0  0 2px rgb(190, 190, 190),
             0.3em 0.3em 1em rgba(0,0,0,0.3);
}

.socialContainer {
  display: flex;
  align-items: center;
  gap: 10px; /* espacio entre icono y texto */
  width: fit-content;
  height: 52px;
  background-color: rgb(44, 44, 44);
  padding: 0 10px;
  transition: 0.3s;
}

.socialContainer:hover {
  transform: scale(1.05);
}

.socialSvg {
  width: 20px;
  height: 20px;
}

.socialSvg path {
  fill: #fff;
}

.socialText {
  color: white;
  font-size: 14px;
  font-family: sans-serif;
}

.contacto-section{
    margin-bottom: 40%;
}