/* NO TOCAR, si es necesaria una modificación consultar

    Para implementar esta clase a sus archivos css ingresar:

    @import url('globalStyles.css');

API de fuente de google*/
@import url('https://fonts.googleapis.com/css2?family=Poppins:ital,wght@0,100;0,200;0,300;0,400;0,500;0,600;0,700;0,800;1,100;1,200;1,300;1,400&display=swap');

body {
  margin: 0;
  padding: 0;
  font-family: "Poppins", sans-serif;
  background-color: #eef4fd;
}

/*Aca van todos los elementos que no se pueden seleccionar*/
#sidebar,
img,
.calendar,
legend,
button,
pre,
a,
label,
.btnDashboard {
  user-select: none;
}

/*
    Variables de la hoja de estilos global
    ":root" permite que las variables sean de acceso global, para solo invocarlas.

    Desde root se declaran las variables como (--Nombre: Valor)

    No tocar*/
:root {
  /*Permite cambiar el borde de los inputs, select y textarea más fácil*/
  --border: #e6ebf7;

  --border-radius: 8px;
  /*Permite cambiar el borde a los elementos más fácil*/

  --color-bg-int: #f2f7ff;
  /*Color del fondo de cada interfaz*/
  --color-bg-tb: rgba(254, 254, 255, 0.9);
  /*Color del fondo de las tablas.                                  Ej. Empleados, Mantenimientos, etc.*/
  --color-search: #FEFEFF77;
  --color-btn-primary: linear-gradient(134deg, rgba(120, 132, 237, 1) 0%, rgba(97, 111, 239, 1) 100%);
  /*Color de la mayoria de botones*/
  --color-secondary: #616FEF;
  /*Color secundario, usado en botones secundarios, iconos, etc.    Ej. Estadísticas*/
  --color-btn-ghost-border: 2px solid var(--color-breadcrumb);
  --color-btn-text: #F2F9FE;
  /*Color del texto de los botones.                                 Ej. Todos los botones principales*/
  --color-breadcrumb: #616FEF;
  /*Color del breadcrumb y color de botones fantasma.               Ej. "Detalles", "Editar", etc.*/
  --color-danger: #D85E5E;
  /*Color usado para eliminación o resaltar algo importante.        Ej. Mensajes de error, botones de eliminar, etc.*/
  --color-element-border: 1px solid #7B96C7;
  --color-img-border: 3px solid #8F90DE;
  /*Borde de las imagenes de los empleados.                         Ej. Registro de empleado, Selección de empleado, etc.*/
  --color-modal-container: rgba(133, 133, 172, 0.3);
  --color-neutral: #FFFFFF;
  /*Implica muchos tipos de elementos, blanco.*/
  --color-txt: #81859E;
  /*Color de texto simple.                                          Ej. Texto ingresado en formulario*/
  --color-txt-title: #5E6489;
  /*Color de titulos.                                               Ej. Títulos de tablas, título de pregunta de formulario, etc.*/
  --content-gap: 20px;
  /*Permite controlar un margen incluido en todas las interfaces*/
  --display: block;
  /*Variable que permite sobreescribir el display de algunos contenedores   Ej. Modals*/

  --font-size-base: 1.1em;
  /*Tamaño de letra estándar.                                       Ej. Mostrar información, forms, etc.*/
  --font-size-medium: 1.3em;
  /*Tamaño de letra mediano.                                        Ej. Títulos de formularios, títulos de tablas, etc.*/
  --font-size-title: 1.8em;
  /*Tamaño de los títulos.                                          Ej. Breadcrumb*/
  --font-weight-Semibold: 600;
  --font-weight-Medium: 500;
  --font-weight-Regular: 400;

  --height-container: 55vh;
  /*Para manejar el tamaño de los contenedores de información.      Ej. Tablas, contenedores de paneles/cartas*/
  --height-pnl: 8.2em;

  --shadow-btn-primary: 0px 0px 10px 1px rgba(120, 132, 237, 0.4);
  /*Sombra de los botones principales.      Ej. "Agregar", "Enviar", etc.*/
  --shadow-btn-secondary: 0px 0px 5px 1px rgba(120, 132, 237, 0.45);
  /*Sombra de los botones secundarios.      Ej. "Evidencias", "Buscar", etc.*/
  --shadow-hover: 0 5px 10px rgba(133, 155, 208, 0.3);

  /*Esta sombra se repite con shadow pnl*/
  --shadow-modal: 2px 4px 25px 0px rgba(122, 149, 214, 0.35);

  --shadow-pnl: 2px 2px 4px 0px rgba(133, 155, 208, 0.25);
  /*Sombra de los paneles dentro de un contenedor.    Ej. Registros médicos, Permisos área de la empresa, etc.*/
  --shadow-pnl-container: 5px 5px 4px 0px rgba(140, 158, 200, 0.35);
  /*Sombra del contenedor que muestra los paneles.    Ej. Capacitaciones, Permisos, Regulaciones, etc.*/
  --shadow-search-container: 4px 4px 3px 0px rgba(140, 158, 200, 0.25);
  /*Sombra de contenedor de búsqueda                Ej. Regulaciones, Áreas, etc.*/

  --space-elements: 20px;
  /*Controlar padding de los elementos (Útil al heredar)*/
  --transition-base: transform 0.3s ease, box-shadow 0.3s ease;
  --width-container: 90%;
  /*Tamaño del contenedor de todo el contenido    Ej. Clases: ["card-container", "headerContent"]*/
  --width-modal: clamp(400px, 90%, 850px);
  /*Ancho del modal*/
}

