/* ==========================================================================
   Abhrao Scaff — Psicoterapia Corporal em Core Energetics
   Sistema visual: papel/osso quente, terra-roxa e musgo, anéis de respiração
   como elemento de assinatura (respiração / anéis de crescimento / água).
   ========================================================================== */

/* ---------- Tokens ---------- */
:root{
  /* superfícies */
  --paper:        #F1EAD9;   /* papel quente, base */
  --paper-deep:    #E7DAC0;  /* "osso" — seções alternadas */
  --paper-line:    #DCCBA6;  /* hairlines sobre papel */

  /* tinta */
  --ink:           #2A2318;  /* quase-preto quente */
  --ink-soft:      #5C513F;  /* texto secundário */
  --ink-faint:     #8C8067;  /* legendas, metadados */

  /* acentos — terra roxa (solo de Campinas) e musgo */
  --terra:         #8B4A32;
  --terra-deep:    #6C3A26;
  --terra-tint:    #E9D2C2;
  --moss:          #55613F;
  --moss-deep:     #414A30;
  --gold-line:     #B79A6B;

  /* seção escura */
  --night:         #211D14;
  --night-ink:     #EFE6D2;
  --night-line:    #4A4231;

  /* tipografia */
  --f-display: "Fraunces", Georgia, serif;
  --f-body: "Work Sans", -apple-system, BlinkMacSystemFont, sans-serif;
  --f-mono: "IBM Plex Mono", ui-monospace, monospace;

  /* ritmo */
  --container-w: 1180px;
  --radius-sm: 6px;
  --radius-md: 14px;
  --radius-lg: 28px;
  --ease-organic: cubic-bezier(.34,.03,.19,1);

  color-scheme: light;
}

/* ---------- Reset ---------- */
*, *::before, *::after{ box-sizing: border-box; }
html{ scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce){
  html{ scroll-behavior: auto; }
  *, *::before, *::after{ animation-duration: 0.01ms !important; animation-iteration-count: 1 !important; transition-duration: 0.01ms !important; scroll-behavior: auto !important; }
}
body{ margin: 0; }
img{ max-width: 100%; display: block; }
a{ color: inherit; text-decoration: none; }
ul{ margin: 0; padding: 0; list-style: none; }
button{ font: inherit; color: inherit; background: none; border: none; cursor: pointer; }
input, textarea{ font: inherit; color: inherit; }
h1, h2, h3, blockquote, p{ margin: 0; }

body{
  background: var(--paper);
  color: var(--ink);
  font-family: var(--f-body);
  font-size: 16px;
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
}

:focus-visible{
  outline: 2px solid var(--terra);
  outline-offset: 3px;
  border-radius: 3px;
}

.container{
  max-width: var(--container-w);
  margin: 0 auto;
  padding: 0 clamp(1.25rem, 4vw, 2.5rem);
}

.skip-link{
  position: absolute;
  left: -999px;
  top: 0;
  background: var(--ink);
  color: var(--paper);
  padding: .75rem 1.25rem;
  z-index: 999;
  border-radius: 0 0 8px 0;
}
.skip-link:focus{ left: 0; }

