/* Contenedor principal del componente de simulación */
.simulacion__result {
  border-radius: 8px; /* Bordes redondeados */
  overflow: hidden; /* Asegura que el contenido interno no se desborde */
  box-shadow: 0 4px 4px rgba(0,0,0,0.25);
}

/* Encabezado de la tabla */
.simulacion__result thead {
  background-color: #21a39f; /* Verde oscuro del encabezado */
  color: #fff;
}

.simulacion__result thead th {
  padding: 1em;
  font-weight: bold;
  text-align: left;
}

/* Fila del mensaje principal */
.simulacion__result tbody tr:first-of-type {
  background-color: #DCE6DD; /* Verde claro del fondo */
}

.simulacion__result tbody tr:first-of-type td {
  padding: 1.5em;
  font-size: 1em;
  line-height: 1.4;
}

/* Fila de los puntajes */

/* Alternar colores en las filas a partir de la segunda */
.simulacion__result tbody tr:not(:first-of-type):nth-child(even) {
  background-color: #fcfcfc; /* Fondo blanco */
}
.simulacion__result tbody tr:not(:first-of-type):nth-child(odd) {
  background-color: #F5F5F5; /* Fondo gris claro */
}

.simulacion__result tbody tr:not(:first-of-type) td {
  padding: 0.75em 1em;
  
}

/* Quitamos el borde de la última fila */
.simulacion__result tbody tr:last-of-type td {
  border-bottom: none;
}

/* Alineación y estilo del texto en las celdas */
.simulacion__result table {
  width: 100%;
    border-collapse: collapse;
  
}

.simulacion__result strong {
  font-weight: bold;
}

.simulacion__result .simulacion__result__message strong {
  color: #000;
}

.simulacion__result .simulacion__result__table__data {
  text-align: right;
  font-weight: bold;
}


.button-descarga-certificado {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5em;
  padding: 0.75em 1.5em;
  border-radius: 10px;
  background-color: #fff;
  border: 1px solid #004F45;
  color: #004F45;
  text-decoration: none;
  font-weight: bold;
  transition: all 0.3s ease;
}

.button-descarga-certificado:hover {
  background-color: #f0f0f0;
}

/*
 * SKELETON MODE (Versión Estática con Colores Originales de la Tabla)
 * Esta clase .skeleton es la única que necesitas para activar el modo de esqueleto.
 */
.skeleton {
    /* Desactiva interacciones para prevenir clics accidentales */
    pointer-events: none;
    
    /* Define el color base para los placeholders del esqueleto (gris sólido) */
    --skeleton-color-base: #e2e2e2;
}

/*
 * Oculta el contenido de texto, números y cualquier icono
 * dentro del contenedor con la clase .skeleton
 */
.skeleton * {
    color: transparent !important; /* Oculta el color del texto */
    border-color: transparent !important; /* Oculta bordes */
    /* No sobrescribir background-color para los elementos de la tabla
       donde queremos mantener los colores originales.
       Los placeholders se generarán con pseudoelementos. */
}

/*
 * Crea el efecto de esqueleto en los elementos principales del diseño
 */

/* Placeholder para el encabezado */
.skeleton .simulacion__result thead th {
    /* Mantener el background-color original del thead */
    position: relative;
    /* Remover overflow: hidden y shimmer si no hay animación */
}

/* El placeholder se hará con un pseudoelemento para el texto del thead */
.skeleton .simulacion__result thead th::before {
    content: '';
    position: absolute;
    height: 1.5em; /* Altura para el placeholder del texto del título */
    width: 70%; /* Ancho para simular el texto del título */
    background-color: var(--skeleton-color-base);
    border-radius: 4px;
    top: 50%;
    left: 1em; /* Alineado a la izquierda como el texto original */
    transform: translateY(-50%);
    /* No hay animación de shimmer */
}

/* Placeholder para las celdas de la tabla (mantienen su color de fondo) */
.skeleton td {
    position: relative;
}

.skeleton td::before {
    content: '';
    position: absolute;
    height: 1em;
    background-color: var(--skeleton-color-base);
    border-radius: 4px;
    
    /* Estilos del placeholder */
    top: 50%;
    transform: translateY(-50%);
    /* No hay animación de shimmer */
}

/* Placeholder del mensaje principal (primera fila del tbody) */
.skeleton tbody tr:first-of-type td::before {
    left: 1.5em;
    right: 1.5em;
    height: 1.2em; /* Ligeramente más alto para este mensaje */
}

/* Placeholders para las etiquetas (primera columna, no primera fila) */
.skeleton tbody tr:not(:first-of-type) td:first-child::before {
    left: 1em;
    width: 60%;
}

/* Placeholders para los valores (segunda columna, no primera fila) */
.skeleton tbody tr:not(:first-of-type) td:last-child::before {
    right: 1em;
    width: 30%;
}

/* Placeholder para el botón de descarga */
.skeleton .button-descarga-certificado {
    /* Mantener el background-color original del botón si no se especifica.
       Aquí se sobrescribe a gris para el placeholder.
    */
    background-color: var(--skeleton-color-base) !important;
    border: none !important; /* Remover el borde original */
    position: relative; /* Para el pseudoelemento */
}

