:root {
  /* Colores primarios */
  --primario: #7C7C97;
  --primario-tono-10: #DCDCE3;
  --primario-tono-30: #ACACBD;
  --primario-tono-80: #54546A;
  --primario-tono-90: #414152;
  --primario-tono-100: #2E2E3A;

  /* Colores secundarios */
  --secundario: #E98C00;
  --secundario-tono-10: #FAE3C0;
  --secundario-tono-30: #F4C680;
  --secundario-tono-80: #D17E00;
  --secundario-tono-100: #B86F00;

  /* Colores neutrales */
  --blanco: #ffffff;
  --neutral-tono-10: #F8F9FA;
  --neutral-tono-20: #E9ECEF;
  --neutral-tono-30: #DEE2E6;
  --neutral-tono-40: #CED4DA;
  --neutral-tono-50: #ADB5BD;
  --neutral-tono-60: #6C757D;
  --neutral-tono-70: #495057;
  --neutral-tono-80: #343A40;
  --neutral-tono-90: #212529;
  --neutral-tono-100: #17171B;
  --negro: #000000;

  /* Otros */
  --feedback-warning: #FFD11C;
  --feedback-warning-bg: #FFF8DA;
  --feedback-error: #FF0000;
  --feedback-error-bg: #FFD6D6;
  --feedback-info: #3CB4FA;
  --feedback-info-bg: #D8F0FE;
  --feedback-success: #2DAB66;
  --feedback-success-bg: #DDF1E6;

  /* Revisar */
  --error: #ba1a1a;
  --neutral: #333333;
  --medium-grey: #707070;
  --vn-tonal-99: #F5F5F5;
  --vn-tonal-95: #e1e5eb;
  --vn-tonal-80: #c2c9bd;
  --vn-tonal-60: #8c9388;
  --vn-tonal-40: #5a6057;
  --vn-tonal-20: #2C322A;
}

/* Tablas */
.table-fiex {
  width: calc(100% - 3rem);
  border-collapse: separate;
  border-spacing: 0;
}

.table-label {
  background-color: var(--primario);
  border-top-left-radius: 15px;
  border-top-right-radius: 15px;
  border: 2px solid var(--primario);
  border-bottom: none;
  color: var(--blanco);
  white-space: nowrap;
  font-size: 15px;
  font-weight: 600;

  & svg {
    width: 10px;
    height: auto;
  }
}

.table-label th {
  background-color: var(--primario);
  color: var(--blanco);
  border-top: 2px solid var(--primario);
}

.table-label th:first-child {
  border-top-left-radius: 15px;
}

.table-label th:last-child {
  border-top-right-radius: 15px;
}

.table-body {
  border-bottom-left-radius: 15px;
  border-bottom-right-radius: 15px;
  border: 2px solid var(--primario);
}

.table-body td:first-child {
  border-left: 2px solid var(--primario);
}

.table-body td:last-child {
  border-right: 2px solid var(--primario);
}

.table-body tr:last-child td {
  border-bottom: 2px solid var(--primario);
}

.table-body tr:last-child td:first-child {
  border-bottom-left-radius: 15px;
}

.table-body tr:last-child td:last-child {
  border-bottom-right-radius: 15px;
}

.table-label th:first-child {
  border-top-left-radius: 15px;
  border-left: 2px solid var(--primario);
}
.table-label th:last-child {
  border-top-right-radius: 15px;
  border-right: 2px solid var(--primario);
}

.table-label th {
  border-top: 2px solid var(--primario);
}

.table-body tr {
  width: fit-content !important;
}

.table-container {
  margin: 0rem;
}

@media (min-width: 640px) {
  .table-container {
    margin: 0rem 1rem;
  }
}

.data-cell:last-of-type button.black-icon svg * {
  width: 28px;
  height: 28px;
  fill: var(--primario-tono-100);
}

.black-icon svg {
  width: 28px;
  height: 28px;
  fill: var(--primario-tono-100);
}

.purple-icon svg {
  width: 28px;
  height: 28px;
  fill: var(--primario-tono-100);
}

.data-cell:last-of-type button.orange-icon svg * {
  width: 28px;
  height: 28px;
  fill: var(--secundario);
}

.data-cell:last-of-type button.orange-icon svg * {
  fill: var(--secundario);
}

.orange-icon-small svg {
  height: 24px;
  width: 24px;
  fill: var(--secundario);
}

.btn-caja {
  border-radius: 15px;
}

.btn-caja:hover {
  background-color: var(--primario-tono-30);
}

.data-cell:has(.selector-parcela) {
  min-width: 280px;
  max-width: 280px;
}

.data-cell .selector-parcela:last-of-type {
  margin-bottom: 0 !important;
}

thead tr:last-of-type th {
  padding-bottom: 0px;
}

.last-row,
.last-row td:first-child {
  border-bottom-left-radius: 15px;
}

.last-row,
.last-row td:last-child {
  border-bottom-right-radius: 15px;
}

tr.data-row #unica {
  border: 2px solid var(--Neutral-40, #CED4DA);
  background: var(--Neutral-20, #E9ECEF);
}

tr.data-row #unica .table-fiex {
  margin-left: 50px;
}

tr.data-row #unica .table-fiex .table-label {
  background-color: var(--primario);
}

tr.data-row #unica .table-fiex tr.data-row:nth-of-type(2) td.data-cell {
  border-top: 1px solid var(--medium-grey);
}

tr.data-row:nth-child(2n),
tr.data-row #unica .table-fiex tr.data-row:nth-child(2n) {
  background: var(--neutral-tono-40);
}

tr.data-row:nth-child(2n + 1),
tr.data-row #unica .table-fiex tr.data-row:nth-child(2n + 1) {
  background: var(--neutral-tono-20);
}

table.tabla-seleccion tr.data-row:hover,
tr.data-row:has(td.data-cell:first-of-type input[type="checkbox"]:checked) {
  background-color: var(--neutral-tono-50) !important;
}

tr.data-row.data-row-cue td.data-cell:first-of-type {
  height: 62px;
}