/* ---------- Tipografia utilitária ---------- */
.eyebrow{
  display: inline-block;
  font-family: var(--f-mono);
  font-size: .72rem;
  font-weight: 500;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--terra);
  margin-bottom: 1rem;
}
.eyebrow.claro{ color: #D8B98E; }

h1{
  font-family: var(--f-display);
  font-weight: 440;
  font-size: clamp(2.5rem, 3.2vw + 1.6rem, 4.2rem);
  line-height: 1.06;
  letter-spacing: -.012em;
  color: var(--ink);
}
h1 em{
  font-style: normal;
  color: var(--terra);
}

h2{
  font-family: var(--f-display);
  font-weight: 460;
  font-size: clamp(1.9rem, 1.4vw + 1.5rem, 2.6rem);
  line-height: 1.14;
  letter-spacing: -.01em;
}

h3{
  font-family: var(--f-display);
  font-weight: 500;
  font-size: 1.28rem;
  line-height: 1.3;
}

.section-head{
  max-width: 640px;
  margin-bottom: 3rem;
}
.section-head p{ color: var(--ink-soft); font-size: 1.05rem; }

/* ---------- Botões / links ---------- */
.btn{
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  padding: .95rem 1.9rem;
  border-radius: 999px;
  font-family: var(--f-body);
  font-weight: 500;
  font-size: .98rem;
  transition: transform .35s var(--ease-organic), background .25s ease, box-shadow .25s ease;
}
.btn-primario{
  background: var(--terra);
  color: var(--paper);
  box-shadow: 0 1px 0 rgba(42,35,24,.05);
}
.btn-primario:hover{
  background: var(--terra-deep);
  transform: translateY(-2px);
}

.link-sutil{
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  font-weight: 500;
  border-bottom: 1px solid var(--gold-line);
  padding-bottom: .15rem;
  transition: gap .3s var(--ease-organic), border-color .25s ease;
}
.link-sutil:hover{
  gap: .7rem;
  border-color: var(--terra);
}
.link-sutil .seta{ transition: transform .3s var(--ease-organic); }
.link-sutil:hover .seta{ transform: translateX(2px); }

.tag{
  display: inline-block;
  font-family: var(--f-mono);
  font-size: .74rem;
  letter-spacing: .03em;
  padding: .45rem .9rem;
  border: 1px solid var(--gold-line);
  border-radius: 999px;
  color: var(--ink-soft);
}

/* ---------- Seções / ritmo vertical ---------- */
.section{
  padding: clamp(4rem, 7vw, 7rem) 0;
}
.section-osso{
  background: var(--paper-deep);
  border-top: 1px solid var(--paper-line);
  border-bottom: 1px solid var(--paper-line);
}

/* revelação suave no scroll */
.reveal{
  opacity: 0;
  transform: translateY(22px);
  transition: opacity .8s var(--ease-organic), transform .8s var(--ease-organic);
}
.reveal.visivel{ opacity: 1; transform: none; }

/* ---------- Marca (anéis) ---------- */
.marca-aneis{
  width: 1.6rem;
  height: 1.6rem;
  color: var(--terra);
}
.marca-aneis .anel-1, .marca-aneis .anel-2, .marca-aneis .anel-3{
  fill: none;
  stroke: currentColor;
}
.marca-aneis .anel-1{ stroke-width: 10; opacity: 1; }
.marca-aneis .anel-2{ stroke-width: 6; opacity: .6; }
.marca-aneis .anel-3{ stroke-width: 3; opacity: .32; }

/* ---------- Header ---------- */
.header{
  position: sticky;
  top: 0;
  z-index: 100;
  background: rgba(241, 234, 217, .88);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--paper-line);
}
.header-inner{
  max-width: var(--container-w);
  margin: 0 auto;
  padding: 1.05rem clamp(1.25rem, 4vw, 2.5rem);
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.logo{
  display: flex;
  align-items: center;
  gap: .6rem;
  font-family: var(--f-display);
  font-weight: 500;
  font-size: 1.2rem;
  color: var(--ink);
}
.nav{
  display: flex;
  align-items: center;
  gap: clamp(1.2rem, 2vw, 2.1rem);
  font-size: .95rem;
}
.nav a{
  color: var(--ink-soft);
  transition: color .2s ease;
  position: relative;
}
.nav a:not(.nav-cta):hover{ color: var(--ink); }
.nav a:not(.nav-cta)::after{
  content: "";
  position: absolute;
  left: 0; right: 0; bottom: -6px;
  height: 1px;
  background: var(--terra);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform .3s var(--ease-organic);
}
.nav a:not(.nav-cta):hover::after{ transform: scaleX(1); }
.nav-cta{
  background: var(--ink);
  color: var(--paper) !important;
  padding: .55rem 1.15rem;
  border-radius: 999px;
  font-weight: 500;
  transition: background .25s ease;
}
.nav-cta:hover{ background: var(--terra); }

.menu-toggle{
  display: none;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  width: 34px;
  height: 34px;
}
.menu-toggle span{
  display: block;
  height: 2px;
  background: var(--ink);
  border-radius: 2px;
  transition: transform .3s var(--ease-organic), opacity .2s ease;
}

/* ---------- Hero ---------- */
.hero{
  padding-top: clamp(3.5rem, 7vw, 6rem);
  padding-bottom: clamp(3.5rem, 7vw, 6rem);
  display: grid;
  grid-template-columns: 1.15fr .85fr;
  gap: clamp(2rem, 5vw, 4rem);
  align-items: center;
}
.hero p{
  font-size: 1.12rem;
  color: var(--ink-soft);
  max-width: 46ch;
  margin-top: 1.4rem;
}
.hero-cta-row{
  display: flex;
  align-items: center;
  gap: 1.6rem;
  flex-wrap: wrap;
  margin-top: 2.2rem;
}
.hero-local{
  margin-top: 2.6rem;
  font-family: var(--f-mono);
  font-size: .78rem;
  letter-spacing: .02em;
  color: var(--ink-faint);
}

/* elemento de assinatura — anéis de respiração
   camadas independentes (halo · anéis em parálax · guia que se desenha · núcleo)
   para uma sensação orgânica, viva, e não-mecânica. */
.respiracao{
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  aspect-ratio: 1;
  max-width: 380px;
  margin-inline: auto;
}

/* halo — respiração de luz por trás dos anéis */
.respiracao-halo{
  position: absolute;
  inset: 8%;
  border-radius: 50%;
  background: radial-gradient(circle, var(--terra) 0%, transparent 68%);
  filter: blur(26px);
  animation: respirar-halo 9.2s var(--ease-organic) infinite;
  pointer-events: none;
}

.respiracao svg{
  width: 100%;
  height: 100%;
  overflow: visible;
}

/* cada anel respira em seu próprio ritmo — leve defasagem cria parálax */
.respiracao svg .anel-1,
.respiracao svg .anel-2,
.respiracao svg .anel-3{
  transform-origin: 100px 100px;
  transform-box: view-box;
}
.respiracao svg .anel-1{
  stroke-width: 1.5;
  opacity: .92;
  color: var(--terra);
  stroke: currentColor;
  animation: respirar-anel-1 9.2s var(--ease-organic) infinite;
}
.respiracao svg .anel-2{
  stroke-width: 1;
  color: var(--moss);
  stroke: currentColor;
  animation: respirar-anel-2 9.2s var(--ease-organic) infinite;
  animation-delay: .12s;
}
.respiracao svg .anel-3{
  stroke-width: .6;
  color: var(--gold-line);
  stroke: currentColor;
  animation: respirar-anel-3 9.2s var(--ease-organic) infinite;
  animation-delay: .24s;
}

/* anel-guia — traça e apaga a circunferência acompanhando o ciclo,
   como uma respiração que se pode "seguir" com o olhar */
.respiracao-guia{
  fill: none;
  stroke: var(--terra);
  stroke-width: 1.6;
  stroke-linecap: round;
  stroke-dasharray: 440;
  transform-origin: 100px 100px;
  transform-box: view-box;
  transform: rotate(-90deg);
  animation:
    respirar-guia-traco 9.2s var(--ease-organic) infinite,
    respirar-cor-tracado 9.2s var(--ease-organic) infinite;
}

.respiracao-nucleo{
  fill: var(--terra);
  transform-origin: 100px 100px;
  transform-box: view-box;
  animation:
    respirar-nucleo-escala 9.2s var(--ease-organic) infinite,
    respirar-cor-nucleo 9.2s var(--ease-organic) infinite;
}

.respiracao-legenda{
  position: absolute;
  font-family: var(--f-mono);
  font-size: .78rem;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--ink-soft);
}
.respiracao-legenda .legenda-texto{
  display: inline-block;
  transition: opacity .32s ease, transform .32s var(--ease-organic);
}
.respiracao-legenda .legenda-texto.trocando{
  opacity: 0;
  transform: translateY(3px) scale(.94);
}

