@font-face { font-family: 'Montserrat'; src: url('../fonts/Montserrat/Montserrat-Thin.ttf'); font-weight: 100; font-display: swap; }
@font-face { font-family: 'Montserrat'; src: url('../fonts/Montserrat/Montserrat-ThinItalic.ttf'); font-weight: 100; font-display: swap; font-style: italic; }
@font-face { font-family: 'Montserrat'; src: url('../fonts/Montserrat/Montserrat-ExtraLight.ttf'); font-weight: 200; font-display: swap; }
@font-face { font-family: 'Montserrat'; src: url('../fonts/Montserrat/Montserrat-ExtraLightItalic.ttf'); font-weight: 200; font-display: swap; font-style: italic; }
@font-face { font-family: 'Montserrat'; src: url('../fonts/Montserrat/Montserrat-Light.ttf'); font-weight: 300; font-display: swap; }
@font-face { font-family: 'Montserrat'; src: url('../fonts/Montserrat/Montserrat-LightItalic.ttf'); font-weight: 300; font-display: swap; font-style: italic; }
@font-face { font-family: 'Montserrat'; src: url('../fonts/Montserrat/Montserrat-Regular.ttf'); font-weight: 400; font-display: swap; }
@font-face { font-family: 'Montserrat'; src: url('../fonts/Montserrat/Montserrat-Italic.ttf'); font-weight: 400; font-display: swap; font-style: italic; }
@font-face { font-family: 'Montserrat'; src: url('../fonts/Montserrat/Montserrat-Medium.ttf'); font-weight: 500; font-display: swap; }
@font-face { font-family: 'Montserrat'; src: url('../fonts/Montserrat/Montserrat-MediumItalic.ttf'); font-weight: 500; font-display: swap; font-style: italic; }
@font-face { font-family: 'Montserrat'; src: url('../fonts/Montserrat/Montserrat-SemiBold.ttf'); font-weight: 600; font-display: swap; }
@font-face { font-family: 'Montserrat'; src: url('../fonts/Montserrat/Montserrat-SemiBoldItalic.ttf'); font-weight: 600; font-display: swap; font-style: italic; }
@font-face { font-family: 'Montserrat'; src: url('../fonts/Montserrat/Montserrat-Bold.ttf'); font-weight: 700; font-display: swap; }
@font-face { font-family: 'Montserrat'; src: url('../fonts/Montserrat/Montserrat-BoldItalic.ttf'); font-weight: 700; font-display: swap; font-style: italic; }
@font-face { font-family: 'Montserrat'; src: url('../fonts/Montserrat/Montserrat-ExtraBold.ttf'); font-weight: 800; font-display: swap; }
@font-face { font-family: 'Montserrat'; src: url('../fonts/Montserrat/Montserrat-ExtraBoldItalic.ttf'); font-weight: 800; font-display: swap; font-style: italic; }
@font-face { font-family: 'Montserrat'; src: url('../fonts/Montserrat/Montserrat-Black.ttf'); font-weight: 900; font-display: swap; }
@font-face { font-family: 'Montserrat'; src: url('../fonts/Montserrat/Montserrat-BlackItalic.ttf'); font-weight: 900; font-display: swap; font-style: italic; }
@font-face { font-family: 'DigitalDisplay'; src: url('../fonts/DigitalDisplayTBF/digital-display-tfb.ttf'); font-display: swap; }

:root {
    --color-azul-tema: #0B2B39;
    --color-dorado-tema: #FFC107;
    --color-gris-poco-clarito: #CECFD1;
    --color-gris-clarito: #EAEAEA;
    --color-gris-mas-clarito: #F8F8F8;
    --color-gris-mas-clarito-o-80: #F8F8F8CD;
    --color-gris-mas-clarito--shade-10: #dfdfdf;
    --color-gris-mas-clarito--shade-20: #c6c6c6;
    --color-gris-oscuro: #595A5C;
    /* --color-nwl-rojo: #771416; */
    --color-rosa-sutil: #FFF5F4;
    --color-azul-cta: #32C0FB;
    --color-azul-cta-apenas-oscurecido: #20a3db;
    --color-azul-cta-o-75: #32C0FBBF;

    /* --color-asueto: #00BCD4;
    --color-feriado: #E91E63;
    --color-medio-dia: #f3bf3b; */

    --bg-body: white;
    --bg-body-o-80: #CDCDCD;

    /* Utils */
    --resaltar--parpadeo--s: 3s;
    --resaltar--parpadeo--rgb: 255 165 0;
    /* table.tabla-compacta */
    --tabla-compacta--padding-x: .5rem;
    --tabla-compacta--padding-y: .25rem;
    --tabla-compacta--padding-start: 0;
    --tabla-compacta--padding-end: 0;
    --tabla-compacta--line-height: 1.2;
    --tabla-compacta--vertical-align: top;

    --celdas-bg-color: mistyrose;

    /* DataTables */
    /* --dt-row-selected: 234, 234, 234; */
    --dt-row-selected: 234 234 234 / 50%;
    --dt-row-selected-text: 33, 37, 41;
    --dt-row-selected-link: 9, 10, 11;

    /* FancyApp < FancyBox */
    --fancybox-zIndex: 10050;
}
html {
    font-size: 14px;
}
html, body {
    font-family: Montserrat;
}
body {
    --bg-body: var(--color-gris-mas-clarito);
    --bg-body-o-80: var(--color-gris-mas-clarito-o-80);
    background-color: var(--bg-body);
    padding-right: 0 !important;
}
body ::-webkit-scrollbar, body::-webkit-scrollbar {
    width: 10px;
    height: 10px;
}
body ::-webkit-scrollbar-thumb, body::-webkit-scrollbar-thumb {
    background: #e5e5e5;
    background-clip: padding-box;
    box-shadow: inset 0 0 6px rgba(0, 0, 0, .5);
    -webkit-box-shadow: inset 0 0 6px rgba(0, 0, 0, .5);
}
body ::-webkit-scrollbar-track, body::-webkit-scrollbar-track {
    box-shadow: inset 0 0 6px rgba(0, 0, 0, .3);
    -webkit-box-shadow: inset 0 0 6px rgba(0, 0, 0, .3);
}
.scrollbar-3px::-webkit-scrollbar {
    width: 3px;
    height: 3px;
}
.scrollbar-3px::-webkit-scrollbar-thumb {
    background-color: #4B4B4B;
    box-shadow: none;
    -webkit-box-shadow: none;
}
.scrollbar-3px::-webkit-scrollbar-track {
    background: var(--color-gris-mas-clarito);
    box-shadow: none;
    -webkit-box-shadow: none;
}
.scrollbar-0::-webkit-scrollbar {
    width: 0;
    height: 0;
}
.fabted{
    font-size: 18px;
    color: #676767;
    cursor: pointer;
}
.fabted:hover{
    color: #212529;
}
.contenedor-app {
    display: flex;
    flex-direction: column;
    /* display: grid;
    grid-template-areas: 'header' 'menu' 'contenido';
    grid-template-columns: 100%;
    grid-template-rows: max-content max-content 1fr; */
    position: relative;
    width: 100%;
    min-height: 100vh;
}
.contenedor-app > header {
    align-items: center;
    background-color: var(--color-azul-tema);
    color: white;
    display: flex;
    flex-direction: row;
    grid-area: header;
    justify-content: space-between;
    /* overflow-x: hidden; */
    padding: 1rem .5rem;
    width: 100%;
    position: sticky;
    top: 0;
    z-index: 99;
}
.contenedor-app > nav {
    position: sticky;
    top: calc(39px + 2rem);
    z-index: 2099;
    background-color: white;
    grid-area: menu;
    max-height: calc(100vh - (39px + 2rem));
    overflow-y: auto;
    width: 100%;
}