/*
  ESTRUCTURA <HTML> DE CONTENIDO - Interfaces principales
  ------------------------------------------------------------
  content 
    headerContent 
      breadcrumb 
      /breadcrumb 
      headerContentButtons 
      /headerContentButtons 
    /headerContent 
    cardContainer 
      pnlContainer 
        PANELS
      /pnlContainer
    /cardContainer 
  /content 
  ------------------------------------------------------------
*/
.content {
  height: 100%;
  box-sizing: border-box;
  overflow-y: auto;
  overflow-x: hidden;
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--content-gap);
  padding: 20px;
}

i {
  pointer-events: none;
  user-select: none;
}

.bodyContainer {
  display: flex;
  width: 100%;
  height: 100dvh;
}

.headerContent {
  width: var(--width-container);
  display: flex;
  flex-direction: column;
}

.breadcrumb {
  padding: 1em 0em;
  font-size: var(--font-size-title);
  font-weight: var(--font-weight-Semibold);
  max-width: 100%;
  overflow-wrap: break-word;
}

.breadcrumb a {
  font-size: var(--font-size-title);
  text-decoration: none;
  color: var(--color-breadcrumb);
  white-space: normal;
  word-break: break-word;
}

h2,
ul,
li {
  margin: 0;
  padding: 0;
}

.breadcrumb>ul {
  display: inline-flex;
  font-size: initial;
  list-style: none;
  flex-wrap: wrap;
}

.breadcrumb ul>li a[href] {
  display: flex;
  align-items: center;
  text-decoration: none;
  position: relative;
  color: gray;
}

.headerContentButtons {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 4rem 0 1rem 0;
}

.topHeader {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.icons {
  display: flex;
  /* Muestra los íconos en línea horizontal */
  gap: 2em;
  align-items: center;
}

.optionsBtn {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  width: auto;
  height: 100%;
  background: none;
  border: none;
  padding: 0;
  cursor: pointer;
}

.optionsBtn i {
  font-size: 1.9em;
  color: #6582ff;
  display: flex;
  align-items: center;
  justify-content: flex-start;
}

.optionsMenu {
  position: fixed;
  background: #fff;
  border: 1px solid #eee;
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.12);
  border-radius: 8px;
  z-index: 30;
  min-width: 140px;
  display: flex;
  flex-direction: column;
  padding: 0.5em 0;
}

.optionsMenu.hide {
  display: none;
}

.option {
  background: none;
  border: none;
  padding: 10px 18px;
  text-align: left;
  cursor: pointer;
  font-size: 1em;
  color: #5d68ff;
  display: flex;
  align-items: center;
  gap: 10px;
}

.option:hover {
  background: #F3F0FF;
}


.icons img {
  width: 100%;
  height: 100%;
}

.cardContainer {
  position: relative;
  display: flex;
  align-items: center;
  width: var(--width-container);
}

.pnlContainer {
  width: 100%;
  border-radius: var(--border-radius);
  box-sizing: border-box;
  padding: 20px;
  --color-bg-tb: rgba(254, 254, 255, 0.35);
  background-color: var(--color-bg-tb);
  box-shadow: var(--shadow-pnl-container);
  height: var(--height-container);
  overflow: auto;
  /*Crear scroll dentro de panel*/
  scrollbar-width: none;
  /*Ocultar scrollbar interna del contenedor: Firefox */
  -ms-overflow-style: none;
  /*Ocultar scrollbar interna del contenedor: Explorer */
}

/*Ocultar scrollbar interna del contenedor:  Chrome, Safari y Edge */
.pnlContainer::-webkit-scrollbar {
  display: none;
}

