/* === HOME — estilos específicos ===================================== */

/* === Rotador de frases do hero ======================================= */
/* Grid de 1 célula compartilhada: a frase mais alta determina a altura
   e todas se sobrepõem na mesma área, sem precisar de min-height fixo. */
.hero__rotador {
  display: grid;
  grid-template-areas: "stack";
}
.hero__rot-frase {
  grid-area: stack;
  display: block;
  opacity: 0; transform: translateY(10px);
  transition: opacity .55s var(--ease), transform .55s var(--ease);
  will-change: opacity, transform;
}
.hero__rot-frase.ativo    { opacity: 1; transform: translateY(0); }
.hero__rot-frase.saindo   { opacity: 0; transform: translateY(-10px); }
.hero__rot-frase.entrando { opacity: 0; transform: translateY(10px); }

/* Bolinhas do carrossel — pílula expandida no ativo */
.hero__rot-dots {
  display: flex; gap: 8px; align-items: center;
  margin: var(--sp-4) 0 var(--sp-5);
}
.hero__rot-dots button {
  width: 8px; height: 8px;
  padding: 0; border: 0; cursor: pointer;
  background: rgba(255,255,255,.35);
  border-radius: 99px;
  transition: background .2s var(--ease), width .3s var(--ease), transform .15s var(--ease);
}
.hero__rot-dots button:hover { background: rgba(255,255,255,.6); transform: scale(1.15); }
.hero__rot-dots button.ativo {
  background: var(--yellow);
  width: 28px;   /* pílula expandida sinalizando posição atual */
}
@media (prefers-reduced-motion: reduce) {
  .hero__rot-frase { transition: opacity .2s ease; transform: none; }
  .hero__rot-dots button { transition: background .2s; }
}


/* Referências (antiga "Modelos"): cabeçalho editorial com link à direita
   e blob amarelo decorativo no canto. */
.modelos-sec { position: relative; overflow: hidden; }
.modelos-sec::before {
  content: ""; position: absolute; top: 60px; right: -100px; width: 300px; height: 300px;
  background: var(--yellow); border-radius: 50%; opacity: .15; filter: blur(20px);
}
.modelos-sec__head {
  display: flex; justify-content: space-between; align-items: end; gap: var(--sp-5);
  margin-bottom: var(--sp-7); flex-wrap: wrap; position: relative;
}
.modelos-sec__titulo { max-width: 640px; }
.modelos-sec__titulo .eyebrow { margin-bottom: var(--sp-3); }
.modelos-sec__titulo h2 { margin-bottom: var(--sp-3); }
.modelos-sec__titulo h2 em { font-style: normal; color: var(--pink); font-weight: 700; }
.modelos-sec__sub {
  color: var(--muted); font-size: var(--fs-md); line-height: 1.55;
  max-width: 56ch; margin: 0;
}
@media (max-width: 720px) {
  .modelos-sec__head { flex-direction: column; align-items: flex-start; }
}

/* === NASCE — "Como sua casa nasce", processo em 4 passos ============ */
.nasce { background: var(--bg); }
.nasce .sec-head { text-align: center; margin-inline: auto; }
.nasce .sec-head h2 em { font-style: normal; color: var(--pink); font-weight: 700; }
.nasce__passos {
  list-style: none; padding: 0; margin: 0;
  display: grid; gap: var(--sp-5);
  grid-template-columns: 1fr;
  counter-reset: nasce;
  position: relative;
}
@media (min-width: 720px) {
  .nasce__passos { grid-template-columns: repeat(2, 1fr); gap: var(--sp-5); }
}
@media (min-width: 1080px) {
  .nasce__passos { grid-template-columns: repeat(4, 1fr); gap: var(--sp-4); }
}
.nasce__passo {
  position: relative;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: var(--r);
  padding: var(--sp-6) var(--sp-5);
  transition: transform .25s var(--ease), box-shadow .25s var(--ease), border-color .25s var(--ease);
}
.nasce__passo:hover {
  transform: translateY(-4px);
  box-shadow: var(--sh-3);
  border-color: transparent;
}
.nasce__passo::before {
  content: ""; position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: var(--yellow);
  border-radius: var(--r) var(--r) 0 0;
  transform: scaleX(0); transform-origin: left;
  transition: transform .35s var(--ease);
}
.nasce__passo:hover::before { transform: scaleX(1); }
.nasce__num {
  font-family: var(--font-body);
  font-size: 44px; font-weight: 800;
  color: var(--yellow);
  line-height: 1; letter-spacing: -.04em;
  margin-bottom: var(--sp-4);
  display: inline-block;
}
.nasce__passo h3 {
  font-size: var(--fs-xl); color: var(--navy);
  margin: 0 0 var(--sp-2);
  letter-spacing: -.01em;
}
.nasce__passo p {
  color: var(--muted); font-size: var(--fs-base); line-height: 1.55;
  margin: 0;
}
/* linha conectora entre passos (somente desktop horizontal) */
@media (min-width: 1080px) {
  .nasce__passo::after {
    content: ""; position: absolute;
    top: 56px; right: -12px;
    width: 24px; height: 2px;
    background: linear-gradient(to right, var(--yellow), rgba(247,199,61,0));
    border-radius: 2px;
    z-index: 1;
  }
  .nasce__passo:last-child::after { display: none; }
}