.contenedor-app > main {
    grid-area: contenido;
    position: relative;
    flex-grow: 1;
    z-index: 98;
}
.contenedor-app > header .toggle-menu {
    display: inline-block;
    height: 39px;
    order: 1;
    width: 39px;
}
.contenedor-app > header .boton-imagen-mi-perfil {
    order: 3;
}
.contenedor-app > header .bloque-fecha {
    order: 2;
}
.contenedor-app > nav > .contenedor-menu-nav {
    display: flex;
    flex-direction: column;
    min-height: 240px;
    overflow-x: hidden;
    /* padding-bottom: 1rem;    
    padding-top: 1rem; */
}


.contenedor-app > nav .boton-mostrar-menu {
    display: none;
    background-color: var(--color-azul-tema);
    border: 0;
    border-radius: .25rem;
    box-shadow: 0 .5rem 1rem rgb(0 0 0 / 15%);
    color: white;
    cursor: pointer;
    font-size: .85em;
    padding: 5px 8px;
    position: absolute;
    right: .25rem;
    top: .25rem;
    text-align: center;
}
.contenedor-app > nav.contraido .boton-mostrar-menu {
    width: calc(100% - 0.5rem);
}
.contenedor-app > nav:not(.contraido) .boton-mostrar-menu .icono-expandido,
.contenedor-app > nav.contraido .boton-mostrar-menu .icono-contraido {
    display: inline-block;
}
.contenedor-app > nav.contraido .boton-mostrar-menu .icono-expandido,
.contenedor-app > nav:not(.contraido) .boton-mostrar-menu .icono-contraido {
    display: none;
}

.contenedor-app > nav .logoEmpresa,
.contenedor-app > nav .logoUnidad {
    height: auto;
    max-height: 40px;
    max-width: calc(50% - 4px);
    min-width: 80px;
    width: auto;
}
.contenedor-app > nav .logoEmpresa {
    margin-right: 4px;
}
.contenedor-app > nav .elemento-menu-contraido .logoEmpresa {
    max-height: 32px;
    max-width: 100%;
    min-width: unset;
    margin-right: 0;
}
.contenedor-app > nav .logoUnidad {
    margin-left: 4px;
}
.boton-imagen-mi-perfil {
    display: inline-block;
    height: 39px;
    width: 39px;
    border-radius: 50%;
}

.contenedor-basico {
    display: grid;
    /* grid-template-areas: 'titulo' 'principal'; */
    grid-template-areas: 'header' 'titulo' 'principal';
    grid-template-columns: 100%;
    position: relative;
    width: 100%;
}
.contenedor-basico > section.contenedor-header {
    grid-area: header;
}
.contenedor-basico > div:nth-of-type(1) {
    grid-area: titulo;
}
.contenedor-basico > div:nth-of-type(2) {
    grid-area: principal;
}

.contenedor-aux-lateral {
    display: grid;
    /* grid-template-areas: 'titulo' 'auxiliar' 'principal'; */
    grid-template-areas: 'header' 'titulo' 'auxiliar' 'principal';
    grid-template-columns: 100%;
    position: relative;
    width: 100%;
}
.contenedor-aux-lateral > section.contenedor-header {
    grid-area: header;
}
.contenedor-aux-lateral > div:nth-of-type(1) {
    grid-area: titulo;
}
.contenedor-aux-lateral > div:nth-of-type(2) {
    grid-area: auxiliar;
}
.contenedor-aux-lateral > div:nth-of-type(3) {
    grid-area: principal;
}
@media (min-width: 1200px){
    .contenedor-aux-lateral {
        /* grid-template-areas: 'titulo auxiliar' 'principal auxiliar'; */
        grid-template-areas: 'header header' 'titulo auxiliar' 'principal auxiliar';
        grid-template-columns: 1fr 33%;
        /* grid-template-rows: min-content 1fr; */
        grid-template-rows: min-content min-content 1fr;
    }
}