tr.data-row .data-cell:last-of-type button {
  padding: 10px;
  border-radius: 50%;

  &:hover {
    background-color: rgba(96, 97, 112, 0.16);
  }
}

.rounded-tl-lg {
  border-top-left-radius: 15px !important;
}

.rounded-tr-lg {
  border-top-right-radius: 15px !important;
}

/*Menú*/
.info-user {
  color: var(--blanco);
  height: 100%;
}

.info-user .settings:hover {
  background-color: var(--primario-tono-80);
}

.info-user .settings .dropdown-menu>div>*,
.info-user .settings .dropdown-menu>div>*>a {
  background-color: transparent;
  color: var(--primario-tono-80);
  cursor: pointer;
  border-radius: 0.25rem;
}

.info-user .settings .dropdown-menu>div>*>div>svg>*,
.info-user .settings .dropdown-menu>div>*>a>div>svg>*,
.nav-menu_title .adminIcon>svg>*,
.nav-menu_list_item>svg>*,
.nav-menu_list_item svg *,
.panel_header>button>svg>*,
.btn-nuevo>svg>*,
button.btn-nuevo>svg>*,
form button.form-guardar>svg>*,
button.form-guardar>svg>*,
.form-guardar>svg>*,
form button.form-cancelar>svg>*,
button.form-cancelar>svg>*,
.form-cancelar>svg>* {
  fill: var(--primario);
}

.nav-menu_title .adminIcon>svg>*,
.nav-menu_list_item>svg>*,
.nav-menu_list_item svg *,
.panel_header>button>svg>*,
.btn-nuevo>svg>*,
button.btn-nuevo>svg>*,
form button.form-guardar>svg>*,
button.form-guardar>svg>*,
.form-guardar>svg>*,
form button.form-cancelar>svg>*,
button.form-cancelar>svg>*,
.form-cancelar>svg>* {
  fill: var(--blanco);
}

.info-user .settings .dropdown-menu>div>*:hover,
.info-user .settings .dropdown-menu>div>*:hover>a {
  background-color: var(--primario-tono-30);
  color: var(--primario-tono-80);
}

.info-user .settings .dropdown-menu>div>*:hover>div>svg>*,
.info-user .settings .dropdown-menu>div>*:hover>a>div>svg>*,
.panel_header>svg>*,
.panel_header>svg *,
#unica .data-cell svg *,
.data-cell:last-of-type svg * {
  fill: var(--primario);
}

:not(hgroup).main {
  min-height: 100svh;
}

.admin-dropdown {
  &>div {
    width: 100%;
    text-align: center;
  }

  & .dropdown-menu {
    width: calc(100% + 2rem);
    transform: translateX(-1rem);
    right: unset;
    margin-top: -1px;
    background-color: #FFC46A;
    border-radius: .25rem;
    box-shadow: unset;

    &>div {
      padding: 10px;
      display: flex;
      flex-direction: column;
      gap: 5px;
    }
  }
}

/*Nav-menu*/
.nav-menu {
  background-color: var(--primario-tono-80);
  width: 30%;
  max-width: 265px;
  transition: all 0.5s ease-out;
  position: relative;
  min-height: 100svh;
}

.nav-menu * {
  transition: all 0.5s ease-out;
}

@media (max-width: 640px) {
  .nav-menu {
    display: none;
  }
}

.nav-menu.close .text {
  display: none;
}

.nav-menu.close .nav-menu_list_item:hover .text,
.nav-menu.close .dropdown-menu_item:hover .text {
  display: block;
  white-space: nowrap;
}

.nav-menu_title {
  background-color: var(--secundario-tono-60);
  color: var(--blanco);
  padding: 14px 16px 14px 24px;
  height: 48px;
  gap: 1rem;
  width: 30%;
  max-width: 265px;
  justify-content: space-between;
  position: fixed;
  top: 60px;
  left: 0;
  z-index: 50;
  transition: all 0.5s ease-out;
}

.nav-menu_subtitle {
  color: var(--blanco);
  padding: 14px 16px 14px 24px;
  height: 48px;
  max-width: 265px;
  background-color: var(--primario-tono-100);
  transition: all 0.5s ease-out;
  white-space: nowrap;
  text-overflow: ellipsis;
}

.nav-menu.close .nav-menu_subtitle {
  padding: 14px 0 14px 0;
  text-align: center;
}

.nav-menu.close,
.nav-menu.close .nav-menu_title {
  max-width: 88px;
}

.nav-menu.close .nav-menu_title {
  justify-content: unset;
}

.nav-menu .nav-menu_title .adminIcon {
  display: none;
}

.nav-menu.close .nav-menu_title .adminIcon {
  display: block;
}

.nav-menu_title .toggleArrow {
  cursor: pointer;
  transition: transform 0.5s ease-out;
}

.nav-menu_list {
  margin-top: 60px;
}

.nav-menu_list_item {
  padding: 0.5rem 1rem;
  color: var(--blanco);
  gap: 1rem;
  width: 100%;
  border-radius: 1rem;
}

.nav-menu.close .nav-menu_list_item,
.nav-menu.close .nav-menu_title {
  gap: 0.5rem;
}

.nav-menu_list_item>svg {
  width: 20px;
}

.nav-menu_list_item.active,
.nav-menu_list_item:hover {
  background-color: var(--primario);
}

.nav-menu.close .nav-menu_list_item:hover,
.nav-menu.close .dropdown-menu_item:hover {
  width: 20vw;
  position: relative;
  transition: all 0.5s ease-out;
  z-index: 2;
}

.dropdown-menu {
  color: var(--primario);
  background-color: var(--primario-tono-80);
  transition: all 0.5s ease-out;
}

.nav-menu.close #menu.dropdown-menu {
  position: relative;
  top: 0;
  left: 23px;
  width: 65px;
}

.nav-menu.close #menu.dropdown-menu .text {
  display: none;
}

.nav-menu.close #menu.dropdown-menu>div>a {
  margin-left: 0;
}

