@charset "UTF-8";
.main-sidebar {
  background-color: #EEEEEE;
}
.main-sidebar p {
  color: black;
}
.main-sidebar .brand-text {
  color: black;
}
.main-sidebar ul li i {
  color: #5a6bff;
}
.main-sidebar ul li form i {
  color: black;
}
.main-sidebar .navactivo {
  border-bottom: 3px solid #5a6bff;
  border-radius: 0;
}
.main-sidebar p {
  font-size: 0.9em;
}

.main-header {
  background-color: #EEEEEE;
  border: none;
  padding: 0;
}
.main-header .contenedor-datos, .main-header .contenedor-alarmas, .main-header .contenedor-usuario {
  flex: auto;
  background-color: white;
  margin: 10px;
  padding: 10px;
  border-radius: 40px;
  box-shadow: 0 0 1px rgba(0, 0, 0, 0.125), 0 1px 3px rgba(0, 0, 0, 0.2);
}
.main-header .contenedor-datos ul .datos, .main-header .contenedor-alarmas ul .datos, .main-header .contenedor-usuario ul .datos {
  margin-right: 20px;
  flex: 1;
}
.main-header .contenedor-datos ul .datos div, .main-header .contenedor-alarmas ul .datos div, .main-header .contenedor-usuario ul .datos div {
  display: inline-block;
}
.main-header .contenedor-datos ul .datos .icon-container i, .main-header .contenedor-alarmas ul .datos .icon-container i, .main-header .contenedor-usuario ul .datos .icon-container i {
  background-color: #5a6bff;
  padding: 10px;
  color: white;
  border-radius: 100%;
  margin-right: 5px;
}
.main-header .contenedor-datos ul .datos .text-container, .main-header .contenedor-alarmas ul .datos .text-container, .main-header .contenedor-usuario ul .datos .text-container {
  vertical-align: middle;
}
.main-header .contenedor-datos ul .datos .text-container h6, .main-header .contenedor-datos ul .datos .text-container p, .main-header .contenedor-alarmas ul .datos .text-container h6, .main-header .contenedor-alarmas ul .datos .text-container p, .main-header .contenedor-usuario ul .datos .text-container h6, .main-header .contenedor-usuario ul .datos .text-container p {
  margin: 0;
}
.main-header .contenedor-datos ul .datos .text-container h6, .main-header .contenedor-alarmas ul .datos .text-container h6, .main-header .contenedor-usuario ul .datos .text-container h6 {
  font-weight: 600;
}
.main-header .contenedor-datos ul .datos .text-container p, .main-header .contenedor-alarmas ul .datos .text-container p, .main-header .contenedor-usuario ul .datos .text-container p {
  font-size: x-small;
  color: #848484;
}
.main-header .contenedor-alarmas {
  background-color: #5a6bff;
}
.main-header .contenedor-alarmas ul .alarmas {
  margin-right: 20px;
  margin: auto;
}
.main-header .contenedor-alarmas ul .alarmas div {
  display: inline-block;
}
.main-header .contenedor-alarmas ul .alarmas .icon-container i {
  background-color: white;
  padding: 10px;
  color: #5a6bff;
  border-radius: 100%;
  margin-right: 5px;
}
.main-header .contenedor-alarmas ul .alarmas .text-container {
  vertical-align: middle;
}
.main-header .contenedor-alarmas ul .alarmas .text-container h6, .main-header .contenedor-alarmas ul .alarmas .text-container p {
  margin: 0;
  color: white;
}
.main-header .contenedor-alarmas ul .alarmas .text-container p {
  font-size: x-small;
}
.main-header .contenedor-usuario p {
  text-align: center;
  vertical-align: middle;
  margin: auto;
  padding: 5px;
}
.main-header .contenedor-usuario .usuario-rol {
  color: #5a6bff;
}
.main-header .navbar-nav {
  display: flex;
  flex-direction: row;
}

#contenido-principal {
  background-color: #EEEEEE;
  padding: 0;
}
#contenido-principal .resaltado {
  color: #5a6bff;
  border-bottom: 3px solid #5a6bff;
  padding-bottom: 3px;
}
#contenido-principal .titulo-pagina {
  background-color: white;
  padding: 10px;
  margin: auto;
  border-radius: 40px;
  box-shadow: 0 0 1px rgba(0, 0, 0, 0.125), 0 1px 3px rgba(0, 0, 0, 0.2);
}
#contenido-principal .titulo-pagina p {
  font-size: large;
  font-weight: 600;
}
#contenido-principal .titulo-buscador {
  background-color: white;
  padding: 5px;
  margin: auto;
  border-radius: 40px;
  box-shadow: 0 0 1px rgba(0, 0, 0, 0.125), 0 1px 3px rgba(0, 0, 0, 0.2);
}
#contenido-principal .titulo-buscador input {
  border: none;
  border-radius: 40px;
}
#contenido-principal .titulo-buscador p {
  font-size: large;
  font-weight: 600;
}
@media only screen and (max-width: 767px) {
  #contenido-principal .titulo-buscador {
    margin-top: 15px;
  }
}
#contenido-principal .card {
  border-radius: 40px;
}
#contenido-principal .card .card-header {
  border-radius: 40px 40px 0 0;
  border: none;
  padding: 20px;
}
#contenido-principal .card .card-header .card-title {
  font-weight: 600;
}
#contenido-principal .card .card-body {
  padding-top: 0;
}
#contenido-principal .card .card-body tr, #contenido-principal .card .card-body td {
  vertical-align: middle;
}
#contenido-principal .card .card-body #card-poblaciones button {
  background-color: #5a6bff;
  color: white;
  border-radius: 40px;
}
#contenido-principal .card .card-body #card-poblaciones i {
  font-size: larger;
  color: #5a6bff;
}
#contenido-principal .card .card-body #card-poblaciones .poblaciones-datos {
  flex: 1;
}
#contenido-principal .card .card-body #card-poblaciones .poblaciones-datos div {
  display: inline-block;
}
#contenido-principal .card .card-body #card-poblaciones .poblaciones-datos .text-container {
  padding: 0;
  vertical-align: middle;
  font-weight: 600;
  max-width: 120px;
}
#contenido-principal .card .card-body #card-poblaciones .poblaciones-datos .text-container p:last-of-type {
  font-weight: 100;
  color: #848484;
}
#contenido-principal .card #buscador-tablas {
  display: flex;
  justify-content: flex-end;
}
#contenido-principal .card #buscador-tablas div {
  margin-right: 20px;
}
#contenido-principal .card #buscador-tablas div input {
  background-color: #EEEEEE;
  border-radius: 40px;
  margin-top: 15px;
}