/* ---------- curvas do ciclo respiratório ----------
   0%–38%  inspire (expande)   38%–48% segure (pausa cheia)
   48%–88% expire (contrai)    88%–100% repouse (pausa vazia) */

@keyframes respirar-halo{
  0%   { opacity: .18; transform: scale(.78); }
  38%  { opacity: .5;  transform: scale(1.14); }
  48%  { opacity: .5;  transform: scale(1.14); }
  88%  { opacity: .18; transform: scale(.78); }
  100% { opacity: .18; transform: scale(.78); }
}

@keyframes respirar-anel-1{
  0%   { transform: scale(.86) rotate(0deg);  opacity: .78; }
  38%  { transform: scale(1.05) rotate(1.5deg); opacity: 1;  }
  48%  { transform: scale(1.05) rotate(1.5deg); opacity: 1;  }
  88%  { transform: scale(.86) rotate(0deg);  opacity: .78; }
  100% { transform: scale(.86) rotate(0deg);  opacity: .78; }
}
@keyframes respirar-anel-2{
  0%   { transform: scale(.82) rotate(0deg);   opacity: .4; }
  38%  { transform: scale(1.1) rotate(-2deg);  opacity: .72; }
  48%  { transform: scale(1.1) rotate(-2deg);  opacity: .72; }
  88%  { transform: scale(.82) rotate(0deg);   opacity: .4; }
  100% { transform: scale(.82) rotate(0deg);   opacity: .4; }
}
@keyframes respirar-anel-3{
  0%   { transform: scale(.78) rotate(0deg);  opacity: .2; }
  38%  { transform: scale(1.16) rotate(3deg); opacity: .42; }
  48%  { transform: scale(1.16) rotate(3deg); opacity: .42; }
  88%  { transform: scale(.78) rotate(0deg);  opacity: .2; }
  100% { transform: scale(.78) rotate(0deg);  opacity: .2; }
}

