/* ============================= */
/* HEADER */
/* ============================= */
header {
    position: fixed; /* Fija el header en la parte superior */
    width: 100%; /* Ocupa el 100% del ancho de la pantalla */
    height: 5em; /* Altura del header */
    background: transparent; /* Fondo transparente */
    transition: 0.3s ease-in-out; /* Transición suave para cambios de estilo */
    padding: 15px 50px; /* Espaciado interno */
    z-index: 1000; /* Asegura que el header esté por encima de otros elementos */
    display: flex; /* Usa flexbox para alinear elementos */
    align-items: center; /* Centra verticalmente los elementos */
    justify-content: space-between; /* Distribuye el espacio entre los elementos */
    background-color: var(--font-color);
}

header.scrolled {
    background-color: #112D4E; /* Cambia el fondo a negro cuando se hace scroll */
}

.logo {
    width: 33%; /* Ancho del logo */
    margin-top: 0.4em; /* Margen superior para ajustar la posición */
}

nav {
    margin-right: 3em; /* Margen derecho para separar del borde */
}

nav ul {
    list-style: none; /* Quita los estilos de lista */
    display: flex; /* Usa flexbox para alinear elementos */
    gap: 25px; /* Espacio entre elementos */
    padding: 0; /* Quita el padding por defecto */
    margin: 0; /* Quita el margen por defecto */
}

nav ul li {
    position: relative; /* Posición relativa para el menú desplegable */
}

nav ul li a {
    text-decoration: none; /* Quita el subrayado de los enlaces */
    color: var(--color-primario); /* Color del texto */
    padding: 1em; /* Espaciado interno */
    display: flex; /* Usa flexbox para alinear elementos */
    align-items: center; /* Centra verticalmente los elementos */
    font-weight: bold; /* Texto en negrita */
    font-size: 1.2em;
}

nav ul li a:hover {
    color: var(--color-terciario); /* Cambia el color al hacer hover */
}

.dropdown-menu {
    position: absolute; /* Posición absoluta para el menú desplegable */
    top: 100%; /* Se posiciona debajo del elemento padre */
    left: 0; /* Alineado a la izquierda */
    background: var(--color-segundario); /* Fondo del menú */
    width: 150px; /* Ancho del menú */
    opacity: 0; /* Inicialmente invisible */
    transform: translateY(-10px); /* Desplazamiento inicial */
    transition: opacity 0.3s ease, transform 0.3s ease; /* Transición suave */
    pointer-events: none; /* Desactiva interacciones inicialmente */
    border-radius: 1em; /* Bordes redondeados */
}

.dropdown-menu a {
    display: block; /* Cada enlace ocupa una línea */
    padding: 10px; /* Espaciado interno */
    color: var(--color-primario); /* Color del texto */
    text-decoration: none; /* Quita el subrayado */
    transition: 0.5s; /* Transición suave */
    border-radius: 0.5em; /* Bordes redondeados */
}

.dropdown-menu a:hover {
    background: var(--color-terciario); /* Cambia el fondo al hacer hover */
    color: var(--color-segundario); /* Cambia el color del texto */
}

nav ul li:hover .dropdown-menu {
    opacity: 1; /* Hace visible el menú */
    transform: translateY(0); /* Restablece la posición */
    pointer-events: auto; /* Activa interacciones */
}

.arrow {
    margin-left: 0.2em; /* Margen izquierdo para separar del texto */
    transition: transform 0.3s ease; /* Transición suave para la rotación */
}

.dropdown-toggle {
    transition: 0.8s; /* Transición suave para el borde */
    border: 1px solid transparent; /* Borde transparente inicialmente */
    border-radius: 5em; /* Bordes redondeados */
}

.dropdown-toggle:hover {
    border-color: #c8a21d; /* Cambia el color del borde al hacer hover */
    transform: scale(1.05); /* Efecto de escala al hacer hover */
}

.alone {
    transition: 0.8s; /* Transición suave para el borde */
    border: 1px solid transparent; /* Borde transparente inicialmente */
    border-radius: 5em; /* Bordes redondeados */
}