/*Sombra que se muestra para que el usuario sepa que hay varios por ejemplo (Solo aplicable en interfaces con paneles, tablas NO)*/
.bottomShadow {
  width: 100%;
  height: 10%;
  position: absolute;
  bottom: 0;
  pointer-events: none;
  right: 0;
  left: 0;
  z-index: 25;
  border-radius: var(--border-radius);
  background: linear-gradient(to top, #dcddee, transparent);
}

/* Scroll personalizado */
::-webkit-scrollbar {
  width: 8px;
  border-radius: var(--border-radius);
}

/* Camino */
::-webkit-scrollbar-track {
  border-radius: var(--border-radius);
  background: linear-gradient(rgb(187, 193, 247), rgb(224, 226, 251));
}

/* Indicador */
::-webkit-scrollbar-thumb {
  background: var(--color-breadcrumb);
  border-radius: var(--border-radius);
}

/*
  -------------------------------------------------------------------------------------------------------------------------------
  Elementos reutilizables 

  Contiene estilos para: Labels, Dropdowns, textbox y textareas
*/
a {
  text-decoration: none;
}

.lbl {
  font-size: var(--font-size-base);
  color: var(--color-txt-title);
  font-weight: var(--font-weight-Semibold);
  text-overflow: ellipsis;
  overflow: hidden;
  white-space: nowrap;
}

/*Combobox - Select*/
.dropdown {
  width: 100%;
  --border-radius: 5px;
  border-radius: var(--border-radius);
  height: 3em;
  font-family: "Poppins", sans-serif;
  padding-left: 0.4em;
}

/*Textareas*/
.txtTextarea {
  height: 100%;
  font-family: "Poppins", sans-serif;
}

.txtTextbox,
.txtTextarea {
  /* Valor de la variable por defecto: 1px solid #7B96C7*/
  resize: none;
  border-radius: 5px;
  box-sizing: border-box;
  width: 100%;
  padding: 10px;
  font-size: var(--font-size-base);
  color: var(--color-txt-title);
  font-weight: var(--font-weight-Regular);
}

/*
-------------------------------------------------------------------------------------------------------------------------
  Todos los botones

  Propiedades generales
*/
.btnPrimary,
.btnDetalles,
.btnNotifications,
/*BtnDetalles es temporal hasta eliminar dependencias*/
.btnCloseAdd,
.btnClose,
.btnAdd,
.btnResponsive {
  user-select: none;
  cursor: pointer;
  transition: var(--transition-base);
  font-size: var(--font-size-base);
}

.btnPrimary,
.btnDetalles,
.btnNotifications {
  border-radius: var(--border-radius);
}

.btnPrimary {
  /*Se debe agregar el tamaño por cada vez que se utilice*/
  background: var(--color-btn-primary);
  border: 0;
  box-shadow: var(--shadow-btn-primary);
  color: var(--color-btn-text);
  font-weight: var(--font-weight-Medium);
}

.btnPrimary:hover {
  --color-btn-primary: #6876f2;
  background: var(--color-btn-primary);
  box-shadow: var(--shadow-btn-primary);
}

.btnDetalles {
  background-color: var(--color-neutral);
  border: 2px solid var(--color-breadcrumb);
  box-shadow: var(--shadow-btn-secondary);
  color: var(--color-breadcrumb);
  height: 3.5em;
}

/*
  Botón filtro - Filtrar datos mostrados dentro de una interfaz
*/
.btnFilter {
  display: none;
  scale: 1.6;
  border: none;
  background-color: transparent;
  user-select: none;
  cursor: pointer;
  transition: var(--transition-base);
}

.btnFilter img {
  width: 100%;
  height: 100%;
}

.btnFilter:hover,
.btnPrimary:hover {
  transform: translateY(-2px);
}

.btnNotifications,
.btnCloseAdd,
.btnClose,
.btnResponsive {
  border: none;
  background-color: transparent;
}

.btnCloseAdd,
.btnClose {
  position: absolute;
  margin: 20px;
  right: 0;
}

.btnClose .bx {
  font-size: 2rem;
  color: #81859E;
}

.btnFilter .bx {
  font-size: 1.4rem;
  color: #81859E;
}

.btnCloseAdd {
  top: 3px;
}

/* Botón X - Cerrar modal */
.btnClose {
  top: 0;
}

/* btnAdd y btnResponsive sirven para cambiar el boton para abrir un modal de varios apartados dependiendo el ancho de la pagina*/
.btnAdd {
  height: 3.5em;
  width: 12em
}

.btnResponsive {
  display: none;
}

/*
-------------------------------------------------------------------------------------------------------------------------

  Búsqueda - Contenedor 
*/
.searchContainer {
  display: flex;
  position: relative;
  align-items: stretch;
  gap: 10px;
  width: 50%;
  min-width: 550px;
  padding: var(--space-elements);
  /*Al modificar el padding se hace como si no existiera, útil para tablas como Empleados*/
  box-sizing: border-box;
  background-color: var(--color-search);
  border-radius: var(--border-radius);
  box-shadow: var(--shadow-search-container);
}

/*
  Input - Barra de búsqueda
*/
.txtSearch {
  background-image: url('../media/globalMedia/searchbar-icon.svg');
  background-position: 12px center;
  background-repeat: no-repeat;
  padding: 12px;
  border-radius: 5px;
  border: solid 1px #7B96C7;
  flex: 5;
  padding-left: 45px;
  font-size: var(--font-size-base);
  color: var(--color-txt);
}

.txtSearch:focus {
  border: 1px solid #343968;
  font-size: var(--font-size-base);
  color: var(--color-txt);
  outline: none;
  border: 1px solid var(--color-txt);
}

/*
  -------------------------------------------------------------------------------------------------------------------------------
  Paneles comunes - Mostrar información en lugar de una tabla
*/
.informationPnl {
  display: flex;
  align-items: center;
  /*Centra los elementos, Evitando que la img y la flecha se vayan hacia arriba*/
  font-weight: var(--font-weight-Medium);
  --font-size-base: 1.2em;
  font-size: var(--font-size-base);
  padding: 1em 1.2em;
  border-radius: var(--border-radius);
  box-shadow: var(--shadow-pnl);
  margin-bottom: 0.7em;
  /*Distancia entre un panel a otro*/
  background-color: var(--color-neutral);
  transition: var(--transition-base);
  /*Animación de regreso una vez termine hover*/
  height: var(--height-pnl);
}

.informationPnl:hover {
  transform: translateY(-4px);
  /*Levanta un poco */
  box-shadow: var(--shadow-hover);
  /*Sombra más fuerte */
}

.arrow {
  margin-left: auto;
  margin-right: 0.4em;
}

/*
  Íconos para acciones - Boxicons
  Se usa para acciones de editar, eliminar, ver, etc.
*/
.actions {
  margin-left: auto;
  display: flex;
  gap: 12px;
  align-items: center;
}

.btnIcon {
  background: none;
  border: none;
  cursor: pointer;
  padding: 6px;
  border-radius: 50%;
  color: #7884ed;
  font-size: 1.4em;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.2s;
}

.btnIcon:hover {
  background: #f2f6fe;
}

.btnDelete {
  color: var(--color-danger);
}

/*
  Modal -------------------------------------------------------------------------------------------------------------------------

  Modal - Contenedor (Sombra del contenedor)
*/
.containerModal {
  z-index: 100;
  display: flex;
  /*Valor por defecto: block*/
  position: absolute;
  justify-content: center;
  align-items: center;
  width: 100dvw;
  height: 100dvh;
  background-color: var(--color-modal-container);
}

/*
  Form - Modal
*/
.modalAdd {
  position: relative;
  display: flex;
  border-radius: var(--border-radius);
  padding: 45px 70px;
  /*flex-direction lo debe agregar c/u, Sino da problemas*/
  background: #F2F9FE;
  background: linear-gradient(316deg,rgba(253, 253, 253, 1) 0%, rgba(245, 252, 252, 0.95) 100%);
  box-shadow: var(--shadow-modal);
}

/*acciones de modales*/
.showModal {
  display: flex !important;
}

/*anteriormente hideModal*/
.hide {
  display: none !important;
}

/* Inputs - Contenedor para modal*/
.formField {
  display: flex;
  flex-direction: column;
  gap: 15px;
  margin-bottom: 15px;
}

/*
  Fotografía del empleado desplegada - Usada en Registros médicos, dashboard, config, empleados, etc.
*/
/*Imagen del modal*/
.employeePicture {
  height: 320px;
  width: 320px;
  border-radius: 20%;
  /*En caso de empleados debe cambiarse el border radius*/
  object-fit: cover;
  border: var(--color-img-border);
}

/*
  Modal de empleados 

  -Incluye btn de filtro, checkbox, etc.

  Propiedades generales del modal
*/
.modalEmployees,
.headerModalEmployees,
.headerModalEmployees>div,
.employee>div {
  display: flex;
  align-items: center;

}

.modalEmployees {
  flex-direction: column;
  position: relative;
  z-index: 50;
  border-radius: var(--border-radius);
  padding: 35px;
  gap: 15px;
  background-color: #F2F9FE;
  width: clamp(200px, 90%, 950px);
  box-sizing: border-box;
}

.headerModalEmployees {
  justify-content: space-between;
  width: 100%;
  padding: 15px 20px 0 0;
  color: var(--color-txt);
  box-sizing: border-box;
}

.containerFilterEmployees {
  position: relative;
  display: flex;
  margin: 30px;
  height: 40px;
  width: 80%;
}

.containerEmployeeImage {
  padding: 5px;
  height: 55px;
  width: 55px;
}

#txtSearchEmployees {
  flex: 1;
  font-size: 1em;
  padding: 5px;
  box-sizing: border-box;
  border-radius: 5px;
  border: solid 1px #6873BA;
  box-shadow: 0 0 2px #6873BA;
}