.mensaje-notificacion {
  color: white;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  padding: 15px;
  z-index: 9999;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.mensaje-notificacion span {
  flex: 1;
  text-align: center;
}
.mensaje-notificacion .cerrar-mensaje {
  background-color: transparent;
  border: none;
  cursor: pointer;
  color: #ffffff;
}

.mensaje-success {
  background-color: rgb(0, 214, 0);
}

.mensaje-fail {
  background-color: rgb(214, 0, 0);
}

.contadores input {
  background-color: #EEEEEE;
  border-radius: 40px;
}
.contadores #card-contadores .dt-buttons {
  background-color: #5a6bff;
  border-radius: 20px;
  border: 1px solid #5a6bff;
}
.contadores #card-contadores button {
  background-color: #5a6bff;
  border: 1px solid #5a6bff;
  border-radius: 40px;
}

.ultimas-alarmas input {
  background-color: #EEEEEE;
  border-radius: 40px;
}
.ultimas-alarmas table tr {
  font-size: 1em;
}
.ultimas-alarmas table tr td {
  font-size: 100%;
  padding-bottom: 20px;
}
.ultimas-alarmas #card-alarmas .dt-buttons {
  background-color: #5a6bff;
  border-radius: 20px;
  border: 1px solid #5a6bff;
}
.ultimas-alarmas #card-alarmas button {
  background-color: #5a6bff;
  border: 1px solid #5a6bff;
  border-radius: 40px;
}

#boton-satelite {
  padding: 0px 10px 20px 0px;
}
#boton-satelite button {
  background-color: #5a6bff;
  color: white;
}

.resumen-contadores .icon-container i {
  background-color: #5a6bff;
  text-align: center;
  width: 40px;
  padding: 10px;
  color: white;
  border-radius: 100%;
  margin-right: 5px;
}
.resumen-contadores .text-container {
  vertical-align: middle;
}
.resumen-contadores .text-container h6, .resumen-contadores .text-container p {
  margin: 0;
}
.resumen-contadores .text-container h6 {
  font-weight: 600;
}
.resumen-contadores .text-container p {
  font-size: small;
  color: #848484;
}

.mensaje-graficas {
  font-size: smaller;
  display: inline-block;
  align-items: center;
  text-align: center;
}
.mensaje-graficas i {
  color: #5a6bff;
}

#mensaje-dia, #mensaje-mes, #mensaje-anyo {
  visibility: hidden;
}

.datos-cliente ul, .datos-contador ul {
  padding: 0;
}
.datos-cliente ul li, .datos-contador ul li {
  list-style: none;
  font-size: small;
  padding: 10px;
}
.datos-cliente ul li p, .datos-contador ul li p {
  display: inline;
  margin: 0;
  text-align: center;
  float: right;
}

.card-alarma .card {
  background-color: #5a6bff;
  color: white;
}
.card-alarma .card i {
  margin: 5px;
}

.popover {
  max-width: 50%;
}

.editar-contador-boton {
  background-color: #5a6bff;
  color: white;
  border-radius: 40px;
  padding: 10px;
}

.admin-usuarios .nuevo-usuario {
  background-color: #5a6bff;
  color: white;
  padding: 10px;
  border-radius: 40px;
}
.admin-usuarios .editar-usuario input, .admin-usuarios .add-usuario input {
  border-radius: 40px;
}
.admin-usuarios .editar-usuario button, .admin-usuarios .add-usuario button {
  background-color: #5a6bff;
  color: white;
}
.admin-usuarios .editar-usuario .botones-contra button, .admin-usuarios .add-usuario .botones-contra button {
  background-color: #5a6bff;
  border-radius: 40px;
}
.admin-usuarios .card-footer {
  background-color: transparent;
}
.admin-usuarios .card-footer button {
  background-color: #5a6bff;
  color: white;
  border-radius: 40px;
}
.admin-usuarios .card-footer a button {
  background-color: white;
  color: #5a6bff;
  border: 1px solid lightgrey;
}
.admin-usuarios #borrar button {
  width: 100px;
  margin: 10px;
}

.admin-contadores .nuevo-contador {
  background-color: #5a6bff;
  color: white;
  padding: 10px;
  border-radius: 40px;
}
.admin-contadores .editar-contador input, .admin-contadores .add-contador input {
  border-radius: 40px;
}
.admin-contadores .editar-contador button, .admin-contadores .add-contador button {
  background-color: #5a6bff;
  color: white;
}
.admin-contadores .card-footer {
  background-color: transparent;
}
.admin-contadores .card-footer button {
  background-color: #5a6bff;
  color: white;
  border-radius: 40px;
}
.admin-contadores .card-footer a button {
  background-color: white;
  color: #5a6bff;
  border: 1px solid lightgrey;
}

.admin-poblaciones .nuevo-poblacion {
  background-color: #5a6bff;
  color: white;
  padding: 10px;
  border-radius: 40px;
}
.admin-poblaciones .editar-poblacion input, .admin-poblaciones .add-poblacion input {
  border-radius: 40px;
}
.admin-poblaciones .editar-poblacion button, .admin-poblaciones .add-poblacion button {
  background-color: #5a6bff;
  color: white;
}
.admin-poblaciones .card-footer {
  background-color: transparent;
}
.admin-poblaciones .card-footer button {
  background-color: #5a6bff;
  color: white;
  border-radius: 40px;
}
.admin-poblaciones .card-footer a button {
  background-color: white;
  color: #5a6bff;
  border: 1px solid lightgrey;
}

.admin-clientes .nuevo-cliente {
  background-color: #5a6bff;
  color: white;
  padding: 10px;
  border-radius: 40px;
}
.admin-clientes .editar-cliente input, .admin-clientes .editar-cliente select, .admin-clientes .add-cliente input, .admin-clientes .add-cliente select {
  border-radius: 40px;
  padding: 8px;
  width: 100%;
}
.admin-clientes .editar-cliente #cbox1, .admin-clientes .add-cliente #cbox1 {
  padding: 0;
  width: auto;
}
.admin-clientes .editar-cliente button, .admin-clientes .add-cliente button {
  background-color: #5a6bff;
  color: white;
}
.admin-clientes .card-footer {
  background-color: transparent;
}
.admin-clientes .card-footer button {
  background-color: #5a6bff;
  color: white;
  border-radius: 40px;
}
.admin-clientes .card-footer a button {
  background-color: white;
  color: #5a6bff;
  border: 1px solid lightgrey;
}
.admin-clientes #borrar button {
  width: 100px;
  margin: 10px;
}