/* .contenedor-secciones > .seccion-primaria,
.contenedor-secciones > .seccion-secundaria {
    padding-top: 2rem;
    padding-bottom: 2rem;
}
.contenedor-secciones > .seccion-primaria > *,
.contenedor-secciones > .seccion-secundaria > * {
    padding-left: 1.5rem;
    padding-right: 1.5rem;
}
.contenedor-secciones > .seccion-primaria .cabecera-modulo {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    margin-bottom: 1rem;
    margin-top: -1rem;
    margin-left: -1rem;
}
.contenedor-secciones > .seccion-primaria .cabecera-modulo > * {
    margin-left: 1rem;
    margin-top: 1rem;
} */
/* .contenedor-secciones > .seccion-primaria .cabecera-modulo .titulo-modulo { */
.titulo-modulo > *:first-child {
    font-size: 1.5rem;
    font-weight: 900;
    text-transform: uppercase;
}
.subtitulo-modulo {
    font-size: 1.3rem;
    font-weight: 600;
}
@media (min-width: 768px){
    .contenedor-app {
        flex-direction: row;
        height: 100vh;
        /* display: grid;
        grid-template-areas: 'header menu contenido';
        grid-template-columns: max-content 72px 1fr;
        grid-template-rows: 100%; */
        /* position: relative; */
    }
    .contenedor-app > header {
        flex-direction: column;
        /* justify-content: unset; */
        max-width: 66px;
        overflow-x: hidden;
    }
    .contenedor-app > nav {
        max-width: 230px;
        max-height: unset;
        /* width: 72px;
        min-width: 72px; */
        width: 68px;
        min-width: 68px;
        /* border-right: 10px solid var(--color-gris-clarito); */
        border-right: 3px solid var(--color-gris-clarito);
        box-shadow: 0 .125rem .25rem rgb(0 0 0 / 7.5%)!important;
        z-index: 99;
    }
    .contenedor-app > main {
        overflow-x: auto;
    }
    .contenedor-app > header .boton-imagen-mi-perfil {
        order: 2;
    }
    .contenedor-app > header .bloque-fecha {
        order: 3;
    }
    .contenedor-app > header .toggle-menu {
        display: none;
        height: 52px;
        width: 52px;
    }
    .boton-imagen-mi-perfil {
        height: 52px;
        width: 52px;
    }
    /* .contenedor-secciones > .seccion-primaria .cabecera-modulo .titulo-modulo { */
    .titulo-modulo > *:first-child {
        font-size: 2rem;
        /* padding-left: 2rem; */
    }
    .modal-header.modalHeaderTema {
        font-size: 1.8rem;
    }
}
@media (min-width: 992px){
    .contenedor-app > nav .boton-mostrar-menu {
        display: block;
        opacity: 0;
        transition: opacity .25s .125s;
    }
    .contenedor-app > nav:hover .boton-mostrar-menu {
        opacity: .85;
    }
    .contenedor-app {
        /* grid-template-columns: max-content max-content 1fr; */
    }
    .contenedor-app > nav:not(.contraido) {
        width: 100%;
        min-width: 230px;
    }
}
.contenedor-menu-nav .items-menu {
    padding: 0;
    margin: 0;
}
.contenedor-menu-nav .items-menu > li {
    list-style: none;
}
.contenedor-menu-nav .items-menu > li.modulo-activo {
    background-color: lavender;
}
.contenedor-menu-nav .items-menu > li.item-menu-logout {
    background-color: var(--color-rosa-sutil);
}
.contenedor-menu-nav .items-menu > li.separador-modulos > div {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: .5rem 0;
    width: 100%;
}
.contenedor-menu-nav .items-menu > li.separador-modulos > div > span {
    display: inline-block;
    width: calc(100% - 2rem);
    height: 1px;
    background-color: var(--color-azul-tema);
}
.contenedor-menu-nav .items-menu > li > a {
    display: flex;
    align-items: center;
    color: inherit;
    padding: 0.5rem 1rem;
    text-decoration: none;
    position: relative;
}
.contenedor-menu-nav .items-menu > li:not(.submodulo) > a {
    font-weight: 500;
}
.contenedor-menu-nav .items-menu > li.submodulo > a {
    padding: 0.25rem 1rem;
}
.contenedor-menu-nav .items-menu > li > a.auxiliar {
    pointer-events: none;
    cursor: initial;
    -webkit-filter: drop-shadow(0px 0px 0px black);
            filter: drop-shadow(0px 0px 0px black);
}
.contenedor-menu-nav .items-menu > li > a:not(.auxiliar):hover {
    background-color: var(--color-azul-tema);
    color: white;
}
.contenedor-menu-nav .items-menu > li .item-menu-icono .icono-hover,
.contenedor-menu-nav .items-menu > li > a:not(.auxiliar):hover .item-menu-icono .icono {
    display: none;
}
.contenedor-menu-nav .items-menu > li > a:not(.auxiliar):hover .item-menu-icono .icono-hover {
    display: inline;
}
.contenedor-menu-nav .items-menu > li .item-menu-icono {
    align-items: center;
    justify-content: center;
    display: inline-flex;
    height: 28px;
    margin-right: 10px;
    width: 100%;
    max-width: 28px;
}
.contenedor-menu-nav .items-menu > li .item-menu-icono > img {
    height: auto;
    max-height: 28px;
    max-width: 28px;
    width: auto;
}
.contenedor-menu-nav .items-menu > li .item-menu-icono > .icono-fa {
    display: none;
}
.contenedor-menu-nav .items-menu > li.submodulo .item-menu-icono {
    height: 1rem;
    /* margin-right: 36px; */
    margin-right: 10px;
    width: 1rem;
}
.contenedor-menu-nav .items-menu > li.submodulo .item-menu-icono > img {
    max-height: 1rem;
    max-width: 1rem;
}
.contenedor-menu-nav .items-menu > li .item-menu-nombre {
    line-height: 1.2;
}
.contenedor-menu-nav .elemento-menu-contraido {
    display: none;
}
@media (min-width: 768px){
    .contenedor-menu-nav .items-menu > li > a {
        justify-content: center;
    }
    .contenedor-menu-nav .items-menu > li .item-menu-icono {
        margin-right: 0;
    }
    .contenedor-menu-nav .items-menu > li .item-menu-icono > img {
        width: 100%;
    }
    .contenedor-menu-nav .items-menu > li .item-menu-icono > .icono-fa {
        display: inline-block;
    }
    .contenedor-menu-nav .items-menu > li.submodulo > a {
        justify-content: center;
    }
    .contenedor-menu-nav .items-menu > li.submodulo .item-menu-icono {
        height: 1.4rem;
        margin-right: 0;
    }
    .contenedor-menu-nav .items-menu > li .item-menu-nombre {
        display: none;
    }
    .contenedor-menu-nav .elemento-menu-completo {
        display: none;
    }
    .contenedor-menu-nav .elemento-menu-contraido {
        display: block;
    }
}
@media (min-width: 992px){
    nav:not(.contraido) .contenedor-menu-nav .items-menu > li > a {
        justify-content: unset;
    }
    nav:not(.contraido) .contenedor-menu-nav .items-menu > li .item-menu-icono {
        margin-right: 10px;
    }
    nav:not(.contraido) .contenedor-menu-nav .items-menu > li .item-menu-icono > img {
        width: auto;
    }
    nav:not(.contraido) .contenedor-menu-nav .items-menu > li .item-menu-icono > .icono-fa {
        display: none;
    }
    nav:not(.contraido) .contenedor-menu-nav .items-menu > li.submodulo > a {
        justify-content: unset;
    }
    nav:not(.contraido) .contenedor-menu-nav .items-menu > li.submodulo .item-menu-icono {
        height: 1rem;
        margin-right: 10px;
    }
    nav:not(.contraido) .contenedor-menu-nav .items-menu > li .item-menu-nombre {
        display: block;
    }
    nav:not(.contraido) .contenedor-menu-nav .elemento-menu-completo {
        display: block;
    }
    nav:not(.contraido) .contenedor-menu-nav .elemento-menu-contraido {
        display: none;
    }
}

