*,
h1,
h2,
h3,
h4,
h5,
h6 {
  color: var(--on-background);
}

/*OPEN: PRIMER SECTION + EFECTO LINTERNA*/

/*--------------------------------------open: interna*/
.fondo-luz {
  position: fixed; /* o absolute, según tu setup */
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh; /* limitar altura aquí */
  overflow: hidden;
  pointer-events: none;
  z-index: 0;
  transition: opacity 0.4s ease;
  opacity: 1;
  background: url("https://www.catedrahch.org/wp-content/uploads/2025/06/fondo-body-light.jpg")
    center/cover no-repeat;
}

html.dark-mode .fondo-luz {
  background: url("https://www.catedrahch.org/wp-content/uploads/2025/06/fondo-body-dark.jpg")
    center/cover no-repeat;
}

.overlay-mapa {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 1;
  background: radial-gradient(
    circle 250px at var(--x, 50%) var(--y, 50%),
    rgba(0, 0, 0, 0) 0%,
    rgba(255, 255, 255, 0.8) 40%,
    rgba(252, 252, 252, 1) 100%
  );
  transition: background 0.1s ease-out;
}

html.dark-mode .overlay-mapa {
  background: radial-gradient(
    circle 300px at var(--x, 50%) var(--y, 50%),
    rgba(20, 20, 20, 0) 0%,
    /* centro transparente */ #141414 60%,
    /* transición oscura */ #141414 100% /* fondo gris oscuro */
  );
}

/*--------------------------------------close: interna*/

.et_pb_section.primer-section {
  position: relative;
  height: 100vh;
  display: flex;
  flex-direction: column;
  justify-content: center;
  z-index: 10; /* sobre la capa con mapa + overlay */
  overflow: hidden;
}

/*CLOSE: PRIMER SECTION + EFECTO LINTERNA*/

/*OPEN: EL GRAN BUSCADOR HOME*/
.buscador-home .search-form {
  max-width: 1064px;
  margin: 0 auto;
  opacity: 0;
  transform: translateY(12vh);
  transition: opacity 0.6s ease-out, transform 0.6s ease-out;
}

/* Animacion entrada */
.buscador-home .search-form.visible {
  opacity: 1;
  transform: translateY(8vh);
}

@media (max-width: 980px) {
  .buscador-home .search-form {
    transform: translateY(140px);
  }

  .buscador-home .search-form.visible {
    transform: translateY(50px);
  }
}
/* Animacion entrada */

.buscador-home .search-form label {
  display: block;
  margin: 0 0 16px 32px;
  font-family: var(--typo-primary);
  font-size: 32px;
  font-style: italic;
  text-align: left;
  color: var(--on-background);
}

.search-wrapper {
  position: relative;
  display: flex;
  align-items: center;
}

.search-wrapper input[type="search"] {
  flex: 1;
  padding: 24px;
  font-size: 1rem;
  color: var(--on-fill-hight);
  border-radius: var(--corner-full);
  border: 1px solid var(--input-outline-default);
  background: var(--fill);
  transition: var(--transition-color-background-border),
    var(--transition-shadow-smooth);
}

.search-wrapper input[type="search"]::placeholder {
  color: var(--on-fill);
}

.search-wrapper input[type="search"]::-webkit-input-placeholder {
  color: var(--on-fill);
}

.search-wrapper input[type="search"]::-moz-placeholder {
  color: var(--on-fill);
}

.search-wrapper input[type="search"]:-ms-input-placeholder {
  color: var(--on-fill);
}

.search-wrapper input[type="search"]:hover {
  border: 1px solid var(--input-outline-hover-color);
  background: var(--fill-high);
}

.search-wrapper input[type="search"]:focus-visible,
.search-wrapper input[type="search"]:focus {
  outline: 1px solid var(--input-outline-focus-color);
  background: var(--fill-high);
  color: var(--on-fill-hight);
  box-shadow: 0px 0px 0px 8px var(--input-focus-shadow-color);
}

.search-wrapper button {
  position: absolute;
  display: flex;
  right: 8px;
  padding: 18px 48px;
  font-size: 16px;
  font-weight: 600;
  cursor: pointer;
  border: none;
  background: var(--button-solid-background-color);
  border-radius: var(--corner-full);
  transition: var(--transition-color-background-border);
  outline: 2px solid transparent;
  outline-offset: 2px;
}

.search-wrapper button:hover {
  background: var(--button-solid-hover-background-color);
  color: var(--button-solid-hover-on-background-color);
}

.search-wrapper button:active {
  background: var(--button-solid-active-background-color);
  color: var(--button-solid-active-on-background-color);
}

.search-wrapper button:focus-visible,
.search-wrapper button:focus {
  background: var(--button-solid-focus-background-color);
  color: var(--button-solid-focus-on-background-color);
  outline: 2px solid var(--button-solid-focus-on-outline-color);
}