#pagina-index {
  /* ANIMATION */
}
#pagina-index * {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}
#pagina-index body,
#pagina-index input {
  font-family: "Poppins", sans-serif;
}
#pagina-index .mensaje-error-login {
  color: #fe0c0c;
}
#pagina-index .container-flex {
  position: relative;
  width: 100%;
  background-image: url("/imagenes/login/agua2.png");
  min-height: 100vh;
  overflow: hidden;
}
#pagina-index .forms-container {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
}
#pagina-index .signin-signup {
  position: absolute;
  top: 50%;
  transform: translate(-50%, -50%);
  left: 75%;
  width: 50%;
  transition: 1s 0.7s ease-in-out;
  display: grid;
  grid-template-columns: 1fr;
  z-index: 5;
}
#pagina-index form {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  padding: 0rem 5rem;
  transition: all 0.2s 0.7s;
  overflow: hidden;
  grid-column: 1/2;
  grid-row: 1/2;
}
#pagina-index form.sign-up-form {
  opacity: 0;
  z-index: 1;
}
#pagina-index form.sign-in-form {
  z-index: 2;
}
#pagina-index .title {
  font-size: 2.2rem;
  color: #444;
  margin-bottom: 10px;
}
#pagina-index .input-field {
  max-width: 380px;
  width: 100%;
  background-color: #f0f0f0;
  margin: 10px 0;
  height: 55px;
  border-radius: 55px;
  display: grid;
  grid-template-columns: 15% 85%;
  padding: 0 0.4rem;
  position: relative;
}
#pagina-index .input-field i {
  text-align: center;
  line-height: 55px;
  color: #acacac;
  transition: 0.5s;
  font-size: 1.1rem;
}
#pagina-index .input-field input {
  background: none;
  outline: none;
  border: none;
  line-height: 1;
  font-weight: 600;
  font-size: 1.1rem;
  color: #333;
}
#pagina-index .input-field input::-moz-placeholder {
  color: #aaa;
  font-weight: 500;
}
#pagina-index .input-field input::placeholder {
  color: #aaa;
  font-weight: 500;
}
#pagina-index .social-text {
  padding: 0.7rem 0;
  font-size: 1rem;
}
#pagina-index .social-media {
  display: flex;
  justify-content: center;
}
#pagina-index .social-icon {
  height: 46px;
  width: 46px;
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 0 0.45rem;
  color: #333;
  border-radius: 50%;
  border: 1px solid #333;
  text-decoration: none;
  font-size: 1.1rem;
  transition: 0.3s;
}
#pagina-index .social-icon:hover {
  color: #4481eb;
  border-color: #4481eb;
}
#pagina-index .btn {
  width: 150px;
  background-color: #5a6bff;
  border: none;
  outline: none;
  height: 49px;
  border-radius: 49px;
  color: #fff;
  text-transform: uppercase;
  font-weight: 600;
  margin: 10px 0;
  cursor: pointer;
  transition: 0.5s;
}
#pagina-index .btn:hover {
  background-color: #4d84e2;
}
#pagina-index .panels-container {
  position: absolute;
  height: 100%;
  width: 100%;
  top: 0;
  left: 0;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
}
#pagina-index .container-flex:before {
  content: "";
  position: absolute;
  height: 2000px;
  width: 2000px;
  top: -10%;
  right: 48%;
  transform: translateY(-50%);
  background-image: linear-gradient(-45deg, #5a6bff 0%, #04befe 100%);
  transition: 1.8s ease-in-out;
  border-radius: 50%;
  z-index: 6;
}
#pagina-index .image {
  width: 100%;
  transition: transform 1.1s ease-in-out;
  transition-delay: 0.4s;
}
#pagina-index .panel {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  justify-content: space-around;
  text-align: center;
  z-index: 6;
}
#pagina-index .left-panel {
  pointer-events: all;
  padding: 3rem 17% 2rem 12%;
}
#pagina-index .right-panel {
  pointer-events: none;
  padding: 3rem 12% 2rem 17%;
}
#pagina-index .panel .content {
  color: #fff;
  transition: transform 0.9s ease-in-out;
  transition-delay: 0.6s;
}
#pagina-index .panel h3 {
  font-weight: 600;
  line-height: 1;
  font-size: 1.5rem;
}
#pagina-index .panel p {
  font-size: 0.95rem;
  padding: 0.7rem 0;
}
#pagina-index .btn.transparent {
  margin: 0;
  background: none;
  border: 2px solid #fff;
  width: 130px;
  height: 41px;
  font-weight: 600;
  font-size: 0.8rem;
}
#pagina-index .right-panel .image,
#pagina-index .right-panel .content {
  transform: translateX(800px);
}
#pagina-index footer {
  background-color: black;
  width: 100%;
  padding: 10px;
}
#pagina-index footer #footer-info {
  color: white;
  font-weight: 600;
  align-items: center;
  margin-top: auto;
}
#pagina-index footer #footer-info p {
  font-size: small;
  text-align: center;
}
#pagina-index footer #footer-info img {
  width: 40%;
}
#pagina-index .container-flex.sign-up-mode:before {
  transform: translate(100%, -50%);
  right: 52%;
}
#pagina-index .container-flex.sign-up-mode .left-panel .image,
#pagina-index .container-flex.sign-up-mode .left-panel .content {
  transform: translateX(-800px);
}
#pagina-index .container-flex.sign-up-mode .signin-signup {
  left: 25%;
}
#pagina-index .container-flex.sign-up-mode form.sign-up-form {
  opacity: 1;
  z-index: 2;
}
#pagina-index .container-flex.sign-up-mode form.sign-in-form {
  opacity: 0;
  z-index: 1;
}
#pagina-index .container-flex.sign-up-mode .right-panel .image,
#pagina-index .container-flex.sign-up-mode .right-panel .content {
  transform: translateX(0%);
}
#pagina-index .container-flex.sign-up-mode .left-panel {
  pointer-events: none;
}
#pagina-index .container-flex.sign-up-mode .right-panel {
  pointer-events: all;
}
@media (max-width: 870px) {
  #pagina-index .container-flex {
    min-height: 800px;
    height: 100vh;
  }
  #pagina-index .signin-signup {
    width: 100%;
    top: 95%;
    transform: translate(-50%, -100%);
    transition: 1s 0.8s ease-in-out;
  }
  #pagina-index .signin-signup,
  #pagina-index .container-flex.sign-up-mode .signin-signup {
    left: 50%;
  }
  #pagina-index .panels-container {
    grid-template-columns: 1fr;
    grid-template-rows: 1fr 2fr 1fr;
  }
  #pagina-index .panel {
    flex-direction: row;
    justify-content: space-around;
    align-items: center;
    padding: 2.5rem 8%;
    grid-column: 1/2;
  }
  #pagina-index .right-panel {
    grid-row: 3/4;
  }
  #pagina-index .left-panel {
    grid-row: 1/2;
  }
  #pagina-index .image {
    width: 200px;
    transition: transform 0.9s ease-in-out;
    transition-delay: 0.6s;
  }
  #pagina-index .panel .content {
    padding-right: 15%;
    transition: transform 0.9s ease-in-out;
    transition-delay: 0.8s;
  }
  #pagina-index .panel h3 {
    font-size: 1.2rem;
  }
  #pagina-index .panel p {
    font-size: 0.7rem;
    padding: 0.5rem 0;
  }
  #pagina-index .btn.transparent {
    width: 110px;
    height: 35px;
    font-size: 0.7rem;
  }
  #pagina-index .container-flex:before {
    width: 1500px;
    height: 1500px;
    transform: translateX(-50%);
    left: 30%;
    bottom: 68%;
    right: initial;
    top: initial;
    transition: 2s ease-in-out;
  }
  #pagina-index .container-flex.sign-up-mode:before {
    transform: translate(-50%, 100%);
    bottom: 32%;
    right: initial;
  }
  #pagina-index .container-flex.sign-up-mode .left-panel .image,
  #pagina-index .container-flex.sign-up-mode .left-panel .content {
    transform: translateY(-300px);
  }
  #pagina-index .container-flex.sign-up-mode .right-panel .image,
  #pagina-index .container-flex.sign-up-mode .right-panel .content {
    transform: translateY(0px);
  }
  #pagina-index .right-panel .image,
  #pagina-index .right-panel .content {
    transform: translateY(300px);
  }
  #pagina-index .container-flex.sign-up-mode .signin-signup {
    top: 5%;
    transform: translate(-50%, 0);
  }
}
@media (max-width: 570px) {
  #pagina-index form {
    padding: 0 1.5rem;
  }
  #pagina-index .image {
    display: none;
  }
  #pagina-index .panel .content {
    padding: 0.5rem 1rem;
  }
  #pagina-index .container-flex {
    padding: 1.5rem;
  }
  #pagina-index .container-flex:before {
    bottom: 72%;
    left: 50%;
  }
  #pagina-index .container-flex.sign-up-mode:before {
    bottom: 28%;
    left: 50%;
  }
}

