html, body {
  height: 100%; /* Para tener el row del login y selección del módulo 100% de alto */
}

a:hover {
  text-decoration: none;
}

/* COLORES DE FONDO */

.bg-gris {
  background-color: #2B303B;
}

.bg-gris-claro {
  background-color: #e3e3e3;
}

.bg-gris-oscuro {
  background-color: #21252d;
}

/* COLORES DE TEXTO */

.text-gris-claro {
  color: #788195;
}

/* GENERALES */

.btn-limpio {
  border: 0px;
  background-color: transparent;
}

.sin-bullet {
  list-style: none;
}

@media (min-width: 992px) {
  .modal-xl {
    max-width: 95vw;
  }
}

/* LOGIN FORM */

.login-bg {
  background-image: url(/assets/img/fondo.jpg);
  background-size: cover;
  background-attachment: fixed;
}

/* MENÚ Y NAVEGACIÓN */

.nav-off-canvas {
  width: 250px;
  transition: 0.3s;
  z-index: 999;
  height: 100%;
  margin-left: -190px;
  overflow-y: scroll;
}

.nav-off-canvas:hover {
  margin-left: 0px;
}

.navegacion {
  z-index: 99;
}

.texto-menu {
  text-overflow:ellipsis;
  overflow: hidden;
  white-space: nowrap;
  width: 170px;
}

.nav-off-canvas a{
  overflow: auto;
  transition: 0.5s;
}

.nav-off-canvas a:hover {
  color: #ffffff;
}

.dropdown-item:hover {
  background-color: transparent;
}

.logo-menu {
  overflow: auto;
}

.logo-navegacion {
  height: 38px;
}

.icono-menu {
  float: right;
  width: 30px;
  text-align: center;
}

.navbar-brand img {
  width: 100px;
}

footer {
  height: 40px;
}

footer p {
  font-size: 11px;
  padding-top: 12px;
}

.modulos-internos {
  width: 20px;
}

@media (min-width:768px) {
  main, footer, .navegacion {
    width: calc(100% - 60px) !important;
    margin-left: 60px !important;
  }
  
  main {
    padding-bottom: 50px;
  }
  
  .navegacion {
    top: 0px;
  }
  
  footer {
    position: fixed;
    bottom: 0px;
  }
}