/* ============================================================
   ESTILOS PRINCIPAIS — KIDS Centro Educacional
   Reset, tipografia, layout, seções, hero, componentes globais.
   ============================================================ */

/* ============================================================
   RESET BÁSICO
   ============================================================ */

*,
*::before,
*::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  scroll-behavior: smooth;
  -webkit-text-size-adjust: 100%;
}

body {
  font-family: var(--fonte-corpo);
  font-size: var(--texto-base);
  font-weight: 400;
  line-height: 1.65;
  color: var(--cor-texto);
  background-color: var(--cor-branca);
  overflow-x: hidden;
}

img, svg, video {
  display: block;
  max-width: 100%;
  height: auto;
}

a {
  color: inherit;
  text-decoration: none;
  transition: color var(--transicao-rapida);
}

button {
  font-family: inherit;
  border: none;
  background: none;
  cursor: pointer;
}

ul, ol {
  list-style: none;
}


/* ============================================================
   TIPOGRAFIA BASE
   ============================================================ */

h1, h2, h3, h4, h5, h6 {
  font-family: var(--fonte-titulo);
  font-weight: 700;
  line-height: 1.15;
  letter-spacing: -0.025em;
  color: var(--cor-primaria);
}

h1 { font-size: clamp(2.25rem, 6vw, var(--titulo-display)); }
h2 { font-size: clamp(1.75rem, 4vw, var(--titulo-grande)); font-weight: 700; }
h3 { font-size: clamp(1.25rem, 2.5vw, var(--titulo-pequeno)); font-weight: 600; }

p { margin-bottom: var(--espaco-pequeno); }
p:last-child { margin-bottom: 0; }


/* ============================================================
   CONTAINERS
   ============================================================ */

.conteudo-central {
  width: 100%;
  max-width: var(--largura-conteudo);
  margin: 0 auto;
  padding: 0 var(--espaco-medio);
}

.conteudo-estreito {
  width: 100%;
  max-width: var(--largura-estreita);
  margin: 0 auto;
  padding: 0 var(--espaco-medio);
}


/* ============================================================
   SEÇÕES
   ============================================================ */

.secao {
  padding: var(--espaco-secao) 0;
}

.secao-creme {
  background-color: var(--cor-creme);
}

.secao-escura {
  background-color: var(--cor-escura);
  color: var(--cor-creme);
}

.secao-escura h1,
.secao-escura h2,
.secao-escura h3 {
  color: var(--cor-branca);
}

.secao-verde {
  background-color: var(--cor-verde);
  color: var(--cor-branca);
}

.secao-verde h1,
.secao-verde h2,
.secao-verde h3 {
  color: var(--cor-branca);
}


/* ============================================================
   ETIQUETA DE SEÇÃO
   ============================================================ */

.etiqueta-secao {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--fonte-corpo);
  font-size: var(--texto-pequeno);
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--cor-verde);
  margin-bottom: var(--espaco-pequeno);
}

.etiqueta-secao::before {
  content: "";
  width: 28px;
  height: 2px;
  background-color: var(--cor-verde);
  border-radius: 2px;
  flex-shrink: 0;
}

.secao-escura .etiqueta-secao {
  color: var(--cor-amarelo);
}

.secao-escura .etiqueta-secao::before {
  background-color: var(--cor-amarelo);
}


/* ============================================================
   CABEÇALHO DE SEÇÃO
   ============================================================ */

.cabecalho-secao {
  max-width: 720px;
  margin-bottom: var(--espaco-grande);
}

.cabecalho-secao.centralizado {
  margin-left: auto;
  margin-right: auto;
  text-align: center;
}

.cabecalho-secao.centralizado .etiqueta-secao::before {
  display: none;
}

.cabecalho-secao p {
  font-size: var(--texto-medio);
  color: var(--cor-texto-suave);
  margin-top: var(--espaco-pequeno);
  line-height: 1.75;
}

.secao-escura .cabecalho-secao p {
  color: rgba(245, 241, 225, 0.7);
}


/* ============================================================
   HERO PRINCIPAL
   ============================================================ */

