/* 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-----------------------*/
/*----------------------------------------------*/
/*  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: 1rem;  /* 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: #FFD700;
  text-align: center;
}

/*Información de promoción especial*/
.info-promo {
  font-size: 1.6rem;
  font-weight: bold;
  color: #1c1c14;
  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: #FFD700;
}
/*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: #FFD700;
  color: #ffffff;
  border: none;
  border-radius: 25px;
  font-size: 1rem;
  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---------------*/
/* Estilos del banner de promoción */
/* Banner de Promoción Mejorado */
.promo-banner {
  background: linear-gradient(135deg, #00c3ff, #0055ff); /* Degradado bicolor moderno */
  padding: 3rem 2rem;
  border-radius: 20px;
  text-align: center;
  max-width: 900px;
  margin: 3rem auto;
  box-shadow: 0 10px 25px rgba(0, 0, 0, 0.25);
  transform: skewY(-2deg); /* Efecto vectorial inclinado */
  overflow: hidden;
}

/* Corrección del contenido para desinclinar */
.promo-content {
  transform: skewY(2deg); /* Corrige el contenido */
}

/* Título */
.promo-content h2 {
  font-size: 1.8rem;
  color: #ffffff;
  margin-bottom: 1rem;
  font-weight: 700;
}

/* Texto */
.promo-content p {
  font-size: 1.4rem;
  color: #e0e0e0;
  margin-bottom: 2rem;
}

/* Botón */
.promo-button {
  display: inline-block;
  padding: 1rem 2.5rem;
  background-color: #ffffff;
  color: #0055ff;
  font-weight: 700;
  border-radius: 50px;
  text-decoration: none;
  font-size: 1rem;
  transition: all 0.3s ease;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2);
}

/* Hover efecto */
.promo-button:hover {
  background-color: #0055ff;
  color: #ffffff;
}
/*----------------------------------------------*/
/*----------CONTAINER 2---------------*/
/* Contenedor principal de la línea de tiempo */
.timeline-container {
  max-width: 1200px; /* Ancho máximo */
  margin: 2rem auto 15rem auto; /* Márgenes: 35rem arriba, 25px abajo, centrado horizontal */
  padding: 2rem; /* Espaciado interno */
  font-family: 'Comfortaa', sans-serif; /* Fuente */
}

/* Títulos principales */
.timeline-title, .timeline-titlea {
  text-align: center; /* Centrar texto */
  font-size: 2.4rem; /* Tamaño de letra */
  color: #FFD700; /* Color morado */
  margin-bottom: 3rem; /* Espacio inferior */
}

/* Segundo tipo de título (con color distinto) */
.timeline-titlea {
  color: #FFFF00; /* Color diferente */
  font-size: 2.3rem; /* Tamaño ligeramente mayor */
}

/* Línea de tiempo general */
.timeline {
  position: relative; /* Posicionar elementos hijos */
  margin: 4rem 0; /* Márgenes superior e inferior grandes */
  padding-left: 2rem; /* Espacio a la izquierda */
}

/* Línea vertical morada */
.timeline::before {
  content: ''; /* Pseudo-elemento */
  position: absolute; /* Posición absoluta */
  left: 50%; /* Centrada */
  width: 4px; /* Grosor de la línea */
  height: 100%; /* MÁS larga que el contenedor */
  background-color: #FFD700; /* Color amarillo */
  transform: translateX(-50%); /* Ajustar exactamente al centro */
}

/* Cada ítem (evento) de la línea */
.timeline-item {
  position: relative; /* Posicionamiento interno */
  width: 50%; /* Ocupa mitad del ancho */
  padding: 2rem; /* Espaciado interno */
  box-sizing: border-box; /* Incluye padding y borde en el tamaño */
}

/* Contenido de cada evento */
.timeline-content {
  background-color: #FFD700; /* Fondo rosado claro */
  padding: 1.8rem; /* Espaciado interno */
  border-radius: 12px; /* Bordes redondeados */
  box-shadow: 0 4px 8px rgba(0,0,0,0.1); /* Sombra suave */
  position: relative; /* Para colocar decoraciones encima */
}

/* Puntos circulares de conexión */
.timeline-item::after {
  content: '';
  position: absolute;
  top: 20px; /* Separación desde arriba */
  width: 20px; /* Tamaño del círculo */
  height: 20px;
  background-color: #FFD700; /* Morado */
  border-radius: 50%; /* Círculo perfecto */
  border: 4px solid white; /* Borde blanco */
  box-shadow: 0 0 0 2px #FFD700; /* Efecto de halo */
}

/* Elementos alineados a la izquierda */
.timeline-item.left {
  left: 0; /* Pegado a la izquierda */
  text-align: right; /* Texto alineado a la derecha */
}

/* Posición del punto en la izquierda */
.timeline-item.left::after {
  right: -10px; /* Ajustar hacia fuera */
}

/* Elementos alineados a la derecha */
.timeline-item.right {
  left: 50%; /* Comienza desde la mitad */
  text-align: left; /* Texto alineado a la izquierda */
}