.headerModalEmployees h4 {
  font-size: 1.6em;
  font-weight: var(--font-weight-Semibold);
}

.headerModalEmployees>div {
  gap: 15px;
  font-size: 1em;
  font-weight: var(--font-weight-Medium);
}

.bodyModalEmployees {
  width: 100%;
  height: clamp(150px, 30vh, 300px);
  display: flex;
  flex-direction: column;
  gap: 10px;
  overflow-y: auto;
  overflow-x: hidden;
}

.modalEmployees {
  padding: 25px !important;
  background-color: #fff !important;
  max-height: 90%;
  overflow-y: auto;
  overflow-x: hidden;
}

.employeesSelectedContent {
  min-width: 0;
  max-height: 100%;
  border: solid 1px #E1E8F8;
  border-radius: 20px;
  padding: 20px;
  display: flex;
  flex-direction: column;
  box-sizing: border-box;
  background-color: var(--color-neutral);
  gap: 10px;
  transition: .5s;
  flex: 5;
}

.containerSearchModalE {
  width: 100%;
}

.headerModalEmployees>div {
  margin-right: 20px;
}

.mainContentModalE {
  flex: 1;
  position: relative;
  max-height: 450px;
  width: 100%;
  display: flex;
  gap: 10px;
}

.bodyModalEmployees,
.containerSelectedEmployees,
.modalEmployees {
  scrollbar-width: none;
}