@keyframes respirar-guia-traco{
  0%   { stroke-dashoffset: 440; opacity: 0;  }
  6%   { opacity: 1; }
  38%  { stroke-dashoffset: 0;   opacity: 1;  }
  48%  { stroke-dashoffset: 0;   opacity: 1;  }
  82%  { opacity: 1; }
  88%  { stroke-dashoffset: 440; opacity: 0;  }
  100% { stroke-dashoffset: 440; opacity: 0;  }
}

@keyframes respirar-nucleo-escala{
  0%   { transform: scale(.8);  }
  38%  { transform: scale(1.6); }
  48%  { transform: scale(1.6); }
  88%  { transform: scale(.8);  }
  100% { transform: scale(.8);  }
}

/* núcleo e anel-guia trocam de temperatura: terra (inspirar) → musgo (repousar) */
@keyframes respirar-cor-tracado{
  0%   { stroke: var(--moss);  }
  38%  { stroke: var(--terra); }
  48%  { stroke: var(--terra); }
  88%  { stroke: var(--moss);  }
  100% { stroke: var(--moss);  }
}
@keyframes respirar-cor-nucleo{
  0%   { fill: var(--moss);  }
  38%  { fill: var(--terra); }
  48%  { fill: var(--terra); }
  88%  { fill: var(--moss);  }
  100% { fill: var(--moss);  }
}

@media (prefers-reduced-motion: reduce){
  .respiracao-halo,
  .respiracao svg .anel-1,
  .respiracao svg .anel-2,
  .respiracao svg .anel-3,
  .respiracao-guia,
  .respiracao-nucleo{
    animation: none;
  }
  .respiracao-guia{ stroke-dashoffset: 0; opacity: 1; }
  .respiracao svg .anel-1{ opacity: .9; }
  .respiracao svg .anel-2{ opacity: .55; }
  .respiracao svg .anel-3{ opacity: .3; }
}

/* ---------- Sobre ---------- */
.sobre-grid{
  display: grid;
  grid-template-columns: .82fr 1.18fr;
  gap: clamp(2rem, 5vw, 4.5rem);
  align-items: start;
}
.foto-perfil-wrap{ position: relative; }
.foto-perfil{
  border-radius: var(--radius-lg);
  border: 1px solid var(--paper-line);
  aspect-ratio: 4/5;
  object-fit: cover;
  width: 100%;
}
.foto-legenda{
  margin-top: .9rem;
  font-family: var(--f-mono);
  font-size: .74rem;
  color: var(--ink-faint);
  letter-spacing: .02em;
}

