:root {
  /* Colores primarios */
  --primario: #E54857;
  --primario-tono-10: #EFB5CB;
  --primario-tono-30: #EA7F91;
  --primario-tono-80: #B33A48;
  --primario-tono-100: #822C39;

  /* Colores secundarios */
  --secundario: #192D4A;
  --secundario-tono-10: #C6CBD2;
  --secundario-tono-30: #6F7C8E;
  --secundario-tono-80: #132238;
  --secundario-tono-100: #0D1725;

  /* Colores neutrales */
  --blanco: #ffffff;
  --neutral-tono-10: #F8F9FA;
  --neutral-tono-20: #E9ECEF;
  --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: #ECC26C;
  --feedback-error: #E54857;
  --feedback-info: #0DACA6;
  --feedback-success: #48A871;

  /* 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);
}

.table-label {
  background-color: var(--primario);
  color: var(--blanco);
  white-space: nowrap;
  font-size: 15px;
  font-weight: 600;

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

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

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

.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: 0.5rem;
}

.last-row, .last-row td:last-child {
  border-bottom-right-radius: 0.5rem;
}

tr.data-row #unica {
  background-color: var(--vn-tonal-95);
}

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-color: var(--secundario-tono-10);
}

tr.data-row:nth-child(2n + 1),
tr.data-row #unica .table-fiex tr.data-row:nth-child(2n + 1) {
  background-color: var(--vn-tonal-95);
}

table.tabla-seleccion tr.data-row:hover,
tr.data-row:has(td.data-cell:first-of-type input[type="checkbox"]:checked) {
  background-color: #FFD595;
}

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);
  }
}

/*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;
}

.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: 6vh;
  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: 6vh;
}

.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: 20px;
}

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

.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(--primario-tono-80);
}

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

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

html {
  background-color: var(--vn-tonal-99);
  font-family: 'Arial Rounded MT' !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: 'Arial Rounded MT' !important;
}

h1, h2, h3, h4, button, th {
  font-family: 'Arial Rounded MT Bold' !important;
}

.body20-bold {
  font-size: 20px;
  font-weight: 700;
  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-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);
}

/* Líneas y subrayados */
.title-subrayado {
  height: 2px;
  background-color: var(--vn-tonal-40);
  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: 6vh;
  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(6vh + 60px);
}

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

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

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

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

.panel_header>svg {
  width: 25px;
}

/* Botones */
.btn-nuevo,
form button.form-guardar,
button.form-guardar,
.form-guardar,
a[type="button"].form-guardar,
.modal-btn-cancelar {
  background-color: var(--primario)!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(--neutral-tono-50)!important;
  color: var(--blanco);
  padding: 6px 12px;
  gap: 0.5rem;
  font-weight: 500;
  font-size: 15px;
}

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

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

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

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

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

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

.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(--neutral-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: 1.5px solid var(--secundario-tono-30);
  color: var(--neutral);
  font-size: 14px;
}

.btn-upload-file {
  font-family: 'Arial Rounded MT Bold' !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;
}

/* Formularios */
.label-formulario {
  color: var(--neutral);
}

.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_footer {
  border-top: 4px solid var(--primario);
}

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

.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: 6vh;
  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;
}
/* washapp*/
footer {
    background-color: white;
    overflow-y: auto;
    width: 100%;
    width: -webkit-fill-available;
    width: -moz-available;
    width: stretch;

}
footer div{
gap: 20px;
}

/*Contenedor de mensajes*/
div[wire\:key="chat-messages"] {
    margin-bottom: 67px;
}

/*Imagenes mensajes*/
div[wire\:key="chat-messages"] img {
    width: 100%;
    height: 300px;
    border-radius: 20px;
}

/*Contenedores de mensajes*/
div[wire\:key="chat-messages"] div {
    margin-top: 5px;
    margin-bottom: 5px;
    border-radius: 20px;
}

div[wire\:key="chat-messages"] div div {
     padding: 15px;
}

/*Mensajes cliente*/
div[wire\:key="chat-messages"] div.justify-start div {
    background-color: rgb(229 231 235);
}

/*Busqueda contacto*/
input[wire\:model="search_contacto"] {
    width: 100%;
    width: -webkit-fill-available;
    width: -moz-available;
    width: stretch;
    margin: 10px;
    font-size: 1em;
}

/*lista mensajes*/
button[wire\:click^="abrirChat"] div {
    gap: 10px;
}

/*Circulo inicial de Usuario*/
button[wire\:click^="abrirChat"] > div:first-child {
    background-color: #e54857;
    color: white;
    margin-right: 10px;
}

header > div:first-child {
    background-color: #b33a48;
    color: white;
    font-weight: bold;
}