/* DEPOIMENTO — ilustração da chave + quote, estilo editorial limpo */
.depoimento {
  background: var(--bg);
  padding-block: var(--sp-9);
}
.depoimento__row {
  display: grid; gap: var(--sp-7); align-items: center;
  grid-template-columns: 1fr;
}
@media (min-width: 900px) { .depoimento__row { grid-template-columns: 1fr 1.2fr; } }
.depoimento__art {
  position: relative;
  background: var(--bg-soft);
  border-radius: var(--r-lg);
  aspect-ratio: 1/1; max-width: 380px; margin-inline: auto;
  display: grid; place-items: center;
  padding: var(--sp-6);
}
.depoimento__art::before {
  content: ""; position: absolute; inset: 0;
  background: radial-gradient(circle at 30% 30%, rgba(247,199,61,.18), transparent 60%);
  border-radius: inherit; pointer-events: none;
}
.depoimento__art img { width: 80%; position: relative; }
.depoimento__quote {
  font-size: clamp(22px, 2.6vw, 32px);
  line-height: 1.25; color: var(--navy);
  font-weight: 400; letter-spacing: -.01em;
  margin: var(--sp-3) 0 var(--sp-5);
}
.depoimento__quote::before {
  content: "\201C"; /* aspa dupla curva esquerda, inline antes do texto */
}
.depoimento__quote::after {
  content: "\201D"; /* aspa dupla curva direita, inline apos o texto */
}
.depoimento__quote em { font-style: normal; color: var(--pink); font-weight: 700; }
.depoimento__autor {
  font-size: var(--fs-sm); color: var(--muted);
  display: flex; flex-direction: column; gap: 2px;
}
.depoimento__autor b { color: var(--navy); font-size: var(--fs-md); }

/* CTA final em wrap escuro com glow + ilustração de família */
.cta-wrap {
  background: linear-gradient(135deg, var(--navy) 0%, var(--navy-3) 100%);
  border-radius: var(--r-lg); padding: var(--sp-8) var(--sp-7); color: #fff;
  position: relative; overflow: hidden;
  display: grid; grid-template-columns: 1fr; gap: var(--sp-6); align-items: center;
}
@media (min-width: 900px) { .cta-wrap { grid-template-columns: 1.4fr 1fr; } }
.cta-wrap::before { content: ""; position: absolute; right: -80px; top: -80px; width: 380px; height: 380px; background: radial-gradient(circle, rgba(247,199,61,.35) 0%, transparent 70%); border-radius: 50%; }
.cta-wrap::after { content: ""; position: absolute; left: -60px; bottom: -60px; width: 240px; height: 240px; background: radial-gradient(circle, rgba(43,196,240,.25) 0%, transparent 70%); border-radius: 50%; }
.cta-wrap h2 { color: #fff; max-width: 18ch; position: relative; }
.cta-wrap h2 b { color: var(--yellow); font-weight: 700; }
.cta-wrap p { color: rgba(255,255,255,.88); font-size: var(--fs-md); max-width: 44ch; position: relative; margin-top: var(--sp-3); }
.cta-wrap .cluster { position: relative; }
.cta-wrap__art { display: none; position: relative; }
@media (min-width: 900px) {
  .cta-wrap__art { display: block; text-align: center; }
  .cta-wrap__art img { width: 260px; margin-inline: auto; filter: drop-shadow(0 12px 32px rgba(0,0,0,.25)); }
}

/* === ASSINATURA — selo da marca com logo vertical (entre CTA e footer) === */
.assinatura {
  position: relative;
  background: var(--bg);
  padding: var(--sp-9) var(--sp-5) var(--sp-8);
  overflow: hidden;
}
.assinatura::before {
  content: ""; position: absolute; inset: 0;
  background:
    radial-gradient(circle at 15% 30%, rgba(247,199,61,.10), transparent 40%),
    radial-gradient(circle at 85% 70%, rgba(43,196,240,.08), transparent 45%);
  pointer-events: none;
}
.assinatura__inner {
  position: relative; z-index: 1;
  display: flex; flex-direction: column; align-items: center; gap: var(--sp-5);
  text-align: center;
}
.assinatura__logo {
  width: 140px; height: auto;
  filter: drop-shadow(0 8px 24px rgba(13, 43, 107, 0.12));
  transition: transform .4s var(--ease);
}
.assinatura__logo:hover { transform: translateY(-4px); }
.assinatura__frase {
  max-width: 52ch;
  font-size: var(--fs-md);
  color: var(--muted);
  line-height: 1.55;
}
.assinatura__frase b { color: var(--navy); font-weight: 700; }
.assinatura__dotline { display: inline-flex; gap: 4px; margin-top: var(--sp-2); }
.assinatura__dotline i {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--yellow); display: inline-block;
}
.assinatura__dotline i:nth-child(2) { background: var(--sky); }
.assinatura__dotline i:nth-child(3) { background: var(--pink); }