.skeleton .button-descarga-certificado::before {
    content: '';
    position: absolute;
    /* El pseudoelemento cubre todo el botón */
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: var(--skeleton-color-base); /* Color sólido para el placeholder */
    border-radius: 10px; /* Mantener los bordes redondeados del botón */
    /* No hay animación de shimmer */
}

/* CÓDIGO ORIGINAL (sin cambios, solo incluido para contexto) */

/* Contenedor principal del componente de simulación */
.simulacion__result {
  border-radius: 8px; /* Bordes redondeados */
  overflow: hidden; /* Asegura que el contenido interno no se desborde */
  box-shadow: 0 4px 4px rgba(0,0,0,0.25);
}

/* Encabezado de la tabla */
.simulacion__result thead {
  background-color: #21a39f; /* Verde oscuro del encabezado */
  color: #fff;
}

.simulacion__result thead th {
  padding: 1em;
  font-weight: bold;
  text-align: left;
}

/* Fila del mensaje principal */
.simulacion__result tbody tr:first-of-type {
  background-color: #DCE6DD; /* Verde claro del fondo */
}

.simulacion__result tbody tr:first-of-type td {
  padding: 1.5em;
  font-size: 1em;
  line-height: 1.4;
}

/* Fila de los puntajes */

/* Alternar colores en las filas a partir de la segunda */
.simulacion__result tbody tr:not(:first-of-type):nth-child(even) {
  background-color: #fcfcfc; /* Fondo blanco */
}
.simulacion__result tbody tr:not(:first-of-type):nth-child(odd) {
  background-color: #F5F5F5; /* Fondo gris claro */
}

.simulacion__result tbody tr:not(:first-of-type) td {
  padding: 0.75em 1em;
  
}

/* Quitamos el borde de la última fila */
.simulacion__result tbody tr:last-of-type td {
  border-bottom: none;
}

/* Alineación y estilo del texto en las celdas */
.simulacion__result table {
  width: 100%;
    border-collapse: collapse;
  
}

.simulacion__result strong {
  font-weight: bold;
}

.simulacion__result .simulacion__result__message strong {
  color: #000;
}

.simulacion__result .simulacion__result__table__data {
  text-align: right;
  font-weight: bold;
}


.button-descarga-certificado {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5em;
  padding: 0.75em 1.5em;
  border-radius: 10px;
  background-color: #fff;
  border: 1px solid #004F45;
  color: #004F45;
  text-decoration: none;
  font-weight: bold;
  transition: all 0.3s ease;
}

.button-descarga-certificado:hover {
  background-color: #f0f0f0;
}
/*
 * ANIMACIÓN SHIMMER
 * Esta clase se aplica solo al div principal y activa la animación.
 * El efecto de shimmer solo se activa si el div tiene las dos clases.
 */
.skeleton.loading {
  position: relative;
  overflow: hidden;
}

.skeleton.loading::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(
    90deg,
    transparent 0%,
    rgba(255, 255, 255, 0.3) 20%,
    rgba(255, 255, 255, 0.6) 50%,
    rgba(255, 255, 255, 0.3) 80%,
    transparent 100%
  );
  animation: shimmer 1.5s infinite;
}

@keyframes shimmer {
  from {
    transform: translateX(-100%);
  }
  to {
    transform: translateX(100%);
  }
}
.uppercase{
    text-transform: uppercase;
}

.simulacion__calculadora__trigger{
  display: flex;
  flex-direction: column;
  gap: 1rem;
  align-items: flex-start;
}
.simulacion__calculadora__trigger.right {
  align-items: flex-end;
}



.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 12px 24px;
    border-radius: 8px;
    font-size: 16px;
    font-weight: 600;
    cursor: pointer;
    text-decoration: none;
    border: 2px solid transparent;
    transition: all 0.2s ease-in-out;
}


.btn-primary {
    background-color: #F5A623; 
    color: #333333; 
}

.btn-primary:hover {
    background-color: #e6861a;
    transform: translateY(-2px);
}


.btn-secondary {
    background-color: transparent;
    color: #007A8D;
    border-color: #007A8D;
    align-self: flex-end;
    flex-direction: row;
    display: flex;
    gap: 5px;
}

.btn-secondary:hover {
    background-color: #007A8D;
    color: #fff;
}

.link-secondary {
    color: #555;
    font-size: 16px;
    font-weight: 500;
    text-decoration: underline;
    color: #004F45;
}
.btn-beca {
    background-color:#21a39f;
    color: #fff;
  }
.btn-beca:hover {
    background-color: #007A8D;
    color: #fff;
  }

.link-secondary:hover {
    text-decoration: underline;
    color: #000;
}
.trigger-group {
    display: flex;         
    align-items: center;   
    gap: 1.5rem;           
}

.simulacion__calculadora__tabla .calculadora__tabla__row__input .regular-input {    
    max-width: 100px !important;
    min-width: 100px !important;

}

.calculadora__tabla__row__title {
    color: #004F45 !important;
}

  /* :disabled="sendit" */
  .btn:disabled{
    background-color: #e0e0e0 !important; /* Gris claro para indicar que está deshabilitado */
    color: #a0a0a0 !important; /* Texto gris para indicar que está deshabilitado */
    border-color: #e0e0e0 !important; /* Borde gris claro */
    cursor: not-allowed; /* Cambia el cursor para indicar que no es clickeable */
    pointer-events: none; /* Desactiva todas las interacciones */
    opacity: 0.6; /* Reduce la opacidad para un efecto visual */
  }