:root {
  --main-bg-color: #243047;
  --mensaje-error: #59c082;
  --text-no-modificacion: #979797;
  --correcto: #005427;
  --btnCancelar: #979797;
  --fondo-input: #f3eed9;
  --seleccionado: #e3d562;
}


a:link,
a:visited,
a:active {
  text-decoration: none;
}

.nav-link {
  cursor: pointer !important;
}

label.error {
  color: var(--mensaje-error);

}

label,
h1,
h2,
h3,
h4,
h5,
h6,
li,
a,
.card-header {
  color: var(--main-bg-color) !important;
}

.card-header-anulada {
  color: var(--btnCancelar) !important;
}
input.error,
select,
textarea {
  color: var(--mensaje-error);
  border-bottom: 1px solid var(--mensaje-error) !important;
}


.select2-selection {
  -webkit-box-shadow: 0;
  box-shadow: 0;
  background-color: #fff;
  border-bottom: 1px solid var(--mensaje-error) !important;
  border-radius: 0;
  color: var(--mensaje-error);
  font-size: 14px;
  outline: 0;
  min-height: 40px;
  text-align: left;
}

.select2-selection__rendered {
  margin: 5px;
}

.select2-selection__arrow {
  margin: 5px;
}

input.correcto {
  color: var(--correcto) !important;
  border-bottom: 1px solid var(--correcto) !important;
}

.unboton {
  background-color: var(--main-bg-color) !important;
  font-weight: bold !important;
  color: #ffffff !important;
  margin-top: 2% !important;
}
.unbotonCancelado {
  background-color: var(--btnCancelar) !important;
  font-weight: bold !important;
  color: #ffffff !important;
  margin-top: 2% !important;
}

.unbotonASmall {
  background-color: var(--main-bg-color) !important;
  font-weight: bold !important;
  color: #ffffff !important;
}

table thead {
  background-color: var(--main-bg-color) !important;
  color: #ffffff !important;
}

label {
  font-size: 1.2rem !important;
}

.campos {
  border: 0 !important;
  font-weight: bolder !important;
  background-color: var(--fondo-input) !important;
  font-family: 'Roboto', sans-serif !important;
  font-size: 1.2rem !important;
}

.campos:focus {
  background-color: #f7f7f7 !important;
  text-align: left !important;
  border: 2px solid var(--main-bg-color) !important;
}


input[type="search"]::-webkit-search-cancel-button {
  -webkit-appearance: none;
  height: 13px;
  width: 13px;
  background: url("data:image/svg+xml;charset=UTF-8,%3csvg viewPort='0 0 12 12' version='1.1' xmlns='http://www.w3.org/2000/svg'%3e%3cline x1='1' y1='11' x2='11' y2='1' stroke='grey' stroke-width='2'/%3e%3cline x1='1' y1='1' x2='11' y2='11' stroke='grey' stroke-width='2'/%3e%3c/svg%3e");
}

.field-icon {
  float: right;
  margin-right: 10px;
  margin-top: -39px;
  position: relative;
  z-index: 2;
  color: var(--main-bg-color) !important;

}

