/* ══════════════════════════════════════════════
 * CECA Heading Text Widget — Estilos BEM
 * Variables CSS3 del tema ceca-theme
 * ══════════════════════════════════════════════ */

/* ── Contenedor ── */
.ceca-heading-text__container {
  display: flex;
  flex-direction: column;
  width: 100%;
  margin: 0 auto;
  padding: 64px 120px;
  box-sizing: border-box;
}

.ceca-heading-text {
  position: relative;
  width: 100%;
  display: flex;
  flex-direction: column;
}

.ceca-heading-text__wrapper {
  display: flex;
  flex-direction: column;
  gap: 24px;
  width: 100%;
}

/* ── Antetítulo ── */
.ceca-heading-text__pre-title {
  margin: 0;
  padding: 0;
  font-family: var(--ceca-font-family, "Encode Sans Expanded", sans-serif);
  font-size: 14px;
  font-weight: 700;
  line-height: normal;
  letter-spacing: 1.4px;
  text-transform: uppercase;
  color: var(--ceca-cyan, #00b5dd);
}

/* ── Título Principal ── */
.ceca-heading-text__title {
  margin: 0;
  padding: 0;
  font-family: var(--ceca-font-family, "Encode Sans Expanded", sans-serif);
  line-height: 1.1;
  letter-spacing: -1.14px;
  display: flex;
  flex-wrap: wrap; /* Para permitir saltos si el espacio es reducido */
}

/* Modifiers de tamaño de título */
.ceca-heading-text__title--size-big {
  font-size: 48px;
}
.ceca-heading-text__title--size-medium {
  font-size: 48px;
}
.ceca-heading-text__title--size-small {
  font-size: 32px;
}

/* Modifier: Inline (Unido con espacio) */
.ceca-heading-text__title--inline {
  flex-direction: row;
  align-items: baseline;
  gap: 12px;
}

/* Modifier: Stacked (Apilado) */
.ceca-heading-text__title--stacked {
  flex-direction: column;
  align-items: inherit;
  gap: 4px;
}

/* ── Título Bold ── */
.ceca-heading-text__title-regular {
  font-weight: 700;
  color: var(--ceca-primary, #002a4f);
}

/* ── Título Italic ── */
.ceca-heading-text__title-highlight {
  font-weight: 400;
  font-style: italic;
  color: var(--ceca-secondary, #aa004f);
}

/* ── Descripción ── */
.ceca-heading-text__description {
  margin: 0;
  padding: 0;
  font-family: var(--ceca-font-family, "Encode Sans Expanded", sans-serif);
  font-size: 20px;
  font-weight: 400;
  line-height: 1.5;
  color: var(--ceca-text-secondary, #676767);
}

.ceca-heading-text__description p {
  margin-bottom: 0;
}
.ceca-heading-text__description p:not(:last-child) {
  margin-bottom: 1em;
}

/* Asegurar que las etiquetas bold dentro del wysiwyg mantengan el peso */
.ceca-heading-text__description strong,
.ceca-heading-text__description b {
  font-weight: 700;
  color: inherit;
}

/* ── Separador ── */
.ceca-heading-text__separator {
  width: 100%;
  height: 1px !important;
  background-color: var(--ceca-text-secondary, #676767) !important;
  border: none;
  margin-top: 32px !important;
  margin-bottom: 0 !important;
  opacity: 0.3;
}

/* ══════════════════════════════════════════════
 * Modos de alineación (controlan flexbox)
 * El control de Elementor ya gestiona text-align
 * Estas clases corrigen el flex del título y wrapper
 * ══════════════════════════════════════════════ */

/* ── Modo Izquierda (default) ── */
.ceca-heading-text--align-left .ceca-heading-text__title--inline {
  justify-content: flex-start;
}
.ceca-heading-text--align-left .ceca-heading-text__title--stacked {
  align-items: flex-start;
}

/* ── Modo Centrado ── */
.ceca-heading-text--align-center .ceca-heading-text__wrapper {
  align-items: center;
}
.ceca-heading-text--align-center .ceca-heading-text__title--inline {
  justify-content: center;
}
.ceca-heading-text--align-center .ceca-heading-text__title--stacked {
  align-items: center;
}
.ceca-heading-text--align-center .ceca-heading-text__description {
  text-align: center;
}

/* ── Modo Derecha ── */
.ceca-heading-text--align-right .ceca-heading-text__wrapper {
  align-items: flex-end;
}
.ceca-heading-text--align-right .ceca-heading-text__title--inline {
  justify-content: flex-end;
}
.ceca-heading-text--align-right .ceca-heading-text__title--stacked {
  align-items: flex-end;
}
.ceca-heading-text--align-right .ceca-heading-text__description {
  text-align: right;
}

/* ── Responsive ── */
@media (max-width: 1024px) {
  .ceca-heading-text__container {
    padding: 32px 16px;
  }
}

@media (max-width: 768px) {
  .ceca-heading-text__title {
    font-size: 40px;
  }
  .ceca-heading-text__description {
    font-size: 16px;
  }
}