#searchResults {
  display: none;
  border: 1px solid #ccc;
  padding: 10px;
  background-color: #fff;
  max-height: 200px;
  overflow-y: auto;
  position: absolute;
  border-radius: 0px 0px 20px 20px;
  top: calc(100% + 10px); /* Ajusta la distancia entre el input y los resultados */
  left: 0;
  width: 100%;
  z-index: 999; /* Ajusta el valor según sea necesario para que aparezca por encima de otros elementos */
}

* {
  font-family: "Poppins", sans-serif;
}

.main-footer {
  background-color: #EEEEEE;
}

#example1_filter input, #example2_filter input {
  background-color: #EEEEEE;
  border-radius: 40px;
}

.editar-boton {
  background-color: #5a6bff;
  color: white;
}/*# sourceMappingURL=styles.css.map */

.custom-icon {
  width: 30px;
  height: 30px;
  border-radius: 50%;
  text-align: center;
  line-height: 30px;
  font-size: 14px;
  color: white;
  box-shadow: 0 0 2px black;
}

.icon-sectorial.green {
  background-color: #28a745;
}

.icon-sectorial.red {
  background-color: #dc3545;
}

.icon-sectorial.blue {
  background-color: #007bff;
}

.icon-sectorial.gold {
  background-color: #ffc107;
}

.leaflet-sectorial-green {
  background-color: green !important;
}

.leaflet-sectorial-red {
  background-color: red !important;
}

.leaflet-sectorial-blue {
  background-color: blue !important;
}

.leaflet-sectorial-gold {
  background-color: goldenrod !important;
}

/* Cada KPI: icono + texto en una fila, alineados arriba */
.resumen-contadores > .col-md-3 {
  display: flex;
  align-items: flex-start;    /* ← alinear por arriba */
  gap: 12px;
}

/* Icono redondo, centrado, y con pequeño ajuste vertical */


/* El contenedor de texto ocupa el resto */
.resumen-contadores .text-container {
  flex: 1 1 auto;
}

/* Ajustes de tipografía para evitar saltos */
.resumen-contadores h6 { margin: 0 0 2px 0; line-height: 1.2; font-weight: 700; }
.resumen-contadores p  { margin: 0;        line-height: 1.2; color: #6c757d; }
.kpi-badges .badge { margin-right: 6px; }


/* === Cards: respeta el margen vertical (como AdminLTE) */
#contenido-principal .card {
  margin-bottom: 1.25rem; /* separa las cards entre sí */
}

/* === Icono redondo SOLO en el <i> (tu estilo original, pero robusto) */
.resumen-contadores .icon-container i {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background-color: #5a6bff;
  color: #fff;
  margin-right: 8px;
  font-size: 18px;
}

/* === Mantén el texto al lado del icono, sin romper el grid */
.resumen-contadores .text-container {
  display: inline-block;
  vertical-align: top;
}

/* Badges alineados y con pequeño espacio */
.kpi-badges .badge { margin-right: 6px; }

/* Footer: fondo gris (igual que el resto de páginas) */
.main-footer {
  background-color: #EEEEEE; /* ya lo tenías; mantenemos este */
  border-top: 0; /* opcional si no quieres línea */
}

/* Oculta el footer solo en cuadro_mandos.php */
body[data-page="cuadro-mandos"] .wrapper > .main-footer {
  display: none !important;
}

  /* --- SOLO esta página --- */
  html,
  body[data-page="cuadro-mandos"],
  body[data-page="cuadro-mandos"] .wrapper,
  body[data-page="cuadro-mandos"] .content-wrapper,
  body[data-page="cuadro-mandos"] #contenido-principal {
    background: #EEEEEE !important;
  }

  /* Quita cualquier separación al fondo */
  body[data-page="cuadro-mandos"] .content-wrapper {
    min-height: 100vh;        /* forzamos a ocupar alto completo */
    margin-bottom: 0 !important;
    padding-bottom: 0 !important;
  }
  /* Si llevas layout-fixed, AdminLTE añade padding-bottom: corrígelo aquí */
  body[data-page="cuadro-mandos"].layout-fixed .content-wrapper {
    padding-bottom: 0 !important;
  }

  /* Oculta el footer por si existe (y su posible borde superior) */
  body[data-page="cuadro-mandos"] .wrapper > .main-footer {
    display: none !important;
    border-top: 0 !important;
    background: transparent !important;
  }

  /* En algunos setups aparece un overlay/side extra: escóndelo también */
  body[data-page="cuadro-mandos"] .control-sidebar,
  body[data-page="cuadro-mandos"] .control-sidebar-bg {
    display: none !important;
  }

/* =========================
   SOLO MAPA (#map-panel)
   ========================= */

/* Contenedor de chips */
#map-panel #filtroContadores {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
  margin-bottom: 12px;
}

/* Chip básico */
#map-panel .chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 10px;
  border: 1px solid #e8eef7;
  background: #f7f9fc;
  color: #1f2d3d;
  border-radius: 999px;
  font-size: 13px;
  font-weight: 600;
  line-height: 1;
  transition: transform .15s ease, box-shadow .15s ease, background-color .2s ease, border-color .2s ease;
  cursor: pointer;
  user-select: none;
}

/* Estado visual cuando el checkbox está marcado */
#map-panel .chip.is-checked {
  background: #e9f2ff;
  border-color: #cfe1ff;
  box-shadow: 0 6px 14px rgba(31,45,61,.09);
}

/* Hover */
#map-panel .chip:hover {
  transform: translateY(-1px);
  box-shadow: 0 6px 14px rgba(31,45,61,.08);
  background: #f9fbff;
  border-color: #deebff;
}

#map-panel .chip input {
  margin: 0 4px 0 0;
  transform: translateY(1px);
  cursor: pointer;
}