.bodyModalEmployees::-webkit-scrollbar,
.containerSearchEmployees::-webkit-scrollbar,
.modalEmployees::-webkit-scrollbar {
  display: none;
}

.containerSelectedEmployees {
  overflow-y: scroll;
  overflow-x: hidden;
  display: flex;
  gap: 10px;
  flex: 1;
  flex-direction: column;
}

.newEmployeesContent {
  max-height: 450px;
  min-width: 0;
  display: flex;
  justify-content: space-between;
  flex: 10;
  flex-direction: column;
  gap: 10px;
}

.containerNameSelected {
  display: flex;
  flex: 1;
  overflow: hidden;
  align-items: center;
  gap: 5px;
}

.selectedEmployee {
  display: flex;
  align-items: center;
  box-sizing: border-box;
  width: 100%;
  background-color: #F2F3F9;
  padding: 5px 10px;
  border-radius: 20px;
}

.deleteSelectedEmployees {
  background-color: transparent;
  border: none;
  color: var(--color-danger);
}

.selectedEmployee .checks:checked::before {
  font-size: 1em;
}

.selectedEmployee .containerEmployeeImage {
  color: var(--color-txt);
  max-width: 35px;
  max-height: 35px;
}

.selectedEmployee .chEmployee {
  height: 18px;
  width: 18px;
}

.titleSelectedEm {
  font-weight: var(--font-weight-Medium);
  color: var(--color-txt-title);
  margin: 0;
}

.containerChkAll {
  display: flex;
  align-items: center;
  gap: 5px;
}

.containerChkAll .checks {
  width: 18px !important;
  height: 18px !important;
}

.headerModalEmployees {
  border-radius: 20px;
}

.modalEmployees .btnClose {
  margin: 10px;
}

.containerFilterEmployees {
  margin: 0 !important;
  gap: 15px;
  height: fit-content !important;
  width: 100% !important;
  align-items: center;
}

.containerFilterEmployees .btnPrimary,
.headerSelectedContent .btnPrimary {
  display: none;
  padding: 10px 20px !important;
  font-size: 1em;
  width: auto;
  height: auto;
}

#txtSearchEmployee {
  background-color: #F7F8FF !important;
  border: solid 1px #E1E8F8 !important;
  padding: 10px;
}

#txtSearchEmployee::placeholder {
  color: #bebebe;
  font-weight: var(--font-weight-Regular);
}

.containerCmbs {
  background-color: var(--color-neutral);
  box-sizing: border-box;
  display: flex;
  width: 500px;
  transition: .5s;
  gap: 10px;
}

.containerCmbs>div {
  display: flex;
  width: 100%;
  gap: 10px;
}

.containerFilterEmployees .containerInputUpdateTraining {
  flex: 1 1 300px;
  display: flex;
  gap: 5px;
  flex-direction: column;
  max-width: 215px;
}

.containerFilterEmployees .txtTextbox {
  padding: 5px;
}

.containerEmployeeName>div {
  min-width: 0;
  width: 100%;
}

.containerFilterEmployees .lbl {
  font-size: 1em !important;
  overflow: visible;
  color: var(--color-txt-title);
}

.bodyModalEmployees {
  border-radius: 20px;
  border: solid 1px #E1E8F8 !important;
  height: clamp(150px, 100%, 300px) !important;
}

.containerDtName .employeeName {
  width: 100%;
  min-width: 0px;
  text-overflow: ellipsis;
  overflow: hidden;
  white-space: nowrap;
  color: var(--color-txt-title);
}

.footerEmployee {
  display: flex;
  gap: 5px;
}

.dataEmp {
  font-weight: var(--font-weight-Regular);
  font-size: .9em;
}

.containerDtName {
  min-width: 0;
  width: 100%;
  display: flex;
  gap: 10px;
  align-items: center;
}

.committeEmployee {
  border-radius: 20px;
  border: solid 1px var(--color-breadcrumb);
  padding: 5px 10px;
  box-sizing: border-box;
  color: var(--color-breadcrumb);
  font-size: .8em;
  cursor: default;
  transition: .4s;
}

.committeEmployee:hover {
  background-color: var(--color-breadcrumb);
  color: var(--color-neutral);
}

.openSelectedEmployees {
  right: 0 !important;
}

