/* ============================================================
   ELTON DANIEL LEME — style.css
   Sistema visual extraído da home atual (matriz visual).
   Editável sem dependência de IA: tudo parte das variáveis abaixo.
   Estrutura: 1.Tokens 2.Base 3.Header 4.Botões 5.Seções
              6.Hero 7.Cards de serviço 8.Ferramenta 9.Método
              10.CTA final 11.Artigos 12.Footer 13.Animações
              14.Acessibilidade
   Breakpoints: desktop (base) · tablet ≤1024px · mobile ≤767px
   ============================================================ */

/* ---------- 1. TOKENS ---------- */
:root {
  /* Cores extraídas da home atual */
  --azul-profundo: #071A2D;   /* fundo das seções escuras */
  --azul-marinho:  #0B1F3A;   /* círculos do método, botão "Saiba mais" */
  --azul-primario: #1E3A5F;   /* cor primária do kit, texto de botão claro */
  --azul-hover:    #152C47;   /* hover do botão fantasma */
  --azul-borda:    #3A5791;   /* borda da imagem do diagnóstico */
  --bronze:        #B77444;   /* acento da marca */
  --bronze-claro:  #C8963E;   /* ícones sociais */
  --creme:         #F6F3EE;   /* fundo das seções claras */
  --creme-2:       #F4F2EF;   /* fundo da seção de artigos */
  --gelo:          #D7DEE7;   /* texto claro sobre azul */
  --gelo-2:        #E0E6EE;   /* texto de botões escuros */
  --grafite:       #282F36;   /* texto corrido sobre claro */
  --grafite-footer:#101213;   /* fundo do rodapé */
  --branco:        #FFFFFF;
  --marca-num:     rgba(20, 57, 93, 0.30); /* números 1·2·3 dos cards */
  --nav-link:      #324A6D;

  /* Tipografia */
  --fonte-titulo: "Source Serif 4", Georgia, serif;
  --fonte-texto:  "Source Sans 3", "Segoe UI", Arial, sans-serif;
  --fonte-letra:  "Montserrat", "Source Sans 3", sans-serif; /* letras L·E·M·E */

  /* Escalas (desktop) */
  --texto-hero-nome:  35px;
  --texto-hero-h1:    50px;
  --texto-hero-sub:   25px;
  --texto-label:      30px;   /* "O QUE FAÇO?", "O MÉTODO" */
  --texto-titulo:     50px;   /* títulos serifados de seção */
  --texto-corpo:      20px;
  --texto-botao:      20px;

  /* Layout */
  --largura-max: 1600px;
  --espaco-secao: 100px;
  --raio-botao: 4px;
  --raio-card: 10px;
  --sombra-card: 1px 0px 17px -4px rgba(0, 0, 0, 0.35);
  --transicao: 0.3s ease;
}

/* ---------- 2. BASE ---------- */
*, *::before, *::after { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  margin: 0;
  font-family: var(--fonte-texto);
  font-size: var(--texto-corpo);
  font-weight: 400;
  line-height: 1.5;
  color: var(--grafite);
  background: var(--branco);
  -webkit-font-smoothing: antialiased;
}

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

h1, h2, h3 { margin: 0; font-weight: 400; }
p { margin: 0; }

a { color: inherit; }

.container {
  width: min(var(--largura-max), 100% - 60px);
  margin-inline: auto;
}

/* Link de pulo para leitores de tela / teclado */
.skip-link {
  position: absolute;
  left: -9999px;
  top: 0;
  background: var(--azul-primario);
  color: var(--branco);
  padding: 10px 18px;
  z-index: 200;
}
.skip-link:focus { left: 10px; }

/* ---------- 3. HEADER ---------- */
.site-header {
  background: var(--branco);
  position: relative;
  z-index: 500; /* elevado para cobrir stacking contexts dos elementos animados (.revelar com transform) */
}