.dropdown-menu_item,
.dropdown-2 .nav-menu_list_item {
  background-color: var(--primario);
  color: var(--blanco);
}

.dropdown-menu_item {
  padding: 14px 25px;
}

.dropdown-menu_item>svg,
.dropdown-2 .nav-menu_list_item>svg {
  width: 24px;
}

.dropdown-menu_item>svg>*,
.dropdown-2 .nav-menu_list_item svg>* {
  fill: var(--blanco);
}

.dropdown-menu_item:hover,
.dropdown-menu_item.active,
.dropdown-2 .nav-menu_list_item:hover,
.dropdown-2 .nav-menu_list_item.active {
  background-color: var(--primario-tono-80);
}

.dropdown-menu_item:hover>svg>*,
.dropdown-menu_item.active>svg>*,
.dropdown-2 .nav-menu_list_item:hover>svg>*,
.dropdown-2 .nav-menu_list_item.active>svg>* {
  fill: var(--blanco);
}

.dropdown-2 .dropdown-menu_item {
  padding-left: 32px;
}

.menu-burger {
  fill: var(--blanco);
}

.menu-burger:hover {
  background-color: var(--primario-tono-80);
}

.menu-burger .div svg {
  fill: var(--blanco) !important
}

.icons-menu-burger {
  fill: var(--blanco) !important;
  width: 24px;
  height: 24px;
}

.nav-menu-burger {
  background-color: var(--primario);
}

*,
*::after,
*::before {
  box-sizing: border-box;
}

html {
  background-color: var(--vn-tonal-99);
  font-family: 'Roboto' !important;
}

.bg-login {
  background-color: #2E2E3A;
}

.pointer {
  cursor: pointer;
}

/* Width */
.w-10 {
  width: 10%;
}

.w-50-modal {
  width: 50%;
}

.w-30-modal {
  width: 30%;
}

.w-10 {
  width: 2.5rem;
}

.w-70 {
  width: 70%;
}

.min-w-210 {
  min-width: 210px;
}

.w-1\/8 {
  width: calc(100% / 8);
}

.w-2\/8 {
  width: calc(100% / 8 * 2);
}

/* Height */
.h-40px {
  height: 40px;
}

.h-32p {
  height: 32px;

  &>svg {
    width: 18px;
    height: 18px;
  }
}

.h-30 {
  height: 30px;
}

/* Tipografía */
.font-sans {
  background-color: var(--vn-tonal-99);
  font-family: 'Roboto' !important;
}

h1,
h2,
h3,
h4,
button,
th {
  font-family: 'Montserrat' !important;
}

.only-mobile  { display: inline; }
.only-desktop { display: none; }

@media (min-width: 640px) {
  .only-mobile  { display: none; }
  .only-desktop { display: inline; }
}

.header-title {
  font-family: 'Montserrat' !important;
  font-size: 20px;
  font-style: normal;
  font-weight: 600;
  line-height: 46px;
}

.text-menu {
  font-family: 'Montserrat' !important;
  font-size: 16px;
  font-style: normal;
  font-weight: 500;
  line-height: normal;
}

.text-menu-bootom {
  font-family: 'Montserrat' !important;
  font-size: 12px;
  font-style: normal;
  font-weight: 500;
  line-height: normal;
}

.body20-bold {
  font-size: 20px;
  font-weight: 600;
  line-height: 24px;
}

.body20-regular {
  font-size: 20px;
  font-weight: 400;
  line-height: 24px;
}

.body15-semibold {
  font-style: normal;
  font-weight: 600 !important;
  font-size: 15px;
  line-height: 20px;
}

.body15-regular {
  font-style: normal;
  font-size: 15px;
  font-weight: 400;
  line-height: 20px;
}

.body14-bold {
  font-size: 14px;
  line-height: 20px;
  font-weight: 700;
}

.body14-semibold {
  font-size: 14px;
  line-height: 20px;
  font-weight: 600;
}

.body10-medium {
  font-size: 10px;
  line-height: 12px;
  font-weight: 500;
}

/* Colores */
.neutral {
  color: var(--neutral);
}

.vn {
  color: var(--vn-tonal-40);
}

.vn-tonal-20 {
  color: var(--vn-tonal-20) !important;
}

.vn>svg>* {
  fill: var(--vn-tonal-40);
}

.bg-success {
  background-color: var(--feedback-success-bg);
  border-radius: 10px;
  /*border: 1pc solid var(--feedback-success);*/
}

.bg-error {
  background-color: var(--feedback-error-bg);
  border-radius: 10px;
  /*border: 1pc solid var(--feedback-error);*/
}

.error-container {
  max-height: 250px;
  overflow-y: auto;
  padding: 1rem 1.25rem; 
  background-color: var(--feedback-error-bg);
  border-radius: 10px;
  color: var(--neutral-tono-90);
  font-family: Roboto;
  font-size: 16px;
  font-style: normal;
  font-weight: 500;
  line-height: normal;
}

.error-container::-webkit-scrollbar {
  width: 8px;
  background: transparent;
}

.tu-contenedor::-webkit-scrollbar-track {
    background: transparent;
}

.error-container::-webkit-scrollbar-thumb {
  background-color: var(--primario);
  border-radius: 4px;
  border: 2px solid transparent;
}

.error-container {
  scrollbar-width: thin;
  scrollbar-color: var(--primario) transparent;
}