.sobre-titulo{ margin-top: .1rem; }
.sobre-cargo{
  display: block;
  margin-top: .45rem;
  margin-bottom: 1.6rem;
  font-family: var(--f-mono);
  font-size: .82rem;
  letter-spacing: .04em;
  color: var(--moss);
}
.sobre-grid p + p{ margin-top: 1.1rem; }
.sobre-grid > div > p{ color: var(--ink-soft); font-size: 1.02rem; }

.tags-formacao{
  display: flex;
  flex-wrap: wrap;
  gap: .6rem;
  margin-top: 1.8rem;
}

.trajetoria-box{
  margin-top: clamp(3rem, 5vw, 4.5rem);
  padding: clamp(2rem, 4vw, 3rem);
  background: var(--paper);
  border: 1px solid var(--paper-line);
  border-left: 3px solid var(--moss);
  border-radius: var(--radius-md);
}
.trajetoria-box p{
  margin-top: .8rem;
  color: var(--ink-soft);
  font-size: 1.02rem;
  max-width: 74ch;
}

/* ---------- Cards (abordagem) ---------- */
.cards-grid{
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1.25rem;
}
.card{
  padding: 2rem 1.6rem;
  background: var(--paper);
  border: 1px solid var(--paper-line);
  border-radius: var(--radius-md);
  transition: border-color .25s ease, transform .35s var(--ease-organic), box-shadow .3s ease;
  position: relative;
  overflow: hidden;
}
.card::before{
  content: "";
  position: absolute;
  top: -30%; right: -30%;
  width: 90px; height: 90px;
  border-radius: 50%;
  border: 1px solid var(--gold-line);
  opacity: .5;
}
.card:hover{
  border-color: var(--terra);
  transform: translateY(-4px);
  box-shadow: 0 14px 30px -18px rgba(42,35,24,.35);
}
.card h3{ margin-bottom: .65rem; }
.card p{ color: var(--ink-soft); font-size: .98rem; }

/* ---------- Áreas de atuação ---------- */
.areas-lista{
  border-top: 1px solid var(--paper-line);
}
.area-item{
  display: grid;
  grid-template-columns: 260px 1fr;
  gap: clamp(1.5rem, 4vw, 3.5rem);
  padding: 2.1rem 0;
  border-bottom: 1px solid var(--paper-line);
  position: relative;
}
.area-item::before{
  content: "";
  position: absolute;
  left: 0; top: 2.1rem; bottom: 2.1rem;
  width: 2px;
  background: transparent;
  transition: background .3s ease;
}
.area-item:hover::before{ background: var(--terra); }
.area-termo{
  font-family: var(--f-display);
  font-weight: 500;
  font-size: 1.2rem;
  color: var(--ink);
}
.area-item p{ color: var(--ink-soft); }

/* ---------- Seção escura / tese ---------- */
.section-escura{
  position: relative;
  background: var(--night);
  color: var(--night-ink);
  overflow: hidden;
  padding: clamp(5rem, 9vw, 8rem) 0;
}
.marca-fundo{
  position: absolute;
  top: 50%; right: -8%;
  transform: translateY(-50%);
  width: min(56vw, 620px);
  height: auto;
  color: var(--night-line);
  opacity: .55;
  pointer-events: none;
}
.marca-fundo .anel-1{ fill:none; stroke: currentColor; stroke-width: 1.4; }
.marca-fundo .anel-2{ fill:none; stroke: currentColor; stroke-width: 1; opacity: .7; }
.marca-fundo .anel-3{ fill:none; stroke: currentColor; stroke-width: .7; opacity: .45; }

.tese-wrap{ position: relative; max-width: 780px; }
.tese-wrap blockquote{
  font-family: var(--f-display);
  font-weight: 440;
  font-size: clamp(1.9rem, 3vw, 2.9rem);
  line-height: 1.32;
  letter-spacing: -.01em;
  color: var(--night-ink);
}

