/* Navbar Styles */

#mainNav {
  transition: all 0.3s ease-in-out;
  background-color: transparent;
  padding-top: 15px;
  padding-bottom: 15px;
  color: #ff0000;
}

#mainNav.navbar-shrink {
  background-color: white;
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
  padding-top: 10px;
  padding-bottom: 10px;
}

#mainNav.navbar-shrink .navbar-brand {
  color: var(--primary);
}

#mainNav.navbar-shrink .navbar-nav .nav-link {
  color: var(--primary);
}

#mainNav .navbar-nav .nav-link {
  font-size: 1.2rem;
  color: white;
}

#mainNav.navbar-shrink .navbar-toggler-icon {
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba%280, 0, 0, 0.55%29' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e");
}

/* Logo: tamaño por defecto y transición suave */

#mainNav .navbar-brand img {
  width: calc(80px);
  transition: width 0.3s ease-in-out;
}

/* Al hacer scroll (navbar-shrink): logo más pequeño */

#mainNav.navbar-shrink .navbar-brand img {
  width: calc(60px);
  padding: 0px;
}

/* Ajuste para dispositivos móviles: mismo tamaño que el scroll en desktop */

@media (max-width: 768px) {
  #mainNav .navbar-brand img {
    width: calc(60px);
  }
}

/* En móvil no cambia al hacer scroll */

@media (max-width: 768px) {
  #mainNav.navbar-shrink .navbar-brand img {
    width: calc(60px);
  }
}

#mainNav.bg-white .navbar-nav .nav-link {
  color: var(--primary) !important;
}

#mainNav.bg-white .navbar-toggler-icon {
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba(232,107,13,1)' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e");
}

/* Transición base del logo */

#mainNav .navbar-brand img {
  transition: opacity .28s ease, transform .28s ease;
}

/* Estado inicial: oculto */

#logo.logo--hidden {
  opacity: 0;
  transform: scale(1);
}

/* Estado visible (scroll): aparece y más pequeño */

#logo.logo--visible {
  opacity: 1;
  transform: scale(.8);
}