.bloco-hero {
  min-height: 100svh;
  display: flex;
  align-items: center;
  background-color: var(--cor-creme);
  padding: calc(var(--espaco-extra) + 72px) 0 var(--espaco-extra);
  position: relative;
  overflow: hidden;
}

/* Detalhe decorativo de fundo */
.bloco-hero::before {
  content: "";
  position: absolute;
  width: 700px;
  height: 700px;
  right: -180px;
  top: 50%;
  transform: translateY(-60%);
  background: radial-gradient(circle, rgba(0, 164, 112, 0.07) 0%, transparent 70%);
  border-radius: 50%;
  pointer-events: none;
}

.bloco-hero::after {
  content: "";
  position: absolute;
  width: 400px;
  height: 400px;
  left: -100px;
  bottom: -100px;
  background: radial-gradient(circle, rgba(0, 164, 200, 0.05) 0%, transparent 70%);
  border-radius: 50%;
  pointer-events: none;
}

.hero-grade {
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: var(--espaco-grande);
  align-items: center;
}

/* Linha de cor acima da etiqueta */
.hero-etiqueta-wrapper {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: var(--espaco-medio);
}

.hero-tag {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background-color: rgba(0, 164, 112, 0.1);
  color: var(--cor-verde);
  font-size: var(--texto-pequeno);
  font-weight: 600;
  letter-spacing: 0.08em;
  padding: 6px 14px;
  border-radius: var(--raio-pilula);
  border: 1px solid rgba(0, 164, 112, 0.2);
}

.hero-tag .ponto {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background-color: var(--cor-verde);
  animation: piscar 2s ease-in-out infinite;
}

@keyframes piscar {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.3; }
}

.hero-titulo {
  font-size: clamp(2.5rem, 6.5vw, 5rem);
  font-weight: 800;
  line-height: 1.05;
  letter-spacing: -0.03em;
  color: var(--cor-primaria);
  margin-bottom: var(--espaco-medio);
}

.hero-titulo .em-destaque {
  color: var(--cor-verde);
  position: relative;
  white-space: nowrap;
}

.hero-titulo .em-destaque-azul {
  color: var(--cor-azul);
}

.hero-subtitulo {
  font-size: var(--texto-medio);
  color: var(--cor-texto-suave);
  max-width: 520px;
  margin-bottom: var(--espaco-medio);
  line-height: 1.75;
  font-weight: 400;
}

.hero-acoes {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--espaco-pequeno);
  margin-bottom: var(--espaco-grande);
}

/* Barra de credibilidade */
.hero-credibilidade {
  display: flex;
  flex-wrap: wrap;
  gap: var(--espaco-medio);
  padding-top: var(--espaco-medio);
  border-top: 1px solid var(--cor-borda);
}

.indicador {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.indicador strong {
  font-family: var(--fonte-titulo);
  font-size: var(--titulo-pequeno);
  font-weight: 800;
  color: var(--cor-primaria);
  letter-spacing: -0.03em;
  line-height: 1;
}

.indicador span {
  font-size: var(--texto-pequeno);
  color: var(--cor-texto-suave);
  font-weight: 400;
}

/* Imagem do hero */
.hero-imagem {
  position: relative;
}

.hero-imagem-principal {
  aspect-ratio: 4 / 5;
  border-radius: var(--raio-grande);
  overflow: hidden;
  background-color: var(--cor-creme-escura);
  box-shadow: var(--sombra-forte);
  position: relative;
}

.hero-imagem-principal > img:first-child {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--transicao-lenta);
}

.hero-imagem:hover .hero-imagem-principal > img:first-child {
  transform: scale(1.03);
}

/* Hero com mascote — fallback quando foto real está ausente */
.hero-com-mascote {
  background: linear-gradient(145deg, #CCE8DC 0%, #BAD5C7 45%, #D5E8F0 100%);
}

.hero-mascote-bloco {
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 82%;
  height: auto;
  object-fit: contain;
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--transicao-padrao);
}

.sem-foto .hero-mascote-bloco {
  opacity: 1;
}