/* ---------- Atendimento ---------- */
.atendimento-grid{
  display: grid;
  grid-template-columns: 1.1fr .9fr;
  gap: clamp(2rem, 5vw, 4rem);
  align-items: start;
}
.lista-motivos{ margin-top: 1.6rem; }
.lista-motivos li{
  position: relative;
  padding: .7rem 0 .7rem 1.6rem;
  border-bottom: 1px solid var(--paper-line);
  color: var(--ink-soft);
  font-size: 1.02rem;
}
.lista-motivos li::before{
  content: "";
  position: absolute;
  left: 0; top: 1.15rem;
  width: 7px; height: 7px;
  border-radius: 50%;
  background: var(--terra);
}
.nota-familiares{
  margin-top: 1.6rem;
  padding-top: 1.4rem;
  border-top: 1px solid var(--gold-line);
  color: var(--ink-soft);
  font-style: normal;
}

.info-box{
  background: var(--paper);
  border: 1px solid var(--paper-line);
  border-radius: var(--radius-md);
  padding: clamp(1.8rem, 3vw, 2.4rem);
}
.info-box h3{ margin-bottom: 1.3rem; }
.info-linha{
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  padding: .85rem 0;
  border-top: 1px solid var(--paper-line);
  font-size: .96rem;
}
.info-linha:first-of-type{ border-top: none; }
.info-linha span:first-child{
  font-family: var(--f-mono);
  font-size: .74rem;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--ink-faint);
  padding-top: .15rem;
}
.info-linha span:last-child{ text-align: right; color: var(--ink); font-weight: 500; }

/* ---------- Processo ---------- */
.processo-grid{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(2rem, 4vw, 3rem);
  position: relative;
}
.processo-grid::before{
  content: "";
  position: absolute;
  top: 1.15rem;
  left: calc(100% / 6);
  right: calc(100% / 6);
  height: 1px;
  background: repeating-linear-gradient(to right, var(--gold-line) 0 6px, transparent 6px 12px);
  z-index: 0;
}
.passo{ position: relative; z-index: 1; }
.passo-numero{
  display: inline-block;
  font-family: var(--f-mono);
  font-size: .82rem;
  color: var(--terra);
  background: var(--paper);
  padding-right: .6rem;
  margin-bottom: 1.1rem;
}
.passo h3{ margin-bottom: .6rem; }
.passo p{ color: var(--ink-soft); font-size: .98rem; }

/* ---------- Depoimentos ---------- */
.depoimentos-nota{
  color: var(--ink-faint);
  font-size: .88rem;
  margin-top: -1.6rem;
  margin-bottom: 2.6rem;
}
.depoimentos-lista{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.25rem;
}
.depoimento{
  background: var(--paper);
  border: 1px solid var(--paper-line);
  border-radius: var(--radius-md);
  padding: 2rem 1.7rem;
  display: flex;
  flex-direction: column;
  gap: 1.2rem;
}
.depoimento blockquote{
  font-family: var(--f-display);
  font-size: 1.14rem;
  line-height: 1.5;
  color: var(--ink);
}
.depoimento cite{
  font-family: var(--f-mono);
  font-style: normal;
  font-size: .74rem;
  letter-spacing: .03em;
  color: var(--ink-faint);
}

/* ---------- Contato ---------- */
.contato-grid{
  display: grid;
  grid-template-columns: 1.15fr .85fr;
  gap: clamp(2.5rem, 5vw, 4.5rem);
}
.contato-grid > .reveal > p{ color: var(--ink-soft); margin-top: 1rem; max-width: 52ch; }

#formContato{
  margin-top: 2.2rem;
  display: flex;
  flex-direction: column;
  gap: 1.3rem;
}
.campo{ display: flex; flex-direction: column; gap: .5rem; }
.campo label{
  font-family: var(--f-mono);
  font-size: .74rem;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--ink-faint);
}
.campo input, .campo textarea{
  padding: .85rem 1rem;
  background: var(--paper);
  border: 1px solid var(--paper-line);
  border-radius: var(--radius-sm);
  font-size: 1rem;
  transition: border-color .2s ease, background .2s ease;
}
.campo input:focus, .campo textarea:focus{
  border-color: var(--terra);
  background: #fff;
  outline: none;
}
.campo textarea{ min-height: 130px; resize: vertical; }
#formContato .btn{ align-self: flex-start; margin-top: .4rem; }

