/* Estilo global para el cuerpo del sitio */
body {
  font-family: 'Comfortaa', sans-serif; /* Fuente principal */
  margin: 0;
  padding: 0;
  background-color: #ffffff; /* Fondo blanco */
  color: #000000; /* Texto negro */
  font-size: 1rem;
}

/* Barra de navegación (navbar) */
.navbar {
  display: flex; /* Elementos en fila */
  justify-content: space-between; /* Espacio entre elementos */
  align-items: center; /* Centrado vertical */
  background-color: #ffffff; /* Fondo blanco */
  padding: 1rem 2rem; /* Espaciado interno */
  box-shadow: 0 2px 8px rgba(0,0,0,0.1); /* Sombra inferior */
  position: sticky; /* Fija al hacer scroll */
  top: 0; /* Pegado arriba */
  z-index: 100; /* Superposición */
}

/* Contenedor del logo (imagen + texto) */
.logo-container {
  display: flex;
  align-items: center;
}
/* LOGO IZQUIERDO */
.logo-img {
  height: 90px; /*Tamaño de imagen del logo*/
  margin-right: 10px; /* Espacio entre imagen y texto */
}
/* TEXTO CERCA DE LOGO */
.logo-text {
  font-size: 1.5rem;
  font-weight: bold;
  color: #e65f12;
}

/* Enlaces de navegación */
.nav-links {
  display: flex;
  gap: 1.5rem;
  list-style: none; /* Sin viñetas */
}

.nav-links a {
  text-decoration: none; /* Quitar subrayado */
  color: #000000; /* Color texto de barra de navegación*/
  font-weight: bold;
  transition: color 0.3s; /* Transición suave */
}

.nav-links a:hover {
  color: #1e90ff; /* Azul al pasar el mouse */
}

/* Estilos para submenú */
.submenu {
  position: relative;
}

/* Menú desplegable oculto inicialmente */
.dropdown {  /* Estilo para el menú desplegable (submenú) */
  display: none;  /* Oculta el submenú por defecto */
  position: absolute;  /* Posiciona el submenú de manera absoluta en relación a su contenedor padre */
  top: 100%; /* Justo debajo del enlace */
  left: 0;
  background-color: #ffffff;  /* Define el color de fondo del submenú */
  box-shadow: 0 4px 8px rgba(0,0,0,0.1);  /* Aplica una sombra sutil para dar un efecto de profundidad */
  list-style: none;  /* Elimina los puntos o viñetas de la lista */
  padding: 10px 0;  /* Añade un relleno (espacio) dentro del submenú en la parte superior e inferior */
  border-radius: 8px;  /* Redondea las esquinas del submenú */
  z-index: 99; /* Asegura que esté sobre otros elementos */
  min-width: 150px;
}

/* Mostrar el menú al pasar el mouse */
.submenu:hover .dropdown, 
.dropdown:hover{
  display: block;
}

/* Mostrar submenú cuando tiene clase 'open' (modo móvil) */
.submenu.open .dropdown {
  display: block;
}

.dropdown li a {
  display: block;
  padding: 10px 20px;
  color: #000000; /*Texto de submenu del navegador de barra*/
  text-decoration: none;
  transition: background 0.3s;
}

.dropdown li a:hover {
  background-color: #f0f0f0; /* Fondo gris claro al pasar el mouse */
}

/* Botón de menú hamburguesa (visible en móvil) */
.menu-toggle {
  display: none; /* Oculto en escritorio */
  font-size: 1.5rem;
  cursor: pointer;
}
/*---------------------FIN MENU-----------------------*/
/*----------------------------------------------*/
/*----------CONTAINER 0---------------*/
/*  CONTENEDOR Registro*/
.info-section {
  display: flex;  /* Usa Flexbox para organizar los elementos dentro de la sección */
  flex-wrap: wrap;  /* Permite que los elementos se envuelvan en dispositivos pequeños */
  align-items: center;  /* Alinea los elementos verticalmente al centro */
  justify-content: center;  /* Centra los elementos horizontalmente CONTENEDOR*/
  padding: 3rem 2rem;  /* Añade un relleno de 3rem en la parte superior e inferior, 2rem en los lados */
  gap: 2rem;  /* Añade un espacio de 2rem entre los elementos dentro de la sección */
  background-color: #f9f9f9;  /* Establece el color de fondo como un gris claro */
}
/*Tamaño de segundo contenedor*/
.info-left,
.info-form {
  flex: 1 1 400px; /*Tamaño minimo de contenedor*/
  max-width: 700px; /*Tamaño de contenedor*/
}
/*Titulo de 2 contenedor*/
.info-title {
  font-size: 2rem;
  margin-bottom: 3rem;
  line-height: 1.6; /* Interlineado cómodo y legible */
  color: #c81aff;
  text-align: center;
}