/* Selo flutuante */
.selo-flutuante {
  position: absolute;
  bottom: var(--espaco-medio);
  left: calc(-1 * var(--espaco-medio));
  background-color: var(--cor-branca);
  padding: 14px 18px;
  border-radius: var(--raio-medio);
  box-shadow: var(--sombra-media);
  display: flex;
  align-items: center;
  gap: 12px;
  max-width: 220px;
}

.selo-flutuante .icone-selo {
  width: 42px;
  height: 42px;
  border-radius: 50%;
  background-color: var(--cor-amarelo);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.2rem;
  flex-shrink: 0;
}

.selo-flutuante strong {
  display: block;
  font-size: var(--texto-pequeno);
  font-weight: 700;
  color: var(--cor-primaria);
  line-height: 1.2;
}

.selo-flutuante span {
  font-size: var(--texto-mini);
  color: var(--cor-texto-suave);
}

/* Badge de mascote */
.hero-mascote {
  position: absolute;
  top: var(--espaco-medio);
  right: calc(-1 * var(--espaco-pequeno));
  width: 80px;
  height: 80px;
  filter: drop-shadow(0 8px 20px rgba(0, 0, 0, 0.12));
  animation: flutuar 4s ease-in-out infinite;
}

@keyframes flutuar {
  0%, 100% { transform: translateY(0px) rotate(-3deg); }
  50% { transform: translateY(-10px) rotate(3deg); }
}


/* ============================================================
   IMAGEM-BLOCO COM MASCOTE (ilustração como elemento principal)
   ============================================================ */

.imagem-com-mascote {
  background: linear-gradient(145deg, #D4EEE4 0%, #BDD5C8 55%, #EBE6D4 100%);
}

/* Aplica apenas a blocos de seção (não ao hero) */
.bloco-duas-colunas .imagem-com-mascote img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  padding: 2rem 2rem 0;
}


/* ============================================================
   BLOCO DE DUAS COLUNAS
   ============================================================ */

.bloco-duas-colunas {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--espaco-grande);
  align-items: center;
}

.bloco-duas-colunas.invertido .imagem-bloco {
  order: 2;
}

.bloco-duas-colunas .imagem-bloco {
  aspect-ratio: 5 / 8;
  border-radius: var(--raio-grande);
  overflow: hidden;
  background-color: var(--cor-creme-escura);
  position: relative;
}

.bloco-duas-colunas .imagem-bloco img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--transicao-lenta);
}

.bloco-duas-colunas:hover .imagem-bloco img {
  transform: scale(1.03);
}

/* Detalhe de cor na imagem */
.imagem-bloco::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(0, 164, 112, 0.08) 0%, transparent 50%);
  pointer-events: none;
}

.bloco-texto {
  display: flex;
  flex-direction: column;
  gap: var(--espaco-pequeno);
}

.bloco-texto h2 {
  margin-bottom: var(--espaco-pequeno);
}

.bloco-texto p {
  color: var(--cor-texto-suave);
  font-size: var(--texto-medio);
  line-height: 1.75;
}


/* ============================================================
   LISTA DE BENEFÍCIOS / DIFERENCIAIS
   ============================================================ */

.lista-beneficios {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-top: var(--espaco-medio);
}

.lista-beneficios li {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  font-size: var(--texto-base);
  color: var(--cor-texto-suave);
  line-height: 1.5;
}

.lista-beneficios li::before {
  content: "";
  flex-shrink: 0;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background-color: var(--cor-verde);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: center;
  background-size: 12px;
  margin-top: 2px;
}


/* ============================================================
   GRADE DE TURMAS / CATEGORIAS
   ============================================================ */

.grade-turmas {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--espaco-medio);
}

.card-turma {
  position: relative;
  border-radius: var(--raio-grande);
  overflow: hidden;
  background-color: var(--cor-creme-escura);
  min-height: 420px;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  transition: transform var(--transicao-padrao), box-shadow var(--transicao-padrao);
  cursor: pointer;
}

.card-turma:hover {
  transform: translateY(-6px);
  box-shadow: var(--sombra-forte);
}

.card-turma-imagem {
  position: absolute;
  inset: 0;
  overflow: hidden;
}

.card-turma-imagem img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--transicao-lenta);
}