.contenedor-iconoHerramientaMenu {
    color: rgb(255 255 255 / 65%);
}
.contenedor-iconoHerramientaMenu:hover {
    color: rgb(255 255 255 / 100%);
}
/* .contenedor-iconoHerramientaMenu:not(:last-child) {
    border-right: 1px solid rgb(255 255 255 / 65%);
} */

.contenedor-iconoEntornoMenu:not(.activo) {
    cursor: pointer;
}
.contenedor-iconoEntornoMenu:not(.activo):hover {
    background-color: rgb(255 255 255 / 15%);
}
.iconoEntornoMenu {
    width: 32px;
    height: 32px;
}

#entornoApp-menuBotones {
    position: relative;
}
#entornoApp-menuBotones:before,
#entornoApp-menuBotones:after {
    content: '';
    position: absolute;
    height: 100%;
    top: 0;
    z-index: 1;
    box-shadow: 0 0 80px 36px var(--color-azul-tema);
}
#entornoApp-menuBotones:before {
    left: 0;
}
#entornoApp-menuBotones:after {
    right: 0;
}
#entornoApp-menuBotones .entornoApp-menuBotones-contenedorIconos .icono {
    width: 100px;
    height: 100px;
    max-width: 100%;
}
#entornoApp-menuBotones .entornoApp-entorno {
    position: relative;
    background-color: transparent;
}
#entornoApp-menuBotones .entornoApp-entorno:after {
    content: '';
    box-shadow: 0 0 80px 20px white;
    width: 0;
    height: 0;
    position: absolute;
    top: 50%;
    left: 50%;
    opacity: 0;
    transition: all .5s;
}
#entornoApp-menuBotones .entornoApp-entorno:hover:after {
    opacity: 1;
}
#entornoApp-menuBotones .entornoApp-entorno .entornoApp-boton {
    cursor: pointer;
    transition: all .5s;
    opacity: .85;
}
#entornoApp-menuBotones .entornoApp-entorno .entornoApp-boton:hover {
    opacity: 1;
}
#entornoApp-menuBotones .entornoApp-entorno:not(.activo) .entornoApp-boton {
    background-color: var(--color-azul-cta);
}
#entornoApp-menuBotones .entornoApp-entorno.activo .entornoApp-boton {
    border: 1px solid;
}
#entornoApp-menuBotones .entornoApp-entorno:not(.activo):hover .entornoApp-boton {
    background-color: var(--color-dorado-tema);
    color: black;
    font-weight: bold;
}
@media (min-width: 576px){
    #entornoApp-menuBotones .entornoApp-menuBotones-contenedorIconos .icono {
        width: 140px;
        height: 140px;
    }
}
@media (min-width: 768px){
    #entornoApp-menuBotones:before,
    #entornoApp-menuBotones:after {
        content: unset;
    }
}
/* @media (min-width: 992px){
    #entornoApp-menuBotones .entornoApp-menuBotones-contenedorIconos .icono {
        width: 160px;
        height: 160px;
    }
} */


.btn-group-toggle,
.btn-group {
    height: fit-content;
}
.btn-group-toggle > .btn,
.btn-group > .btn,
.btn-sm {
    min-height: calc(1.5em + 0.5rem + 2px);
}

.form-control {
    border: none;
}
.form-control.form-control-inline-block {
    width: unset;
    display: inline-block;
}
.form-control + .select2 {
    width: 100% !important;
}
.form-control-sm ~ .select2-container.select2-container--bootstrap4 .select2-selection--single,
.form-control-sm ~ .select2-container.select2-container--bootstrap4 .select2-selection--multiple {
    height: calc(1.5em + 0.5rem + 2px) !important;
    font-size: .875rem;
}
.form-control:not(.form-control-sm) ~ .select2-container.select2-container--bootstrap4 .select2-selection--single .select2-selection__rendered {
    padding-top: 1px;
}
.form-control ~ .select2-container.select2-container--bootstrap4:not(.select2) {
    font-size: .875rem;
}
.select2-container.select2-container--bootstrap4 .select2-selection {
    border: none;
}
.form-control-sm ~ .select2-container.select2-container--bootstrap4 .select2-dropdown {
    font-size: .875rem;
}
.select2-container.select2-container--bootstrap4 .select2-search--dropdown .select2-search__field {
    padding: 0.1875rem 0.375rem;
}
.select2-container.select2-container--bootstrap4 .select2-results__option {
    word-wrap: break-word;
    padding: 0.1875rem 0.375rem;
}
.select2-container.select2-container--bootstrap4 .select2-results__option[role="group"] {
    padding: 0;
}
.select2-container.select2-container--bootstrap4 .select2-results__group {
    padding: 0.1875rem 0.375rem;
}