.site-header .container {
  min-height: 80px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.menu {
  display: flex;
  gap: 12px;
  list-style: none;
  margin: 0;
  padding: 0;
}

.menu a {
  display: inline-block;
  padding: 10px 14px;
  font-size: 16px;
  font-weight: 600;
  color: var(--nav-link);
  text-decoration: none;
  border-bottom: 2px solid transparent;
  transition: color var(--transicao), border-color var(--transicao);
}

.menu a:hover,
.menu a[aria-current="page"] {
  color: var(--bronze);
  border-bottom-color: currentColor;
}

/* Botão hambúrguer (só aparece no mobile) */
.menu-toggle {
  display: none;
  background: none;
  border: 0;
  padding: 10px;
  cursor: pointer;
}
.menu-toggle .linha {
  display: block;
  width: 26px;
  height: 2px;
  margin: 6px 0;
  background: var(--azul-primario);
  transition: transform var(--transicao), opacity var(--transicao);
}
.menu-toggle[aria-expanded="true"] .linha:nth-child(1) { transform: translateY(8px) rotate(45deg); }
.menu-toggle[aria-expanded="true"] .linha:nth-child(2) { opacity: 0; }
.menu-toggle[aria-expanded="true"] .linha:nth-child(3) { transform: translateY(-8px) rotate(-45deg); }

/* ---------- 4. BOTÕES ---------- */
.botao {
  display: inline-block;
  padding: 12px 24px;
  border-radius: var(--raio-botao);
  font-family: var(--fonte-texto);
  font-size: var(--texto-botao);
  text-decoration: none;
  text-align: center;
  border: 1px solid transparent;
  cursor: pointer;
  transition: background-color var(--transicao), color var(--transicao),
              transform var(--transicao), border-color var(--transicao);
}
.botao:hover { transform: translateY(-2px); }

/* Branco sobre fundo escuro (CTA principal) */
.botao--claro {
  background: var(--branco);
  color: var(--azul-primario);
  font-weight: 600;
}
.botao--claro:hover { background: var(--bronze); color: var(--branco); }

/* Fantasma sobre fundo escuro (CTA secundário) */
.botao--fantasma {
  background: transparent;
  color: var(--gelo);
  border-color: rgba(255, 255, 255, 0.5);
}
.botao--fantasma:hover { background: var(--azul-hover); }

/* Azul sobre fundo claro */
.botao--azul {
  background: var(--azul-marinho);
  color: var(--gelo-2);
  font-weight: 600;
}
.botao--azul:hover { background: var(--bronze); color: var(--branco); }

.grupo-botoes {
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
  justify-content: center;
}

/* ---------- 5. SEÇÕES ---------- */
.secao { padding: var(--espaco-secao) 0; }

.secao--escura  { background: var(--azul-profundo); color: var(--gelo); }
.secao--clara   { background: var(--creme); color: var(--grafite); }
.secao--artigos { background: var(--creme-2); color: var(--grafite); }

/* Rótulo fino acima do título ("O QUE FAÇO?", "FERRAMENTA GRATUITA"…) */
.secao-rotulo {
  font-family: var(--fonte-texto);
  font-size: var(--texto-label);
  font-weight: 300;
  word-spacing: 4px;
  margin-bottom: 8px;
}
.secao--clara .secao-rotulo, .secao--artigos .secao-rotulo { color: var(--azul-profundo); }
.secao--escura .secao-rotulo { color: var(--gelo); }
.secao-rotulo--bronze { color: var(--bronze) !important; }

/* Título serifado de seção */
.secao-titulo {
  font-family: var(--fonte-titulo);
  font-size: var(--texto-titulo);
  font-weight: 400;
  letter-spacing: 1.2px;
  word-spacing: 1px;
  line-height: 1.15;
}
.secao--clara .secao-titulo, .secao--artigos .secao-titulo { color: var(--azul-profundo); }
.secao--escura .secao-titulo { color: var(--branco); }

/* Texto de apoio sob título */
.secao-texto {
  font-size: var(--texto-corpo);
  font-weight: 300;
  letter-spacing: 1.5px;
  margin-top: 16px;
}
.secao--escura .secao-texto { color: var(--gelo); }

/* ---------- 6. HERO ---------- */
.hero {
  background: var(--azul-profundo);
  color: var(--gelo);
  text-align: center;
  padding: 60px 20px 80px;
}

.hero-foto {
  width: min(390px, 70vw);
  margin: 0 auto 40px;
}

.hero-nome {
  font-family: var(--fonte-texto);
  font-size: var(--texto-hero-nome);
  font-weight: 300;
  word-spacing: 4px;
  color: var(--gelo);
}

.hero-titulo {
  font-family: var(--fonte-titulo);
  font-size: var(--texto-hero-h1);
  font-weight: 400;
  letter-spacing: 1.2px;
  line-height: 1.15;
  color: var(--branco);
  margin: 10px 0;
}

.hero-sub {
  font-size: var(--texto-hero-sub);
  font-weight: 300;
  letter-spacing: 1.5px;
  color: var(--gelo);
  margin-bottom: 36px;
}

/* ---------- 7. CARDS DE SERVIÇO ---------- */
.grade-servicos {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 30px;
  margin-top: 50px;
}

.card-servico {
  position: relative;
  display: flex;
  flex-direction: column;
  min-height: 400px;
  padding: 30px 24px;
  border-radius: var(--raio-card);
  border-bottom: 5px solid transparent;
  box-shadow: var(--sombra-card);
  background: transparent;
  text-decoration: none;
  color: inherit;
  transition: border-color var(--transicao), transform var(--transicao),
              box-shadow var(--transicao);
}
.card-servico:hover {
  border-bottom-color: var(--bronze);
  transform: translateY(-4px);
  box-shadow: 1px 6px 22px -4px rgba(0, 0, 0, 0.4);
}

.card-cabecalho {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 10px;
}

.card-rotulo {
  font-size: 18px;
  font-weight: 400;
  word-spacing: 4px;
  color: var(--bronze);
}

.card-numero {
  font-family: var(--fonte-titulo);
  font-size: 90px;
  font-weight: 700;
  line-height: 0.9;
  letter-spacing: 1.2px;
  color: var(--marca-num);
}

.card-titulo {
  font-family: var(--fonte-titulo);
  font-size: 27px;
  font-weight: 400;
  letter-spacing: 0.5px;
  color: var(--azul-profundo);
  margin: 12px 0 0;
}

.card-texto {
  font-size: var(--texto-corpo);
  letter-spacing: 0.5px;
  word-spacing: 2px;
  color: var(--grafite);
  margin: 14px 0 20px;
  flex-grow: 1;
}

.card-link {
  font-size: 28px;
  word-spacing: 4px;
  color: var(--bronze);
  transition: letter-spacing var(--transicao);
}
.card-servico:hover .card-link { letter-spacing: 0.5px; }

/* ---------- 8. FERRAMENTA GRATUITA ---------- */
.duas-colunas {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 60px;
}

.duas-colunas .coluna-texto { flex: 0 1 60%; }
.duas-colunas .coluna-imagem { flex: 0 1 29%; }

.coluna-texto .grupo-botoes { justify-content: flex-start; margin-top: 30px; }

.imagem-borda {
  border: 2px solid var(--azul-borda);
  border-radius: 5px;
  overflow: hidden;
}

/* ---------- 9. O MÉTODO (L·E·M·E) ---------- */
.metodo-intro {
  font-size: var(--texto-corpo);
  font-weight: 500;
  font-style: italic;
  letter-spacing: 0.5px;
  word-spacing: 2px;
  text-align: center;
  max-width: 1100px;
  margin: 16px auto 60px;
}

.metodo-lista {
  display: flex;
  flex-direction: column;
  gap: 36px;
  max-width: 1100px;
  margin: 0 auto 60px;
}

.metodo-item {
  display: flex;
  align-items: center;
  gap: 36px;
}

.metodo-letra {
  flex: 0 0 80px;
  width: 80px;
  height: 80px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--azul-marinho);
  color: var(--creme);
  font-family: var(--fonte-letra);
  font-size: 30px;
  font-weight: 600;
  transition: background-color var(--transicao);
}
.metodo-item:hover .metodo-letra { background: var(--bronze); }