.archivo-input {
  color: var(--Primary-80, #54546A);
  font-family: Montserrat;
  font-size: 16px;
  font-style: normal;
  font-weight: 600;
  line-height: normal;
}

.bg-informacion {
  background-color: var(--feedback-info-bg);
  border-radius: 10px;
  /*border: 1pc solid var(--feedback-info);*/
}

.bg-warning {
  background-color: var(--feedback-warning-bg);
  border-radius: 10px;
  /*border: 1pc solid var(--feedback-warning);*/
}

.bg-vn-90 {
  background-color: var(--secundario-tono-10);
}

.bg-oscuro {
  background-color: rgba(51, 51, 51, .62);
}

.bg-primario {
  background-color: var(--primario);
  color: var(--blanco);
}

.bg-primario-tono-60 {
  background-color: var(--primario) !important;

  & svg>* {
    fill: var(--blanco);
  }
}

button.bg-primario-tono-60:hover {
  background-color: var(--primario-tono-80) !important;
}

.primario {
  color: var(--primario);
}

.modal-title {
  color: var(--primario-tono-80);
  font-family: 'Montserrat' !important;
  font-size: 20px;
  font-style: normal;
  font-weight: 600;
  line-height: normal;
}

.modal-title {
  fill: var(--primario-tono-80);
}

.modal-title b {
  font-weight: 800;
}

.modal-title svg {
  width: 24px;
  height: 24px;
  color: var(--primario-tono-80);
}

.modal-text {
  color: var(--primario-tono-80);
  font-family: 'Montserrat' !important;
  font-size: 16px;
  font-style: normal;
  font-weight: 600;
  line-height: normal;
}

/* Líneas y subrayados */
.title-subrayado {
  height: 2px;
  stroke-width: 2px;
  color: var(--primario-tono-80);;
  background-color: var(--primario-tono-80);
  margin-top: 2px;
}

/* Espacios */
.gap-2 {
  gap: .5rem;
}

/* Tooltip */
.has-tooltip {
  position: relative;

  &::after {
    content: attr(data-tooltip);
    visibility: hidden;
    background-color: var(--neutral);
    color: var(--blanco);
    padding: 4px 10px;
    position: absolute;
    z-index: 1000;
    top: 110%;
    left: 50%;
    transform: translateX(-50%);
    border-radius: 4px;
    font-size: 10px;
    font-weight: 500;
    line-height: 12px;
    white-space: nowrap;
  }

  &[tooltip-position="top"]::after {
    top: unset;
    bottom: 130%;
    left: 50%;
    transform: translateX(-50%);
  }

  &:hover::after {
    visibility: visible;
  }
}

/* Tooltip container */
.tooltip-container {
  position: relative;
  display: inline-block;
}

.tooltip-icon {
  width: 18px;
  height: 18px;
  color: #4B5563;
  /* gris oscuro */
  cursor: pointer;
}

.tooltip-text {
  visibility: hidden;
  opacity: 0;
  width: max-content;
  background-color: #111;
  color: var(--blanco);
  text-align: center;
  padding: 6px 8px;
  border-radius: 6px;
  position: absolute;
  z-index: 100;
  bottom: 125%;
  /* lo sitúa arriba del icono */
  left: 50%;
  transform: translateX(-50%);
  transition: opacity 0.3s ease;
  white-space: nowrap;
}

.tooltip-container:hover .tooltip-text {
  visibility: visible;
  opacity: 1;
}

/* Tooltip img */
.tooltip-icon-img {
  display: inline-block;
  width: 1.25rem;
  height: 1.25rem;
  background-color: #1F2937;
  /* gray-800 */
  color: white;
  font-weight: bold;
  border-radius: 9999px;
  text-align: center;
  line-height: 1.25rem;
  font-size: 0.9rem;
  cursor: pointer;
  z-index: 50;
}

.tooltip-dinamico {
  position: absolute;
  background-color: white;
  border: 1px solid #ddd;
  padding: 0.5rem;
  border-radius: 0.5rem;
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.15);
  z-index: 1000;
  max-width: 260px;
  max-height: 220px;
  text-align: center;
}

.tooltip-dinamico img {
  max-width: 100%;
  max-height: 180px;
  object-fit: contain;
  border-radius: 0.25rem;
}

/* Log in page */
button {
  cursor: pointer;
}

input[type="checkbox"]:focus {
  box-shadow: unset;
}

/* Tags */
.tag {
  &.tag-ok {
    background-color: var(--primario);
  }

  &.tag-error {
    background-color: var(--error);
  }

  &.tag-warning {
    background-color: #e89c25;
    color: var(--neutral);
  }
}

/* Header */
.header {
  background-color: var(--primario);
  color: var(--blanco);
  height: 60px;
  position: fixed;
  top: 0;
  left: 0;
}

.header-title {
  font-size: 20px;
  margin-left: 12px;
}


/* Main content */
.main-content {
  flex-grow: 1;
  width: 70%;
}

/* Panel sección */
.panel {
  background-color: var(--blanco);
  overflow-x: hidden;
  margin-top: calc(60px + 60px);
}

.panel-profile {
  background-color: var(--blanco);
  overflow-x: hidden;
  margin-top: calc(60px);
  display: flex;
  align-items: center;
  flex-direction: column;
  justify-content: flex-start;
  padding-top: 2rem;
}

.panel_header {
  padding: 7px 1.5rem;
  height: 60px;
  width: 100%;
}

@media (min-width: 640px) {
  .panel_header {
    padding: 7px 40px;
  }
}

.panel_header:first-of-type {
  position: fixed;
  top: 60px;
  width: 100%;
  z-index: 40;
}

.panel_header {
  background-color: var(--primario-tono-10);
  color: var(--primario-tono-80);
}

.panel_header>svg {
  width: 24px;
}

.panel_header div svg {
  fill: var(--primario);
  width: 24px !important;
  height: 24px !important;
}

.section_header {
  color: var(--primario-tono-80);
}

.section_header>svg {
  width: 24px;
}

.section_header svg {
  color: var(--primario) !important;
  fill: var(--primario) !important;
}

/* Botones */
.btn-nuevo,
form button.form-guardar,
button.form-guardar,
.form-guardar,
a[type="button"].form-guardar,
.modal-btn-cancelar {
  background-color: var(--secundario) !important;
  color: var(--blanco);
  padding: 6px 12px;
  gap: 0.5rem;
  font-weight: 500;
  font-size: 15px;

  &.bloqueado {
    background-color: var(--vn-tonal-80);
  }
}

.btn-cancelar {
  background-color: var(--primario-tono-80) !important;
  color: var(--blanco);
  padding: 6px 12px;
  gap: 0.5rem;
  font-weight: 500;
  font-size: 15px;
}