.tipoLink {
    cursor: pointer;
    color: #007bff;
}
.tipoLink:hover {
    color: #0056b3;
}

.fc-daygrid-body > table {
    overflow: hidden;
}
.fc .fc-cell-shaded,
.fc .fc-day-disabled {
    background: transparent !important;
}


/* .bloque-filtros {
    margin-top: -9px;
    margin-left: -9px;
}
.bloque-filtros > .form-group {
    display: inline-block;
    margin: 9px 0 0 9px;
    max-width: 180px;
}
.bloque-filtros > .form-group > label {
    margin: 0;
    font-size: 0.85em;
} */

/* .como-link {
    cursor: pointer;
    color: #007bff;
}
.como-link:hover {
    color: #0056b3;
    text-decoration: underline;
} */


/*
.switch-form-control {
    position: relative;
    display: inline-block;
    width: 60px;
    height: calc(1.5em + .75rem + 2px);
    margin: 0;
}
.switch-form-control.form-control-sm {
    height: calc(1.5em + .5rem + 2px);
}
.switch-form-control input.switch-trigger { 
    opacity: 0;
    width: 0;
    height: 0;
}
.switch-form-control .switch-slider {
    position: absolute;
    cursor: pointer;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    border-radius: calc(1.5em + .75rem + 2px);
    background-color: #ccc;
    -webkit-transition: .4s;
    transition: .4s;
}
.switch-form-control.form-control-sm .switch-slider {
    border-radius: calc(1.5em + .5rem + 2px);
}
.switch-form-control .switch-slider:before {
    position: absolute;
    content: "";
    height: calc(1.5em + .75rem - 6px);
    width: calc(1.5em + .75rem - 6px);
    left: 4px;
    bottom: 4px;
    background-color: white;
    -webkit-transition: .4s;
    transition: .4s;
    border-radius: 50%;
}
.switch-form-control.form-control-sm .switch-slider:before {
    height: calc(1.5em + .5rem - 6px);
    width: calc(1.5em + .5rem - 6px);
}
.switch-form-control input.switch-trigger:checked + .switch-slider {
    background-color: #2196F3;
}
.switch-form-control input.switch-trigger:focus + .switch-slider {
    box-shadow: 0 0 1px #2196F3;
}
.switch-form-control input.switch-trigger:checked + .switch-slider:before {
    -webkit-transform: translateX(calc(1.5em + .75rem - 14px));
    -ms-transform: translateX(calc(1.5em + .75rem - 14px));
    transform: translateX(calc(1.5em + .75rem - 14px));
}
.switch-form-control.form-control-sm input.switch-trigger:checked + .switch-slider:before {
    -webkit-transform: translateX(calc(1.5em + .5rem));
    -ms-transform: translateX(calc(1.5em + .5rem));
    transform: translateX(calc(1.5em + .5rem));
}
*/

.historial-registro {
    margin-bottom: 1rem;
    display: flex;
    flex-direction: column;
    line-height: 1.2;
    padding: .5rem;
    border-radius: .5rem;
    box-shadow: 0 0 10px 0 rgb(0, 0, 0, .15);
}

.form-group > label:first-child {
    margin-bottom: .25rem;
    line-height: 1.2;
}

.border-azul-tema {
    border-color: var(--color-azul-tema);
}

.color-azul-tema {
    color: var(--color-azul-tema);
}
.color-azul-cta {
    color: var(--color-azul-cta);
}
.color-gris-oscuro {
    color: var(--color-gris-oscuro);
}
.color-gris-poco-clarito {
    color: var(--color-gris-poco-clarito);
}
.color-asueto {
    color: var(--color-asueto);
}
.color-feriado {
    color: var(--color-feriado);
}
.color-medio-dia {
    color: var(--color-medio-dia);
}

.bg-body {
    background-color: var(--bg-body);
}
.bg-azul-tema {
    background-color: var(--color-azul-tema);
}
.bg-azul-cta {
    background-color: var(--color-azul-cta);
}
.bg-gris-poco-clarito {
    background-color: var(--color-gris-poco-clarito);
}
.bg-gris-clarito {
    background-color: var(--color-gris-clarito);
}
.bg-gris-mas-clarito {
    background-color: var(--color-gris-mas-clarito);
}
.bg-gris-mas-clarito--shade-10 {
    background-color: var(--color-gris-mas-clarito--shade-10);
}
.bg-gris-mas-clarito--shade-20 {
    background-color: var(--color-gris-mas-clarito--shade-20);
}

.font-DigitalDisplay {
    font-family: DigitalDisplay;
}
.texto-reloj {
    font-family: DigitalDisplay;
    line-height: 1;
    letter-spacing: .1em;
}
.relojito {
    display: inline-block;
    background-color: var(--color-azul-tema);
    color: white;
    padding: .0625em .25em;
    text-align: right;
    border-radius: .125em;
    font-family: monospace;
    line-height: 1;
    letter-spacing: .1em;
}

.btn-azul-cta {
    color: #fff;
    background-color: var(--color-azul-cta);
    border-color: var(--color-azul-cta);
}
.btn-azul-cta.disabled, .btn-azul-cta:disabled {
    color: #fff;
    background-color: var(--color-azul-cta);
    border-color: var(--color-azul-cta);
}
.btn-azul-cta:hover:not(:disabled) {
    color: #fff;
    background-color: var(--color-azul-cta-apenas-oscurecido);
    border-color: var(--color-azul-cta-apenas-oscurecido);
}
.btn-azul-cta.focus, .btn-azul-cta:focus {
    color: #fff;
    background-color: var(--color-azul-cta-apenas-oscurecido);
    border-color: var(--color-azul-cta-apenas-oscurecido);
    box-shadow: 0 0 0 0.2rem var(--color-azul-cta-o-75);
}
.btn-azul-cta:not(:disabled):not(.disabled).active, .btn-azul-cta:not(:disabled):not(.disabled):active, .show>.btn-azul-cta.dropdown-toggle {
    color: #fff;
    background-color: var(--color-azul-cta-apenas-oscurecido);
    border-color: var(--color-azul-cta-apenas-oscurecido);
}
.btn-azul-cta:not(:disabled):not(.disabled).active:focus, .btn-azul-cta:not(:disabled):not(.disabled):active:focus, .show>.btn-azul-cta.dropdown-toggle:focus {
    box-shadow: 0 0 0 0.2rem var(--color-azul-cta-o-75);
}