.fondo {
  background: #9d9d9d;
  background: linear-gradient(to right, #9d9d9d, #ffffff);
}

.menuPrincipal {
  background-color: var(--main-bg-color);
  font-weight: bold;
  color: #ffffff !important;
}


.imgLogin {
  background-image: url(../img/login.png);
  background-position: center center;
  background-repeat: no-repeat;

}

.imgBota {
  background-position: center center;
  background-repeat: no-repeat;
  width: 100%;
  height: 100%;
}

.mensajeUsuario {
  color: var(--main-bg-color) !important;
  margin: 1%;

}

.tarjeta {
  width: 100%;
  height: 100%;
  --c: var(--main-bg-color);
  /* the color*/
  box-shadow: 0 0 0 .1em inset var(--c);
  --_g: linear-gradient(var(--c) 0 0) no-repeat;
  background:
    var(--_g) calc(var(--_p, 0%) - 100%) 0%,
    var(--_g) calc(200% - var(--_p, 0%)) 0%,
    var(--_g) calc(var(--_p, 0%) - 100%) 100%,
    var(--_g) calc(200% - var(--_p, 0%)) 100%;
  background-size: 50.5% calc(var(--_p, 0%)/2 + .5%);
  outline-offset: .1em;
  transition: background-size .4s, background-position 0s .4s;
}

.tarjeta:hover {
  --_p: 100%;
  transition: background-position .4s, background-size 0s;
  color: #ffffff !important;
}

b.tarjeta:active {
  box-shadow: 0 0 9e9q inset #0009;
  background-color: var(--main-bg-color);
  color: #ffff !important;
}

.tarjeta p {
  margin: auto !important;
  color: #000000 !important;
  font-weight: bold;
}

.tarjeta p:hover {
  color: #ffffff !important;
}

.documentos {
  --c: var(--main-bg-color);
  /* the color*/
  box-shadow: 0 0 0 .1em inset var(--c);
  --_g: linear-gradient(var(--c) 0 0) no-repeat;
  background:
    var(--_g) calc(var(--_p, 0%) - 100%) 0%,
    var(--_g) calc(200% - var(--_p, 0%)) 0%,
    var(--_g) calc(var(--_p, 0%) - 100%) 100%,
    var(--_g) calc(200% - var(--_p, 0%)) 100%;
  background-size: 50.5% calc(var(--_p, 0%)/2 + .5%);
  outline-offset: .1em;
  transition: background-size .4s, background-position 0s .4s;
}

.documentos:hover {
  --_p: 100%;
  transition: background-position .4s, background-size 0s;
  color: #ffffff !important;
}

b.documentos:active {
  box-shadow: 0 0 9e9q inset #0009;
  background-color: var(--main-bg-color);
  color: #ffff !important;
}

.documentos p {
  margin: auto !important;
  color: #000000 !important;
  font-weight: bold;
}

.tarjeta p:hover {
  color: #ffffff !important;
}

input[type=checkbox]:checked,
input[type=radio]:checked {
  background-color: var(--main-bg-color) !important;
}

.cerrar {
  width: 4% !important;
  background-color: var(--main-bg-color) !important;
  color: #FFFFFF !important;
}

.form-control[disabled],
.form-control[readonly],
fieldset[disabled] .form-control {
  cursor: not-allowed;
  background-color: #eeeeee;
  color: var(--text-no-modificacion)
}

.noPermitido {
  border: 0 !important;
  padding: 1% !important;
  font-weight: bolder !important;
  background-color: #eeeeee !important;

}

.botonEnLineaInput {
  margin-top: 20% !important;
  background-color: var(--main-bg-color) !important;
  color: #fff !important;
}

.lista {
  background: var(--fondo-input);
  /* background: linear-gradient(to top, #fdeaea, #ffffff); */

}

.sinCursor {
  cursor: default !important;
}

.conHand {
  cursor: pointer !important;
}

.botonMapaPrincipal {
  background-color: var(--main-bg-color) !important;
  border: 1px solid var(--main-bg-color) !important;
  color: #ffffff !important;
  font-family: Arial;
  font-size: 23px;
  height: 100px !important;
  width: 100% !important;
  margin-top: 2% !important;
}

.botonMapaPrincipal:hover {
  background-color: #ffffff !important;
  color: var(--main-bg-color) !important;
}

.botonMapaPrincipal:active {
  position: relative;
  top: 1px;
}

.botonMapaAndana {
  background-color: var(--main-bg-color) !important;
  border: 1px solid var(--main-bg-color) !important;
  color: #ffffff !important;
  font-family: Arial;
  font-size: 23px;
  height: 100px !important;
  width: 50% !important;
  margin-top: 2% !important;
}

.botonMapaAndana:hover {
  background-color: #ffffff !important;
  color: var(--main-bg-color) !important;
}

.botonMapaAndana:active {
  position: relative;
  top: 1px;
}

.botonMapaVentana {
  margin-top: 2% !important;
}

.botonMapaOficina {
  background-color: var(--text-no-modificacion) !important;
  border: 1px solid var(--text-no-modificacion) !important;
  color: #ffffff !important;
  font-family: Arial;
  font-size: 23px;
  height: 100px !important;
  width: 100% !important;
  margin-top: 2% !important;
}

.botonSeleccionado {
  background-color: var(--seleccionado) !important;
}

.inner {
  position: absolute;
  top: 90%;
  left: 50%;
}

.rotate {
  transform: translateX(-50%) translateY(-50%) rotate(-90deg);
}

.campoCheck {
  border: 2px solid var(--main-bg-color) !important;
  border-radius: 100% !important;
  height: 50px !important;
  width: 50px !important;
}

.campoCheckMedio {
  border: 2px solid var(--main-bg-color) !important;
  border-radius: 100% !important;
  height: 35px !important;
  width: 35px !important;
}

.campoCheckSmall {
  border: 2px solid var(--main-bg-color) !important;
  border-radius: 100% !important;
  height: 20px !important;
  width: 20px !important;
}

.scrollable-menu {
  height: auto;
  max-height: 200px;
  overflow-x: hidden;
}

.borderInfSup {
  border-bottom: 2px solid var(--main-bg-color) !important;
  border-top: 2px solid var(--main-bg-color) !important;
}


.zoom {}

.zoom:hover {
  transform: scale(2);
}

/******* EvoCalendar *******/
/*Texto del mes activo*/
.calendar-sidebar>.month-list>.calendar-months>li.active-month {
  background-color: #fff !important;
  color: #000000 !important;
  font-weight: bold;
}

.calendar-sidebar>.month-list>.calendar-months>li {
  padding: 7px 30px;
  cursor: pointer;
  font-size: 16px;
  color: #fff !important;
}

.listaTarjeta{

  border: 2px solid var(--mensaje-error) !important;
}
.listaTarjetaCabecera{

  background-color: var(--mensaje-error)!important;
}

/* ----- Modo oscuro para el modal de Saneo de Mazo ----- */
#modalSanearMazo .modal-content {
  background-color: #2f3b4f; /* gris azulado medio-oscuro */
  color: #eef2f7;            /* gris muy claro */
  border-radius: .75rem;     /* bordes redondeados */
  overflow: hidden;          /* respeta el radio en cabecera/pie */
}
#modalSanearMazo .modal-header,
#modalSanearMazo .modal-footer {
  border-color: #445268;
}
#modalSanearMazo .modal-title,
#modalSanearMazo label,
#modalSanearMazo .form-label,
#modalSanearMazo .btn-close {
  color: #e5e7eb !important;
}
#modalSanearMazo .btn-close { filter: invert(0.9) grayscale(100%); }
#modalSanearMazo .form-control {
  background-color: #1f2735; /* mÃ¡s claro que antes */
  border-color: #445268;
  color: #f8fafc;
  border-radius: .6rem;
}
#modalSanearMazo .form-control:focus {
  background-color: #1c2432;
  border-color: #7cb2ff; /* azul enfoque mÃ¡s claro */
  color: #ffffff;
  box-shadow: 0 0 0 .2rem rgba(124,178,255,.15);
}
#modalSanearMazo .form-control::placeholder {
  color: #9ca3af;
}
#modalSanearMazo .invalid-feedback {
  color: #fca5a5;
}
#modalSanearMazo .modal-footer .btn { 
  border-radius: .6rem; 
  padding: .5rem 1rem; 
  min-width: 170px; 
}
#modalSanearMazo .btn-cancel-saneo {
  background-color: #7a8597; /* gris medio */
  border-color: #7a8597;
  color: #ffffff;
}
#modalSanearMazo .btn-cancel-saneo:hover { background-color: #697388; border-color: #697388; }