/* Posición del punto en la derecha */
.timeline-item.right::after {
  left: -10px; /* Ajustar hacia fuera */
}

/* Títulos dentro de los eventos */
.timeline-content h3 {
  font-size: 1.2rem; /* Tamaño del título */
  margin-bottom: 1rem; /* Espacio debajo */
  color: #1c1c14; /* Color vino oscuro */
}

/* Descripciones dentro de los eventos */
.timeline-content p {
  font-size: 1.2rem; /* Tamaño del texto */
  color: #333; /* Color gris oscuro */
}

/* Punto final decorativo */
.timeline-end {
  position: absolute; /* Absoluto respecto al contenedor */
  bottom: -120px; /* Colocado justo debajo del final */
  left: 50%; /* Centrado */
  transform: translateX(-50%); /* Alinear perfecto al centro */
  text-align: center; /* Centrar contenido */
}

/* Círculo grande final */
.timeline-end::after {
  content: '';
  position: absolute;
  top: 170px; /* Justo sobre el final de la línea */
  left: 50%; /* Centrado */
  transform: translateX(-50%); /* Ajuste de centrado */
  width: 32px; /* Más grande que los otros puntos */
  height: 32px;
  background-color: #FFD700; /* Color morado */
  border-radius: 50%; /* Forma circular */
  border: 4px solid white; /* Borde blanco */
  box-shadow: 0 0 0 2px #FFD700; /* Halo */
}

/* Contenedor del contenido del punto final */
.timeline-end .timeline-content {
  background-color: #FFD700; /* Fondo rosado */
  padding: 2rem; /* Espaciado interno mayor */
  border-radius: 12px; /* Bordes redondeados */
  box-shadow: 0 4px 8px rgba(0,0,0,0.1); /* Sombra suave */
  margin-top: 2rem; /* Espacio arriba */
  top: 270px;
}

/* Título del punto final */
.timeline-end .timeline-content h3 {
  font-size: 1.2rem; /* Tamaño mayor */
  color: #1c1c14; /*  */
  margin-bottom: 1rem; /* Espacio debajo */
}

/* Texto del punto final */
.timeline-end .timeline-content p {
  font-size: 1.2rem; /* Texto ligeramente mayor */
  color: #333; /* Gris oscuro */
}

/*----------------------------------------------*/
/*----------CONTAINER 3---------------*/
.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: #FFD700;
  margin-bottom: 1.5rem;
}

.certification-container h3 {
  font-size: 1.2rem;
  color: #28a745;
  margin-bottom: 1.5rem;
  text-align: left;
}
/* 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 4---------------*/
/*----------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;
}
/*------------------CONTAINER 1----------------------*/
.promo-banner {
  padding: 1rem 1rem;
}

.promo-content h2 {
  font-size: 1.9rem;
}

.promo-content p {
  font-size: 1.1rem;
}

.promo-button {
  padding: 0.8rem 2rem;
  font-size: 1rem;
}

/*------------------CONTAINER 2----------------------*/
/* Línea de tiempo - Modo responsive */
.timeline::before {
  left: 8px; /* Línea pegada a la izquierda */
  height: 100%; /* Cubrir todo el alto */
}

/* Cada ítem ocupa todo el ancho */
.timeline-item {
  width: 100%; /* 100% del ancho disponible */
  padding-left: 2.5rem; /* Separación del borde izquierdo */
  padding-right: 1rem; /* Separación derecho */
  margin-bottom: 4rem; /* Espacio entre elementos */
}

/* Todos los ítems alineados a la izquierda */
.timeline-item.left,
.timeline-item.right {
  left: 0; /* Sin desplazamiento */
  text-align: left; /* Texto alineado a la izquierda */
}

/* Puntos de conexión de cada ítem */
.timeline-item.left::after,
.timeline-item.right::after {
  left: 8px; /* Pegado a la línea */
  transform: translateX(-50%); /* Centrado respecto a su círculo */
}

/* Ajuste del punto final */
.timeline-end {
  position: relative; /* Para que fluya normal */
  bottom: 0; /* No lo movemos manualmente */
  margin-top: 4rem; /* Espacio arriba */
}

/* Círculo del punto final */
.timeline-end::after {
  content: '';
  position: absolute;
  left: -1.6rem; /* Pegado a la línea */
  transform: translateX(-50%); /* Centrado en la línea */
  top: 16rem; /* Encima del contenido final */
  width: 30px; /* Tamaño del círculo */
  height: 30px;
  background-color: #FFD700;
  border-radius: 50%;
  border: 4px solid white;
  box-shadow: 0 0 0 2px #FFD700;
}

/*------------------CONTAINER 3----------------------*/

.certification-container {
  padding: 1rem;
}

.certification-container h2 {
  font-size: 1.6rem;
}

.certification-container li {
  font-size: 1rem;
  flex-direction: row;
  text-align: left;
}


/*------------------CONTENEDOR 4----------------------*/
.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;
}

}