.contenedor-inlines {
    margin: -.5rem 0 0 -.5rem;
}
.contenedor-inlines > * {
    display: inline-block;
    margin: .5rem 0 0 .5rem;
}
.contenedor-inlines > label {
    padding: 0 .5rem;
}

.tab-principal-modulo.nav-tabs {
    margin-left: -10px;
    border-bottom: none;
    padding: 1px;
}
.tab-principal-modulo.nav-tabs .nav-link {
    margin-left: 9px;
    background-color: rgba(255, 255, 255, 0.8);
    color: black;
    box-shadow: 0 -2px 3px 0px inset rgb(0 0 0 / 15%);
    border: none;
}
.tab-principal-modulo.nav-tabs .nav-item.show .nav-link,
.tab-principal-modulo.nav-tabs .nav-link.active {
    background-color: white;
    box-shadow: none;
}

tr.celdas-bg-color > td,
tr.celdas-bg-color > th {
    background-color: var(--celdas-bg-color);
}
/* 
table.dataTable.dtr-inline.collapsed>tbody>tr>td.dtr-control, table.dataTable.dtr-inline.collapsed>tbody>tr>th.dtr-control {
    padding-left: 30px !important;
}
table.dataTable > tbody > tr:nth-child(even):not(.selected) {
    background-color: #eeeff0;
}

table.renglonesColorIntercalado > tbody > tr:nth-child(2n) {
    background-color: rgba(0, 0, 0, 0.025)
} */

.boton-excel {
    color: white !important;
    background-color: green !important;
    border-radius: 4px !important;
    padding: .25rem .5rem !important;
}
.boton-excel:focus {
    background: limegreen !important;
}

/* table.tabla-compacta > * > tr > td,
table.tabla-compacta > * > tr > th {
    padding: 3px 6px !important;
    line-height: 1.1;
} */
table.tabla-compacta-py-0 > * > tr > td,
table.tabla-compacta-py-0 > * > tr > th {
    padding: 0 6px !important;
    line-height: 1.1;
    /* vertical-align: top; */
}
table.tabla-semi-compacta > * > tr > th,
table.tabla-semi-compacta > * > tr > td {
    padding: 6px 8px !important;
    line-height: 1.2;
    /* vertical-align: top; */
}



table.borde-entre-lineas {
    --borde-entre-lineas--width: 1px;
    --borde-entre-lineas--style: solid;
    --borde-entre-lineas--color: lightgray;
}
table.borde-entre-lineas > thead > tr > th {
    border-bottom: var(--borde-entre-lineas--width) var(--borde-entre-lineas--style) var(--borde-entre-lineas--color);
}
table.borde-entre-lineas > tbody > tr:not(:first-child) > td {
    border-top: var(--borde-entre-lineas--width) var(--borde-entre-lineas--style) var(--borde-entre-lineas--color);
}
table.borde-entre-columnas {
    --borde-entre-columnas--width: 1px;
    --borde-entre-columnas--style: solid;
    --borde-entre-columnas--color: lightgray;
}
table.borde-entre-columnas > * > tr > *:not(:first-child) {
    border-left: var(--borde-entre-columnas--width) var(--borde-entre-columnas--style) var(--borde-entre-columnas--color);
}

table.tabla-compacta > * > tr > th,
table.tabla-compacta > * > tr > td {
    padding: var(--tabla-compacta--padding-y) var(--tabla-compacta--padding-x) !important;
    line-height: var(--tabla-compacta--line-height);
    vertical-align: var(--tabla-compacta--vertical-align);
}
table.tabla-compacta > * > tr > th:first-child,
table.tabla-compacta > * > tr > td:first-child {
    padding-left: var(--tabla-compacta--padding-start)!important;
}
table.tabla-compacta > * > tr > th:last-child,
table.tabla-compacta > * > tr > td:last-child {
    padding-right: var(--tabla-compacta--padding-end)!important;
}



.modal-header.modal-danger {
    background: crimson;
    color: white;
}
.modal-header.modal-danger .close {
    color: white;
}
.modal-header.modal-warning {
    background: gold;
    color: black;
}
.modal-header.modal-warning .close {
    color: black;
}
.modal-header.modal-success {
    background: limegreen;
    color: black;
}
.modal-header.modal-success .close {
    color: black;
}
.modal-header.modalHeaderTema .modal-title,
.modal-header.modalHeaderTema-sm .modal-title {
    font-weight: 900;
    text-transform: uppercase;
}
.modal-header.modalHeaderTema .modal-title {
    font-size: 1.5rem;
}
.modal-header.modalHeaderTema-sm .modal-title {
    font-size: 1rem;
}
table.sort-table > thead > tr > .sorting {
    background-repeat: no-repeat;
    background-position: center right;
    background-image: url(../vendors/DataTables-1.10.24/DataTables-1.10.24/images/sort_both.png);
    cursor: pointer;
}
table.sort-table > thead > tr > .sorting_desc {
    background-image: url(../vendors/DataTables-1.10.24/DataTables-1.10.24/images/sort_desc.png) !important;
}
table.sort-table > thead > tr > .sorting_asc {
    background-image: url(../vendors/DataTables-1.10.24/DataTables-1.10.24/images/sort_asc.png) !important;
}

