:root {
  --azul-oviedo: #003366;
  --azul-claro: #336699;
  --blanco: #ffffff;
  --rojo-destacado: #e74c3c;
}

/* CONTENEDOR GENERAL */
.menu-principal {
  background-color: white;
  padding: 10px;
  border-radius: 8px;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
  max-width: max-content;
  margin: 0 auto;
  z-index: 20;
}

/* INTERIOR: logo + items + buscador */
.menu-content {
  display: flex;
  align-items: center;
  gap: 16px;
  flex-wrap: nowrap;
}

/* LOGO */
.menu-content .logo img {
  height: 84px;
  display: block;
}

/* ÍTEMS DEL MENÚ */
.menu-items {
  list-style: none;
  display: flex;
  gap: 18px;
  padding: 0;
  margin: 0;
  align-items: center;
  font-size: 1.1rem;
}

/* ENLACES */
.menu-items > li > a {
  text-decoration: none;
  color: var(--azul-oviedo);
  padding: 10px 16px;
  border-radius: 6px;
  transition: background-color 0.3s ease;
  white-space: nowrap;
}

.menu-items > li:hover > a {
  background-color: var(--azul-claro);
  color: white;
}

/* SUBMENÚS */
.menu-items li {
  position: relative;
}

.menu-items ul {
  display: none;
  position: absolute;
  top: 100%;
  left: 0;
  background-color: var(--azul-oviedo);
  border-radius: 0 0 6px 6px;
  z-index: 10;
  white-space: nowrap;
  padding: 4px 0;
}

.menu-items li:hover ul {
  display: block;
}

.menu-items ul li a {
  display: block;
  padding: 8px 14px;
  color: white;
  text-decoration: none;
  font-size: 0.9rem;
}

.menu-items ul li a:hover {
  background-color: var(--azul-claro);
}

/* ENLACE "Organiza tu viaje" con tipografía especial */
.organiza-tu-viaje {
  font-family: "Georgia", serif; /* 👈 aquí eliges la tipografía que quieras */
  font-style: italic;            /* opcional: cursiva para diferenciar */
  font-weight: bold;             /* más grueso para destacarlo */
  color: var(--azul-oviedo);     /* mantiene el color del resto del menú */
  background: none;              /* sin fondo rojo */
  border-radius: 0;              /* sin bordes redondeados */
  padding: 10px 16px;            /* mismo espaciado que otros enlaces */
}

.organiza-tu-viaje:hover {
  background-color: var(--azul-claro); /* efecto hover igual al resto */
  color: white;
}

/* BOTÓN HAMBURGUESA */
.menu-toggle {
  display: none;
}

/* AGRUPACIÓN HAMBURGUESA + BUSCAR */
.menu-actions {
  display: flex;
  align-items: center;
  gap: 10px;
}

@media (max-width: 768px) {
  .menu-toggle {
    display: block;
    background: none;
    border: none;
    font-size: 28px;
    color: var(--azul-oviedo);
    cursor: pointer;
  }

  .menu-content {
    flex-direction: column;
    align-items: flex-start;
    gap: 12px;
    width: 100%;
  }

  .menu-actions {
    width: 100%;
    display: flex;
    justify-content: space-between; /* hamburguesa a la izq, buscar a la der */
  }

  .menu-items {
    display: none;
    flex-direction: column;
    width: 100%;
    gap: 0;
  }

  .menu-items.show {
    display: flex;
  }

  .menu-items li {
    width: 100%;
  }

  .menu-items ul {
    position: static;
    display: none;
    background-color: var(--azul-claro);
    border-radius: 0;
  }

  .menu-items li.active ul {
    display: block;
  }

  .menu-items ul li a {
    padding: 10px 16px;
  }

  /* El buscador ya no ocupa línea entera */
  .search-container {
    margin: 0;
  }
}

/* BUSCADOR */
.search-link {
  display: inline-block;
  font-weight: bold;
  font-size: 1rem;
  padding: 10px 14px;
  background-color: #f2f2f2;
  border-radius: 8px;
  text-decoration: none;
  color: #333;
  transition: background-color 0.3s;
}

.search-link:hover {
  background-color: #e0e0e0;
  color: #00A991;
}

/* POSICIONAMIENTO SOBRE IMAGEN */
#menu-container {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  margin-top: 20px;
  z-index: 10;
}

.hero-image {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: 1;
}

@media screen and (max-width: 768px) {
  .hero-image {
    margin-top: 120px;
  }
}
