/* ==========================================================================
   NAVBAR - ESTILOS GENERALES
   ========================================================================== */

.navbar {
  background-color: var(--main-color) !important;
  padding: 0.5rem 1rem;
  min-height: 60px;
  position: relative;
  font-family: "Montserrat", "Segoe UI", sans-serif !important;
}

.navbar .container {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

/* Marca / Logo texto */
.navbar-brand {
  font-family: "Montserrat", "Segoe UI", sans-serif !important;
  font-size: 1.8rem !important;
  font-weight: 800 !important;
  color: var(--accent-color) !important;
  text-shadow: 0 3px 6px rgba(0, 0, 0, 0.3) !important;
  letter-spacing: 0.5px !important;
  white-space: nowrap !important;
}

/* Enlaces de Navegación (Escritorio) */
.navbar-nav {
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  gap: 0.5rem !important;
  margin-left: auto !important;
}

.navbar-nav .nav-link {
  color: var(--accent-color) !important;
  font-size: 0.9rem;
  font-weight: 400;
  padding: 0.1rem 0.2rem !important;
  transition: all 0.3s ease;
}

.navbar-nav .nav-link:hover {
  color: var(--gold-color) !important;
  text-shadow: 0 2px 8px rgba(255, 215, 0, 0.18);
}

/* Estado Activo */
.navbar-nav .nav-link.active {
  border: 2px solid var(--gold-color);
  border-radius: 8px;
  padding: 0.1rem 0.5rem !important;
}

/* ==========================================================================
   DROPDOWN (MENÚ DESPLEGABLE)
   ========================================================================== */

.dropdown-menu {
  background-color: var(--main-color) !important;
  border: 2px solid var(--main-color-light) !important;
  border-radius: 12px !important;
  box-shadow: 0 8px 32px rgba(30, 64, 175, 0.3) !important;
  padding: 0.5rem 0 !important;
  margin-top: 0.5rem !important;
}

.dropdown-item {
  color: var(--accent-color) !important;
  padding: 0.75rem 1.5rem !important;
  font-size: 0.9rem !important;
  transition: all 0.3s ease !important;
}

.dropdown-item:hover {
  background-color: var(--main-color-light) !important;
  transform: translateX(5px) !important;
}

.dropdown-item.active {
  background-color: var(--main-color-light) !important;
  border-left: 3px solid var(--gold-color);
}

.dropdown-toggle::after {
  border-top-color: var(--accent-color) !important;
  transition: transform 0.3s ease;
}

.dropdown-toggle[aria-expanded="true"]::after {
  transform: rotate(-180deg);
}

/* ==========================================================================
   SELECTOR DE IDIOMAS (DATA-LANG)
   ========================================================================== */

.btn[data-lang] {
  width: 32px;
  height: 28px;
  font-weight: 500;
  font-size: 0.7rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  border: 1px solid rgba(255, 255, 255, 0.6);
  background: transparent;
  color: white;
  transition: all 0.2s ease;
  cursor: pointer;
}

.btn[data-lang]:first-child { border-radius: 4px 0 0 4px; border-right: none; }
.btn[data-lang]:last-child { border-radius: 0 4px 4px 0; }

.btn[data-lang]:hover {
  background-color: rgba(255, 255, 255, 0.1);
  border-color: rgba(255, 255, 255, 0.8);
}

.btn[data-lang].active {
  background-color: var(--gold-color);
  border-color: var(--gold-color);
  color: var(--main-color-dark);
  font-weight: 600;
}

/* ==========================================================================
   REDES SOCIALES (NAVBAR)
   ========================================================================== */

.redes-sociales-navbar {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 48px;
  height: 48px;
  font-size: 1.5rem;
  color: white;
  transition: all 0.3s ease;
  opacity: 0.8;
}

.redes-sociales-navbar:hover {
  opacity: 1;
  color: var(--gold-color) !important;
  transform: scale(1.1);
}

/* ==========================================================================
   OFFCANVAS (MENÚ MÓVIL)
   ========================================================================== */

.offcanvas {
  background-color: var(--main-color) !important;
  width: 280px !important;
  max-width: 80vw !important;
  transition: transform 0.4s ease-in-out;
}

.offcanvas-header {
  border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}

.offcanvas .nav-link {
  padding: 0.75rem 1rem !important;
  margin: 0.25rem 0;
  font-size: 1rem;
  color: var(--accent-color) !important;
}

.offcanvas .nav-link.active {
  color: var(--gold-color) !important;
  border-left: 3px solid var(--gold-color);
}

/* Botón de cerrar personalizado (X) */
.offcanvas-header .btn-close,
.offcanvas-header .btn-close-white {
  background: none !important;
  opacity: 1 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

.offcanvas-header .btn-close::before {
  content: "✕" !important;
  font-size: 1.8rem;
  font-weight: bold;
  
}

/* ==========================================================================
   BOTONES DE IDIOMA (NAVBAR)
   ========================================================================== */

/* Estilo base de los botoncitos */
.idioma-btn {
  border-radius: 20px !important;
  padding: 8px 16px !important;
  font-size: 14px;
  font-weight: 500;
  transition: all 0.3s ease;
  border: 1px solid rgba(255, 255, 255, 0.3) !important;
  background: rgba(255, 255, 255, 0.1) !important;
  color: white !important;
  min-width: 100px;
  white-space: nowrap;
  text-align: center;
}

.idioma-btn:hover {
  background: rgba(255, 255, 255, 0.2) !important;
  border-color: rgba(255, 255, 255, 0.5) !important;
  transform: translateY(-1px);
}

.idioma-btn.active {
  background: rgba(255, 255, 255, 0.9) !important;
  color: #333 !important;
  border-color: rgba(255, 255, 255, 1) !important;
  font-weight: 600;
  
}

.idioma-btn.active:hover {
  background: rgba(255, 255, 255, 1) !important;
  color: #333 !important;
}

/* ==========================================================================
   RESPONSIVE (MEDIA QUERIES)
   ========================================================================== */

/* Ajustes para Tablet/Desktop medio */
@media (max-width: 1000px) {
  .navbar {
    position: fixed !important;
    top: 0; width: 100%; z-index: 1050;
  }
  .navbar .container {
    flex-direction: column !important;
    padding: 8px 1rem;
  }
  .navbar-brand { font-size: 1.3rem !important; text-align: center !important; }
  body { padding-top: 85px !important; }
}

/* Pantallas Grandes (Gap y tamaños) */
@media (min-width: 1001px) {
  .navbar-nav { gap: 1.5rem !important; }
}

@media (max-width: 576px) {
  .navbar-brand { font-size: 1.1rem !important; }
  .btn[data-lang] { width: 35px; height: 30px; font-size: 0.75rem; }
}

/* Ajuste para que no queden pegados arriba en móviles */
@media (max-width: 991px) {
  .idioma-btn {
    margin-top: 10px;
    margin-bottom: 10px;
  }
}