/* Badge contador dentro del chip */
#map-panel .chip .badge {
  background: #eef4ff;
  color: #3156d4;
  border-radius: 999px;
  padding: 3px 7px;
  font-size: 12px;
  font-weight: 700;
  line-height: 1;
}

/* Puntito de color (aseguramos visibilidad) */
#map-panel .icon {
  display: inline-block;
}

#map-panel .icon.dot {
  width: 14px;
  height: 14px;
  border-radius: 50%;
  border: 1px solid #d9e2ef;
  flex: 0 0 14px;
}

/* ¡Colores con !important para evitar que otra CSS los pise! */
#map-panel .dot-green { background: #0bb52a !important; }
#map-panel .dot-gold  { background: gold !important; }
#map-panel .dot-blue  { background: #4287f5 !important; }
#map-panel .dot-red   { background: #dc3545 !important; }
#map-panel .dot-sect  { background: #4a4a4a !important; }

/* Grupo sectoriales */
#map-panel .sectoriales-group {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
  background: #fbfdff;
  border: 1px dashed #d7e4f6;
  border-radius: 14px;
  padding: 10px 12px;
}

#map-panel .sectoriales-title {
  font-weight: 700;
  font-size: 13px;
  color: #223344;
  margin-right: 6px;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

/* Botón de cambio de capa */
#map-panel #changeMapTypeBtn {
  border: 1px solid #e3e9f3 !important;
  border-radius: 10px !important;
  padding: 6px 10px !important;
  font-weight: 600 !important;
  background: #fff !important;
  color: #1f2d3d !important;
  transition: box-shadow .15s ease, transform .15s ease;
}

#map-panel #changeMapTypeBtn:hover {
  box-shadow: 0 6px 14px rgba(31,45,61,.08);
  transform: translateY(-1px);
}

/* Mapa redondeado */
#map-panel #myMap {
  border-radius: 18px;
  overflow: hidden;
}

/* Accesibilidad */
#map-panel .chip:has(input:focus-visible),
#map-panel #changeMapTypeBtn:focus-visible {
  outline: 2px solid #3156d4;
  outline-offset: 2px;
}

/* Responsive */
@media (max-width: 576px) {
  #map-panel .chip { font-size: 12px; padding: 6px 9px; }
  #map-panel .sectoriales-group { padding: 8px 10px; }
}


/* ====== Tabla moderna solo para #example2 (encapsulada) ====== */
.dt-modern {
  --dt-radius: 14px;
  --dt-shadow: 0 6px 16px rgba(0,0,0,.08);
  --dt-border: 1px solid rgba(0,0,0,.06);
  --dt-th-bg: #f9fafb;
  --dt-th-text: #111827;
  --dt-row-hover: #f3f4f6;
  --dt-row-zebra: #fcfcfd;
  --dt-pill-bg: #eef2ff;
  --dt-pill-text: #3730a3;
}

.dt-modern .dataTables_wrapper {
  background: #fff;
  border-radius: var(--dt-radius);
  box-shadow: var(--dt-shadow);
  border: var(--dt-border);
  padding: 14px 14px 8px;
}

/* Header: título + buscador (DataTables) */
.dt-modern .dataTables_wrapper .dataTables_filter {
  float: none !important;
  text-align: left;
  margin: 6px 0 12px;
}
.dt-modern .dataTables_wrapper .dataTables_filter label {
  width: 100%;
  display: block;
  font-weight: 600;
  color: #374151;
}
.dt-modern .dataTables_wrapper .dataTables_filter input {
  width: 100%;
  margin-left: 0 !important;
  border-radius: 10px;
  border: 1px solid #e5e7eb;
  padding: 10px 12px;
  outline: none;
}
.dt-modern .dataTables_wrapper .dataTables_filter input:focus {
  border-color: #6366f1;
  box-shadow: 0 0 0 3px rgba(99,102,241,.15);
}

/* Tabla */
.dt-modern table.table {
  width: 100% !important;
  border-collapse: separate;
  border-spacing: 0;
}

.dt-modern table.table thead th {
  position: sticky;
  top: 0;
  background: var(--dt-th-bg);
  color: var(--dt-th-text);
  font-weight: 700;
  border-bottom: 1px solid #e5e7eb !important;
  white-space: nowrap;
  z-index: 1;
}

.dt-modern table.table thead th:first-child { border-top-left-radius: 10px; }
.dt-modern table.table thead th:last-child  { border-top-right-radius: 10px; }

.dt-modern table.table tbody tr {
  transition: background-color .15s ease, transform .05s ease;
}
.dt-modern table.table tbody tr:nth-child(even) { background: var(--dt-row-zebra); }
.dt-modern table.table tbody tr:hover { background: var(--dt-row-hover); }

.dt-modern table.table td, 
.dt-modern table.table th {
  border: none !important;
  padding: 12px 14px !important;
  vertical-align: middle;
}

.dt-modern table.table tbody td:nth-child(1) {
  color: #6b7280;
  font-variant-numeric: tabular-nums;
}

/* Pill para contadores */
.dt-modern .pill {
  display: inline-block;
  padding: 6px 10px;
  border-radius: 999px;
  background: var(--dt-pill-bg);
  color: var(--dt-pill-text);
  font-size: 0.85rem;
  font-weight: 600;
}

/* Botones-Icono (editar, eliminar) */
.dt-modern .btn-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 36px; width: 36px;
  border-radius: 10px;
  border: 1px solid #e5e7eb;
  background: #fff;
  color: #111827;
  transition: all .15s ease;
}
.dt-modern .btn-icon:hover {
  transform: translateY(-1px);
  box-shadow: 0 4px 10px rgba(0,0,0,.08);
}
.dt-modern .btn-icon i { font-size: 14px; }
.dt-modern .btn-icon.danger { color: #b91c1c; border-color: #fecaca; background: #fff; }
.dt-modern .btn-icon.danger:hover { background: #fef2f2; }

/* Footer y paginación */
.dt-modern .dataTables_wrapper .dataTables_info {
  padding-top: 10px !important;
  color: #6b7280;
}
.dt-modern .dataTables_wrapper .dataTables_paginate {
  padding-top: 6px !important;
}
.dt-modern .dataTables_wrapper .dataTables_paginate .paginate_button {
  border-radius: 8px !important;
  border: 1px solid #e5e7eb !important;
  padding: 6px 10px !important;
  margin: 0 2px;
}
.dt-modern .dataTables_wrapper .dataTables_paginate .paginate_button.current {
  background: #eef2ff !important;
  border-color: #c7d2fe !important;
  color: #3730a3 !important;
}

/* Responsive “plus” cell */
.dt-modern table.dataTable.dtr-inline.collapsed>tbody>tr>td.dtr-control:before,
.dt-modern table.dataTable.dtr-inline.collapsed>tbody>tr>th.dtr-control:before {
  background-color: #6366f1 !important;
  border-radius: 6px !important;
}

/* =========================
   MODAL LOGOUT BCONSULTORS
   ========================= */

#confirmLogoutModal .modal-dialog {
  max-width: 420px;
}

#confirmLogoutModal .modal-content.modal-logout {
  border-radius: 30px;
  border: none;
  background: #ffffff;
  box-shadow: 0 10px 30px rgba(0,0,0,.15);
}

