/* =========================================================
   Home (front-page) - Expansao Teologica
   Direcao: revista academica premium (editorial sereno) com
   um unico beat imersivo (trilha escura) e microinteracoes.
   Mobile-first. Margem unica (container 1320px).
   ========================================================= */

/* ----- Cabecalho de secao (alinhado a esquerda) ----- */
.hp-head { max-width: 720px; margin: 0 0 var(--space-lg); text-align: left; }
.hp-head h2 { margin-bottom: var(--space-2xs); }
.hp-head .lead { margin: 0; max-width: 60ch; }
.hp-head--row { display: flex; flex-direction: column; gap: var(--space-sm); max-width: none; align-items: flex-start; }
.hp-head--row h2 { margin: 0; }
.hp-head__link { position: relative; font-weight: var(--fw-semibold); font-size: var(--fs-sm); white-space: nowrap; }
.hp-head__link::after { content: ""; display: block; height: 1px; background: var(--color-gold); transform: scaleX(0); transform-origin: left; transition: transform var(--transition); }
.hp-head__link:hover::after { transform: scaleX(1); }

/* Hairline dourada de ritmo entre secoes claras */
.hp-rule {
  max-width: var(--container); margin-inline: auto;
  border: 0; border-top: 1px solid var(--color-line);
  position: relative; padding-inline: var(--space-md);
}
.hp-rule::after { content: ""; position: absolute; left: 50%; top: -1px; width: 40px; height: 1px; background: var(--color-gold); transform: translateX(-50%); }

/* =========================================================
   HERO
   ========================================================= */