.card-turma:hover .card-turma-imagem img {
  transform: scale(1.05);
}

.card-turma-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(13, 27, 26, 0.85) 0%, rgba(13, 27, 26, 0.1) 60%, transparent 100%);
}

.card-turma-conteudo {
  position: relative;
  z-index: 2;
  padding: var(--espaco-medio);
  color: var(--cor-branca);
}

.card-turma-tag {
  display: inline-block;
  padding: 4px 12px;
  border-radius: var(--raio-pilula);
  font-size: var(--texto-mini);
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  margin-bottom: 10px;
}

.card-turma-tag.verde  { background-color: var(--cor-verde); }
.card-turma-tag.azul   { background-color: var(--cor-azul); }

.card-turma-conteudo h3 {
  color: var(--cor-branca);
  font-size: var(--titulo-pequeno);
  font-weight: 700;
  margin-bottom: 8px;
}

.card-turma-conteudo p {
  color: rgba(255,255,255,0.75);
  font-size: var(--texto-base);
  margin-bottom: var(--espaco-pequeno);
}

.link-turma {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: var(--cor-amarelo);
  font-size: var(--texto-pequeno);
  font-weight: 600;
  letter-spacing: 0.06em;
  transition: gap var(--transicao-padrao);
}

.card-turma:hover .link-turma {
  gap: 10px;
}


/* ============================================================
   SEÇÃO DE DIFERENCIAIS
   ============================================================ */

.grade-diferenciais {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: var(--espaco-pequeno);
}

.diferencial-item {
  padding: var(--espaco-medio);
  background-color: var(--cor-branca);
  border-radius: var(--raio-medio);
  border: 1px solid var(--cor-borda-suave);
  transition: all var(--transicao-padrao);
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.diferencial-item:hover {
  border-color: var(--cor-verde);
  box-shadow: 0 4px 24px rgba(0, 164, 112, 0.1);
  transform: translateY(-3px);
}

.diferencial-icone {
  width: 52px;
  height: 52px;
  border-radius: var(--raio-medio);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.4rem;
}

.diferencial-icone.verde   { background-color: rgba(0, 164, 112, 0.1); }
.diferencial-icone.azul    { background-color: rgba(0, 164, 200, 0.1); }
.diferencial-icone.amarelo { background-color: rgba(242, 201, 23, 0.15); }
.diferencial-icone.vermelho { background-color: rgba(233, 78, 60, 0.1); }

.diferencial-item h4 {
  font-size: var(--texto-base);
  font-weight: 700;
  color: var(--cor-primaria);
  letter-spacing: -0.01em;
}

.diferencial-item p {
  font-size: var(--texto-pequeno);
  color: var(--cor-texto-suave);
  line-height: 1.6;
}


/* ============================================================
   SEÇÃO DE UNIDADES
   ============================================================ */

.grade-unidades {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--espaco-medio);
}

.card-unidade {
  border-radius: var(--raio-grande);
  overflow: hidden;
  background-color: var(--cor-branca);
  border: 1px solid var(--cor-borda-suave);
  transition: all var(--transicao-padrao);
}

.card-unidade:hover {
  box-shadow: var(--sombra-media);
  transform: translateY(-4px);
}

.card-unidade-imagem {
  aspect-ratio: 16 / 9;
  background-color: var(--cor-creme-escura);
  overflow: hidden;
}

.card-unidade-imagem img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--transicao-lenta);
}

.card-unidade:hover .card-unidade-imagem img {
  transform: scale(1.05);
}

.card-unidade-corpo {
  padding: var(--espaco-medio);
}

.card-unidade-corpo h3 {
  font-size: var(--texto-grande);
  margin-bottom: 8px;
}

.card-unidade-corpo p {
  font-size: var(--texto-base);
  color: var(--cor-texto-suave);
  margin-bottom: var(--espaco-pequeno);
}

.card-unidade-info {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-top: var(--espaco-pequeno);
  padding-top: var(--espaco-pequeno);
  border-top: 1px solid var(--cor-borda-suave);
}

.info-linha {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: var(--texto-pequeno);
  color: var(--cor-texto-suave);
}