@media (min-width: 720px) {
  .assinatura__logo { width: 180px; }
}

/* === ASSINA — "Quem assina" (Ronaldo + logo da marca) ============== */
.assina {
  position: relative;
  background: var(--bg);
  padding: var(--sp-9) var(--sp-5);
  overflow: hidden;
}
.assina::before {
  content: ""; position: absolute; inset: 0;
  background:
    radial-gradient(circle at 20% 30%, rgba(247,199,61,.10), transparent 40%),
    radial-gradient(circle at 80% 70%, rgba(43,196,240,.08), transparent 45%);
  pointer-events: none;
}
.assina__grid {
  position: relative; z-index: 1;
  display: grid; gap: var(--sp-8); align-items: center;
  grid-template-columns: 1fr;
}
@media (min-width: 900px) {
  .assina__grid { grid-template-columns: 1.5fr auto; gap: var(--sp-9); }
}

/* Coluna esquerda: as duas pessoas empilhadas */
.assina__pessoas {
  display: flex; flex-direction: column;
  gap: var(--sp-5);
}
.assina__eyebrow { margin-bottom: var(--sp-1); }

/* Card de pessoa: foto à esquerda, dados à direita (sempre que possível) */
.assina__pessoa {
  display: grid; grid-template-columns: 1fr; gap: var(--sp-4);
  align-items: center;
  text-align: center;
}
@media (min-width: 600px) {
  .assina__pessoa {
    grid-template-columns: 140px 1fr;
    gap: var(--sp-5);
    text-align: left;
  }
}
.assina__foto {
  position: relative;
  width: 140px; height: 140px; margin-inline: auto;
  border-radius: 50%; overflow: hidden;
  box-shadow: 0 10px 28px rgba(13, 43, 107, 0.18);
  border: 4px solid #fff;
  flex-shrink: 0;
}
.assina__foto::after {
  content: ""; position: absolute; inset: -6px;
  border-radius: 50%;
  background: conic-gradient(from 130deg, var(--yellow), var(--sky), var(--pink), var(--yellow));
  z-index: -1;
  filter: blur(8px); opacity: .45;
}
.assina__foto img { width: 100%; height: 100%; object-fit: cover; object-position: center top; }
.assina__dados h3 {
  color: var(--navy);
  margin: 0 0 var(--sp-1);
  font-size: var(--fs-xl);
}
.assina__cargo {
  color: var(--pink); font-weight: 700; font-size: var(--fs-xs);
  letter-spacing: .06em; text-transform: uppercase;
  margin: 0;
  line-height: 1.4;
}
.assina__quote {
  margin: var(--sp-3) 0 0;
  padding-left: var(--sp-3);
  border-left: 3px solid var(--yellow);
}
.assina__quote p {
  font-family: var(--font-body);
  font-size: var(--fs-base);
  color: var(--ink-2);
  font-style: italic;
  line-height: 1.55;
  margin: 0;
}

/* Lado direito: logo + assinatura da marca */
.assina__marca {
  display: flex; flex-direction: column; align-items: center;
  gap: var(--sp-4); text-align: center;
  padding: var(--sp-6) var(--sp-5);
  border-left: 1px dashed var(--line);
}
@media (max-width: 900px) {
  .assina__marca { border-left: 0; border-top: 1px dashed var(--line); padding-top: var(--sp-7); }
}
.assina__logo {
  width: 200px; max-width: 100%; height: auto;
  filter: drop-shadow(0 8px 20px rgba(13, 43, 107, 0.12));
  transition: transform .4s var(--ease);
}
@media (min-width: 900px) { .assina__logo { width: 240px; } }
.assina__logo:hover { transform: translateY(-4px); }
.assina__lugar {
  max-width: 32ch;
  font-size: var(--fs-sm);
  color: var(--muted);
  line-height: 1.55;
}
.assina__lugar b { color: var(--navy); font-weight: 700; }
.assina__dotline { display: inline-flex; gap: 4px; }
.assina__dotline i {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--yellow); display: inline-block;
}
.assina__dotline i:nth-child(2) { background: var(--sky); }
.assina__dotline i:nth-child(3) { background: var(--pink); }