/* Icono redondo como en cabecera */
#confirmLogoutModal .logout-icon-container i {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background-color: #5a6bff;
  color: #fff;
  font-size: 20px;
}

/* Texto de cabecera */
#confirmLogoutModal .logout-text-container h5 {
  font-weight: 600;
  color: #111827;
}

#confirmLogoutModal .logout-text-container p {
  font-size: 0.85rem;
  color: #6b7280;
}

/* Botón de cerrar (X) */
#confirmLogoutModal .close-logout {
  opacity: 0.6;
  font-size: 1.4rem;
}

#confirmLogoutModal .close-logout:hover {
  opacity: 1;
}

/* Mensaje central */
#confirmLogoutModal .logout-message {
  font-size: 0.9rem;
  color: #4b5563;
  margin-top: 0.5rem;
  margin-bottom: 0.5rem;
}

/* Botones redondeados al estilo general */
#confirmLogoutModal .btn-logout-rounded {
  border-radius: 40px;
  padding: 8px 18px;
  font-weight: 600;
  font-size: 0.9rem;
}

/* Botón primario: azul corporativo */
#confirmLogoutModal .btn-primary {
  background-color: #5a6bff;
  border-color: #5a6bff;
}

#confirmLogoutModal .btn-primary:hover {
  background-color: #4d5ae6;
  border-color: #4d5ae6;
}

/* Botón secundario */
#confirmLogoutModal .btn-outline-secondary {
  border-color: #d1d5db;
  color: #4b5563;
  background-color: #ffffff;
}

#confirmLogoutModal .btn-outline-secondary:hover {
  background-color: #f3f4f6;
  color: #111827;
}

/* Pequeño ajuste en móviles */
@media (max-width: 576px) {
  #confirmLogoutModal .modal-dialog {
    margin: 1.5rem;
  }
  #confirmLogoutModal .modal-content.modal-logout {
    border-radius: 24px;
  }
}

/* ================================
   TIPOGRAFÍA MODERNA
   ================================ */

:root {
    --font-main: "Inter", "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
    --font-size-base: 14.5px;
    --font-size-small: 13px;
    --text-color: #2c3e50;
    --text-muted: #6c757d;
}

/* Aplicar tipografía moderna a toda la tabla */
.dt-modern table {
    font-family: var(--font-main);
    font-size: var(--font-size-base);
    color: var(--text-color);
}

/* Cabecera tabla */
.dt-modern thead th {
    font-size: 13px;
    letter-spacing: .3px;
    font-weight: 600;
    color: #4a5568 !important;
    text-transform: uppercase;
    border-bottom: none;
}

/* Celdas */
.dt-modern table tbody td {
    font-size: var(--font-size-base);
    font-weight: 500;
    color: #2d3748;
}

/* Enlaces de población */
.dt-modern table tbody a {
    font-weight: 600;
    color: #1a73e8;
    text-decoration: none;
}
.dt-modern table tbody a:hover {
    text-decoration: underline;
}

/* Etiquetas tipo “pill” */
.pill {
    font-size: 12.5px;
    font-weight: 600;
    padding: 4px 10px;
    border-radius: 50px;
    background: #e7f0ff;
    color: #2c63b8;
    letter-spacing: .2px;
}

/* Botones de acción */
.btn-icon, .btn-icon.danger {
    font-size: 14px;
}

.btn-icon i {
    font-size: 14px;
    transition: 0.2s ease-out;
}

.btn-icon:hover i {
    transform: scale(1.2);
}

/* Texto “No” en sectorial */
.pill-no {
    background: #fef1f1 !important;
    color: #d9534f !important;
    font-weight: 600;
}

/* Filas alternas más claras (efecto moderno) */
.dt-modern table tbody tr:nth-child(even) {
    background: #fafafa;
}

/* Placeholder moderno en búsqueda */
.dataTables_filter input {
    font-family: var(--font-main);
    font-size: 13.5px;
    padding: 6px 10px;
    border-radius: 6px;
    border: 1px solid #cbd5e0;
}
.dataTables_filter input:focus {
    outline: none;
    border-color: #3182ce;
    box-shadow: 0 0 0 2px rgba(49,130,206,0.25);
}



/* =========================================================
   SIDEBAR — PILL MODERNO (sin romper tu alineación actual)
   - NO toca .main-sidebar p global
   - NO toca .main-sidebar ul li i global
   - Solo afecta a .nav-sidebar .nav-link
   ========================================================= */

.main-sidebar{
  background-color:#EEEEEE;
}

/* link en modo pill */
.main-sidebar .nav-sidebar .nav-item > .nav-link{
  display:flex;
  align-items:center;               /* <-- mantiene tu alineación */
  gap:10px;
  margin:6px 10px;
  padding:10px 12px;
  border-radius:18px;
  transition: background .15s ease, box-shadow .15s ease, transform .05s ease;
}

/* hover */
.main-sidebar .nav-sidebar .nav-item > .nav-link:hover{
  background: rgba(90,107,255,.10);
}

/* activo: sustituye tu borde por pill moderno SIN quitar tu navactivo */
.main-sidebar .nav-sidebar .nav-item > .nav-link.navactivo,
.main-sidebar .nav-sidebar .nav-item > .nav-link.active{
  background: rgba(90,107,255,.16);
  box-shadow: 0 6px 14px rgba(0,0,0,.08);
  border-bottom: 0 !important;      /* anula tu línea */
  border-radius:18px !important;
}

/* icono dentro del nav-link (cajita) */
.main-sidebar .nav-sidebar .nav-item > .nav-link > i,
.main-sidebar .nav-sidebar .nav-item > .nav-link .nav-icon{
  width:34px;
  height:34px;
  border-radius:12px;
  background: rgba(90,107,255,.14);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:0 !important;             /* anula p-2 */
  margin:0 !important;
  color:#5a6bff !important;
  flex:0 0 34px;
}

/* icono activo */
.main-sidebar .nav-sidebar .nav-item > .nav-link.navactivo > i,
.main-sidebar .nav-sidebar .nav-item > .nav-link.active > i,
.main-sidebar .nav-sidebar .nav-item > .nav-link.navactivo .nav-icon,
.main-sidebar .nav-sidebar .nav-item > .nav-link.active .nav-icon{
  background:#5a6bff;
  color:#fff !important;
}

/* texto SOLO dentro del nav-link (sin afectar al resto de <p>) */
.main-sidebar .nav-sidebar .nav-item > .nav-link > p{
  margin:0;
  font-weight:600;
  font-size:0.9em;
  color:#111827;
  flex:1 1 auto;
  min-width:0;                      /* CLAVE para flex + texto largo */
  white-space:normal;               /* permite 2 líneas si hace falta */
  overflow-wrap:anywhere;
  line-height:1.15;
}

/* flecha derecha */
.main-sidebar .nav-sidebar .nav-item > .nav-link > p .right{
  float:none !important;
  margin-left:auto;
  opacity:.7;
}