.hp-hero {
  position: relative;
  display: flex;
  align-items: center;
  min-height: 460px;
  padding-block: var(--space-2xl);
  overflow: hidden;
  isolation: isolate;
}
.hp-hero__bg { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; z-index: -2; }
.hp-hero__overlay {
  position: absolute; inset: 0; z-index: -1;
  background:
    linear-gradient(180deg, rgba(15,27,45,0.55) 0%, rgba(15,27,45,0.78) 100%),
    linear-gradient(90deg, rgba(15,27,45,0.92) 0%, rgba(15,27,45,0.45) 100%),
    radial-gradient(120% 120% at 15% 30%, transparent 40%, rgba(15,27,45,0.35) 100%);
}
.hp-hero__inner { color: #fff; max-width: 720px; }
.hp-hero__eyebrow { color: var(--color-gold-soft); }
.hp-hero__eyebrow::before { background: var(--color-gold-soft); }
.hp-hero__title { color: #fff; font-size: clamp(1.9rem, 1.3rem + 3.2vw, 3.1rem); margin-bottom: var(--space-sm); }
.hp-hero__title em { font-style: normal; font-weight: var(--fw-light); color: var(--color-gold-soft); }
.hp-hero__lead { color: rgba(255,255,255,0.85); font-size: var(--fs-lead); max-width: 46ch; font-weight: var(--fw-light); }
.hp-hero__actions { display: flex; flex-wrap: wrap; gap: var(--space-sm); margin: var(--space-md) 0; }
.hp-hero__stats {
  list-style: none; padding: var(--space-md) 0 0; margin: var(--space-md) 0 0;
  display: flex; flex-wrap: wrap; gap: var(--space-lg);
  border-top: 1px solid var(--color-gold-line);
}
.hp-hero__stats strong { display: block; color: #fff; font-size: 1.15rem; font-weight: var(--fw-semibold); letter-spacing: -0.01em; }
.hp-hero__stats span { color: rgba(255,255,255,0.65); font-size: var(--fs-sm); }

/* Card de prova social em vidro (so desktop, com fallback solido) */
.hp-hero__card { display: none; }
@media (min-width: 1200px) {
  .hp-hero__card {
    display: block; position: absolute;
    right: var(--space-lg); bottom: var(--space-lg);
    max-width: 300px; padding: var(--space-md);
    background: rgba(255,255,255,0.10);
    backdrop-filter: blur(14px) saturate(120%);
    -webkit-backdrop-filter: blur(14px) saturate(120%);
    border: 1px solid var(--color-gold-line);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-lg);
    color: #fff; z-index: 2;
  }
  .hp-hero__card .rating { gap: 0.4rem; }
  .hp-hero__card p { font-size: var(--fs-sm); font-style: italic; color: rgba(255,255,255,0.9); margin: var(--space-2xs) 0; }
  .hp-hero__card strong { display: block; color: var(--color-gold-soft); font-size: var(--fs-sm); }
}
@supports not ((backdrop-filter: blur(1px)) or (-webkit-backdrop-filter: blur(1px))) {
  .hp-hero__card { background: rgba(15,27,45,0.82); }
}

/* =========================================================
   MISSAO (pilares editoriais)
   ========================================================= */
.hp-pillars { display: grid; grid-template-columns: 1fr; gap: var(--space-md); }
.hp-pillar { text-align: left; padding: var(--space-md) var(--space-md) var(--space-md) 0; }
.hp-pillar__idx { display: block; font-size: var(--fs-sm); font-weight: var(--fw-semibold); letter-spacing: 0.15em; color: var(--color-gold); margin-bottom: var(--space-sm); }
.hp-pillar__icon {
  width: 48px; height: 48px;
  margin: 0 0 var(--space-sm);
  display: grid; place-items: center;
  background: transparent;
  border: 1px solid var(--color-gold-20);
  color: var(--color-gold);
  border-radius: 10px;
}
.hp-pillar__icon svg { width: 26px; height: 26px; }
.hp-pillar h3 { font-size: var(--fs-h3); }
.hp-pillar p { font-size: var(--fs-sm); }

/* =========================================================
   CURSOS (cards editoriais com micro-acento dourado)
   ========================================================= */
.hp-courses { background: var(--color-surface); }
.hp-courses__grid { display: grid; grid-template-columns: 1fr; gap: var(--space-md); }
.hp-course {
  position: relative;
  display: flex; flex-direction: column; overflow: hidden;
  border: 1px solid var(--color-line);
  box-shadow: none;
}
.hp-course::after {
  content: ""; position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: var(--color-gold);
  border-radius: var(--radius-lg) var(--radius-lg) 0 0;
  transform: scaleX(0); transform-origin: left;
  transition: transform var(--transition-slow); z-index: 1;
}
.hp-course.is-interactive:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); border-color: var(--color-gold-soft); }
.hp-course.is-interactive:hover::after { transform: scaleX(1); }
.hp-course__media {
  position: relative; display: block; aspect-ratio: 16 / 9;
  background: linear-gradient(160deg, var(--color-ink), var(--color-deep));
  overflow: hidden;
}
.hp-course__media img { width: 100%; height: 100%; object-fit: cover; transition: transform var(--transition-slow); will-change: transform; }
.hp-course.is-interactive:hover .hp-course__media img { transform: scale(1.04); }
.hp-course__media--soon { display: grid; place-items: center; color: rgba(255,255,255,0.5); }
.hp-course__media--soon svg { width: 40px; height: 40px; }
.hp-course__tag {
  position: absolute; top: 10px; left: 10px;
  background: rgba(15,27,45,0.55);
  backdrop-filter: blur(6px); -webkit-backdrop-filter: blur(6px);
  border: 1px solid var(--color-gold-line);
  color: #fff; font-size: var(--fs-xs); font-weight: var(--fw-medium);
  padding: 4px 10px; border-radius: var(--radius-pill);
}
.hp-course__tag--soon { background: rgba(255,255,255,0.9); color: var(--color-text-muted); border-color: var(--color-line); }
.hp-course__body { padding: var(--space-md); display: flex; flex-direction: column; gap: var(--space-xs); flex: 1; }
.hp-course__title { font-size: 1.2rem; letter-spacing: -0.01em; margin: 0.25rem 0 0; }
.hp-course__title a { color: var(--color-ink); }
.hp-course__title a:hover { color: var(--color-primary); }
.hp-course__meta { list-style: none; padding: 0; margin: 0; display: flex; flex-wrap: wrap; gap: var(--space-xs); color: var(--color-text-muted); font-size: var(--fs-sm); }
.hp-course__meta li::after { content: "\00B7"; margin-left: var(--space-xs); color: var(--color-line); }
.hp-course__meta li:last-child::after { content: ""; }
.hp-course__foot { margin-top: auto; padding-top: var(--space-sm); display: flex; align-items: flex-end; justify-content: space-between; gap: var(--space-sm); }
.hp-course__pricewrap::before { content: "A partir de"; display: block; font-size: var(--fs-xs); text-transform: uppercase; letter-spacing: 0.08em; color: var(--color-text-muted); font-weight: var(--fw-medium); }
.hp-course__price { font-weight: var(--fw-bold); color: var(--color-ink); font-size: 1.2rem; font-variant-numeric: tabular-nums; }
.hp-course__price del { color: var(--color-text-muted); font-weight: var(--fw-regular); font-size: 0.85em; margin-right: 4px; }
.hp-course--soon { opacity: 0.9; }
.hp-course--soon::after { display: none; }
.hp-course--soon .hp-course__body { justify-content: center; }

