/* Navbar BLANCA (quita el rgba oscuro que pisaba el blanco) */
.navbar{                                  /* abre el bloque de estilos de la barra de navegación */
  --bs-navbar-padding-y:0;                 /* elimina el padding vertical que Bootstrap pone por defecto a la navbar */
  min-height:0;                            /* por si heredara una altura mínima, la anula */
  padding-inline:1.2rem;                   /* agrega padding solo a los lados (izq/der) */
  background:#fff;                         /* fondo blanco para toda la navbar (mantén SOLO este background) */
  position:sticky;                         /* hace que la barra se quede “pegada” al llegar arriba al hacer scroll */
  top:0;                                   /* fija la posición sticky al borde superior */
  z-index:1000;                            /* asegura que quede por encima de otros elementos */
}                                          /* cierra el bloque de la navbar */

/* Por defecto, enlaces sin fondo ni borde */
.navbar .navbar-nav .nav-link{             /* estilos base para todos los enlaces del menú dentro de la navbar */
  background:transparent;                  /* sin fondo por defecto */
  border:1px solid transparent;            /* borde invisible por defecto (facilita la transición al activo) */
  border-radius:20px;                      /* bordes redondeados para dar forma de píldora/ovalo */
}

.navbar .navbar-nav .nav-link.nav-active,  /* cuando el enlace tenga la clase nav-active (la pones tú en PHP) */
.navbar .navbar-nav .nav-link.active {     /* y/o cuando Bootstrap marque .active, aplica el estilo de “pill” activa */
  background-color: #f5f5f5 !important;    /* fondo gris claro para el activo */
  border: 1px solid #ccc !important;       /* borde gris para remarcar el contorno */
  border-radius: 20px;                     /* mantiene la forma ovalada */
  padding: 6px 16px !important;            /* relleno interno para que se vea como botón */
  color: #000 !important;                  /* texto negro para buen contraste sobre el gris */
}

/* Menú desplegable */
.dropdown-menu {
  background-color: #fff;
  border: 1px solid #ccc !important;
  border-radius: 12px;
  padding: 0.5rem;
}

/* Items */
.dropdown-menu .dropdown-item {
  border-radius: 8px;
  padding: 0.5rem 1rem;
}

/* Hover */
.dropdown-menu .dropdown-item:hover,
.dropdown-menu .dropdown-item:focus {
  background-color: #e0e0e0;
  color: #000;
}

/* Activo (seleccionado) */
.dropdown-menu .dropdown-item.active {
  background-color: #bdbdbd !important;
  color: #000 !important;
}

/* asegura el mismo “pill” gris también en enlaces padre de dropdown */
.navbar .nav-item.dropdown > .nav-link.nav-active{
  background-color:#f5f5f5 !important;
  border:1px solid #ccc !important;
  border-radius:20px;
  padding:6px 16px !important;
  color:#000 !important;
}

/* Subrayar el padre cuando un hijo está en hover */
.navbar .dropdown:hover > .nav-link,
.navbar .dropdown-menu:hover ~ .nav-link {
  text-decoration: underline;
  text-underline-offset: 4px; /* separa el subrayado del texto */
  text-decoration-thickness: 2px; /* grosor del subrayado */
}


@media (min-width: 992px){
  .navbar .dropdown:hover .dropdown-menu{
    display:block;      /* muestra el menú al hover */
  }
  .navbar .dropdown .dropdown-toggle:focus{
    outline:0;          /* quita borde de enfoque */
  }
}

@media (max-width: 991.98px) {
  /* Agrega separación vertical entre items */
  .navbar-nav .nav-item {
    margin-bottom: 0.5rem; /* espacio entre enlaces */
  }

  /* Extra padding al menú desplegado */
  .navbar-collapse {
    padding-top: 0.5rem;
    padding-bottom: 0.5rem;
  }

  /* Contacto separado más del último */
  .navbar-nav .nav-item:last-child {
    margin-bottom: 0.8rem;
  }
}




/* INACTIVO y ACTIVO con mismo ancho */
.navbar .nav-link.contact-link,
.navbar .nav-link.contact-link.nav-active {
  border-radius: 20px;
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  border: 1px solid #ccc !important;
  min-width: 160px; /* <-- ancho mínimo igual en ambos estados */
  justify-content: center; /* centra todo el contenido horizontalmente */
}