.info-linha svg {
  width: 16px;
  height: 16px;
  color: var(--cor-verde);
  flex-shrink: 0;
}


/* ============================================================
   DEPOIMENTOS
   ============================================================ */

.grade-depoimentos {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  gap: var(--espaco-medio);
}

.cartao-depoimento {
  padding: var(--espaco-medio);
  background-color: var(--cor-branca);
  border-radius: var(--raio-grande);
  box-shadow: var(--sombra-suave);
  border: 1px solid var(--cor-borda-suave);
  position: relative;
  transition: all var(--transicao-padrao);
}

.cartao-depoimento:hover {
  box-shadow: var(--sombra-media);
  transform: translateY(-3px);
}

.aspas-depoimento {
  font-family: Georgia, serif;
  font-size: 4rem;
  color: var(--cor-verde);
  line-height: 1;
  margin-bottom: 4px;
  display: block;
  opacity: 0.5;
}

.cartao-depoimento p {
  font-size: var(--texto-base);
  color: var(--cor-texto);
  line-height: 1.75;
  margin-bottom: var(--espaco-medio);
  font-style: italic;
}

.autor-depoimento {
  display: flex;
  align-items: center;
  gap: 12px;
  border-top: 1px solid var(--cor-borda-suave);
  padding-top: var(--espaco-pequeno);
}

.foto-autor {
  width: 46px;
  height: 46px;
  border-radius: 50%;
  background-color: var(--cor-creme-escura);
  flex-shrink: 0;
  overflow: hidden;
  border: 2px solid var(--cor-verde);
}

.foto-autor img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.autor-depoimento strong {
  display: block;
  font-size: var(--texto-pequeno);
  font-weight: 700;
  color: var(--cor-primaria);
}

.autor-depoimento span {
  font-size: var(--texto-mini);
  color: var(--cor-texto-suave);
}


/* ============================================================
   ESTATÍSTICAS
   ============================================================ */

.grade-estatisticas {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: var(--espaco-medio);
}

.estatistica {
  text-align: center;
  padding: var(--espaco-medio);
  border-right: 1px solid rgba(255,255,255,0.1);
}

.estatistica:last-child {
  border-right: none;
}

.estatistica .numero {
  font-family: var(--fonte-titulo);
  font-size: clamp(2.5rem, 5vw, 4rem);
  font-weight: 800;
  color: var(--cor-amarelo);
  line-height: 1;
  margin-bottom: 8px;
  display: block;
  letter-spacing: -0.04em;
}

.estatistica .descricao {
  font-size: var(--texto-pequeno);
  color: rgba(245, 241, 225, 0.7);
  letter-spacing: 0.04em;
  font-weight: 400;
}


/* ============================================================
   BLOCO CTA FINAL
   ============================================================ */

.bloco-chamada {
  background-color: var(--cor-escura);
  color: var(--cor-branca);
  padding: var(--espaco-grande);
  border-radius: var(--raio-extra);
  text-align: center;
  position: relative;
  overflow: hidden;
}

.bloco-chamada::before {
  content: "";
  position: absolute;
  width: 500px;
  height: 500px;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  background: radial-gradient(circle, rgba(0, 164, 112, 0.12) 0%, transparent 70%);
  border-radius: 50%;
  pointer-events: none;
}

.bloco-chamada-mascote {
  position: absolute;
  right: 60px;
  bottom: 0;
  height: 200px;
  opacity: 0.15;
  pointer-events: none;
}

.bloco-chamada h2 {
  color: var(--cor-branca);
  max-width: 700px;
  margin: 0 auto var(--espaco-pequeno);
  position: relative;
}

.bloco-chamada p {
  font-size: var(--texto-medio);
  color: rgba(245, 241, 225, 0.75);
  max-width: 560px;
  margin: 0 auto var(--espaco-medio);
  line-height: 1.75;
  position: relative;
}

.bloco-chamada .acoes-cta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: var(--espaco-pequeno);
  position: relative;
}


/* ============================================================
   FORMULÁRIOS
   ============================================================ */

.formulario {
  display: flex;
  flex-direction: column;
  gap: var(--espaco-pequeno);
}