/* Tema DataTablees */
table.dataTable {
    width: 100%;
}
.dataTables_wrapper {
    z-index: 0;
}
.dataTables_wrapper.dt-bootstrap4 {
    width: calc(100% - 1px);
}
table.dataTable.no-footer {
    border-bottom: none;
}
table.dataTable > tbody > tr {
    background-color: transparent;
}
table.dataTable > thead > tr > th,
table.dataTable > thead > tr > td {
    border-bottom: none;
}
table.dataTable > tbody > tr > th, table.dataTable > tbody > tr > td {
    border-top: 1px solid var(--color-gris-poco-clarito);
}
table.dataTable > tbody > tr:last-child > th, table.dataTable > tbody > tr:last-child > td {
    border-bottom: 1px solid var(--color-gris-poco-clarito);
}
table.dataTable tbody th,
table.dataTable tbody td {
    padding: 0.5rem 0.75rem;
}
table.dataTable > tbody > tr.selected,
table.dataTable > tbody > tr > *.selected {
    color: inherit;
}
table.dataTable.dtr-inline.collapsed > tbody > tr > *.dtr-control {
    padding-left: 30px !important;
}
.dataTables_paginate {
    line-height: 1;
}
.dataTables_info {
    padding-top: 0!important;
}

table.dataTable.no-header {
    position: relative;
}
table.dataTable.no-header > thead {
    height: 1px;
    overflow-y: hidden;
    position: absolute;
    top: -1px;
    visibility: hidden;
    width: 100%;
    z-index: -999;
}
table.dataTable > tbody > tr.selected,
table.dataTable > tbody > tr > .selected{
    background-color:var(--color-gris-clarito);
}
table.dataTable > tbody > tr.selected > *.select-checkbox:after {
    text-shadow: 1px 1px var(--color-gris-clarito), -1px -1px var(--color-gris-clarito), 1px -1px var(--color-gris-clarito), -1px 1px var(--color-gris-clarito);
}

.nav-tabs.tabs-tema {
    background-color: var(--color-gris-clarito);
}
.nav-tabs.tabs-tema .nav-item.show .nav-link,
.nav-tabs.tabs-tema .nav-link.active,
.nav-pills.pills-tema .nav-item.show .nav-link,
.nav-pills.pills-tema .nav-link.active {
    font-weight: bold;
}
.nav-tabs.tabs-tema .nav-item.show .nav-link,
.nav-tabs.tabs-tema .nav-link.active {
    background-color: var(--bg-body);
    box-shadow: none!important;
}
.nav-pills.pills-tema .nav-item.show .nav-link,
.nav-pills.pills-tema .nav-link.active {
    background-color: transparent;
}
.nav-tabs.tabs-tema .nav-item.show .nav-link,
.nav-tabs.tabs-tema .nav-link.active {
    border-bottom: 1px solid #f8f9fa;
}
.nav-pills.pills-tema .nav-item .nav-link {
    border: none;
}
.nav-pills.pills-tema .nav-item .nav-link.active {
    box-shadow: 0 0 10px 1px rgb(0 0 0 / 15%);
}
.nav-tabs.tabs-tema .nav-link,
.nav-pills.pills-tema .nav-link {
    color: inherit;
    background-color: var(--bg-body);
    border-bottom: none;
    box-shadow: inset 0 -10px 10px -10px var(--color-gris-poco-clarito);
}

.bloqueFiltros select > option,
.bloqueFiltros select > optgroup,
.bloqueFiltros select > optgroup > option {
    color: #495057;
}
.bloqueFiltros select:invalid,
.bloqueFiltros select:required > option[value=''],
.bloqueFiltros select:required > optgroup > option[value=''],
.bloqueFiltros select:required + .select2 .select2-selection__placeholder {
    /* color: #b8b8b8; */
    color: darkgray;
}

.disabled {
    pointer-events: none;
    opacity: 0.65;
}
.hidden {
    display: none;
}


.nombreCampo {
    font-size: .85em;
    /* text-transform: uppercase; */
    font-weight: bold;
}

input.no-controls::-webkit-outer-spin-button,
input.no-controls::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
}
input.no-controls[type=number] {
    -moz-appearance:textfield; /* Firefox */
}

.bloqueFiltros select,
.bloqueFiltros input:not(.select2-search__field) {
    max-width: 180px;
}

.triggerCambiarImagen:hover {
    opacity: .85;
}
.triggerCambiarImagen:after {
    content: 'Cambiar';
    position: absolute;
    left: 50%;
    bottom: 18px;
    transform: translateX(-50%);
    font-weight: bold;
}

.contenedorArchivos {
    margin-top: -0.5rem;
    margin-left: -0.5rem;
}
.contenedorArchivos .archivo {
    display: inline-grid;
    margin-left: 0.5rem;
    margin-top: 0.5rem;
    padding-left: 0.5rem;
    padding-right: 0.5rem;
    padding-bottom: 0.25rem;
    padding-top: 0.25rem;
}
.contenedorArchivos .archivo > span {
    white-space: nowrap;
    overflow-x: hidden;
    text-overflow: ellipsis;
}

.columna-estrecha {
    width: 0.1%;
    white-space: nowrap;
}

.campoFaltante {
    background-color: antiquewhite;
    box-shadow: 0 0 6px 0 orange;
}

.contenedor-estatusCobranzaPago-select2 .select2-selection {
    background-color: transparent!important;
}
.contenedor-estatusCobranzaPago-select2 .select2-results__options {
    overflow: visible!important;
}
.contenedor-estatusCobranzaPago-select2 .select2-selection__rendered,
.contenedor-estatusCobranzaPago-select2 .select2-results__option {
    padding: 0!important;
    padding-top: 0!important;
    padding-right: 0!important;
    padding-bottom: 0!important;
    padding-left: 0!important;
}
.contenedor-estatusCobranzaPago-select2 .select2-selection__rendered {
    overflow: visible!important;
    position: relative;
}
.contenedor-estatusCobranzaPago-select2 .select2-results__option:hover {
    opacity: .85;
}
.contenedor-estatusCobranzaPago-select2 .select2-results__option > *:not(.select2-selection__clear) {
    min-height: 1.5rem;
}
.contenedor-estatusCobranzaPago-select2 .select2-selection__rendered > *:not(.select2-selection__clear) {
    padding-right: 2.5rem;
}
.contenedor-estatusCobranzaPago-select2 .select2-selection__clear {
    position: absolute;
    margin-top: 0;
    margin-right: 0;
    top: -0.1rem;
    right: -0.1rem;
    color: white;
    background-color: red;
    text-align: center;
    box-shadow: 0 0 1px 1px black;
}
.contenedor-estatusCobranzaPago-select2 .select2-selection__arrow {
    right: 0;
}