/* INACTIVO */
.navbar .nav-link.contact-link {
  background-color: #000 !important;
  color: #fff !important;
}

.navbar .nav-link.contact-link .arrow-circle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: #000;
  border: 1px solid #fff !important;
  transition: transform .2s ease, background-color .2s ease, border-color .2s ease;
}

.navbar .nav-link.contact-link .arrow {
  font-size: 12px;
  line-height: 1;
  color: #fff;
  transition: transform .2s ease, color .2s ease;
}

/* ACTIVO */
.navbar .nav-link.contact-link.nav-active {
  background-color: #f5f5f5 !important;
  color: #000 !important;
}

.navbar .nav-link.contact-link.nav-active .arrow-circle {
  background: #f5f5f5;
  border: 1px solid #000 !important;
}

.navbar .nav-link.contact-link.nav-active .arrow {
  color: #000;
  transform: rotate(90deg);
}


/* --- NUEVO BLOQUE PARA HOVER --- */

/* HOVER: que se vea como activo y rote la flecha */
.navbar .nav-link.contact-link:hover {
  background-color: #f5f5f5 !important;
  color: #000 !important;
  border: 1px solid #ccc !important;
}

.navbar .nav-link.contact-link:hover .arrow-circle {
  background: #f5f5f5;
  border: 1px solid #000 !important;
}

.navbar .nav-link.contact-link:hover .arrow {
  color: #000;
  transform: rotate(90deg); /* ➔ hacia abajo al pasar el mouse */
}










/* Base igual que “Contacto”: pill negro inactivo, gris activo */
.navbar .nav-link.login-link,
.navbar .nav-link.login-link.nav-active{
  border-radius:20px;
  display:inline-flex;
  align-items:center;
  gap:.35rem;
  border:1px solid #ccc !important;
  min-width:160px;
  justify-content:center;
}

/* INACTIVO: fondo negro, texto blanco */
.navbar .nav-link.login-link{
  background:#000 !important;
  color:#fff !important;
}

/* Circulito del icono */
.navbar .nav-link.login-link .icon-circle{
  width:22px; height:22px;
  border-radius:50%;
  display:inline-flex;
  align-items:center; justify-content:center;
  background:#000;                 /* relleno negro */
  border:1px solid #fff !important;/* borde blanco */
  transition:background-color .2s, border-color .2s;
}

/* Iconos: por defecto mostramos el cerrado */
.navbar .nav-link.login-link .lock-open{ display:none; }
.navbar .nav-link.login-link .lock-closed{ display:inline; }

/* HOVER: que parezca activo y muestre el candado abierto */
.navbar .nav-link.login-link:hover{
  background:#f5f5f5 !important;
  color:#000 !important;
  border:1px solid #ccc !important;
}
.navbar .nav-link.login-link:hover .icon-circle{
  background:#f5f5f5;
  border:1px solid #000 !important;
}
.navbar .nav-link.login-link:hover .lock-closed{ display:none; }
.navbar .nav-link.login-link:hover .lock-open{ display:inline; }

/* ACTIVO (servidor pone .nav-active): gris + icono abierto */
.navbar .nav-link.login-link.nav-active{
  background:#f5f5f5 !important;
  color:#000 !important;
}
.navbar .nav-link.login-link.nav-active .icon-circle{
  background:#f5f5f5;
  border:1px solid #000 !important;
}
.navbar .nav-link.login-link.nav-active .lock-closed{ display:none; }
.navbar .nav-link.login-link.nav-active .lock-open{ display:inline; }




body {
  margin: 0;
  font-family: 'Segoe UI', sans-serif;
}

.navbar.navbar-light {
  padding-left: 1rem !important;
  padding-right: 1rem !important;
}

/* Solo el área de contenido principal tiene padding lateral */
main.flex-grow-1 {
  padding-left: 2rem;
  padding-right: 2rem;
}

/* El footer y navbar no se ven afectados */
footer, .navbar {
  padding-left: 0;
  padding-right: 0;
}

/* ------- navbar ------ */

/*  GRUPO CMING LOGO */


/* --------------------- inicio login proyectos ----------------*/





/* --------------------- fin login proyectos ----------------*/






