/* 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: #000898;
  text-align: center;
}

/*Información de promoción especial*/
.info-promo {
  font-size: 1.4rem;
  font-weight: bold;
  color: #1e90ff;
  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.4rem;
  margin-bottom: 1.5rem;
  text-align: center; /* Centra el texto */
  color: #000898;
}
/*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: 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: #1e90ff;
  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---------------*/
/* Container principal */
.timeline-container {
  max-width: 1200px;
  margin: 4rem auto;
  padding: 2rem;
  font-family: 'Comfortaa', sans-serif;
}

/* Título principal */
.timeline-title {
  text-align: center;
  font-size: 2.4rem;
  color: #3cb9fc;
  margin-bottom: 3rem;
}
.timeline-titlea {
  text-align: center;
  font-size: 2.3rem;
  color: #000898;
  margin-bottom: 3rem;
}

/* Línea de tiempo */
.timeline {
  position: relative;
  margin: 2rem 0;
  padding-left: 2rem;
}

/* Línea vertical */
.timeline::before {
  content: '';
  position: absolute;
  left: 50%;
  width: 4px;
  height: 100%;
  background-color: #3cb9fc;
  transform: translateX(-50%);
}

/* Elemento de la línea de tiempo */
.timeline-item {
  position: relative;
  width: 50%;
  padding: 1rem 2rem;
  box-sizing: border-box;
}

/* Contenido del elemento */
.timeline-content {
  background-color: #e6fffd;
  padding: 1.5rem;
  border-radius: 12px;
  box-shadow: 0 4px 8px rgba(0,0,0,0.1);
  position: relative;
}

/* Puntos de conexión */
.timeline-item::after {
  content: '';
  position: absolute;
  top: 20px;
  width: 20px;
  height: 20px;
  background-color: #3cb9fc;
  border-radius: 50%;
  border: 4px solid white;
  box-shadow: 0 0 0 2px #3cb9fc;
}

/* 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;
}

/* Textos */
.timeline-content h3 {
  font-size: 1.2rem;
  margin-bottom: 0.8rem;
  color: #000080;
}

.timeline-content p {
  font-size: 1rem;
  color: #333;
}


/*----------------------------------------------*/
/*----------CONTAINER 2---------------*/
.accordion-container {
  max-width: 800px;
  margin: 2rem auto;
  padding: 1rem;
  background: #f9f9f9;
  border-radius: 15px;
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.1);
}

.accordion-title {
  text-align: center;
  font-size: 1.8rem;
  margin-bottom: 1.5rem;
  color: #005f99;
}

.accordion-item {
  background: #ffffff;
  border-radius: 10px;
  margin-bottom: 1rem;
  overflow: hidden;
  border: 1px solid #ddd;
}

.accordion-header {
  display: flex;
  align-items: center;
  cursor: pointer;
  padding: 1rem;
  transition: background-color 0.3s;
}

.accordion-header:hover {
  background-color: #e6f4ff;
}

.accordion-icon {
  width: 90px;
  height: 90px;
  margin-right: 1rem;
  object-fit: contain;
}

.accordion-header h3 {
  font-size: 1.2rem;
  margin: 0;
  color: #333;
}

.accordion-content {
  padding: 0 1rem 1rem 4rem;
  font-size: 1.2rem;
  color: #666;
  display: none;
}

.accordion-item.active .accordion-content {
  display: block;
}

/*----------------------------------------------*/
/*----------CONTAINER 3---------------*/
    /* 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: 2rem;
      margin-bottom: 1rem;
      font-weight: bold;
    }
    
    .promo-content p {
      font-size: 1.3rem;
      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 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;
}

/*------------------CONTENEDOR 1----------------------*/
.timeline::before {
  left: 8px;
}

.timeline-item {
  width: 100%;
  padding-left: 2.5rem;
  padding-right: 1rem;
  margin-bottom: 2rem;
}

.timeline-item.left,
.timeline-item.right {
  left: 0;
  text-align: left;
}

.timeline-item::after {
  left: -10px;
}


/*------------------CONTENEDOR 2----------------------*/
.accordion-header h3 {
  font-size: 1.2rem;
}
.accordion-content {
  font-size: 0.95rem;
}
.accordion-icon {
  width: 60px;
  height: 60px;
}


/*------------------CONTENEDOR 3----------------------*/
.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 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;
}

}