.metodo-titulo {
  font-family: var(--fonte-texto);
  font-size: 24px;
  font-weight: 400;
  word-spacing: 4px;
  color: var(--bronze);
}

.metodo-desc {
  font-size: 18px;
  letter-spacing: 0.5px;
  word-spacing: 2px;
  color: var(--grafite);
  margin-top: 4px;
}

.metodo-cta { text-align: center; }

/* ---------- 10. CTA FINAL ("Próximo passo") ---------- */
.cta-final { text-align: center; }
.cta-final .grupo-botoes { margin-top: 36px; }

/* ---------- 11. ÚLTIMOS ARTIGOS (carrossel) ----------
   Carrossel por scroll nativo com scroll-snap: funciona sem JS
   (arrasto/deslize). As setas são só um atalho adicionado pelo JS. */
.secao--artigos { text-align: center; }

.carrossel { position: relative; margin: 50px 0 30px; }

.carrossel-pista {
  display: flex;
  gap: 30px;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scroll-behavior: smooth;
  padding: 10px 4px 20px;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none; /* Firefox */
}
.carrossel-pista::-webkit-scrollbar { display: none; }

.carrossel-seta {
  position: absolute;
  top: 35%;
  width: 46px;
  height: 46px;
  border: 0;
  border-radius: 50%;
  background: var(--branco);
  color: var(--azul-primario);
  font-size: 26px;
  line-height: 1;
  cursor: pointer;
  box-shadow: 0 4px 14px rgba(0, 0, 0, 0.18);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 5;
  transition: background-color var(--transicao), color var(--transicao);
}
.carrossel-seta:hover { background: var(--bronze); color: var(--branco); }
.carrossel-seta--prev { left: -8px; }
.carrossel-seta--next { right: -8px; }