.alone:hover {
    border-color: #c8a21d; /* Cambia el color del borde al hacer hover */
    transform: scale(1.05); /* Efecto de escala al hacer hover */
}

nav ul li:hover .arrow {
    transform: rotate(180deg); /* Rota la flecha al hacer hover */
}

.menu-toggle {
  display: none;
}

@media (max-width: 768px) {
  header {
    flex-direction: column;
    align-items: flex-start;
    padding: 10px 20px;
    height: auto;
  }

  .menu-toggle {
    display: block;
    background: none;
    border: none;
    font-size: 2em;
    color: var(--color-primario);
    cursor: pointer;
    margin-left: auto;
    padding: 10px;
    z-index: 1100;
  }

  nav {
    width: 100%;
    display: none;
    flex-direction: column;
    margin-top: 10px;
  }

  nav.open {
    display: flex;
  }

  nav ul {
    flex-direction: column;
    gap: 0;
  }

  nav ul li {
    width: 100%;
  }

  nav ul li a {
    padding: 15px;
    font-size: 1em;
    justify-content: space-between;
  }

  .dropdown-menu {
    display: none;
    flex-direction: column;
    padding-left: 20px;
    background: var(--color-segundario);
    width: 100%;
  }

  .dropdown-menu a {
    padding: 10px 0;
  }

  .has-submenu.active .dropdown-menu {
    display: flex;
  }

  .arrow {
    display: inline;
  }
}

/* Ocultar checkbox nativo */
.menu-toggle {
  display: none;
}

/* Ícono hamburguesa */
.menu-icon {
  display: none;
  font-size: 2em;
  color: var(--color-primario);
  cursor: pointer;
  z-index: 1100;
  padding: 10px;
  margin-right: 0.7em;
}

/* Estilos responsive */
@media (max-width: 768px) {
  header {
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    padding: 100px 20px;
    height: auto;
  }

  .logo img {
    width: 120px;
    height: auto;
  }

  .menu-icon {
    display: block;
  }

  nav {
    width: 100%;
    display: none;
    flex-direction: column;
    background-color: var(--color-segundario);
    padding: 10px 0;
  }

  .menu-toggle:checked + .menu-icon + nav {
    display: flex;
  }

  nav ul {
    flex-direction: column;
    padding: 0;
    margin: 0;
  }

  nav ul li {
    width: 100%;
  }

  nav ul li a {
    padding: 15px 20px;
    display: block;
    font-size: 1em;
  }

  .dropdown-menu {
    position: relative;
    display: none;
    background: var(--color-segundario);
    padding-left: 20px;
  }

  nav ul li:hover .dropdown-menu {
    display: block;
  }
}

/* Ocultar checkbox */
.menu-toggle {
  display: none;
}

/* Botón hamburguesa animado */
.menu-icon {
  display: none;
  width: 30px;
  height: 22px;
  position: relative;
  cursor: pointer;
  z-index: 1100;
}

.menu-icon span {
  position: absolute;
  height: 3px;
  width: 100%;
  background: var(--color-primario);
  border-radius: 2px;
  transition: all 0.4s ease;
}

.menu-icon span:nth-child(1) { top: 0; }
.menu-icon span:nth-child(2) { top: 9px; }
.menu-icon span:nth-child(3) { top: 18px; }

/* Animación a "X" */
.menu-toggle:checked + .menu-icon span:nth-child(1) {
  transform: rotate(45deg);
  top: 9px;
}

.menu-toggle:checked + .menu-icon span:nth-child(2) {
  opacity: 0;
}

.menu-toggle:checked + .menu-icon span:nth-child(3) {
  transform: rotate(-45deg);
  top: 9px;
}