/* submenú: compacto + línea */
.main-sidebar .nav-treeview{
  padding-left:10px;
  margin-left:14px;
  border-left:1px solid rgba(0,0,0,.08);
}

/* nav-link dentro del submenú */
.main-sidebar .nav-treeview .nav-item > .nav-link{
  margin:4px 10px;
  padding:9px 12px;
  border-radius:14px;
}

/* icono submenú (un pelín menor) */
.main-sidebar .nav-treeview .nav-item > .nav-link > i,
.main-sidebar .nav-treeview .nav-item > .nav-link .nav-icon{
  width:30px;
  height:30px;
  border-radius:11px;
  flex:0 0 30px;
}

/* IMPORTANTÍSIMO:
   Tu CSS actual pinta todos los i en azul: .main-sidebar ul li i { color:#5a6bff; }
   Esto asegura que SOLO en los links activos el icono se vuelva blanco */
.main-sidebar .nav-sidebar .nav-item > .nav-link.navactivo i,
.main-sidebar .nav-sidebar .nav-item > .nav-link.active i{
  color:#fff !important;
}

/* Permitir 2 líneas en el texto del sidebar (sin recortes raros) */
.main-sidebar .nav-sidebar .nav-item > .nav-link > p{
  white-space: normal !important;
  overflow: visible !important;
  line-height: 1.15;
}


/* ==========================================================
   FIX DEFINITIVO: NO recortar textos en el sidebar (AdminLTE)
   Pegar al FINAL del CSS
   ========================================================== */

/* Permite que el link pueda crecer en alto (no recortar) */
.main-sidebar .nav-sidebar .nav-link{
  height: auto !important;
  white-space: normal !important;
  overflow: visible !important;
}

/* El texto del menú (p) NO debe ir en una línea con ellipsis */
.main-sidebar .nav-sidebar .nav-link p{
  white-space: normal !important;
  overflow: visible !important;
  text-overflow: clip !important;

  /* importante en flex: deja que el texto use el espacio */
  flex: 1 1 auto !important;
  min-width: 0 !important;

  /* que parta palabras largas si hace falta */
  overflow-wrap: anywhere;
  word-break: break-word;

  /* mejora visual en 2 líneas */
  line-height: 1.15;
}

/* Flecha: que no “empuje” el texto y se quede al final */
.main-sidebar .nav-sidebar .nav-link p{
  position: relative;
  padding-right: 18px; /* hueco para la flecha */
}
.main-sidebar .nav-sidebar .nav-link p .right{
  position: absolute;
  right: 0;
  top: 2px;
  opacity: .7;
}

/* Alineación arriba para icono + texto cuando hay 2 líneas */
.main-sidebar .nav-sidebar .nav-link{
  align-items: flex-start !important;
}
/* ==========================================================
   FIX: Submenú más a la izquierda (evita cortar textos)
   ========================================================== */

/* Reduce indent del contenedor del submenú */
.main-sidebar .nav-treeview{
  padding-left: 0 !important;
  margin-left: 8px !important;     /* antes lo tenías más grande */
  border-left: 1px solid rgba(0,0,0,.08);
}

/* Los links del submenú: menos margen lateral */
.main-sidebar .nav-treeview .nav-link{
  margin: 4px 8px !important;      /* antes 10px */
  padding: 9px 12px !important;
}

/* Icono submenú un pelín más pequeño (gana ancho útil) */
.main-sidebar .nav-treeview .nav-link > i,
.main-sidebar .nav-treeview .nav-link .nav-icon{
  width: 30px !important;          /* antes 34 en principal */
  height: 30px !important;
  border-radius: 11px !important;
}

/* El texto del submenú que use todo el ancho */
.main-sidebar .nav-treeview .nav-link p{
  padding-right: 16px !important;  /* hueco flecha */
}

/* ===== SIDEBAR: 1er nivel centrado y texto con wrap ===== */
.main-sidebar .nav-sidebar > .nav-item > .nav-link{
  display: flex;
  align-items: center !important;   /* <- vuelve a centrar vertical */
}

/* Permitimos 2 líneas en el texto sin romper el centrado */
.main-sidebar .nav-sidebar > .nav-item > .nav-link p{
  flex: 1 1 auto;
  min-width: 0;
  white-space: normal;
  line-height: 1.15;
  margin: 0;
}

/* La flecha siempre a la derecha, centrada */
.main-sidebar .nav-sidebar > .nav-item > .nav-link p .right{
  float: none !important;
  margin-left: auto;
  align-self: center;
}

/* ===== Submenú más distinguible ===== */
.main-sidebar .nav-treeview{
  margin: 6px 8px 10px 18px !important;   /* lo metemos un poco */
  padding: 8px 8px 8px 10px !important;
  border-left: 2px solid rgba(90,107,255,.30) !important;
  background: rgba(90,107,255,.05);       /* fondo suave */
  border-radius: 14px;
}

/* Links del submenú: un pelín más compactos */
.main-sidebar .nav-treeview .nav-link{
  margin: 3px 6px !important;
  padding: 8px 10px !important;
  border-radius: 12px !important;
}

/* Icono submenú: más pequeño y menos protagonista */
.main-sidebar .nav-treeview .nav-link > i,
.main-sidebar .nav-treeview .nav-link .nav-icon{
  width: 28px !important;
  height: 28px !important;
  border-radius: 10px !important;
  background: rgba(90,107,255,.10) !important;
  color: #5a6bff !important;
}
/* Cabecera de grupo (población) un poco más marcada */
.main-sidebar .nav-item.menu-open > .nav-link{
  background: rgba(90,107,255,.12) !important;
}


/* ==========================================================
   FIX alineación icono + texto (submenu + gestión + población)
   Pegar AL FINAL del CSS
   ========================================================== */

/* 1) TODOS los links (también los del submenú) como flex */
.main-sidebar .nav-sidebar .nav-link{
  display: flex !important;
  align-items: center !important;     /* centra icono y 1 línea */
  gap: 10px;
}

/* 2) El <p> dentro del link también en flex (evita “saltos” si hay iconos dentro del <p>) */
.main-sidebar .nav-sidebar .nav-link > p{
  display: flex !important;
  align-items: center !important;
  gap: 8px;
  margin: 0 !important;
  flex: 1 1 auto !important;
  min-width: 0 !important;
}

/* 3) Cualquier icono (i) dentro del nav-link: caja fija */
.main-sidebar .nav-sidebar .nav-link > i,
.main-sidebar .nav-sidebar .nav-link > p > i,
.main-sidebar .nav-sidebar .nav-link .nav-icon{
  width: 34px !important;
  height: 34px !important;
  min-width: 34px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  line-height: 1 !important;          /* clave: evita desalineación por line-height */
  padding: 0 !important;
  margin: 0 !important;
}

/* 4) En submenú, caja algo menor */
.main-sidebar .nav-treeview .nav-link > i,
.main-sidebar .nav-treeview .nav-link > p > i,
.main-sidebar .nav-treeview .nav-link .nav-icon{
  width: 28px !important;
  height: 28px !important;
  min-width: 28px !important;
}