@media screen and (max-width: 910px) {
  .mainContentModalE {
    flex-direction: column;
  }

  .modalEmployees {
    gap: 30px !important;
  }

  .headerSelectedContent {
    display: flex;
  }

  .containerSelectedEmployees {
    max-height: fit-content;
  }

  .containerFilterEmployees,
  .headerSelectedContent {
    justify-content: space-between;
  }

  .containerFilterEmployees .btnSelectedEmployees,
  .headerSelectedContent .btnSelectedEmployees {
    display: block;
  }

  .employeesSelectedContent {
    box-shadow: 0 10px 20px #8C9EC855;
    border-radius: 0;
    position: absolute;
    width: 100%;
    top: 0;
    bottom: 0;
    right: -110%;
  }
}

@media screen and (max-width: 530px) {
  .headerModalEmployees {
    flex-direction: column;
    gap: 10px;
    align-items: start !important;
  }

  .containerFilterEmployees .btnFilterModalEmp,
  .headerSelectedContent .btnFilterModalEmp {
    display: block;
  }

  .containerCmbs {
    box-shadow: 0 10px 20px #8C9EC855;
    position: absolute;
    z-index: 200;
    padding: 10px;
    border-radius: 20px;
    right: -110%;
  }

  .newEmployeesContent {
    justify-content: start;
  }

  .bodyModalEmployees {
    flex: 1;
  }

  .headerModalEmployees>div {
    flex-direction: row-reverse;
    width: 100%;
    justify-content: space-between;
  }

  .btnSelectedEmployees {
    align-self: end;
  }

  .containerFilterEmployees {
    justify-content: end;
  }

  .containerCmbs {
    flex-direction: column;
    width: 100%;
  }

  .containerCmbs .containerInputUpdateTraining {
    max-width: 100%;
  }

  .containerCmbs>div {
    flex-wrap: wrap;
  }
}

@media screen and (max-width: 460px) {
  .footerEmployee {
    flex-direction: column;
    gap: 0;
  }

  .separatorDtEmployee {
    display: none;
  }

  .containerFilterEmployees,
  .containerSearchModalE {
    padding: 0 10px;
    box-sizing: border-box;
  }

  .headerModalEmployees {
    padding: 15px 20px 0 10px !important;
  }

  .containerModal .modalEmployees {
    padding: 30px 0 !important;
  }

  .committeEmployee {
    font-size: .5em;
  }

  .employeeName {
    font-size: .8em;
  }

  .footerModal .pagination {
    margin-left: 10px !important;
    gap: 2px;
  }

  .pagination span {
    font-size: 1em;
  }
}

/* ====== Ficha de Empleado ====== */
.employee {
  display: flex;
  align-items: center;
  font-weight: var(--font-weight-Medium);
  font-size: var(--font-size-base);
  color: var(--color-txt);
  gap: 15px;
  padding: 3px;
  height: 25%;
  padding: 15px;
  height: 100px;
  box-sizing: border-box;
}

.checks {
  appearance: none;
  height: 25px;
  width: 25px;
  border-radius: 3px;
  position: relative;
  display: grid;
  place-items: center;
  transition: 1s;
}

.headerModalEmployees * {
  margin: 0;
}

.employeeDui {
  font-size: .9em;
  color: var(--color-txt-title);
}

.modalEmployees .pagination {
  width: fit-content !important;
  margin-left: 25px;
}

#next,
#prev {
  color: var(--color-txt-title);
  border: none;
}