.campo-formulario {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.campo-formulario label {
  font-size: var(--texto-pequeno);
  font-weight: 600;
  color: var(--cor-primaria);
  letter-spacing: 0.02em;
}

.campo-formulario input,
.campo-formulario textarea,
.campo-formulario select {
  font-family: inherit;
  font-size: var(--texto-base);
  padding: 0.875rem 1.125rem;
  border: 1.5px solid var(--cor-borda);
  border-radius: var(--raio-medio);
  background-color: var(--cor-branca);
  color: var(--cor-texto);
  transition: border-color var(--transicao-rapida), box-shadow var(--transicao-rapida);
  -webkit-appearance: none;
  appearance: none;
}

.campo-formulario input:focus,
.campo-formulario textarea:focus,
.campo-formulario select:focus {
  outline: none;
  border-color: var(--cor-verde);
  box-shadow: 0 0 0 3px rgba(0, 164, 112, 0.12);
}

.campo-formulario textarea {
  min-height: 140px;
  resize: vertical;
}

.linha-formulario {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--espaco-pequeno);
}

.mensagem-retorno {
  padding: var(--espaco-pequeno);
  border-radius: var(--raio-medio);
  font-size: var(--texto-pequeno);
  display: none;
  font-weight: 500;
}

.mensagem-retorno.sucesso {
  background-color: rgba(0, 164, 112, 0.1);
  color: var(--cor-verde);
  border: 1px solid rgba(0, 164, 112, 0.2);
  display: block;
}

.mensagem-retorno.erro {
  background-color: rgba(233, 78, 60, 0.1);
  color: var(--cor-vermelho);
  border: 1px solid rgba(233, 78, 60, 0.2);
  display: block;
}


/* ============================================================
   CABEÇALHO DE PÁGINA INTERNA
   ============================================================ */

.cabecalho-pagina {
  background-color: var(--cor-creme);
  padding: calc(var(--espaco-grande) + 80px) 0 var(--espaco-grande);
  text-align: center;
  position: relative;
  overflow: hidden;
}

.cabecalho-pagina::before {
  content: "";
  position: absolute;
  width: 600px;
  height: 600px;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  background: radial-gradient(circle, rgba(0, 164, 112, 0.06) 0%, transparent 70%);
  border-radius: 50%;
  pointer-events: none;
}

.cabecalho-pagina h1 {
  font-size: clamp(2.25rem, 5vw, var(--titulo-grande));
  margin-bottom: var(--espaco-pequeno);
  position: relative;
}

.cabecalho-pagina p {
  font-size: var(--texto-medio);
  color: var(--cor-texto-suave);
  max-width: 600px;
  margin: 0 auto;
  position: relative;
}

.caminho-navegacao {
  font-size: var(--texto-pequeno);
  color: var(--cor-texto-suave);
  margin-top: var(--espaco-pequeno);
  position: relative;
}

.caminho-navegacao a {
  color: var(--cor-verde);
}

.caminho-navegacao a:hover {
  text-decoration: underline;
}


/* ============================================================
   DIVISÓRIA
   ============================================================ */

.divisoria {
  width: 48px;
  height: 3px;
  background-color: var(--cor-verde);
  margin: var(--espaco-pequeno) 0;
  border: none;
  border-radius: 2px;
}

.divisoria.centralizada {
  margin-left: auto;
  margin-right: auto;
}


/* ============================================================
   BOTÃO FLUTUANTE WHATSAPP
   ============================================================ */

.btn-whatsapp-float {
  position: fixed;
  bottom: 28px;
  right: 28px;
  z-index: calc(var(--camada-modal) - 10);
  display: flex;
  align-items: center;
  gap: 10px;
  background-color: #25D366;
  color: var(--cor-branca);
  padding: 14px 22px 14px 18px;
  border-radius: var(--raio-pilula);
  box-shadow: 0 8px 32px rgba(37, 211, 102, 0.4);
  font-family: var(--fonte-corpo);
  font-size: var(--texto-pequeno);
  font-weight: 700;
  letter-spacing: 0.04em;
  cursor: pointer;
  transition: all var(--transicao-padrao);
  border: none;
  text-decoration: none;
}