/* =========================================================
   BENEFICIOS (indice editorial com barra-acento)
   ========================================================= */
.hp-benefits__grid { display: grid; grid-template-columns: 1fr; gap: var(--space-md); }
.hp-benefit {
  position: relative; overflow: hidden;
  display: flex; align-items: flex-start; gap: var(--space-sm);
  padding: var(--space-md) var(--space-lg) var(--space-md) var(--space-lg);
  background: transparent; border: 0; border-radius: 0; box-shadow: none;
}
.hp-benefit::before { content: ""; position: absolute; left: 0; top: 0; bottom: 0; width: 3px; background: var(--color-gold); transform: scaleY(0); transform-origin: top; transition: transform var(--transition-slow); }
.hp-benefit:hover::before { transform: scaleY(1); }
.hp-benefit__icon {
  flex-shrink: 0; width: 44px; height: 44px;
  display: grid; place-items: center;
  background: transparent; border: 1px solid var(--color-gold-20);
  color: var(--color-gold); border-radius: 10px;
  transition: background var(--transition), color var(--transition), border-color var(--transition);
}
.hp-benefit:hover .hp-benefit__icon { border-color: var(--color-gold); background: var(--color-gold-10); }
.hp-benefit__icon svg { width: 22px; height: 22px; }
.hp-benefit h3 { font-size: 1.05rem; letter-spacing: -0.01em; margin-bottom: 0.15rem; }
.hp-benefit p { font-size: var(--fs-sm); }

/* =========================================================
   POR QUE ESTUDAR CONOSCO (split com moldura e selo)
   ========================================================= */