.btn-cancelar:hover {
  background-color: var(--primario-tono-100) !important;
}

.fila-seleccionada {
  background-color: var(--primario-tono-10) !important;
}

.btn-nuevo svg,
.btn-cancelar svg,
.btn-secundario svg {
  fill: var(--blanco) !important;
  width: 1.25rem;
}

.btn-secundario {
  background-color: var(--neutral-tono-60) !important;
  color: var(--blanco);
  padding: 6px 12px;
  gap: 0.5rem;
  font-weight: 500;
  font-size: 15px;
}

.btn-secundario:hover {
  background-color: var(--neutral-tono-80) !important;
}

.tiempo-total-fichaje {
  background-color: var(--primario-tono-10) !important;
  color: var(--neutral-tono-80);
  padding: 6px 12px;
  gap: 0.5rem;
  font-weight: 500;
  font-size: 15px;
}

.texto-leyenda {
  color: var(--primario-tono-80);
  text-align: center;
  font-family: Montserrat;
  font-size: 20px;
  font-style: normal;
  font-weight: 600;
  line-height: 23px;
}

.btn-nuevo:hover {
  background-color: var(--secundario-tono-80) !important;
}

.btn-nuevo:active {
  background-color: var(--secundario-tono-80);
  color: var(--secundario-tono-30);
}

.btn-nuevo:active>svg>* {
  fill: var(--secundario-tono-30);
}

.btn-subir {
  background-color: var(--primario) !important;
  color: var(--blanco);
  padding: 6px 12px;
  gap: 0.5rem;
  font-weight: 500;
  font-size: 15px;
  border: none;
  border-radius: 20px;
  margin-right: 0.5rem;
  cursor: pointer;
}

.btn-subir:hover {
  background-color: var(--primario-tono-80) !important;
}

.btn-subir:disabled {
  cursor: default;
}

.btn-volver {
  color: var(--primario);
  text-decoration: underline;
  font-size: 15px;
  font-weight: 500;
  gap: .25rem;
}

.btn-volver>svg>path {
  fill: var(--primario);
}

.visible-options {
  background-position: right;
  width: 45px;
  padding: 6px;
}

select.visible-options.form-input,
select.visible-options.form-input:focus,
select.visible-options.form-input:focus-within {
  background-color: unset;
  padding-block: 0;
  background-color: var(--neutral-tono-20);
  border-color: var(--primario-tono-40);
}

form button.form-guardar,
button.form-guardar,
.form-guardar,
a[type="button"].form-guardar {
  background-color: var(--primario) !important;
  border-color: var(--primario);
  color: var(--blanco);
  white-space: nowrap;
  min-width: 105px;

  &.bloqueado {
    background-color: var(--vn-tonal-80) !important;
    border-color: var(--vn-tonal-80) !important;
  }

  &.alerta {
    background-color: #B11616 !important;
    border-color: #B11616 !important;

    &:hover {
      background-color: #841111 !important;
      border-color: #841111 !important;
    }
  }
}

form button.form-guardar:hover,
button.form-guardar:hover,
.form-guardar:hover,
a[type="button"].form-guardar:hover {
  background-color: var(--primario-tono-80) !important;
  border-color: var(--primario-tono-80);
  color: var(--blanco);
}

input.form-input,
select.form-input,
textarea.form-input,
.form-input,
.selector input,
.selector select,
.form-input {
  border: 1px solid var(--primario-tono-80);
  border-radius: 10px;
  color: var(--neutral-tono-90);
  font-size: 14px;
}

.btn-upload-file {
  font-family: 'Montserrat' !important;
  background-color: var(--neutral-tono-60);
  color: var(--blanco);
  padding: 6px 12px;
  gap: 0.5rem;
  font-weight: 500;
  font-size: 15px;
  margin-right: 0.5rem;
  cursor: pointer;
}

.btn-upload-file:hover {
  background-color: var(--neutral-tono-80) !important;
}

.btn-hover:hover {
  color: var(--neutral);
  border: 1.5px solid var(--vn-tonal-20);
  outline: unset;
  box-shadow: rgba(44, 50, 42, 0.15) 0px 4px 12px;
}

.selector * {
  height: inherit;
  z-index: 1;
  font-size: 14px;
}

.selector div {
  flex-grow: 1;
}

.selector:focus-visible {
  outline: unset;
}

.selector input,
.selector select,
div[data-te-select-dropdown-ref] input {
  border-radius: .25rem;
  padding-inline: 0.75rem;
  background-color: var(--blanco);
  outline: unset;
  box-shadow: unset;
  color: var(--neutral);
  border: 1.5px solid var(--neutral);
}

div[data-te-select-dropdown-ref] input {
  height: 32px;
}

div[data-te-select-dropdown-ref] input:focus {
  border: 1.5px solid var(--neutral);
  outline: unset;
  box-shadow: unset;
}

.selector>div>div span {
  font-size: .4rem;
  top: 50%;
  transform: translateY(-50%);
  width: 20px;
  height: 20px;
  color: var(--neutral) !important;
  content: url(https://siex.dev.premm.es/images/arrowDown.svg);
  background: inherit;
  padding: 3px;
}

.selector>div>div:has(input[disabled]) span {
  background-color: inherit;
}

.selector:has(input:focus)>div>div span {
  background-color: linear-gradient(0deg, rgba(144, 216, 137, 0.2) 0%, rgba(144, 216, 137, 0.2) 100%), var(--blanco);
}

.selector div {
  border: unset !important;
  outline: unset !important;
  box-shadow: unset !important;
}

.selector.especial div.truncate {
  display: none;

  &[data-te-input-state-active] {
    transform: unset !important;
    display: flex !important;
    align-items: center;
  }
}

.form-input input:focus {
  outline: 0;
  border: 0;
  box-shadow: unset;
}

.form-input>svg {
  cursor: pointer;
}

input.form-input:focus,
select.form-input:focus,
.form-input:focus-within,
.selector input:focus,
.selector select:focus {
  color: var(--neutral);
  border: 1.5px solid var(--vn-tonal-20);
  outline: unset;
  box-shadow: rgba(44, 50, 42, 0.15) 0px 4px 12px;
}

td select {
  font-size: 14px;
}

/* Formularios */
.label-formulario {
  color: var(--primario-tono-80);
  font-family: "Montserrat";
  font-size: 16px;
  font-style: normal;
  font-weight: 600;
  line-height: normal;
}

.select-form>div>div>input,
.select-form>div>div>input:focus {
  box-shadow: unset !important;
  width: 500px;
  border-radius: 0.25rem;
  border-color: var(--primario) !important;
  padding: 0.5rem 1rem;
}

.select-form>div>div>span:focus {
  color: var(--primario);
}

/* Modal */
#defaultModal {
  z-index: 60;
  background-color: rgba(51, 51, 51, .62);
}