/*label button + icon*/
.search-wrapper button span.text-label,
.search-wrapper button span.search-icon {
  color: var(--button-solid-on-background-color);
}

.search-wrapper button:hover span.text-label,
.search-wrapper button:hover span.search-icon {
  color: var(--button-solid-hover-on-background-color);
}

.search-wrapper button:active span.text-label,
.search-wrapper button:active span.search-icon {
  color: var(--button-solid-active-on-background-color);
}

.search-wrapper button:focus-visible span.text-label,
.search-wrapper button:focus-visible span.search-icon,
.search-wrapper button:focus span.text-label,
.search-wrapper button:focus span.search-icon {
  color: var(--button-solid-focus-on-background-color);
}

.search-wrapper button span.search-icon {
  display: none;
}

.shortcut-hint {
  position: absolute;
  right: 172px;
  display: flex;
  gap: 4px;
  font-size: 0.75rem;
  top: 50%;
  transform: translateY(-50%);
  opacity: 1;
}

.shortcut-box {
  border: 1px solid var(--on-fill);
  padding: 4px 8px;
  border-radius: 4px;
  color: var(--on-fill);
  font-family: var(--typo-secondary);
}

@media (max-width: 1023px) {
  .search-form {
    max-width: 80%;
  }

  .shortcut-hint {
    display: none;
  }
}

@media (max-width: 767px) {
  .search-form {
    max-width: 98%;
  }

  .search-form label {
    margin: 0 0 8px 32px;
    font-size: 24px;
  }

  .search-wrapper input[type="search"]:focus-visible,
  .search-wrapper input[type="search"]:focus {
    box-shadow: 0px 0px 0px 4px var(--input-focus-shadow-color);
  }

  .search-wrapper button {
    right: 8px;
    padding: 4px;
    align-items: center;
    justify-content: center;
    width: 56px;
    height: 56px;
  }

  .search-wrapper button span.text-label {
    display: none;
  }

  .search-wrapper button span.search-icon {
    display: inline;
    font-size: 28px;
  }
}

/*CLOSE: EL GRAN BUSCADOR HOME*/

/*OPEN: EL GRAN BUSCADOR PAGINA BUSCAR*/
.buscador-aislado .search-form {
  max-width: 1064px;
  margin: 0 auto;
  opacity: 0;
  transform: translateY(-10vh);
  transition: opacity 0.6s ease-out, transform 0.6s ease-out;
}

/* Animacion entrada */
.buscador-aislado .search-form.visible {
  opacity: 1;
  transform: translateY(-18vh);
}

/*CLOSE: EL GRAN BUSCADOR PAGINA BUSCAR*/

/*-------------------------------------------OPEN: PROPUESTA DE VALOR*/
.propuesta-valor {
  float: right;
  opacity: 0;
  transform: translateY(30px); /* Inicia desde más abajo */
  transition: opacity 0.6s ease-out, transform 0.6s ease-out;
}

/* Animacion entrada */
.propuesta-valor.visible {
  opacity: 1;
  transform: translateY(0px);
}

@media (max-width: 980px) {
  .propuesta-valor {
    transform: translateY(0px);
  }

  .propuesta-valor.visible {
    transform: translateY(-40px);
  }
}
/* Animacion entrada */

.propuesta-valor .text-block {
  display: flex;
  flex-wrap: wrap;
  margin-bottom: 8px;
  max-width: 750px;
  padding: 8px;
  text-align: left;
}

.propuesta-valor .text-block h3 {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  margin: 0;
  padding: 4px 0;
  font-family: var(--typo-secondary);
  font-size: 30px;
  font-weight: 300;
  line-height: 120%;
  color: var(--on-background);
}

.propuesta-valor .text-block .italic {
  font-family: var(--typo-primary);
  font-size: 42px;
  font-style: italic;
  color: var(--on-background);
}

.propuesta-valor .text-block .icon {
  display: inline-block;
  vertical-align: middle;
  color: var(--on-background);
}

.propuesta-valor .text-block .icon-group {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 8px 16px;
  justify-content: space-between;
  border: 2px solid var(--on-background);
  color: var(--on-background);
  border-radius: var(--corner-full);
}

@media (max-width: 980px) {
  .propuesta-valor .text-block h3 {
    font-size: 24px;
  }

  .propuesta-valor .text-block .italic {
    font-size: 32px;
  }

  .propuesta-valor .text-block .icon {
    height: 16px;
  }

  .propuesta-valor .text-block .icon-group {
    gap: 8px;
    padding: 4px 12px;
  }
}

@media (max-width: 767px) {
  .propuesta-valor .text-block h3 {
    font-size: 16px;
    line-height: 130%;
  }

  .propuesta-valor .text-block .italic {
    font-size: 20px;
  }

  .propuesta-valor .text-block .icon {
    height: 16px;
  }

  .propuesta-valor .text-block .icon-group {
    gap: 8px;
    padding: 4px 12px;
    border: 1px solid var(--on-background);
  }
}