.hp-why { background: var(--color-surface-2); }
.hp-why__grid { display: grid; grid-template-columns: 1fr; gap: var(--space-lg); align-items: center; }
.hp-why__media { position: relative; margin: 0; border-radius: var(--radius-lg); overflow: hidden; box-shadow: var(--shadow-md); aspect-ratio: 16 / 10; }
.hp-why__media img { width: 100%; height: 100%; object-fit: cover; }
.hp-why__media::after { content: ""; position: absolute; inset: 10px; border: 1px solid var(--color-gold-line); border-radius: 8px; pointer-events: none; }
.hp-why__caption {
  position: absolute; left: 16px; bottom: 16px; color: #fff;
  font-size: var(--fs-xs); letter-spacing: 0.06em; text-transform: uppercase;
  background: rgba(15,27,45,0.45); backdrop-filter: blur(4px); -webkit-backdrop-filter: blur(4px);
  padding: 6px 12px; border-radius: var(--radius-pill);
}
.hp-why__badge {
  position: absolute; right: var(--space-sm); bottom: var(--space-sm);
  padding: var(--space-sm) var(--space-md);
  background: var(--color-surface); border-radius: var(--radius);
  box-shadow: var(--shadow-lg); border-left: 3px solid var(--color-gold);
}
.hp-why__badge strong { display: block; color: var(--color-ink); font-size: 1.25rem; }
.hp-why__badge span { font-size: var(--fs-xs); color: var(--color-text-muted); }
.hp-why__content h2 { margin-bottom: var(--space-2xs); }
.hp-why__list { list-style: none; padding: 0; margin: 0 0 var(--space-md); display: grid; gap: var(--space-sm); }
.hp-why__list li { display: flex; align-items: flex-start; gap: 0.65rem; }
.hp-why__list svg {
  flex-shrink: 0; width: 22px; height: 22px;
  color: var(--color-gold); background: transparent;
  border: 1px solid var(--color-gold-20);
  border-radius: 50%; padding: 3px; margin-top: 1px;
}

/* =========================================================
   DEPOIMENTOS (citacao editorial)
   ========================================================= */
.hp-tst__grid { display: grid; grid-template-columns: 1fr; gap: var(--space-md); }
.hp-tst__card {
  position: relative; padding: var(--space-lg) var(--space-md) var(--space-md); margin: 0;
  border: 1px solid var(--color-line); box-shadow: var(--shadow-xs);
  transition: transform var(--transition-slow), box-shadow var(--transition-slow);
}
.hp-tst__card:hover { transform: translateY(-3px); box-shadow: var(--shadow-md); }
.hp-tst__card::before { content: "\201C"; position: absolute; top: 8px; left: 16px; font-size: 4.5rem; line-height: 1; color: var(--color-gold-soft); font-family: Georgia, serif; opacity: 0.7; pointer-events: none; }
.hp-tst__card .lp-testimonial__stars { color: var(--color-star); margin-bottom: var(--space-sm); display: inline-flex; gap: 2px; position: relative; z-index: 1; }
.hp-tst__card .lp-testimonial__stars svg { width: 16px; height: 16px; }
.hp-tst__card p { position: relative; z-index: 1; font-style: normal; font-weight: var(--fw-light); font-size: var(--fs-lead); line-height: 1.55; color: var(--color-ink); }
.hp-tst__card footer { border-top: 1px solid var(--color-line); padding-top: var(--space-sm); margin-top: var(--space-md); display: flex; align-items: center; gap: 0.6rem; }
.hp-tst__avatar {
  width: 40px; height: 40px; border-radius: 50%;
  background: var(--color-primary-10); color: var(--color-primary);
  display: grid; place-items: center; font-weight: var(--fw-semibold); font-size: var(--fs-sm);
  flex-shrink: 0; box-shadow: 0 0 0 1px var(--color-surface), 0 0 0 2px var(--color-gold-20);
}
.hp-tst__card footer strong { display: block; color: var(--color-ink); font-size: var(--fs-sm); }
.hp-tst__card footer > span > span { color: var(--color-text-muted); font-size: var(--fs-xs); }

/* =========================================================
   CHAMADA FINAL
   ========================================================= */