/* 5) Flecha siempre al final y centrada */
.main-sidebar .nav-sidebar .nav-link .right{
  margin-left: auto !important;
  align-self: center !important;
  position: static !important;         /* por si tenías absolute antes */
}

/* 6) Si el texto se parte a 2 líneas, que el icono NO se suba/ baje raro */
.main-sidebar .nav-sidebar .nav-link > p{
  line-height: 1.15 !important;
  white-space: normal !important;
}

/* ==========================================================
   SUBMENÚ más a la izquierda (más ancho útil)
   Pegar AL FINAL del CSS
   ========================================================== */

/* El bloque del submenú (la “caja”): menos sangría */
.main-sidebar .nav-sidebar .nav-item > .nav-treeview{
  margin-left: 8px !important;     /* antes 18px */
  margin-right: 6px !important;
  padding-left: 6px !important;    /* antes 10px */
  padding-right: 6px !important;
}

/* Links del submenú: menos margen lateral */
.main-sidebar .nav-treeview .nav-link{
  margin-left: 4px !important;     /* antes 6/8/10 */
  margin-right: 4px !important;
}

/* (Opcional) Flecha un pelín más pegada para ganar 2-4px */
.main-sidebar .nav-treeview .nav-link > p{
  padding-right: 14px !important;  /* antes 16-18 */
}

/* ==========================================================
   FOOTER PREMIUM (tu HTML actual)
   SOLO LOGIN: body#pagina-index
   Pegar AL FINAL del CSS
   ========================================================== */

#pagina-index .site-footer{
  position: relative;
  overflow: hidden;

  /* línea accent */
  border-top: 4px solid #5a6bff;

  /* fondo moderno con tu paleta */
  background:
    radial-gradient(900px 320px at 12% 0%,
      rgba(90,107,255,.22) 0%,
      rgba(90,107,255,0) 62%),
    radial-gradient(740px 280px at 88% 100%,
      rgba(90,107,255,.14) 0%,
      rgba(90,107,255,0) 60%),
    linear-gradient(180deg, #f7f8ff 0%, #eeeeee 70%, #f4f6ff 100%) !important;

  color: #0b0f19 !important;
  padding: 16px 0 !important;
}

/* Brillos decorativos sutiles */
#pagina-index .site-footer::before,
#pagina-index .site-footer::after{
  content:"";
  position:absolute;
  width: 520px;
  height: 220px;
  border-radius: 999px;
  filter: blur(22px);
  opacity: .55;
  pointer-events:none;
}
#pagina-index .site-footer::before{
  left: -180px;
  top: -90px;
  background: rgba(90,107,255,.22);
}
#pagina-index .site-footer::after{
  right: -180px;
  bottom: -110px;
  background: rgba(90,107,255,.16);
}

/* “Card” interior */
#pagina-index .site-footer #footer-info{
  max-width: 1100px;
  margin: 0 auto;
  padding: 14px 16px;

  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 14px;

  background: rgba(255,255,255,.72);
  border: 1px solid rgba(0,0,0,.06);
  border-radius: 18px;
  box-shadow: 0 10px 24px rgba(0,0,0,.08);

  backdrop-filter: blur(10px);
}

/* Brand */
#pagina-index .site-footer .footer-brand{
  display:inline-flex;
  align-items:center;
  text-decoration:none;
  padding: 6px 10px;
  border-radius: 14px;
  transition: transform .15s ease, background .15s ease;
}
#pagina-index .site-footer .footer-brand:hover{
  transform: translateY(-1px);
  background: rgba(90,107,255,.06);
}

/* Logo: evita el “se ve fatal” */
#pagina-index .site-footer .footer-logo{
  height: 44px !important;
  width: auto !important;        /* mata width:40% o width:100% global */
  max-width: 220px;
  display:block;
  object-fit: contain;
  filter: none !important;
}

/* Links */
#pagina-index .site-footer .footer-links{
  display:flex;
  align-items:center;
  gap: 10px;
  flex-wrap: wrap;
  justify-content:center;
}

/* Links tipo chip */
#pagina-index .site-footer .footer-links a{
  display:inline-flex;
  align-items:center;

  color:#0b0f19 !important;
  text-decoration:none;
  font-weight:700;
  font-size: 13.5px;

  padding: 8px 10px;
  border-radius: 12px;
  border: 1px solid rgba(0,0,0,.06);
  background: rgba(255,255,255,.70);

  transition: transform .15s ease, box-shadow .15s ease, background .15s ease, border-color .15s ease;
}

/* Hover moderno */
#pagina-index .site-footer .footer-links a:hover{
  transform: translateY(-1px);
  box-shadow: 0 8px 18px rgba(0,0,0,.10);
  background: rgba(90,107,255,.08);
  border-color: rgba(90,107,255,.22);
}

/* Meta */
#pagina-index .site-footer .footer-meta{
  display:inline-flex;
  align-items:center;
  gap: 10px;
  font-size: 13px;
  font-weight: 700;
  opacity: .85;
  white-space: nowrap;
}
#pagina-index .site-footer .footer-dot{ opacity:.5; }

/* Responsive */
@media (max-width: 768px){
  #pagina-index .site-footer #footer-info{
    flex-direction: column;
    align-items: flex-start;
  }
  #pagina-index .site-footer .footer-links{
    justify-content: flex-start;
  }
  #pagina-index .site-footer .footer-meta{
    white-space: normal;
  }
}


/* ==========================================
   FOOTER PREMIUM: contenedor interior con degradado
   (sobrescribe el blanco del #footer-info)
   ========================================== */

#pagina-index .site-footer #footer-info{
  max-width: 1100px;
  margin: 0 auto;
  padding: 14px 16px;

  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 14px;

  /* ✅ degradado suave + toque azul */
  background:
    linear-gradient(135deg,
      rgba(255,255,255,.55) 0%,
      rgba(90,107,255,.10) 55%,
      rgba(238,238,238,.70) 100%);

  border: 1px solid rgba(0,0,0,.08);
  border-radius: 18px;
  box-shadow:
    0 10px 24px rgba(0,0,0,.10),
    inset 0 1px 0 rgba(255,255,255,.55);

  backdrop-filter: blur(10px);
}

/* Si quieres un pelín menos “blanco” aún */
#pagina-index .site-footer #footer-info{
  /* baja un poco la claridad */
  filter: saturate(1.05);
}

/* Destaca el 2º enlace (Acceso web) como CTA */
#pagina-index .site-footer .footer-links a:nth-child(2){
  background: #5a6bff !important;
  color: #fff !important;
  border-color: rgba(90,107,255,.35) !important;
  box-shadow: 0 10px 22px rgba(90,107,255,.25);
}
#pagina-index .site-footer .footer-links a:nth-child(2):hover{
  transform: translateY(-2px);
  box-shadow: 0 14px 28px rgba(90,107,255,.28);
  background: #4d5ae6 !important;
}