/*Información de promoción especial*/
.info-promo {
  font-size: 1.4rem;
  font-weight: bold;
  color: #005f99;
  line-height: 1.6; /* Interlineado cómodo y legible */
  text-align: center; /*Centrar texto*/
}

/* Formulario estilo popup */
.popup {
  background-color: #ffffff;
  padding: 2.5rem;
  border-radius: 16px;
  box-shadow: 0 8px 16px rgba(0,0,0,0.1);
}
/*Texto Registro*/
.popup h2 {
  margin-top: 0;
  font-size: 1.2rem;
  margin-bottom: 1.5rem;
  text-align: center; /* Centra el texto */
  color: #c81aff;
}
/*Cajas de texto de registro*/
.popup input,
.popup select {
  width: 100%;
  padding: 0.75rem;
  margin-bottom: 0.5rem;
  border: 1px solid #ccc;
  border-radius: 12px;
  font-size: 1.1rem;
}

/* Agrupación de botones radio */
.radio-group {
  display: flex;
  justify-content: space-between;
  margin: 1rem 0;
}

.radio-group label {
  font-size: 1.1rem;
}

.radio-group input[type="radio"] {
  transform: scale(1.4);  /* Escala el botón radio */
  cursor: pointer;
}

/* Botón del formulario */
.popup button {
  width: 100%;
  padding: 0.75rem;
  background-color: #c81aff;
  color: #ffffff;
  border: none;
  border-radius: 25px;
  font-size: 1.2rem;
  font-weight: bold;
  cursor: pointer;
  transition: background-color 0.3s;
}

.popup button:hover {
  background-color: #52e416;
}

/* Mensaje de error en el formulario */
.error {
  color: red;
  font-size: 0.85rem;
  display: none; /* Oculto por defecto */
  margin-bottom: 0.5rem;
}

/*----------------------------------------------*/
/*----------CONTAINER 1---------------*/
/* Fuente y contenedor principal */
.timeline-container {
  max-width: 1200px;
  margin: 2rem auto 15rem auto;
  padding: 2rem;
  font-family: 'Comfortaa', sans-serif;
}

/* Títulos */
.timeline-title,
.timeline-titlea {
  text-align: center;
  font-size: 2.4rem;
  color: #b600ef;
  margin-bottom: 3rem;
}

.timeline-titlea {
  color: #c81aff;
  font-size: 2.3rem;
}

/* Línea principal */
.timeline {
  position: relative;
  margin: 4rem 0;
  padding-left: 2rem;
}

.timeline::before {
  content: '';
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  width: 4px;
  height: 100%;
  background-color: #b600ef;
}

/* Items */
.timeline-item {
  position: relative;
  width: 50%;
  padding: 2rem;
  box-sizing: border-box;
}

.timeline-content {
  background-color: #f2c6eb;
  padding: 1.8rem;
  border-radius: 12px;
  box-shadow: 0 4px 8px rgba(0,0,0,0.1);
  position: relative;
}

.timeline-item::after {
  content: '';
  position: absolute;
  top: 20px;
  width: 20px;
  height: 20px;
  background-color: #b600ef;
  border-radius: 50%;
  border: 4px solid white;
  box-shadow: 0 0 0 2px #b600ef;
}

/* Izquierda */
.timeline-item.left {
  left: 0;
  text-align: right;
}

.timeline-item.left::after {
  right: -10px;
}

/* Derecha */
.timeline-item.right {
  left: 50%;
  text-align: left;
}

.timeline-item.right::after {
  left: -10px;
}

/* Texto */
.timeline-content h3 {
  font-size: 1.2rem;
  margin-bottom: 1rem;
  color: #b600ef;
}

.timeline-content p {
  font-size: 1.2rem;
  color: #333;
}

/* Punto final */
.timeline-end {
  position: absolute;
  bottom: -120px;
  left: 50%;
  transform: translateX(-50%);
  text-align: center;
}

.timeline-end::after {
  content: '';
  position: absolute;
  top: 160px;
  left: 50%;
  transform: translateX(-50%);
  width: 32px;
  height: 32px;
  background-color: #b600ef;
  border-radius: 50%;
  border: 4px solid white;
  box-shadow: 0 0 0 2px #b600ef;
}