/* Estilos responsive */
@media (max-width: 768px) {
  header {
    flex-wrap: wrap;
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    padding: 10px 20px;
    height: auto;
  }

  .menu-icon {
    display: block;
  }

  nav {
    width: 100%;
    display: none;
    flex-direction: column;
    background-color: var(--color-segundario);
    animation: fadeIn 0.4s ease forwards;
  }

  .menu-toggle:checked + .menu-icon + nav {
    display: flex;
  }

  nav ul {
    flex-direction: column;
    padding: 0;
    margin: 0;
  }

  nav ul li {
    width: 100%;
    position: relative;
  }

  nav ul li a {
    padding: 15px 20px;
    display: block;
    font-size: 1em;
    border-bottom: 1px solid rgba(255,255,255,0.05);
    transition: background 0.3s ease;
  }

  nav ul li a:hover {
    background-color: var(--color-terciario);
    color: var(--color-segundario);
  }

  /* Submenús */
  .dropdown-menu {
    display: none;
    background: var(--color-segundario);
    animation: slideDown 0.3s ease-in-out forwards;
    padding-left: 20px;
  }

  nav ul li:has(.dropdown-menu):hover .dropdown-menu {
    display: block;
  }
}

/* Animaciones */
@keyframes slideDown {
  from {
    opacity: 0;
    transform: translateY(-10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes fadeIn {
  from {
    opacity: 0;
    transform: scaleY(0);
  }
  to {
    opacity: 1;
    transform: scaleY(1);
  }
}

/* Ocultar checkbox */
.menu-toggle {
  display: none;
}

/* Ícono hamburguesa animado */
.menu-icon {
  display: none;
  width: 26px;
  height: 20px;
  position: relative;
  cursor: pointer;
  z-index: 1100;
}

.menu-icon span {
  position: absolute;
  height: 2px; /* más delgado */
  width: 100%;
  background: var(--color-primario);
  border-radius: 1px;
  transition: all 0.3s ease;
}

.menu-icon span:nth-child(1) { top: 0; }
.menu-icon span:nth-child(2) { top: 9px; }
.menu-icon span:nth-child(3) { top: 18px; }

/* Animación a "X" */
.menu-toggle:checked + .menu-icon span:nth-child(1) {
  transform: rotate(45deg);
  top: 9px;
}

.menu-toggle:checked + .menu-icon span:nth-child(2) {
  opacity: 0;
}

.menu-toggle:checked + .menu-icon span:nth-child(3) {
  transform: rotate(-45deg);
  top: 9px;
}

@media (max-width: 768px) {
  header {
    flex-wrap: wrap;
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    padding: 10px 16px;
    height: auto;
    margin: auto;
  }

  .logo img {
    width: 100px; /* más pequeño */
    height: auto;
  }

  .menu-icon {
    display: block;
  }

  nav {
    width: 100%;
    display: none;
    flex-direction: column;
    background-color: var(--color-segundario);
    transform-origin: top;
    animation: fadeIn 0.3s ease-in-out forwards;
    justify-content: center;
    justify-items: center;
    margin: auto;
    border-radius: 1em;
  }

  .menu-toggle:checked + .menu-icon + nav {
    display: flex;
  }

  nav ul {
    flex-direction: column;
    padding: 0;
    margin: 1em;
  }

  nav ul li {
    width: 100%;
    position: relative;
  }

  nav ul li a {
    padding: 12px 16px; /* menos padding */
    display: block;
    font-size: 0.95em; /* más pequeño */
    border-bottom: 1px solid rgba(255,255,255,0.05);
    transition: background 0.2s ease;
  }

  nav ul li a:hover {
    background-color: var(--color-terciario);
    color: var(--color-segundario);
  }

  /* Submenús animados */
  .dropdown-menu {
    display: none;
    background: var(--color-segundario);
    padding-left: 20px;
    animation: slideDown 0.3s ease-in-out forwards;
  }

  nav ul li:has(.dropdown-menu):hover .dropdown-menu {
    display: block;
  }
}

/* Animaciones */
@keyframes slideDown {
  from {
    opacity: 0;
    transform: translateY(-8px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes fadeIn {
  from {
    opacity: 0;
    transform: scaleY(0.95);
  }
  to {
    opacity: 1;
    transform: scaleY(1);
  }
}