.contato-direto{
  background: var(--paper-deep);
  border: 1px solid var(--paper-line);
  border-radius: var(--radius-lg);
  padding: clamp(2rem, 4vw, 2.6rem);
  display: flex;
  flex-direction: column;
  gap: 1rem;
  align-self: start;
}
.contato-direto h3{ margin-bottom: .4rem; }
.contato-direto a{
  font-size: 1.05rem;
  font-weight: 500;
  color: var(--terra);
  width: fit-content;
  border-bottom: 1px solid transparent;
  transition: border-color .2s ease;
}
.contato-direto a:hover{ border-color: var(--terra); }
.contato-direto p{
  margin-top: .6rem;
  padding-top: 1.1rem;
  border-top: 1px solid var(--paper-line);
  color: var(--ink-soft);
  font-size: .92rem;
}

/* ---------- Footer ---------- */
.footer{
  background: var(--night);
  color: var(--night-ink);
  padding: 3rem 0 1.75rem;
}
.footer-inner{
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 1.5rem;
  padding-bottom: 2rem;
  border-bottom: 1px solid var(--night-line);
}
.footer-marca{ display: flex; align-items: center; gap: .8rem; }
.footer-marca .marca-aneis{ color: #D8B98E; }
.footer-credito{ display: flex; flex-direction: column; }
.footer-credito strong{ font-family: var(--f-display); font-size: 1.05rem; font-weight: 500; }
.footer-credito span{ font-size: .82rem; color: #B8AD97; }
.footer-social{ display: flex; gap: 1.4rem; font-size: .92rem; }
.footer-social a{ color: #C9BEA4; transition: color .2s ease; }
.footer-social a:hover{ color: var(--night-ink); }
.footer-copy{
  margin-top: 1.6rem;
  font-family: var(--f-mono);
  font-size: .74rem;
  color: #8A8064;
}

/* ==========================================================================
   Responsivo
   ========================================================================== */
@media (max-width: 1024px){
  .hero{ grid-template-columns: 1fr; }
  .respiracao{ order: -1; max-width: 260px; margin-bottom: 1rem; }
  .sobre-grid{ grid-template-columns: 1fr; }
  .foto-perfil-wrap{ max-width: 340px; }
  .cards-grid{ grid-template-columns: repeat(2, 1fr); }
  .atendimento-grid{ grid-template-columns: 1fr; }
  .contato-grid{ grid-template-columns: 1fr; }
  .depoimentos-lista{ grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 720px){
  .nav{
    position: absolute;
    top: 100%; left: 0; right: 0;
    flex-direction: column;
    align-items: flex-start;
    gap: 0;
    background: var(--paper);
    border-bottom: 1px solid var(--paper-line);
    max-height: 0;
    overflow: hidden;
    transition: max-height .35s var(--ease-organic);
  }
  .header.menu-aberto .nav{ max-height: 380px; }
  .nav a{
    width: 100%;
    padding: 1rem clamp(1.25rem, 4vw, 2.5rem);
    border-bottom: 1px solid var(--paper-line);
  }
  .nav a::after{ display: none; }
  .nav-cta{ border-radius: 0; text-align: center; }
  .menu-toggle{ display: flex; }
  .header.menu-aberto .menu-toggle span:nth-child(1){ transform: translateY(7px) rotate(45deg); }
  .header.menu-aberto .menu-toggle span:nth-child(2){ opacity: 0; }
  .header.menu-aberto .menu-toggle span:nth-child(3){ transform: translateY(-7px) rotate(-45deg); }

  .cards-grid{ grid-template-columns: 1fr; }
  .area-item{ grid-template-columns: 1fr; gap: .5rem; }
  .processo-grid{ grid-template-columns: 1fr; gap: 2.5rem; }
  .processo-grid::before{ display: none; }
  .depoimentos-lista{ grid-template-columns: 1fr; }
  .info-linha{ flex-direction: column; gap: .2rem; }
  .info-linha span:last-child{ text-align: left; }
}

@media (max-width: 480px){
  h1{ font-size: clamp(2.1rem, 8vw, 2.6rem); }
  .hero-cta-row{ flex-direction: column; align-items: flex-start; gap: 1rem; }
}

.cit{
    text-align: end;
}