.btn-whatsapp-float:hover {
  transform: translateY(-3px) scale(1.03);
  box-shadow: 0 12px 40px rgba(37, 211, 102, 0.5);
  color: var(--cor-branca);
}

.btn-whatsapp-float svg {
  width: 22px;
  height: 22px;
  flex-shrink: 0;
}

/* Anel pulsante ao redor do botão */
.btn-whatsapp-float::before {
  content: "";
  position: absolute;
  inset: -4px;
  border-radius: var(--raio-pilula);
  border: 2px solid rgba(37, 211, 102, 0.4);
  animation: pulsar-wa 2.5s ease-in-out infinite;
}

@keyframes pulsar-wa {
  0%, 100% { transform: scale(1); opacity: 0.6; }
  50% { transform: scale(1.06); opacity: 0; }
}


/* ============================================================
   MODAL WHATSAPP
   ============================================================ */

.modal-overlay {
  position: fixed;
  inset: 0;
  background-color: rgba(13, 27, 26, 0.7);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  z-index: var(--camada-modal);
  display: flex;
  align-items: flex-end;
  justify-content: center;
  padding: var(--espaco-pequeno);
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--transicao-padrao);
}

.modal-overlay.aberto {
  opacity: 1;
  pointer-events: all;
}

.modal-whatsapp {
  background-color: var(--cor-branca);
  border-radius: var(--raio-grande) var(--raio-grande) var(--raio-medio) var(--raio-medio);
  padding: var(--espaco-medio);
  width: 100%;
  max-width: 480px;
  transform: translateY(40px);
  transition: transform var(--transicao-padrao);
}

.modal-overlay.aberto .modal-whatsapp {
  transform: translateY(0);
}

.modal-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  margin-bottom: var(--espaco-medio);
}

.modal-header h3 {
  font-size: var(--texto-grande);
  font-weight: 700;
  color: var(--cor-primaria);
}

.modal-header p {
  font-size: var(--texto-pequeno);
  color: var(--cor-texto-suave);
  margin-top: 4px;
}

.modal-fechar {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background-color: var(--cor-creme);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  flex-shrink: 0;
  border: none;
  transition: background-color var(--transicao-rapida);
}

.modal-fechar:hover {
  background-color: var(--cor-borda);
}

.modal-fechar svg {
  width: 16px;
  height: 16px;
  color: var(--cor-texto-suave);
}


/* ============================================================
   ANIMAÇÕES DE SCROLL
   ============================================================ */

@keyframes aparecer-suave {
  from { opacity: 0; transform: translateY(24px); }
  to   { opacity: 1; transform: translateY(0); }
}

.animar-entrada {
  animation: aparecer-suave 700ms cubic-bezier(0.25, 0.46, 0.45, 0.94) forwards;
}