.timeline-end .timeline-content {
  background-color: #f2c6eb;
  padding: 2rem;
  border-radius: 12px;
  box-shadow: 0 4px 8px rgba(0,0,0,0.1);
  margin-top: 2rem;
  top: 270px;
}

.timeline-end .timeline-content h3 {
  font-size: 1.2rem;
  color: #b600ef;
  margin-bottom: 1rem;
}

.timeline-end .timeline-content p {
  font-size: 1rem;
  color: #333;
}
/*----------------------------------------------*/
/*----------CONTAINER 2---------------*/
   /* Estilos del banner de promoción */
   .promo-banner {
    background: linear-gradient(135deg, #3cb9fc, #005f99); /* Degradado azul vibrante */
    color: #ffffff;
    padding: 2rem 1rem;
    border-radius: 15px;
    text-align: center;
    margin: 2rem auto;
    max-width: 900px;
    box-shadow: 0 6px 15px rgba(0, 0, 0, 0.2);
  }
  
  .promo-content h2 {
    font-size: 1.6rem;
    margin-bottom: 1rem;
    font-weight: bold;
  }
  
  .promo-content p {
    font-size: 1.5rem;
    margin: 0.5rem 0;
  }
  
  .promo-button {
    display: inline-block;
    margin-top: 1.5rem;
    padding: 0.8rem 2rem;
    background-color: #ffffff;
    color: #005f99;
    font-weight: bold;
    border-radius: 30px;
    text-decoration: none;
    transition: background-color 0.3s, color 0.3s;
  }
  
  .promo-button:hover {
    background-color: #005f99;
    color: #ffffff;
  }

/*----------------------------------------------*/
/*----------CONTAINER 3---------------*/
/* Contenedor general centrado y responsivo */
.container {
  max-width: 1000px;           /* Limita el ancho máximo */
  width: 90%;                  /* Ocupa 90% del ancho de la pantalla */
  margin: 0 auto;              /* Centrado horizontal */
  padding: 20px;
  box-sizing: border-box;
  text-align: center;
  color: #005f99;
  font-size: 1.1rem;
  font-family: 'Comfortaa', sans-serif;
}

/* Contenedor exclusivo para la tabla, con sombra y bordes redondeados */
.table-wrapper {
  background: #ffffff;
  padding: 20px;
  margin: 0 auto;
  border-radius: 10px;
  box-shadow: 0px 4px 10px rgba(0, 0, 0, 0.3);
  overflow-x: auto; /* Permite desplazamiento horizontal si es necesario */
  text-align: center;
}

/* Tabla centrada y adaptable */
table {
  width: 100%;
  border-collapse: collapse;
  margin: 0 auto;
}

/* Encabezados y celdas */
th, td {
  padding: 15px;
  border: 1px solid #3cb9fc;
  font-size: 18px;
}

/* Estilo para encabezados */
th {
  background-color: #3cb9fc;
  color: #ffffff;
}

/* Estilo para celdas */
td {
  color: #000;
}

/* Resalta la segunda columna */
td:nth-child(2) {
  background-color: #e0f7fa;
}

/* Íconos de check */
.check {
  color: #52e416;
  font-size: 24px;
}

/* Íconos de error */
.cross {
  color: red;
  font-size: 24px;
}
/*----------------------------------------------*/
/*----------CONTAINER 4---------------*/
.certification-container {
  max-width: 800px;
  margin: 4rem auto;
  padding: 2rem;
  text-align: center;
  background-color: #f8f8ff; /* Fondo suave */
  border-radius: 12px;
  box-shadow: 0 4px 10px rgba(0,0,0,0.1);
  font-family: 'Comfortaa', sans-serif;
}

/* Título */
.certification-container h2 {
  font-size: 1.8rem;
  color: #b600ef;
  margin-bottom: 1.5rem;
}

/* Lista */
.certification-container ul {
  list-style: none; /* Quitamos los puntos de lista */
  padding: 0;
}

/* Cada ítem de la lista */
.certification-container li {
  font-size: 1.2rem;
  color: #333;
  margin-bottom: 1rem;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* Icono de check */
.certification-container .check {
  color: #28a745; /* Verde */
  font-size: 1.5rem;
  margin-right: 0.5rem;
}

/*----------------------------------------------*/
/*----------CONTAINER 5---------------*/
/*----------CAMBRIDGE---------------*/
/* Contenedor principal de la publicidad */
.cambridge-container {
  background-color: #3cb9fc;  /* Azul vibrante para llamar la atención */
  color: white;               /* Color de texto blanco para contraste */
  padding: 1rem 1.5rem;       /* Espaciado interior */
  margin: 2rem 0;             /* Espaciado superior e inferior */
  border-radius: 10px;        /* Bordes redondeados */
  display: flex;              /* Flexbox para alinear los elementos */
  justify-content: flex-start; /* Alineación hacia la izquierda */
  align-items: center;        /* Alinear elementos verticalmente */
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1); /* Sombra suave para resaltar */
  transform: skewX(-10deg);   /* Inclinación hacia la izquierda */
  flex-wrap: wrap;            /* Asegurarse de que los elementos se ajusten */
  max-width: 60%;             /* Limitar el ancho del contenedor */
  margin-left: 20%;           /* Dejar un margen hacia la izquierda */
}

/* Contenido de la publicidad */
.cambridge-content {
  display: flex;             /* Flexbox para alinear el texto e imagen */
  justify-content: flex-start; /* Alinear los elementos a la izquierda */
  align-items: center;       /* Alineación vertical */
  width: 100%;               /* Hacer que ocupe todo el ancho disponible */
}

/* Texto de la publicidad */
.cambridge-text {
  font-size: 1.6rem;         /* Tamaño de fuente más pequeño para el texto */
  font-weight: bold;         /* Negrita para resaltar */
  margin-right: 1rem;        /* Espaciado entre el texto y la imagen */
  max-width: 70%;            /* Limitar el ancho del texto */
  text-align: center;          /* Alinear el texto a la izquierda */
}

/* Contenedor del logo de Cambridge */
.cambridge-logo-container {
  width: 99px;               /* Ancho de la imagen */
  height: 99px;              /* Altura para hacerlo cuadrado */
  border-radius: 50%;        /* Hacer la imagen circular */
  overflow: hidden;          /* Cortar la imagen que sobresalga */
  display: flex;             /* Asegurar que esté centrado */
  justify-content: center;   /* Centrar la imagen dentro del contenedor */
  align-items: center;       /* Centrar verticalmente la imagen */
}

/* Imagen del logo de Cambridge */
.cambridge-logo {
  width: 12%;               /* Hacer que la imagen ocupe el 100% del contenedor */
  height: auto;              /* Mantener proporción */
  object-fit: cover;         /* Cubrir el espacio sin distorsionar */
}

/*----------REDES SOCIALES---------------*/

.social-container {
  display: flex;
  justify-content: center;
  gap: 1.5rem;
  padding: 2rem 0;
}

.social-container a img {
  width: 50px;
  height: 50px;
  transition: transform 0.3s ease;
}

.social-container a img:hover {
  transform: scale(1.2);
}
.cursos-siguenos {
  width: 100%;
  text-align: center;
  font-size: 2rem;
  color: #3cb9fc;
  margin-bottom: 2rem;
  font-family: 'Comfortaa', sans-serif;
}
/*----------------------------------------------*/

/*----------------------------------------------*/
/*----------PIE De PÁGINA---------------*/
.footer {
  background-color: #f0f0f0;
  padding: 2rem;
  font-family: 'Comfortaa', sans-serif;
  font-size: 0.8rem;
  color: #333;
}

.footer-container {
  display: flex;               /* Activación de modelo Flexbox */
  flex-wrap: wrap;             /* Permite que los elementos pasen a otra línea en pantallas pequeñas */
  justify-content: space-around; /* Espacio entre columnas */
  align-items: flex-start;     /* Alineación superior de los elementos */
  gap: 1rem;                   /* Espacio entre columnas */
}

.footer-logo img {
  width: 150px;
  border-radius: 19px;
}

.footer-links {
  display: flex;
  gap: 2rem;
  flex-wrap: wrap;
}

.footer-column h4 {
  margin-bottom: 0.8rem;
  color: #000000;
}

.footer-column ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

.footer-column ul li {
  margin-bottom: 0.4rem;
}

.footer-column ul li a {
  color: #000;
  text-decoration: none;
  transition: color 0.3s;
}

.footer-column ul li a:hover {
  color: #1e90ff;
}

.footer-contact p a {
  color: #000;
  text-decoration: none;
  font-weight: bold;
}

.footer-contact p a:hover {
  color: #1e90ff;
}

/*----------------------------------------------*/

/* Estilos responsivos para pantallas pequeñas */
@media (max-width: 768px) {
  .nav-links {
    display: none; /* Ocultar enlaces */
    flex-direction: column;
    gap: 1rem;
    background-color: #ffffff;
    position: absolute;
    top: 70px;
    right: 20px;
    padding: 1rem;
    box-shadow: 0 2px 8px rgba(0,0,0,0.2);
    border-radius: 12px;
  }

  .nav-links.active {
    display: flex; /* Mostrar cuando está activa */
  }

  .menu-toggle {
    display: block; /* Mostrar hamburguesa */
  }
/*------------------CONTENEDOR 0----------------------*/
.info-section {
    flex-direction: column;   /* Apila los elementos uno sobre otro */
    padding: 2rem 1rem;       /* Reduce el relleno lateral */
    gap: 1.5rem;              /* Menor espacio entre bloques */
  }

  .info-left,
  .info-form {
    flex: 1 1 100%;           /* Ocupan todo el ancho disponible */
    max-width: 100%;          /* No se pasan del ancho del contenedor */
    min-width: auto;          /* Elimina ancho mínimo fijo */
  }

  .info-title,
  .info-promo,
  .popup h2 {
    font-size: 1.5rem;
    text-align: center;
  }

  .popup {
    padding: 1.5rem;         /* Reduce el padding interno */
    border-radius: 12px;
  }

  .radio-group {
    flex-direction: column; /* Apila las opciones radio verticalmente */
    align-items: flex-start;
    gap: 0.5rem;
  }

  .radio-group label {
    font-size: 1rem;
  }

  .popup button {
    font-size: 1rem;
    padding: 0.6rem;
  }
/*------------------CONTENEDOR 1----------------------*/
.timeline::before {
  left: 8px;
}

.timeline-item {
  width: 100%;
  padding-left: 2.5rem;
  padding-right: 1rem;
  margin-bottom: 4rem;
}

.timeline-item.left,
.timeline-item.right {
  left: 0;
  text-align: left;
}

.timeline-item.left::after,
.timeline-item.right::after {
  left: 8px;
  right: auto;
  transform: translateX(-50%);
}

.timeline-end {
  position: relative;
  bottom: 0;
  margin-top: 4rem;
}

.timeline-end::after {
  top: 12rem;
  left: -1.6rem;
  transform: translateX(-50%);
}

.timeline-end .timeline-content {
  margin-top: 2rem;
  position: relative;
  top: auto;
}
/*------------------CONTENEDOR 2----------------------*/
.promo-content h2 {
  font-size: 1.8rem;
}
.promo-content p {
  font-size: 1.1rem;
}
.promo-button {
  padding: 0.6rem 1.5rem;
  font-size: 1rem;
}

/*------------------CONTENEDOR 3----------------------*/
.container {
  padding: 10px;
  font-size: 1rem;
}

th, td {
  font-size: 16px;
  padding: 10px;
}

.check, .cross {
  font-size: 20px;
}
/*------------------CONTENEDOR 4----------------------*/

.certification-container {
  padding: 1rem;
}

.certification-container h2 {
  font-size: 1.6rem;
}

.certification-container li {
  font-size: 1rem;
  flex-direction: row;
  text-align: left;
}

/*------------------CONTENEDOR 5----------------------*/
.cambridge-container {
  padding: 1rem;           /* Reducir el espaciado interior en pantallas pequeñas */
  margin-left: 15%;         /* Dejar un margen más pequeño hacia la izquierda */
  transform: skewX(-5deg);     /* Inclinación a la izquierda en dispositivos pequeños */
}

.cambridge-text {
  font-size: 1.1rem;       /* Reducir el tamaño de la fuente en móviles */
  margin-right: 0.5rem;    /* Reducir el margen entre el texto y la imagen */
}

.cambridge-logo-container {
  width: 95px;               /* Aumentar tamaño del logo */
  height: 95px;              /* Aumentar tamaño del logo */
}
/* Imagen del logo de Cambridge */
.cambridge-logo {
  width: 25%;   /* El logo ocupará todo el contenedor en móviles */
  height: 25%;
  object-fit: cover;
}

/*------------------CONTENEDOR REDES----------------------*/
.social-container {
  gap: 1rem;                      /* Reducimos el espacio entre íconos */
  padding: 1rem 0;                /* Menos espacio en pantallas pequeñas */
}

.social-container a img {
  width: 40px;                    /* Íconos un poco más pequeños */
  height: 40px;
}

.cursos-siguenos {
  font-size: 1.5rem;              /* Título un poco más pequeño */
  margin-bottom: 1rem;            /* Menos espacio debajo */
}
/*------------------PIE DE PÁGINA----------------------*/
.footer-container {
  flex-direction: column;
  align-items: center;
  text-align: center;
  font-size: 0.8rem;
}

.footer-links {
  flex-direction: column;
  align-items: center;
}

}