.card-artigo {
  flex: 0 0 calc((100% - 60px) / 3);
  scroll-snap-align: start;
  text-decoration: none;
  color: inherit;
  border-radius: 6px;
  overflow: hidden;
  transition: transform var(--transicao);
}
.card-artigo:hover { transform: translateY(-4px); }

.card-artigo img {
  width: 100%;
  aspect-ratio: 16 / 9;
  object-fit: cover;
  border-radius: 6px;
}

.card-artigo h3 {
  font-family: var(--fonte-titulo);
  font-size: 20px;
  font-weight: 400;
  color: var(--azul-primario);
  padding: 14px 10px 0;
  transition: color var(--transicao);
}
.card-artigo:hover h3 { color: var(--bronze); }

/* ---------- 12. FOOTER ---------- */
.site-footer {
  background: var(--grafite-footer);
  color: var(--gelo);
  text-align: center;
  padding: 60px 20px 40px;
}

.footer-titulo {
  font-family: var(--fonte-texto);
  font-size: 35px;
  font-weight: 300;
  word-spacing: 4px;
  color: var(--bronze);
  margin-bottom: 30px;
}

.redes {
  display: flex;
  justify-content: center;
  gap: 24px;
  margin-bottom: 40px;
}

.redes a {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: var(--branco);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background-color var(--transicao), transform var(--transicao);
}
.redes a svg { width: 22px; height: 22px; fill: var(--bronze-claro); transition: fill var(--transicao); }
.redes a:hover { background: var(--bronze); transform: translateY(-3px); }
.redes a:hover svg { fill: var(--branco); }

.footer-credito {
  font-size: 15px;
  font-weight: 300;
  font-style: italic;
  letter-spacing: 1.5px;
  color: var(--gelo);
}

/* ---------- 13. ANIMAÇÕES DISCRETAS ----------
   REGRA DE SEGURANÇA: a página nasce 100% visível.
   A classe .anima só é adicionada pelo JavaScript quando a animação
   é segura. Sem JS (ou com JS bloqueado), nada fica oculto. */
.anima .revelar {
  opacity: 0;
  transform: translateY(18px);
  transition: opacity 0.6s ease, transform 0.6s ease;
}
.anima .revelar.visivel { opacity: 1; transform: none; }

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { transition: none !important; animation: none !important; }
  .anima .revelar { opacity: 1; transform: none; }
}

/* ---------- 14. ACESSIBILIDADE ---------- */
:focus-visible {
  outline: 3px solid var(--bronze);
  outline-offset: 2px;
}

/* ============================================================
   TABLET ≤ 1024px
   ============================================================ */
@media (max-width: 1024px) {
  :root {
    --texto-hero-nome: 34px;
    --texto-hero-h1: 34px;
    --texto-hero-sub: 24px;
    --texto-label: 28px;
    --texto-titulo: 34px;
    --texto-botao: 16px;
    --espaco-secao: 70px;
  }

  .grade-servicos { grid-template-columns: 1fr; }
  .card-servico { min-height: 0; }

  .duas-colunas { flex-direction: column; text-align: center; gap: 40px; }
  .duas-colunas .coluna-texto, .duas-colunas .coluna-imagem { flex: 1 1 auto; }
  .coluna-texto .grupo-botoes { justify-content: center; }
  .duas-colunas .coluna-imagem { max-width: 75%; }

  .card-artigo { flex-basis: calc((100% - 30px) / 2); }
}