.entrada-rolagem {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity 700ms cubic-bezier(0.25, 0.46, 0.45, 0.94),
              transform 700ms cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.entrada-rolagem.visivel {
  opacity: 1;
  transform: translateY(0);
}

.entrada-rolagem-esquerda {
  opacity: 0;
  transform: translateX(-32px);
  transition: opacity 700ms cubic-bezier(0.25, 0.46, 0.45, 0.94),
              transform 700ms cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.entrada-rolagem-esquerda.visivel {
  opacity: 1;
  transform: translateX(0);
}

.entrada-rolagem-direita {
  opacity: 0;
  transform: translateX(32px);
  transition: opacity 700ms cubic-bezier(0.25, 0.46, 0.45, 0.94),
              transform 700ms cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.entrada-rolagem-direita.visivel {
  opacity: 1;
  transform: translateX(0);
}

/* Atraso escalonado para grupos de elementos */
.entrada-rolagem:nth-child(2),
.entrada-rolagem-esquerda:nth-child(2),
.entrada-rolagem-direita:nth-child(2) { transition-delay: 100ms; }

.entrada-rolagem:nth-child(3),
.entrada-rolagem-esquerda:nth-child(3),
.entrada-rolagem-direita:nth-child(3) { transition-delay: 200ms; }

.entrada-rolagem:nth-child(4),
.entrada-rolagem-esquerda:nth-child(4),
.entrada-rolagem-direita:nth-child(4) { transition-delay: 300ms; }

.entrada-rolagem:nth-child(5),
.entrada-rolagem-direita:nth-child(5) { transition-delay: 400ms; }


/* ============================================================
   STAGGER — GRUPOS DE CARDS
   ============================================================ */

.grade-diferenciais > .entrada-rolagem:nth-child(2) { transition-delay: 90ms; }
.grade-diferenciais > .entrada-rolagem:nth-child(3) { transition-delay: 180ms; }
.grade-diferenciais > .entrada-rolagem:nth-child(4) { transition-delay: 270ms; }
.grade-diferenciais > .entrada-rolagem:nth-child(5) { transition-delay: 360ms; }

.grade-depoimentos > .entrada-rolagem:nth-child(2) { transition-delay: 120ms; }
.grade-depoimentos > .entrada-rolagem:nth-child(3) { transition-delay: 240ms; }

.grade-pilares > .entrada-rolagem:nth-child(2) { transition-delay: 75ms; }
.grade-pilares > .entrada-rolagem:nth-child(3) { transition-delay: 150ms; }
.grade-pilares > .entrada-rolagem:nth-child(4) { transition-delay: 75ms; }
.grade-pilares > .entrada-rolagem:nth-child(5) { transition-delay: 150ms; }
.grade-pilares > .entrada-rolagem:nth-child(6) { transition-delay: 225ms; }

.grade-turmas > .entrada-rolagem:nth-child(2) { transition-delay: 130ms; }
.grade-unidades > .entrada-rolagem:nth-child(2) { transition-delay: 130ms; }


/* ============================================================
   EM-DESTAQUE — SUBLINHADO ANIMADO
   ============================================================ */

.em-destaque {
  position: relative;
  display: inline;
}

.em-destaque::after {
  content: "";
  position: absolute;
  bottom: -3px;
  left: 0;
  width: 0;
  height: 3px;
  background: linear-gradient(to right, var(--cor-verde), var(--cor-azul));
  border-radius: 2px;
  transition: width 1000ms cubic-bezier(0.25, 0.46, 0.45, 0.94) 600ms;
}

.hero-titulo .em-destaque::after {
  width: 100%;
  transition-delay: 800ms;
}

.entrada-rolagem.visivel .em-destaque::after {
  width: 100%;
}


/* ============================================================
   HOVER PROFUNDIDADE — GRUPOS
   ============================================================ */

@media (hover: hover) {
  .grade-turmas:hover .card-turma:not(:hover) {
    opacity: 0.8;
    transform: scale(0.985);
  }

  .grade-depoimentos:hover .cartao-depoimento:not(:hover) {
    opacity: 0.72;
    transform: scale(0.99);
  }

  .grade-unidades:hover .card-unidade:not(:hover) {
    opacity: 0.8;
    transform: translateY(0) scale(0.99);
  }

  .grade-diferenciais:hover .diferencial-item:not(:hover) {
    opacity: 0.75;
  }
}


/* ============================================================
   BLOCO CITAÇÃO — REVEAL LATERAL
   ============================================================ */

.bloco-citacao {
  position: relative;
  overflow: hidden;
}

.bloco-citacao::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 4px;
  height: 0;
  background-color: var(--cor-verde);
  transition: height 700ms cubic-bezier(0.25, 0.46, 0.45, 0.94) 200ms;
}

.bloco-citacao.visivel::before {
  height: 100%;
}


/* ============================================================
   HERO — ANIMAÇÃO DE ENTRADA PROGRESSIVA
   ============================================================ */

.hero-tag          { transition-delay: 50ms; }
.hero-titulo       { transition-delay: 150ms; }
.hero-subtitulo    { transition-delay: 250ms; }
.hero-acoes        { transition-delay: 350ms; }
.hero-credibilidade .indicador:nth-child(1) { transition-delay: 450ms; }
.hero-credibilidade .indicador:nth-child(2) { transition-delay: 530ms; }
.hero-credibilidade .indicador:nth-child(3) { transition-delay: 610ms; }
.hero-imagem-principal { transition-delay: 100ms; }