.modal-overlay {
  background-color: rgba(0, 0, 0, 0.25);
  /* Más suave que 0.5 */
}

.modal_header {
  color: var(--primario);
  border-bottom: 4px solid var(--primario);

  & h3 svg>* {
    fill: var(--primario);
    min-width: 40px;
    height: auto;
  }

  & h3 svg>.blanco {
    fill: var(--blanco);
  }

  & h3 svg>.rojo {
    fill: #9E2020;
  }
}

.modal_header h3 {
  color: var(--primario-tono-80);
}

.modal_footer {
  border-top: 4px solid var(--primario);
}

.modal-confirmacion {
  background-color: var(--vn-tonal-95);
  border-radius: 20px;
}

.modal-btn-confirmar {
  background-color: var(--primario) !important;
  border-color: var(--primario) !important;
  color: var(--blanco);
}

.modal-btn-cancelar {
  background-color: var(--vn-tonal-60) !important;
  border-color: var(--vn-tonal-60) !important;
  color: var(--blanco);

  &:hover {
    background-color: var(--vn-tonal-40) !important;
    border-color: var(--vn-tonal-40) !important;
  }
}

/* Paginación */
nav[role="navigation"]>div:last-of-type>div:last-of-type>span,
nav[role="navigation"]>#paginacion,
nav[role="navigation"]>#paginacionEscogidas {
  gap: .25rem;

  &>span {

    & span>span,
    & button,
    & span {
      width: 40px;
      font-size: 15px;
      font-weight: 600;
      color: var(--vn-tonal-40);
      display: flex;
      justify-content: center;
      padding-inline: unset;
      border-color: var(--vn-tonal-40);

      &:hover {
        background-color: var(--vn-tonal-80);
      }

      &:active {
        background-color: #e1f5df;
      }
    }

    & span[aria-current="page"]>span,
    & button[aria-label^="Go to page"],
    &>span {
      border-radius: .25rem;
    }

    & span[aria-current="page"]>span {
      background-color: var(--vn-tonal-80);
      color: var(--neutral);
    }
  }
}

.pagination-disable svg * {
  fill: var(--neutral-tono-50);
}

/* Otras clases */
section.section-border {
  border-style: solid;
  border-width: 1.5px;
  border-color: black;
  border-radius: 11px;
  margin-bottom: 10px;
}

td.unica {
  text-align: center;
}

.scroll {
  max-height: 88px;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  padding-right: 4px;

  &::-webkit-scrollbar {
    width: 8px;
  }

  &::-webkit-scrollbar-thumb {
    background-color: var(--vn-tonal-60);
  }

  &::-webkit-scrollbar-track {
    background-color: #d9d9d9;
  }
}

input.error {
  border-color: var(--error);
}

p.error {
  color: var(--error);
}

.fichajes {
  flex-wrap: wrap;
}

.border-color-primario {
  border-color: var(--primario);
}

.flextop {
  align-items: flex-start !important;
}

.truncate-message {
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
  max-height: 4.5em;
  line-height: 1.5em;
}

.modal_icon>svg * {
  fill: var(--neutral);
}

/* Mensajes de sesión */
.session-message {
  position: fixed;
  bottom: 1.5rem;
  right: 1.5rem;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  color: var(--negro);
  padding: 1rem 1rem;
  border-radius: 1rem;
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.15);
  z-index: 40;
  display: inline-flex;
  align-items: center;
  gap: 1rem;
}

.session-success {
  background-color: #48A87166;
  border: #48A87126 1px solid;
}

.session-success svg * {
  fill: var(--feedback-success);
}

.session-error {
  background-color: #E5485766;
  border: #E5485726 1px solid;
}

.session-error svg * {
  fill: var(--feedback-error);
}

.session-warning {
  background-color: #ECC26C66;
  border: #ECC26C26 1px solid;
}

.session-warning svg * {
  fill: var(--feedback-warning);
}

/* Checkbox */
.sent-checkbox {
  background-color: transparent !important;
  border: var(--primario) 2px solid !important;
  border-radius: 0.25em !important;
  cursor: pointer;
}

.sent-checkbox:checked {
  background-image: url("data:image/svg+xml,%3csvg viewBox='0 0 16 16' fill='%23E54857' xmlns='http://www.w3.org/2000/svg'%3e%3cpath d='M12.207 4.793a1 1 0 010 1.414l-5 5a1 1 0 01-1.414 0l-2-2a1 1 0 011.414-1.414L6.5 9.086l4.293-4.293a1 1 0 011.414 0z'/%3e%3c/svg%3e") !important;
}

/* Tipo de ejercicio */
.tipo-ejercicio {
  background-color: var(--neutral-tono-20) !important;
  color: var(--secundario-tono-30);
  padding: 3px 9px 3px 5px;
  font-size: 14px;
  border: var(--neutral-tono-40) 1px solid;
  border-radius: 1rem;
  outline: none;
}

.tipo-ejercicio svg {
  width: 1.25rem;
  height: 1.25rem;
  margin-bottom: 0;
}

.tipo-ejercicio svg * {
  fill: var(--secundario-tono-30);
}