/* ============================================================
   MOBILE ≤ 767px
   ============================================================ */
@media (max-width: 767px) {
  :root {
    --texto-hero-nome: 24px;
    --texto-hero-h1: 22px;
    --texto-hero-sub: 17px;
    --texto-label: 24px;
    --texto-titulo: 26px;
    --texto-corpo: 18px;
    --texto-botao: 15px;
    --espaco-secao: 50px;
  }

  .container { width: calc(100% - 40px); }

  /* Menu hambúrguer */
  .site-header .container { justify-content: space-between; }
  .menu-toggle { display: block; }
  .menu {
    display: none;
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    flex-direction: column;
    gap: 0;
    background: var(--branco);
    padding: 10px 0 20px;
    box-shadow: 0 10px 20px rgba(0, 0, 0, 0.12);
  }
  .menu.aberto { display: flex; }
  .menu a { display: block; text-align: center; padding: 14px; border-bottom: 0; }

  .hero { padding: 40px 16px 60px; }
  .hero-foto { margin-bottom: 30px; }

  .card-numero { font-size: 60px; }
  .card-titulo { font-size: 23px; }
  .card-texto { font-size: 18px; }
  .card-link { font-size: 20px; }
  .card-rotulo { font-size: 21px; }

  .metodo-item { gap: 20px; }
  .metodo-letra { flex-basis: 64px; width: 64px; height: 64px; font-size: 24px; }
  .metodo-titulo { font-size: 24px; }
  .metodo-desc { font-size: 18px; }

  .card-artigo { flex-basis: 100%; }
  .carrossel-seta { display: none; } /* no toque, desliza com o dedo */

  .footer-titulo { font-size: 24px; }
  .footer-credito { font-size: 12px; }
}

/* ============================================================
   AJUSTES RESPONSIVOS DE REVISÃO — 11/06/2026
   Objetivo: fortalecer tablet/mobile sem alterar a estética da home.
   ============================================================ */