#modalSanearMazo .btn-confirm-saneo {
  background-color: #22c55e; /* verde */
  border-color: #22c55e;
  color: #0b1a0f; /* texto oscuro para accesibilidad */
  font-weight: 700;
}
#modalSanearMazo .btn-confirm-saneo:hover { background-color: #16a34a; border-color: #16a34a; color: #051208; }

/* ----- Estilo del modal de Observaciones (igual a Sanear Mazo) ----- */
#modalObsMazos .modal-content {
  background-color: #2f3b4f;
  color: #eef2f7;
  border-radius: .75rem;
  overflow: hidden;
}
#modalObsMazos .modal-header,
#modalObsMazos .modal-footer {
  border-color: #445268;
}
#modalObsMazos .modal-title,
#modalObsMazos label,
#modalObsMazos .form-label,
#modalObsMazos .btn-close {
  color: #e5e7eb !important;
}
#modalObsMazos .btn-close { filter: invert(0.9) grayscale(100%); }

/* Cuerpo de texto (pre) legible en modo oscuro */
#modalObsMazos pre {
  color: #f8fafc;
  background: transparent;
}

/* Botón cerrar semejante al botón cancelar de saneo */
#modalObsMazos .btn.btn-secondary {
  background-color: #7a8597;
  border-color: #7a8597;
  color: #ffffff;
}
#modalObsMazos .btn.btn-secondary:hover {
  background-color: #697388;
  border-color: #697388;
}

/* Eliminados estilos de botón Editar mazo en histórico */
/* Ocultar cualquier indicador de procesamiento de DataTables */
div.dataTables_processing {
  display: none !important;
}