/* Eliminar elementos */
.delete-field,
.delete-field svg * {
  color: var(--primario);
  fill: var(--primario);
  font-size: 14px;
}

.delete-field:hover,
.delete-field:hover svg * {
  color: var(--primario-tono-80);
  fill: var(--primario-tono-80);
}

.delete-field svg {
  width: 18px;
}

/* Menú de navegación */
.fixed-sidebar {
  position: sticky;
  top: 60px;
  height: 94vh;
  overflow-y: auto;
}

/* Imágenes ejercicios */
.contenedor-imagenes-ejercicio {
  border: 1.5px solid var(--secundario-tono-30);
  border-radius: 1rem;
  padding: 0.5rem;
}

.btn-delete-img {
  transform: scale(0.75) translate(50%, -50%);
  z-index: 10;
}

/* Tablas dinámicas */
.dynamic-table {
  border-radius: 1rem;
  overflow: hidden;
  border-collapse: separate;
  border-spacing: 0;
}

.dynamic-table thead {
  background-color: var(--primario);
  color: var(--blanco);
}

.dynamic-table-header {
  background-color: var(--primario);
  color: var(--blanco);
  width: 2rem;
  min-width: 2rem;
}

.dynamic-table-cell {
  border: 0.075rem solid var(--primario-tono-80);
  padding: 0.25rem;
}

tbody tr:first-of-type td.dynamic-table-cell {
  border-top: 0.15rem solid var(--primario-tono-80);
}

tbody tr:last-of-type td.dynamic-table-cell {
  border-bottom: 0.15rem solid var(--primario-tono-80);
}

tbody tr td.dynamic-table-cell:nth-child(2) {
  border-left: 0.15rem solid var(--primario-tono-80);
}

td.dynamic-table-cell:last-child {
  border-right: 0.15rem solid var(--primario-tono-80);
}

tbody tr:last-of-type td.dynamic-table-cell:last-child {
  border-bottom-right-radius: 0.925rem;
}

.dynamic-table-cell input[type="text"],
.dynamic-table-cell input[type="file"] {
  border: transparent 1px solid;
  border-radius: 0.5rem;
}

.btn-selected {
  background-color: var(--primario) !important;
  color: var(--blanco);
  padding: 3.75px 12px !important;
  gap: 0.5rem;
  font-weight: 500;
  font-size: 15px;
  border: 0.15em solid var(--primario-tono-80);
}

.btn-selected svg * {
  fill: var(--blanco);
}

.btn-unselected {
  color: var(--secundario-tono-30);
  padding: 6px 12px !important;
  gap: 0.5rem;
  font-weight: 500;
  font-size: 15px;
}

.btn-unselected svg * {
  fill: var(--secundario-tono-30);
}

/* Grid */
.grid-cols-5 {
  grid-template-columns: repeat(5, minmax(0, 1fr));
}

.grid-rows-5 {
  grid-template-rows: repeat(5, minmax(0, 1fr));
}

.col-span-4 {
  grid-column: span 4 / span 4;
}

.col-span-5 {
  grid-column: span 5 / span 5;
}

.row-span-4 {
  grid-row: span 4 / span 4;
}

.row-span-2 {
  grid-row: span 2 / span 2;
}

.col-start-1 {
  grid-column-start: 1;
}

.col-start-5 {
  grid-column-start: 5;
}

.row-start-2 {
  grid-row-start: 2;
}

.row-start-5 {
  grid-row-start: 5;
}

/* Mensajes error */
.text-error {
  color: var(--error);
  font-size: 12px;
}

.textarea-error {
  border-color: var(--error) !important;
}

/* Spinner */
.no-spinner::-webkit-inner-spin-button,
.no-spinner::-webkit-outer-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

.no-spinner {
  -moz-appearance: textfield;
}

.user-icon {
  background-color: var(--primario-tono-30);
}

.user-icon svg {
  fill: var(--blanco);
}

.switch {
  --button-width: 2.5em;
  --button-height: 1.4em;
  --toggle-diameter: 1em;
  --button-toggle-offset: calc((var(--button-height) - var(--toggle-diameter)) / 2);
  --toggle-shadow-offset: 8px;
  --toggle-wider: 2em;
  --color-grey: var(--neutral-tono-20);
  --color-green: var(--secundario);
}

.slider {
  display: inline-block;
  width: var(--button-width);
  height: var(--button-height);
  background-color: var(--color-grey);
  border-radius: calc(var(--button-height) / 2);
  position: relative;
  transition: 0.3s all ease-in-out;
  cursor: pointer;
}

.slider::after {
  content: "";
  display: inline-block;
  width: var(--toggle-diameter);
  height: var(--toggle-diameter);
  background-color: var(--blanco);
  border-radius: calc(var(--toggle-diameter) / 2);
  position: absolute;
  top: var(--button-toggle-offset);
  transform: translateX(var(--button-toggle-offset));
  box-shadow: var(--toggle-shadow-offset) 0 calc(var(--toggle-shadow-offset) * 4) rgba(0, 0, 0, 0.1);
  transition: 0.3s all ease-in-out;
}

.switch input[type="checkbox"]:checked+.slider {
  background-color: var(--color-green);
}

.switch input[type="checkbox"]:checked+.slider::after {
  transform: translateX(calc(var(--button-width) - var(--toggle-diameter) - var(--button-toggle-offset)));
  box-shadow: calc(var(--toggle-shadow-offset) * -1) 0 calc(var(--toggle-shadow-offset) * 4) rgba(0, 0, 0, 0.1);
}

.switch input[type="checkbox"] {
  display: none;
}

.switch input[type="checkbox"]:active+.slider::after {
  width: var(--toggle-wider);
}

.switch input[type="checkbox"]:checked:active+.slider::after {
  transform: translateX(calc(var(--button-width) - var(--toggle-wider) - var(--button-toggle-offset)));
}

.contenedor-superior {
  border-radius: 20px;
  border: 2px solid var(--primario);
}