/* Tablet horizontal: evita cards excessivamente estreitos ou uma rolagem longa demais */
@media (min-width: 900px) and (max-width: 1180px) {
  .grade-servicos {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .grade-servicos .card-servico:nth-child(3) {
    grid-column: 1 / -1;
    max-width: 640px;
    width: 100%;
    justify-self: center;
  }
}

/* Tablet vertical: menu mais seguro e leitura mais limpa */
@media (max-width: 900px) {
  .site-header .container {
    justify-content: space-between;
  }
  .menu-toggle {
    display: block;
  }
  .menu {
    display: none;
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    flex-direction: column;
    gap: 0;
    background: var(--branco);
    padding: 10px 0 20px;
    box-shadow: 0 10px 20px rgba(0, 0, 0, 0.12);
  }
  .menu.aberto {
    display: flex;
  }
  .menu a {
    display: block;
    text-align: center;
    padding: 14px;
    border-bottom: 0;
  }
}

/* Mobile fino: botões, imagens e carrossel com menos risco de aperto */
@media (max-width: 767px) {
  .grupo-botoes {
    flex-direction: column;
    align-items: center;
  }
  .botao {
    width: min(100%, 340px);
    padding-inline: 18px;
  }
  .duas-colunas .coluna-imagem {
    max-width: 100%;
    width: 100%;
  }
  .imagem-borda {
    max-width: 360px;
    margin-inline: auto;
  }
  .card-servico {
    padding: 26px 20px;
  }
  .carrossel-pista {
    padding-inline: 0;
  }
}

/* Mobile muito estreito */
@media (max-width: 380px) {
  .container {
    width: calc(100% - 28px);
  }
  .hero {
    padding-inline: 12px;
  }
  .hero-foto {
    width: min(300px, 76vw);
  }
  .secao-titulo {
    font-size: 24px;
  }
  .card-rotulo {
    font-size: 18px;
  }
}

/* ============================================================
   AJUSTES FINAIS DE PROPORÇÃO, MÉTODO E BLOG DINÂMICO
   ============================================================ */
:root {
  --texto-hero-nome: 28px;
  --texto-hero-h1: 46px;
  --texto-hero-sub: 22px;
  --texto-label: 26px;
  --texto-titulo: 44px;
  --texto-corpo: 18px;
  --texto-botao: 17px;
  --espaco-secao: 84px;
}

.botao {
  padding: 11px 22px;
  line-height: 1.25;
}

/* Hero em duas colunas no desktop. No mobile volta a ser vertical. */
.hero {
  padding: 70px 0 78px;
  text-align: left;
}

.hero-inner {
  display: grid;
  grid-template-columns: minmax(280px, 0.44fr) minmax(360px, 0.56fr);
  gap: clamp(34px, 5vw, 86px);
  align-items: center;
}

.hero-visual {
  justify-self: end;
}

.hero-foto {
  width: min(360px, 34vw);
  margin: 0;
}

.hero-conteudo {
  max-width: 680px;
}

.hero .grupo-botoes {
  justify-content: flex-start;
}

.hero-sub {
  max-width: 680px;
  margin-bottom: 30px;
}

/* Cards mais contidos, sem perder presença. */
.grade-servicos {
  gap: 24px;
  margin-top: 42px;
}

.card-servico {
  min-height: 345px;
  padding: 25px 22px 24px;
}

.card-rotulo {
  font-size: 16px;
  line-height: 1.2;
}

.card-numero {
  font-size: 72px;
}

.card-titulo {
  font-size: 24px;
  line-height: 1.22;
}

.card-texto {
  font-size: 17px;
  line-height: 1.55;
  margin-bottom: 16px;
}

.card-link {
  font-size: 20px;
  line-height: 1.25;
}

/* Imagem do diagnóstico: deixa a imagem respirar, sem depender de texto miúdo interno. */
.imagem-borda--diagnostico {
  background: rgba(255,255,255,0.03);
  box-shadow: 0 18px 40px rgba(0,0,0,0.18);
}

/* Método LEME: horizontal e interativo no desktop. */
.metodo-secao,
.metodo-secao .container {
  text-align: center;
}

.metodo-intro {
  max-width: 1050px;
  margin-bottom: 54px;
  font-weight: 400;
}

.metodo-lista {
  position: relative;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 28px;
  max-width: 1120px;
  margin: 0 auto 50px;
}

.metodo-lista::before {
  content: "";
  position: absolute;
  top: 40px;
  left: 11%;
  right: 11%;
  height: 1px;
  background: rgba(30, 58, 95, 0.18);
  z-index: 0;
}

.metodo-item {
  position: relative;
  z-index: 1;
  flex-direction: column;
  justify-content: flex-start;
  align-items: center;
  gap: 18px;
  min-height: 178px;
  padding: 0 10px;
  cursor: default;
}

.metodo-texto {
  text-align: center;
}

.metodo-letra {
  flex: 0 0 80px;
  box-shadow: 0 0 0 8px var(--creme);
}

.metodo-titulo {
  font-size: 21px;
  line-height: 1.15;
}

.metodo-desc {
  max-height: 0;
  opacity: 0;
  overflow: hidden;
  transform: translateY(-4px);
  transition: opacity var(--transicao), transform var(--transicao), max-height var(--transicao);
  font-size: 17px;
  line-height: 1.35;
  max-width: 230px;
  margin-inline: auto;
}

.metodo-item:hover .metodo-desc,
.metodo-item:focus .metodo-desc,
.metodo-item:focus-within .metodo-desc {
  max-height: 80px;
  opacity: 1;
  transform: none;
}

.metodo-item:focus {
  outline: none;
}

.metodo-item:focus-visible .metodo-letra {
  outline: 3px solid var(--bronze);
  outline-offset: 4px;
}

/* CTA e artigos com menos peso visual. */
.cta-final .secao-texto {
  max-width: 760px;
  margin-inline: auto;
}

.secao--artigos .secao-rotulo {
  color: var(--azul-profundo);
}

.carrossel {
  margin: 42px 0 28px;
}

.card-artigo h3 {
  font-size: 19px;
  line-height: 1.22;
}

.card-artigo-placeholder {
  aspect-ratio: 16 / 9;
  border-radius: 6px;
  background: linear-gradient(135deg, var(--azul-profundo), var(--azul-primario));
}

/* Rodapé: ícones uniformes, sem bolinha branca destoando. */
.redes a {
  background: transparent;
  border: 1px solid rgba(215, 222, 231, 0.32);
}

.redes a svg {
  fill: var(--gelo);
}

.redes a:hover {
  background: var(--bronze);
  border-color: var(--bronze);
}

/* Tablet: equilíbrio entre densidade e leitura. */
@media (max-width: 1180px) {
  :root {
    --texto-hero-nome: 26px;
    --texto-hero-h1: 38px;
    --texto-hero-sub: 20px;
    --texto-label: 25px;
    --texto-titulo: 36px;
    --texto-botao: 16px;
    --espaco-secao: 70px;
  }

  .hero-inner {
    grid-template-columns: 0.42fr 0.58fr;
    gap: 44px;
  }

  .hero-foto {
    width: min(320px, 32vw);
  }
}

@media (max-width: 900px) {
  .hero {
    padding: 46px 0 62px;
    text-align: center;
  }

  .hero-inner {
    grid-template-columns: 1fr;
    gap: 28px;
  }

  .hero-visual {
    justify-self: center;
  }

  .hero-foto {
    width: min(320px, 64vw);
    margin-inline: auto;
  }

  .hero-conteudo {
    max-width: 680px;
    margin-inline: auto;
  }

  .hero .grupo-botoes {
    justify-content: center;
  }

  .grade-servicos {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .grade-servicos .card-servico:nth-child(3) {
    grid-column: 1 / -1;
    max-width: 620px;
    justify-self: center;
  }

  .metodo-lista {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    row-gap: 40px;
  }

  .metodo-lista::before {
    display: none;
  }

  .metodo-desc {
    max-height: none;
    opacity: 1;
    overflow: visible;
    transform: none;
  }
}

@media (max-width: 767px) {
  :root {
    --texto-hero-nome: 22px;
    --texto-hero-h1: 28px;
    --texto-hero-sub: 17px;
    --texto-label: 22px;
    --texto-titulo: 27px;
    --texto-corpo: 17px;
    --texto-botao: 15px;
    --espaco-secao: 52px;
  }

  .hero-foto {
    width: min(300px, 72vw);
  }

  .hero-sub br,
  .hero-titulo br {
    display: none;
  }

  .grade-servicos,
  .grade-servicos .card-servico:nth-child(3) {
    display: grid;
    grid-template-columns: 1fr;
    max-width: none;
  }

  .card-servico {
    min-height: 0;
    padding: 24px 20px;
  }

  .card-numero {
    font-size: 56px;
  }

  .card-rotulo {
    font-size: 17px;
  }

  .card-titulo {
    font-size: 23px;
  }

  .metodo-lista {
    display: flex;
    flex-direction: column;
    gap: 28px;
    margin-bottom: 42px;
  }

  .metodo-item {
    flex-direction: row;
    align-items: center;
    justify-content: flex-start;
    min-height: 0;
    gap: 18px;
    padding: 0;
  }

  .metodo-texto {
    text-align: left;
  }

  .metodo-letra {
    flex-basis: 64px;
    width: 64px;
    height: 64px;
    box-shadow: none;
  }

  .metodo-desc {
    margin-inline: 0;
    max-width: none;
    font-size: 17px;
  }

  .carrossel-pista {
    gap: 18px;
  }

  .card-artigo h3 {
    font-size: 20px;
  }
}

/* ---------- HERO TÍTULO HOME — quebra de linha responsiva ----------
   No desktop os spans ficam inline (título flui numa linha).
   Em tablet e mobile cada span vira bloco, gerando quebra natural
   sem depender de <br> hardcoded. */
.hero-titulo-home span { display: inline; }

@media (max-width: 738px) {
  .hero-titulo-home span { display: block !important; }
  .hero-titulo-home span + span { margin-top: 4px; }
}
@media (max-width: 400px) {
  .hero-foto {
    width: 180px;
    max-width: 72vw;
    height: auto;
  }

  .hero-visual {
    max-width: 180px;
    margin: 0 auto;
  }
}