.hp-final { position: relative; overflow: hidden; isolation: isolate; text-align: center; color: #fff; padding-block: var(--space-2xl); }
.hp-final__bg { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; z-index: -2; }
.hp-final__overlay { position: absolute; inset: 0; z-index: -1; background: radial-gradient(120% 120% at 50% 40%, rgba(15,27,45,0.78), rgba(15,27,45,0.92)); }
.hp-final__inner { max-width: 680px; margin: 0 auto; }
.hp-final .eyebrow { justify-content: center; color: var(--color-gold-soft); }
.hp-final .eyebrow::before { background: var(--color-gold-soft); }
.hp-final h2 { color: #fff; font-size: clamp(1.7rem, 1.2rem + 2.4vw, 2.6rem); font-weight: var(--fw-light); }
.hp-final h2 strong { font-weight: var(--fw-bold); color: var(--color-gold-soft); }
.hp-final p { color: rgba(255,255,255,0.85); margin-bottom: var(--space-lg); position: relative; padding-bottom: var(--space-lg); }
.hp-final p::after { content: ""; position: absolute; left: 50%; bottom: 0; transform: translateX(-50%); width: 40px; height: 1px; background: var(--color-gold-soft); }
.hp-final__seal {
  display: inline-flex; align-items: center; gap: 0.5rem; margin-top: var(--space-md);
  padding: 0.5rem 1rem; background: rgba(255,255,255,0.08);
  border: 1px solid rgba(255,255,255,0.18); border-radius: var(--radius-pill);
  font-size: var(--fs-sm); color: rgba(255,255,255,0.85);
}
.hp-final__seal svg { width: 18px; height: 18px; color: var(--color-gold-soft); }

/* =========================================================
   TRILHA DE FORMACAO (unico beat imersivo escuro)
   ========================================================= */
.hp-path { position: relative; isolation: isolate; background: linear-gradient(160deg, var(--color-ink) 0%, var(--color-deep) 100%); }
.hp-path::before { content: ""; position: absolute; inset: 0; z-index: -1; background: radial-gradient(80% 60% at 15% 0%, rgba(201,162,75,0.14), transparent 60%); }
.hp-path .eyebrow { color: var(--color-gold-soft); }
.hp-path .eyebrow::before { background: var(--color-gold-soft); }
.hp-path h2 { color: #fff; }
.hp-path .lead { color: rgba(255,255,255,0.78); }
.hp-path__steps { list-style: none; padding: 0; margin: 0; display: grid; grid-template-columns: 1fr; gap: var(--space-md); }
.hp-path__step {
  position: relative; overflow: hidden;
  padding: var(--space-md);
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.10);
  border-radius: var(--radius-lg);
  transition: transform var(--transition-slow), box-shadow var(--transition-slow);
}
.hp-path__step:hover { transform: translateY(-3px); }
.hp-path__step--live { border-color: var(--color-gold); box-shadow: 0 0 0 1px var(--color-gold), 0 18px 44px rgba(201,162,75,0.18); }
.hp-path__num {
  position: absolute; top: -0.2em; right: 0.1em;
  font-size: clamp(3rem, 2rem + 4vw, 5rem); font-weight: var(--fw-bold);
  color: transparent; -webkit-text-stroke: 1px var(--color-gold);
  line-height: 1; opacity: 0.55; z-index: 0; pointer-events: none;
}
@supports not ((-webkit-text-stroke: 1px red)) { .hp-path__num { color: rgba(201,162,75,0.18); } }
.hp-path__body { position: relative; z-index: 1; }
.hp-path__body h3 { color: #fff; font-size: var(--fs-h3); margin: var(--space-2xs) 0 0.2rem; }
.hp-path__body p { color: rgba(255,255,255,0.7); font-size: var(--fs-sm); margin: 0; }
.hp-path__status { display: inline-block; font-size: var(--fs-xs); font-weight: var(--fw-semibold); padding: 3px 10px; border-radius: var(--radius-pill); }
.hp-path__status--soon { background: rgba(255,255,255,0.08); color: rgba(255,255,255,0.7); }
.hp-path__status--live { background: rgba(47,133,90,0.28); color: #8FE0B4; }
.hp-path__link { position: relative; display: inline-block; margin-top: var(--space-xs); font-weight: var(--fw-semibold); font-size: var(--fs-sm); color: var(--color-gold-soft); }
.hp-path__link::after { content: ""; display: block; height: 1px; background: var(--color-gold-soft); transform: scaleX(0); transform-origin: left; transition: transform var(--transition); }
.hp-path__link:hover::after { transform: scaleX(1); }

/* =========================================================
   SCROLL-REVEAL (transform/opacity, respeita reduced-motion)
   ========================================================= */
.reveal { opacity: 0; transform: translateY(16px); transition: opacity 0.6s ease, transform 0.6s ease; will-change: opacity, transform; }
.reveal.is-in { opacity: 1; transform: none; transition-delay: calc(var(--i, 0) * 70ms); }
@media (prefers-reduced-motion: reduce) { .reveal { opacity: 1; transform: none; } }

/* =========================================================
   BREAKPOINTS
   ========================================================= */
@media (min-width: 768px) {
  .hp-pillars { grid-template-columns: repeat(3, 1fr); gap: var(--space-xl); }
  .hp-pillar + .hp-pillar { border-left: 1px solid var(--color-line); padding-left: var(--space-lg); }
  .hp-courses__grid { grid-template-columns: repeat(2, 1fr); }
  .hp-benefits__grid { grid-template-columns: repeat(2, 1fr); gap: 0; border-top: 1px solid var(--color-line); }
  .hp-benefit { border-bottom: 1px solid var(--color-line); }
  .hp-tst__grid { grid-template-columns: repeat(3, 1fr); }
  .hp-head--row { flex-direction: row; align-items: flex-end; justify-content: space-between; }
}

@media (min-width: 880px) {
  .hp-path__steps { position: relative; grid-template-columns: repeat(3, 1fr); gap: var(--space-lg); }
  .hp-path__steps::before { content: ""; position: absolute; top: 46px; left: 12%; right: 12%; height: 1px; background: linear-gradient(90deg, transparent, var(--color-gold-line), transparent); z-index: 0; }
  .hp-path__step { z-index: 1; }
}

@media (min-width: 1024px) {
  .hp-hero { min-height: clamp(520px, 76vh, 660px); }
  .hp-courses__grid { grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: var(--space-lg); }
  .hp-benefits__grid { grid-template-columns: repeat(3, 1fr); }
  .hp-tst__grid { gap: var(--space-lg); }
  .hp-why__grid { grid-template-columns: 1fr 1.05fr; gap: var(--space-xl); }
}

/* =========================================================
   PAGINA SOBRE - reaproveita hp-hero / hp-why / hp-final,
   com um hero mais contido (institucional, sem CTAs duplos)
   ========================================================= */
.about-hero { min-height: 340px; padding-block: var(--space-xl); }
.about-hero .hp-hero__inner { max-width: 640px; }
@media (min-width: 1024px) {
  .about-hero { min-height: 380px; }
}

/* =========================================================
   PAGINA CONTATO - cards de canal (WhatsApp / e-mail)
   ========================================================= */
.contact-grid { display: grid; grid-template-columns: 1fr; gap: var(--space-md); max-width: 880px; margin: 0 auto; }
.contact-card {
  padding: var(--space-lg);
  text-align: center;
  display: flex; flex-direction: column; align-items: center;
  transition: transform var(--transition-slow), box-shadow var(--transition-slow);
}
.contact-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); }
.contact-card--highlight { border-color: var(--color-gold); box-shadow: var(--shadow-md); }
.contact-card__icon {
  width: 64px; height: 64px;
  margin-bottom: var(--space-sm);
  display: grid; place-items: center;
  background: var(--color-gold-10);
  color: var(--color-gold);
  border-radius: 16px;
}
.contact-card__icon svg { width: 30px; height: 30px; }
.contact-card .badge { margin-bottom: var(--space-sm); }
.contact-card__title { margin: 0 0 var(--space-2xs); }
.contact-card__text { color: var(--color-text-muted); font-size: var(--fs-sm); max-width: 32ch; }
.contact-card__value { font-weight: var(--fw-semibold); color: var(--color-ink); font-size: 1.1rem; margin: var(--space-xs) 0 var(--space-md); }
.contact-card__cta { width: 100%; max-width: 280px; }

@media (min-width: 768px) {
  .contact-grid { grid-template-columns: repeat(2, 1fr); align-items: stretch; }
}