.contenedor-hintEstatus {
    position: relative;
}
.contenedor-hintEstatus .hintEstatus {
    position: absolute;
    right: calc(100% + .25rem);
    top: 50%;
    transform: translateY(-50%);
    padding: .25rem .5rem;
    background-color: black;
    border-radius: .25rem;
    color: white;
    display: none;
}
.contenedor-hintEstatus:hover .hintEstatus {
    display: block;
}

tr.dangerTr {
    background-color: #ffdddd!important;
}
tr.dangerTr.selected {
    --dt-row-selected: 33 37 41 / 10%;
}


.grid-galeria { 
    width: 100%;
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    grid-gap: 1rem;
    align-items: start;
}
.grid-galeria > .elemento-galeria {
    box-shadow: 2px 2px 6px 0  rgb(0 0 0 / 30%);
    display: flex;
    flex-direction: column;
    padding: .5rem;
    border-radius: .5rem;
}
.grid-galeria > .elemento-galeria .menu-acciones {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    margin: -.25rem 0 .25rem -.25rem;
}
.grid-galeria > .elemento-galeria .menu-acciones > * {
    margin: .25rem 0 0 .25rem;
}
.grid-galeria > .elemento-galeria .eliminar-elemento {
    cursor: pointer;
    color: crimson;
}
.grid-galeria > .elemento-galeria img.imagen {
    margin: 0 auto;
    border: 1px solid #ccc;
    width: auto;
    max-width: 100%;
    height: auto;
    max-height: 150px;
}

.resaltar--auxiliar {
    box-shadow: inset 0 0 .25rem 1px rgb(var(--resaltar--parpadeo--rgb) / 1);
}
.resaltar--parpadeo,
tr.resaltar--parpadeo > td {
    animation: bg var(--resaltar--parpadeo--s) ease-in;
    -webkit-animation: bg var(--resaltar--parpadeo--s) ease-in;
    -moz-animation: bg var(--resaltar--parpadeo--s) ease-in;
    -ms-animation: bg var(--resaltar--parpadeo--s) ease-in;
    -o-animation: bg var(--resaltar--parpadeo--s) ease-in;
}
@-webkit-keyframes bg{
    0% {
        background: rgb(var(--resaltar--parpadeo--rgb) / 1);
        box-shadow: 0 0 1rem 1px rgb(var(--resaltar--parpadeo--rgb) / 1);
    }
    20% {
        background: rgb(var(--resaltar--parpadeo--rgb) / 0.8);
        box-shadow: 0 0 1rem 1px rgb(var(--resaltar--parpadeo--rgb) / 0.8);
    }
    50% {
        background: rgb(var(--resaltar--parpadeo--rgb) / 0.5);
        box-shadow: 0 0 1rem 1px rgb(var(--resaltar--parpadeo--rgb) / 0.5);
    }
    100% {
        background: rgb(var(--resaltar--parpadeo--rgb) / 0);
        box-shadow: 0 0 1rem 1px rgb(var(--resaltar--parpadeo--rgb) / 0);
    }
}
@-moz-keyframes bg{
    0% {
        background: rgb(var(--resaltar--parpadeo--rgb) / 1);
        box-shadow: 0 0 1rem 1px rgb(var(--resaltar--parpadeo--rgb) / 1);
    }
    20% {
        background: rgb(var(--resaltar--parpadeo--rgb) / 0.8);
        box-shadow: 0 0 1rem 1px rgb(var(--resaltar--parpadeo--rgb) / 0.8);
    }
    50% {
        background: rgb(var(--resaltar--parpadeo--rgb) / 0.5);
        box-shadow: 0 0 1rem 1px rgb(var(--resaltar--parpadeo--rgb) / 0.5);
    }
    100% {
        background: rgb(var(--resaltar--parpadeo--rgb) / 0);
        box-shadow: 0 0 1rem 1px rgb(var(--resaltar--parpadeo--rgb) / 0);
    }
}    
@-ms-keyframes bg{
    0% {
        background: rgb(var(--resaltar--parpadeo--rgb) / 1);
        box-shadow: 0 0 1rem 1px rgb(var(--resaltar--parpadeo--rgb) / 1);
    }
    20% {
        background: rgb(var(--resaltar--parpadeo--rgb) / 0.8);
        box-shadow: 0 0 1rem 1px rgb(var(--resaltar--parpadeo--rgb) / 0.8);
    }
    50% {
        background: rgb(var(--resaltar--parpadeo--rgb) / 0.5);
        box-shadow: 0 0 1rem 1px rgb(var(--resaltar--parpadeo--rgb) / 0.5);
    }
    100% {
        background: rgb(var(--resaltar--parpadeo--rgb) / 0);
        box-shadow: 0 0 1rem 1px rgb(var(--resaltar--parpadeo--rgb) / 0);
    }
}    
@-o-keyframes bg{
    0% {
        background: rgb(var(--resaltar--parpadeo--rgb) / 1);
        box-shadow: 0 0 1rem 1px rgb(var(--resaltar--parpadeo--rgb) / 1);
    }
    20% {
        background: rgb(var(--resaltar--parpadeo--rgb) / 0.8);
        box-shadow: 0 0 1rem 1px rgb(var(--resaltar--parpadeo--rgb) / 0.8);
    }
    50% {
        background: rgb(var(--resaltar--parpadeo--rgb) / 0.5);
        box-shadow: 0 0 1rem 1px rgb(var(--resaltar--parpadeo--rgb) / 0.5);
    }
    100% {
        background: rgb(var(--resaltar--parpadeo--rgb) / 0);
        box-shadow: 0 0 1rem 1px rgb(var(--resaltar--parpadeo--rgb) / 0);
    }
}