.footerModal {
  width: 100%;
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.employeeImage {
  border-radius: 50%;
  object-fit: cover;
}

/* ====== Checkbox Personalizados ====== */
.chEmployee {
  border: solid 1px #5666FF;
  border-radius: 50%;
  transform: scale(1.4);
}

.chEmployee:checked {
  background-color: #5666FF;
  transition: .6s;
}

/*
  -------------------------------------------------------------------------------------------------------------------------
  Tabla 
*/
.tableContainer {
  --color-neutral: #ffffffc7;
  box-sizing: border-box;
  background-color: var(--color-neutral);
  box-shadow: 0px 4px 12px rgba(95, 104, 182, 0.15);
  width: var(--width-container);
  min-height: var(--height-container);
  border-radius: var(--border-radius);
  padding: 0 1.5em;
  overflow: hidden auto;
  /*Combina overflow-x: hidden con overflow-y: auto*/
}

table {
  width: 100%;
  min-width: 150px;
  border-collapse: collapse;
  font-size: var(--font-size-base);
  color: var(--color-txt-title);
  margin-top: 0.2em;
}

thead {
  font-weight: var(--font-weight-Semibold);
  color: var(--color-txt-title);
  border-bottom: 2px solid #94ACDA;
}

th,
td {
  text-align: left;
  /* Alineación a la izquierda para celdas*/
  padding: 1.2em;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

td img {
  cursor: pointer;
  width: 1em;
  margin-left: 0.3em;
}

tbody tr:hover {
  box-shadow: var(--shadow-hover);
}

/*Pestaña de filtros*/
.tabFilter {
  background-color: var(--color-neutral);
  position: absolute;
  border-radius: 10px;
  z-index: 60;
  width: 300px;
  height: 280px;
  padding: 20px;
  justify-content: center;
}

.tabFilter>form,
.containerSelectFilter,
.tabFilter {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.tabFilter::before {
  content: '';
  background-color: var(--color-neutral);
  display: var(--display);
  position: absolute;
  clip-path: polygon(85% 6%, 93% 6%, 97% 8%, 100% 12%, 100% 19%, 100% 100%, 0 100%, 31% 63%, 72% 16%, 78% 10%);
  width: 30px;
  height: 30px;
  top: -20px;
  right: 0;
}

.tbFilterTitle {
  font-size: 1em;
  color: var(--color-txt-title);
}

.tabFilter input[type="submit"] {
  align-self: end;
  width: 60%;
  height: 2.5em;
  box-shadow: none;
  margin-top: 10px;
}

.containerSelectFilter {
  color: var(--color-txt);
  font-weight: var(--font-weight-Medium);
}

.btnDisabled {
  opacity: .5;
  background: var(--color-btn-primary);
  border: 0;
  box-shadow: var(--shadow-btn-primary);
  color: var(--color-btn-text);
  font-weight: var(--font-weight-Medium);
  height: 3em;
  width: 15em;
  border-radius: 5px;
  font-size: var(--font-size-base);
}

/*Paginacion*/

.pagination {
  width: var(--width-container);
  display: flex;
  gap: 8px;
  align-items: center;
  justify-content: end;
}

.numberPagination {
  padding: 5px 10px;
  display: grid;
  place-content: center;
  box-sizing: border-box;
  width: 30px;
  border-radius: 6px;
  font-size: var(--font-size-base);
  color: var(--color-txt-title);
  font-weight: var(--font-weight-Semibold);
}

.pagination button {
  border: 1px solid #5c6eff;
  background: none;
  color: #5c6eff;
  font-size: 16px;
  font-weight: 600;
  padding: 5px 10px;
  border-radius: 6px;
  cursor: pointer;
  transition: background 0.3s;
}


.pagination button:hover {
  background: rgba(92, 110, 255, 0.1);
}

.pagination button:disabled {
  opacity: 0.4;
  cursor: not-allowed;
}

@media screen and (max-width: 920px) {

  .btnAdd,
  .btnSearch {
    display: none;
  }

  .btnResponsive {
    display: var(--display);
  }

  .headerContent,
  .cardContainer,
  .txtSearch,
  .tableContainer,
  .searchContainer {
    width: 100%;
  }

  .topHeader {
    flex-direction: column-reverse;
    align-items: start !important;
  }

  .breadcrumb {
    padding: 0 10px;
  }

  .icons {
    align-self: end;
  }

  .btnNotifications {
    width: 25px;
  }

  .profile {
    height: 50px;
    width: 50px;
  }

  .headerContentButtons {
    gap: 20px;
  }

  .searchContainer {
    background-color: transparent;
    box-shadow: none;
    min-width: 0;
    padding: 0;
  }

  .btnFilter {
    position: absolute;
    right: 10px;
    top: 1px;
    height: 40px;
  }

  .informationPnl {
    height: 4em;
    padding: 12px;
  }
}

/* =========================
   ANIMACIONES MODAL
   ========================= */

@keyframes zoomIn {
  from {
    opacity: 0;
    transform: scale(0.7);
  }

  to {
    opacity: 1;
    transform: scale(1);
  }
}

@keyframes zoomOut {
  from {
    opacity: 1;
    transform: scale(1);
  }

  to {
    opacity: 0;
    transform: scale(0.7);
  }
}

@-webkit-keyframes fadeIn {
  from {
    opacity: 0
  }

  to {
    opacity: 1
  }
}

@keyframes fadeIn {
  from {
    opacity: 0
  }

  to {
    opacity: 1
  }
}

input,
textarea,
select {
  border: 1.5px solid var(--border);
}

input:focus,
textarea:focus,
select:focus {
  box-shadow: 0 0 0 4px rgba(59, 78, 255, 0.26);
}

.btnResponsive .bx {
  font-size: 2rem;
  color: #fff;
  background-color: #7884ED;
  border-radius: 50%;
  padding: 0.4rem;
}


/* Normaliza el peso en estos controles (sin cambiar tamaño) */
select,
input[type="date"],
input[type="time"] {
  font-family: var(--app-font-family);
  font-weight: var(--app-font-weight-controls);
  font-size: inherit;
  color: var(--color-txt-title, #374151);
  -webkit-font-smoothing: antialiased;
  /* ayuda en WebKit/Chromium */
  -moz-osx-font-smoothing: grayscale;
  /* ayuda en macOS */
  text-rendering: optimizeLegibility;
  font-variant-numeric: tabular-nums;
  /* números más claros en hh:mm y fechas */
}

/* Si tienes esta regla, la “rompe” para inputs de control */
.containerInputAddTraining label+ :is(select, input[type="date"], input[type="time"]) {
  font-weight: var(--app-font-weight-controls);
}

/* Sub-partes internas (Chromium/WebKit) para que también bajen el peso */
input[type="date"]::-webkit-datetime-edit,
input[type="date"]::-webkit-datetime-edit-fields-wrapper,
input[type="date"]::-webkit-datetime-edit-text,
input[type="date"]::-webkit-datetime-edit-month-field,
input[type="date"]::-webkit-datetime-edit-day-field,
input[type="date"]::-webkit-datetime-edit-year-field,
input[type="time"]::-webkit-datetime-edit,
input[type="time"]::-webkit-datetime-edit-fields-wrapper,
input[type="time"]::-webkit-datetime-edit-hour-field,
input[type="time"]::-webkit-datetime-edit-minute-field,
input[type="time"]::-webkit-datetime-edit-second-field,
input[type="time"]::-webkit-datetime-edit-ampm-field {
  font-weight: inherit;
  font-size: inherit;
}


/* === Controles de selección y fecha/hora (ya lo tenías) === */
select,
input[type="date"],
input[type="time"] {
  font-family: var(--app-font-family);
  font-weight: var(--app-font-weight-controls);
  font-size: inherit;
  color: var(--color-txt-title, #374151);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
  font-variant-numeric: tabular-nums;
}

/* Sub-partes internas WebKit (fecha/hora) */
input[type="date"]::-webkit-datetime-edit,
input[type="date"]::-webkit-datetime-edit-fields-wrapper,
input[type="date"]::-webkit-datetime-edit-text,
input[type="date"]::-webkit-datetime-edit-month-field,
input[type="date"]::-webkit-datetime-edit-day-field,
input[type="date"]::-webkit-datetime-edit-year-field,
input[type="time"]::-webkit-datetime-edit,
input[type="time"]::-webkit-datetime-edit-fields-wrapper,
input[type="time"]::-webkit-datetime-edit-hour-field,
input[type="time"]::-webkit-datetime-edit-minute-field,
input[type="time"]::-webkit-datetime-edit-second-field,
input[type="time"]::-webkit-datetime-edit-ampm-field {
  font-weight: inherit;
  font-size: inherit;
}

/* === NUEVO: inputs de texto y textareas con el mismo look === */
:where(input[type="text"],
  input[type="email"],
  input[type="password"],
  input[type="search"],
  input[type="tel"],
  input[type="url"],
  input[type="number"],
  input[type="datetime-local"],
  input[type="month"],
  input[type="week"],
  textarea) {
  font-family: var(--app-font-family);
  font-weight: var(--app-font-weight-controls);
  font-size: inherit;
  color: var(--color-txt-title, #374151);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}

/* Placeholders más ligeros (sin tocar tamaño) */
:where(input[type="text"],
  input[type="email"],
  input[type="password"],
  input[type="search"],
  input[type="tel"],
  input[type="url"],
  input[type="number"],
  input[type="datetime-local"],
  input[type="month"],
  input[type="week"],
  textarea)::placeholder {
  color: color-mix(in srgb, var(--color-txt-title, #5E6489) 55%, white);
  font-weight: 400;
  /* evita verse “negrita” */
}

/* Rompe la regla que sube peso al hermano después del label en tus formularios */
.containerInputAddTraining label+ :is(select,
  input[type="date"],
  input[type="time"],
  input[type="text"],
  input[type="email"],
  input[type="password"],
  input[type="search"],
  input[type="tel"],
  input[type="url"],
  input[type="number"],
  input[type="datetime-local"],
  input[type="month"],
  input[type="week"],
  textarea) {
  font-weight: var(--app-font-weight-controls);
}

/* ==== Loader global ==== */
.app-loader {
  position: fixed;
  inset: 0;
  display: grid;
  place-items: center;
  background: rgba(255, 255, 255, .55);
  backdrop-filter: blur(2px);
  z-index: 9999;
  opacity: 0;
  pointer-events: none;
  transition: opacity .22s ease;
}

.app-loader.is-visible {
  opacity: 1;
  pointer-events: auto;
}

.app-loader__card {
  background: #fff;
  border: 1px solid rgba(0, 0, 0, .06);
  box-shadow: 0 8px 24px rgba(0, 0, 0, .10);
  border-radius: 14px;
  padding: 18px 20px;
  display: flex;
  gap: 12px;
  align-items: center;
}

.app-loader__text {
  font-weight: 600;
  color: #3d3d6b;
}

/* Spinner */
.app-loader__spinner {
  --c: var(--color-primary, #616FEF);
  width: 28px;
  height: 28px;
  border-radius: 50%;
  border: 3px solid transparent;
  border-top-color: var(--c);
  border-right-color: var(--c);
  animation: appspin .8s linear infinite;
}

@keyframes appspin {
  to {
    transform: rotate(360deg);
  }
}

/* (opcional) modo oscuro suave */
@media (prefers-color-scheme: dark) {
  .app-loader {
    background: rgba(10, 12, 16, .45);
  }

  .app-loader__card {
    background: #12151b;
    color: #e8e8f0;
    border-color: rgba(255, 255, 255, .06);
  }

  .app-loader__text {
    color: #e8e8f0;
  }
}