@media (max-width: 540px) {
  .propuesta-valor .text-block {
    display: inline-block;
  }

  .propuesta-valor .text-block .icon-group {
    width: 80px;
  }
}

/*-------------------------------------------CLOSE: PROPUESTA DE VALOR*/

/*OPEN: CARDS DE CATEGORIAS*/
.container-categorias {
  display: grid;
  grid-template-columns: repeat(5, 174px);
  gap: 16px;
  justify-content: start;
  padding: 40px 0;
}

.card.item-categoria {
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  height: 296px;
  padding: 4px;
  background-color: var(--surface);
  border-radius: var(--corner-small);
  transition: var(--transition-color-background-border),
    var(--transition-shadow-smooth);
}

.card.item-categoria:hover {
  background-color: var(--surface-medium);
}

.card.item-categoria:focus,
.card.item-categoria:focus-visible {
  border: 1px solid var(--card-active-outline-color);
  box-shadow: 0px 0px 0px 5px
    var(--Schemes-ch-card-active-shadow-color, rgba(178, 221, 255, 0.3));
}

.item-categoria img {
  border-radius: var(--corner-extra-small);
  width: 100%;
  transition: var(--transition-filter);
}

.item-categoria:hover img {
  filter: brightness(1.2) contrast(1.1) saturate(1.5);
}

.item-categoria .nombre-categoria {
  margin-top: auto;
  padding: 4px;
  font-style: italic;
  font-weight: 600;
  color: var(--on-surface);
}

.item-categoria .flecha-movil {
  display: none;
}

@media (max-width: 980px) {
  .container-categorias {
    gap: 8px;
    grid-template-columns: repeat(4, 174px);
  }
}

@media (max-width: 767px) {
  .container-categorias {
    grid-template-columns: repeat(2, 1fr); /* 2 columnas responsivas */
  }

  .card.item-categoria {
    display: flex;
    padding: 4px 16px 4px 4px;
    flex-direction: row; /* Imagen y texto en fila */
    align-items: center; /* Alineamos los elementos hacia abajo */
    justify-content: flex-start; /* Alineamos los elementos a la izquierda */
    height: auto; /* Ajusta la altura automáticamente */
    gap: 8px; /* Espacio entre la imagen y el texto */
  }

  .item-categoria img {
    width: auto;
    height: 72px;
    flex-shrink: 0;
  }

  .item-categoria .nombre-categoria {
    display: flex;
    width: 100%;
    margin: auto;
    justify-content: flex-start; /* Asegura que el texto esté alineado al fondo */
    align-items: flex-start; /* Alinea el texto a la izquierda */
    text-align: left;
  }

  .item-categoria .flecha-movil {
    display: inline-block;
    color: var(--on-surface-medium);
    opacity: 0.6;
  }
}

@media (max-width: 639px) {
  .container-categorias {
    grid-template-columns: 1fr; /* Una columna */
  }
}
/*CLOSE: CARDS DE CATEGORIAS*/

/*OPEN: FILA ACCESO A TERMINOS HOSTORICOS*/

.et_pb_row.row-terminos-historicos .column-terminos-historicos {
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
  justify-content: space-between;
  padding: 24px;
  gap: 24px;
  background: var(--background);
  border-radius: var(--corner-medium);
  border: 1px solid var(--on-background);
}

.et_pb_row.row-terminos-historicos .column-terminos-historicos .icon-terminos {
  width: 56px;
  height: auto;
}

.et_pb_row.row-terminos-historicos .column-terminos-historicos .texto-terminos {
  width: calc(100% - 303px);
}

.et_pb_row.row-terminos-historicos
  .column-terminos-historicos
  .texto-terminos
  .et_pb_text_inner {
  max-width: 600px;
}

.et_pb_row.row-terminos-historicos
  .column-terminos-historicos
  .texto-terminos
  .et_pb_text_inner
  h2 {
  padding: 0;
  font-size: 32px;
  font-weight: 600;
  font-style: italic;
}

@media (max-width: 639px) {
  .et_pb_row.row-terminos-historicos .column-terminos-historicos {
    flex-wrap: wrap;
    padding: 24px 8px;
    gap: 8px;
  }

  .et_pb_row.row-terminos-historicos
    .column-terminos-historicos
    .imagen-terminos,
  .et_pb_row.row-terminos-historicos
    .column-terminos-historicos
    .texto-terminos,
  .et_pb_row.row-terminos-historicos .column-terminos-historicos .cta-terminos {
    width: 100%;
    text-align: center;
  }

  .et_pb_row.row-terminos-historicos
    .column-terminos-historicos
    .icon-terminos {
    width: 32px;
  }
}

/*CLOSE: FILA ACCESO A TERMINOS HOSTORICOS*/