.leyenda-atributos {
  color: #FFF;
  text-align: center;
  font-family: "Montserrat";
  font-size: 16px;
  font-style: normal;
  font-weight: 600;
  line-height: normal;
}

@media (max-width: 640px) {
  .leyenda-atributos {
    font-size: 12px;
  }
}

.titulo-mes {
  color: var(--primario-tono-80);
  text-align: center;
  font-family: "Montserrat";
  font-size: 15.95px;
  font-style: normal;
  font-weight: 600;
  line-height: normal;
  font-variant: all-small-caps;
}

.texto-dias {
  color: var(--primario-tono-100);
  text-align: center;
  font-family: "Montserrat" !important;
  font-size: 15.95px;
  font-style: normal;
  font-weight: 500;
  line-height: normal;
}

.dia-calendario {
  color: var(--Neutral-100, #17171B);
  text-align: center;
  font-family: Montserrat;
  font-size: 15.95px;
  font-style: normal;
  font-weight: 500;
  line-height: normal;
}

.dia-calendario div {
  width: 35px;
  height: 35px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.dia-actual {
  border: 1.45px solid var(--primario-tono-80);
  background: var(--neutral-tono-20) !important;
  color: var(--neutral-tono-100) !important;
}

.estado-pendiente {
  display: flex;
  align-items: flex-start;
  padding: 4px 8px;
  border-radius: 8px;
  background-color: var(--primario-tono-80);
}

.estado-aceptada {
  display: flex;
  align-items: flex-start;
  padding: 4px 8px;
  border-radius: 8px;
  background-color: var(--secundario);
}

.estado-rechazada {
  display: flex;
  align-items: flex-start;
  padding: 4px 8px;
  border-radius: 8px;
  background-color: var(--feedback-error);
}

.form-textarea {
  border-radius: 10px;
  border: 1px solid var(--primario-tono-80);
}

.toast-correcto {
  background-color: var(--feedback-success-bg);
  border-radius: 20px;
  border: 1px solid var(--feedback-success);
  color: black;
  box-shadow: 30px 32px 17.4px 0 rgba(255, 255, 255, 0.10) inset, 0 1px 18.6px 0 rgba(0, 0, 0, 0.15);
  pointer-events: none;
}

.toast-correcto svg {
  /*color: var(--feedback-success) !important;*/
  fill: var(--feedback-success) !important;
}

input[readonly] {
  color: var(--neutral-tono-60);
  background-color: var(--neutral-tono-30);
  border: 1px solid var(--primario-tono-30);
  border-radius: 15px;
}

.text-nowrap {
  text-wrap: nowrap;
}

textarea:focus {
  outline: none;
  outline-offset: none;
  border: 1px solid var(--primario-tono-80);
}

.btn-dia {
  color: var(--primario-tono-100);
  border: 2px solid var(--primario-tono-100);
  width: 3rem;
  height: 3rem;
  font-size: 1rem;
}

@media (max-width: 640px) {
  .btn-dia {
    width: 2.5rem;
    height: 2.5rem;
    font-size: 0.875rem;
  }
}

.btn-dia:not(:disabled):hover {
  background-color: var(--neutral-tono-20);
}

.btn-dia-laborable {
  color: var(--blanco);
  background-color: var(--primario-tono-100);
  border: 2px solid var(--primario-tono-100);
}

.btn-dia-laborable:not(:disabled):hover {
  background-color: var(--primario-tono-90);
  border: 2px solid var(--primario-tono-90);
}

.campo-obligatorio {
  color: var(--secundario);
}

.contenedor-si-no {
  display: flex;
  justify-content: center;
  align-items: center;
  border-radius: 8px;
  width: 40px;
  color: var(--blanco);
  background-color: var(--neutral-tono-60);
}
.success {
  color: var(--blanco);
  background-color: var(--feedback-success);
}

.contenedor-fichaje-color {
  display: flex;
  justify-content: center;
  align-items: center;
  border-radius: 8px;
  color: var(--blanco);
  background-color: var(--neutral-tono-60);
}
.hora-inicio {
  color: var(--blanco);
  background-color: var(--primario-tono-80);
}
.contenedor-fichaje-color.mas {
  color: var(--blanco);
  background-color: var(--feedback-success);
}
.contenedor-fichaje-color.menos {
  color: var(--blanco);
  background-color: var(--feedback-error);
}
.contenedor-fichaje-color svg {
  height: 16px;
  width: 16px;
  fill: var(--blanco);
}

.opciones-menu{
    top:100%;
    margin-top:8px;
    border-radius: 20px;
    background-color: var(--primario-tono-10);
    border: 1px solid var(--primario);
}

.spinner {
    animation: spin 1s linear infinite;
}

@keyframes spin {
    from { transform: rotate(0deg); }
    to { transform: rotate(360deg); }
}

#loader {
    display: flex;
    justify-content: center;
    align-items: center;
}

.caja-nuevo-festivo {
  border-radius: 15px;
  border: 2px solid var(--primario);
}

.scrollbar-hide::-webkit-scrollbar {
    display: none;
}
.scrollbar-hide {
    -ms-overflow-style: none;
    scrollbar-width: none;
}

.responsive-container {
  margin: 0rem;
}

@media (min-width: 640px) {
  .responsive-container {
    margin: 0rem 1rem;
  }
}

.responsive-container-50 {
  width: 100%;
}

@media (min-width: 1024px) {
  .responsive-container-50 {
    width: 50%;
  }
}

.responsive-container-33 {
  width: 100%;
}

@media (min-width: 1024px) {
  .responsive-container-33 {
    width: 33.3333%;
  }
}

#smallMap {
  border-radius: 15px;
}

.menu-notificacion {
  padding: 0px 8px; 
  height: 24px; 
  min-width: 24px;
  background-color: #ACACBD;
  color: var(--primario-tono-80);
  border-radius: 8px;

  font-family: 'Roboto' !important; /* Montserrat */
  font-size: 15px;
  font-style: normal;
  font-weight: 700;
  line-height: normal;
}

.pr-8 {
  padding-right: 2rem !important;
}