/* =============================================================================
   DR. CARLOS MIRANDA — Site oficial
   styles.css · v1 (Hero/Dobra 1)
   Base: design_system.html (cobre · preto · marfim · Jost + Mulish)
   ============================================================================= */

/* ============================== TOKENS ===================================== */
:root{
  /* Cobre (primária — amostrada do logo) */
  --copper-50:#FAF0E9;  --copper-100:#F3DBC9; --copper-200:#E9BD9E;
  --copper-300:#DBA37D; --copper-400:#CE8E63; --copper-500:#BD7552;
  --copper-600:#9F5D3D; --copper-700:#884C2E; --copper-800:#6A3A24;
  --copper-900:#4A2817;

  /* Neutros quentes */
  --ink-900:#0B0A09; --ink-800:#1A1714; --ink-700:#2C2722;
  --ink-600:#463F38; --ink-500:#6B6259; --ink-400:#948A7E;
  --ink-300:#BDB3A6; --ink-200:#DBD2C5; --ink-100:#ECE6DB;
  --ink-50:#F7F3EC;
  --white:#FFFFFF; --black:#000000;
  --black-light:#141414; --white-dim:#E8E6E1;

  /* Papéis (tema escuro — assinatura da marca) */
  --bg:var(--black);
  --surface:var(--ink-900);
  --surface-2:var(--ink-800);
  --text:var(--white);
  --text-muted:var(--ink-300);
  --text-subtle:var(--ink-400);
  --primary:var(--copper-400);
  --primary-hover:var(--copper-300);
  --accent:var(--copper-300);
  --border:rgba(206,142,99,.16);
  --border-strong:rgba(206,142,99,.30);

  /* Tipografia */
  --font-display:'Jost','Century Gothic',system-ui,sans-serif;
  --font-body:'Mulish',system-ui,-apple-system,sans-serif;
  --font-serif:'Cormorant Garamond',Georgia,serif;
  --font-script:'Allura','Brush Script MT',cursive;

  /* Easings */
  --ease-out-expo:cubic-bezier(0.16,1,0.3,1);
  --ease-out-quart:cubic-bezier(0.25,1,0.5,1);

  /* Raios */
  --r-xs:4px; --r-sm:8px; --r-md:14px; --r-lg:22px;
  --r-xl:32px; --r-2xl:44px; --r-full:999px;

  /* Sombras + glow cobre */
  --shadow-sm:0 1px 2px rgba(0,0,0,.4);
  --shadow-md:0 8px 22px -8px rgba(0,0,0,.5);
  --shadow-lg:0 24px 60px -18px rgba(0,0,0,.6);
  --shadow-xl:0 40px 90px -24px rgba(0,0,0,.7);
  --shadow-copper:0 14px 40px -10px rgba(189,117,82,.45);
  --glow-copper:0 0 60px -10px rgba(206,142,99,.55);

  /* Layout */
  --container:1200px;
  --container-wide:1440px;
  --nav-h:78px;

  /* Z-index scale */
  --z-grain:9998;
  --z-nav:1000;
  --z-progress:2000;
  --z-cta-sticky:1100;
  --z-skip:9999;
}

/* ============================== RESET ====================================== */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
html{
  scroll-behavior:smooth;
  -webkit-text-size-adjust:100%;
  overflow-x:hidden;
  scrollbar-width:thin;
  scrollbar-color:var(--copper-600) var(--black);
}
body{
  font-family:var(--font-body);
  background:var(--black);
  color:var(--white);
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;
}
img,svg,video{display:block;max-width:100%;height:auto;}
a{text-decoration:none;color:inherit;}
button{border:none;background:none;cursor:pointer;font-family:inherit;color:inherit;}
ul{list-style:none;}
::selection{background:var(--copper-500);color:var(--black);}
.iconify{display:inline-block;}

/* Focus visível e acessível (preserva keyboard nav, esconde no clique) */
:focus{outline:none;}
:focus-visible{
  outline:2px solid var(--copper-300);
  outline-offset:3px;
  border-radius:var(--r-xs);
}

/* Skip link (acessibilidade — teclado) */
.skip-link{
  position:absolute;left:-9999px;top:1rem;z-index:var(--z-skip);
  background:var(--copper-500);color:var(--black);
  padding:.75rem 1.25rem;border-radius:var(--r-sm);
  font-family:var(--font-body);font-size:.78rem;font-weight:700;
  letter-spacing:.18em;text-transform:uppercase;
}
.skip-link:focus-visible{left:1rem;}

/* Helpers */
.italic{font-family:var(--font-serif);font-style:italic;font-weight:500;color:var(--copper-300);}
.sr-only{
  position:absolute;width:1px;height:1px;padding:0;margin:-1px;
  overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0;
}

/* Reveal on scroll (vira .visible via IntersectionObserver no main.js) */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .8s var(--ease-out-expo),transform .8s var(--ease-out-expo);}
.reveal.visible{opacity:1;transform:translateY(0);}
.reveal-delay-1{transition-delay:.1s;}
.reveal-delay-2{transition-delay:.2s;}
.reveal-delay-3{transition-delay:.3s;}
.reveal-delay-4{transition-delay:.4s;}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1 !important;transform:none !important;}
}

/* Grão sutil — uniformiza textura sobre o tema escuro */
.grain{
  position:fixed;inset:0;z-index:var(--z-grain);
  pointer-events:none;opacity:.04;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* Barra de progresso de scroll */
.scroll-progress{
  position:fixed;top:0;left:0;height:2px;width:0;z-index:var(--z-progress);
  background:linear-gradient(90deg,var(--copper-600),var(--copper-300));
  box-shadow:0 0 12px rgba(206,142,99,.7);
  transition:width .12s linear;
}

/* ============================== NAV ======================================== */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:var(--z-nav);
  padding:1.4rem 3rem;
  display:flex;align-items:center;justify-content:space-between;
  transition:padding .4s var(--ease-out-quart),
             background .4s var(--ease-out-quart),
             border-color .4s var(--ease-out-quart);
}
.nav.scrolled{
  padding:.85rem 3rem;
  background:rgba(10,10,9,.82);
  backdrop-filter:blur(18px) saturate(140%);
  -webkit-backdrop-filter:blur(18px) saturate(140%);
  border-bottom:1px solid var(--border);
}
.nav-logo{
  display:flex;align-items:center;gap:.85rem;
  color:var(--white);
  transition:opacity .3s ease;
}
.nav-logo:hover,.nav-logo:focus-visible{opacity:.85;}
.nav-mark{
  width:auto;height:38px;
  display:block;
  filter:drop-shadow(0 4px 12px rgba(189,117,82,.35));
  transition:height .4s var(--ease-out-quart),
             filter .4s var(--ease-out-quart);
}
.nav.scrolled .nav-mark{height:34px;}
.nav-wordmark{
  font-family:var(--font-display);font-weight:300;
  font-size:1.05rem;letter-spacing:.26em;text-transform:uppercase;
  color:var(--white);line-height:1;
  padding-top:.1em; /* alinhamento óptico com o logo */
}
.nav-logo .dot{color:var(--copper-400);margin:0 .1em;}
.nav-links{display:flex;align-items:center;gap:2.4rem;}
.nav-links a{
  font-family:var(--font-body);font-size:.72rem;font-weight:600;
  letter-spacing:.2em;text-transform:uppercase;color:var(--ink-400);
  position:relative;transition:color .3s ease;
}
.nav-links a::after{
  content:'';position:absolute;bottom:-6px;left:0;
  width:0;height:1px;background:var(--copper-400);
  transition:width .35s var(--ease-out-expo);
}
.nav-links a:hover,.nav-links a:focus-visible{color:var(--copper-300);}
.nav-links a:hover::after,.nav-links a:focus-visible::after{width:100%;}

/* Container das ações do nav (ligação + WhatsApp) */
.nav-actions{
  display:flex;align-items:center;gap:.7rem;
}

/* Botão circular de ligação (icon-only) */
.nav-call{
  display:grid;place-items:center;
  width:40px;height:40px;
  border-radius:var(--r-full);
  border:1px solid var(--copper-500);
  color:var(--copper-300);
  transition:background .4s var(--ease-out-expo),
             color .4s var(--ease-out-expo),
             box-shadow .4s var(--ease-out-expo),
             transform .35s var(--ease-out-expo);
}
.nav-call .iconify{font-size:1.05rem;}
.nav-call:hover,.nav-call:focus-visible{
  background:var(--copper-500);color:var(--black);
  box-shadow:var(--glow-copper);
  transform:translateY(-1px);
}

.nav-cta{
  font-family:var(--font-body);font-size:.68rem;font-weight:600;
  letter-spacing:.22em;text-transform:uppercase;
  padding:.78rem 1.6rem;
  border:1px solid var(--copper-500);color:var(--copper-300);
  border-radius:var(--r-full);
  display:inline-flex;align-items:center;gap:.55rem;
  transition:background .4s var(--ease-out-expo),
             color .4s var(--ease-out-expo),
             box-shadow .4s var(--ease-out-expo);
}
.nav-cta:hover,.nav-cta:focus-visible{
  background:var(--copper-500);color:var(--black);
  box-shadow:var(--glow-copper);
}
.nav-cta .iconify{font-size:1rem;}

.nav-hamburger{
  display:none;width:32px;height:32px;
  flex-direction:column;justify-content:center;gap:6px;
  cursor:pointer;background:transparent;
}
.nav-hamburger span{
  display:block;width:24px;height:1px;background:var(--white);
  transition:transform .35s var(--ease-out-expo),opacity .25s ease;
}
.nav-hamburger.open span:nth-child(1){transform:translateY(3.5px) rotate(45deg);}
.nav-hamburger.open span:nth-child(2){opacity:0;}
.nav-hamburger.open span:nth-child(3){transform:translateY(-3.5px) rotate(-45deg);}

/* ============================== HERO ======================================= */
.hero{
  position:relative;overflow:hidden;
  min-height:100vh;min-height:100dvh;
  display:grid;grid-template-columns:1.05fr .95fr;
  border-bottom:1px solid var(--border);
  background:var(--black);
}

/* Camada aurora — luz cobre difusa de fundo */
.hero-aurora{
  position:absolute;inset:-15% -10%;z-index:0;pointer-events:none;
  background:
    radial-gradient(40% 50% at 22% 30%,rgba(206,142,99,.30),transparent 60%),
    radial-gradient(38% 46% at 78% 68%,rgba(189,117,82,.28),transparent 62%),
    radial-gradient(30% 40% at 60% 18%,rgba(219,163,125,.18),transparent 60%);
  animation:auroraDrift 22s var(--ease-out-quart) infinite alternate;
  filter:blur(8px);
}
@keyframes auroraDrift{
  0%{transform:translate(0,0) rotate(0deg);}
  100%{transform:translate(-40px,30px) rotate(6deg);}
}

/* Grade vetorial sutil ao fundo (eco do design system) */
.hero-grid{
  position:absolute;inset:0;z-index:0;pointer-events:none;
  background-image:
    linear-gradient(rgba(206,142,99,.045) 1px,transparent 1px),
    linear-gradient(90deg,rgba(206,142,99,.045) 1px,transparent 1px);
  background-size:64px 64px;
  mask-image:radial-gradient(circle at 30% 40%,#000,transparent 75%);
  -webkit-mask-image:radial-gradient(circle at 30% 40%,#000,transparent 75%);
}

/* ----- Coluna esquerda — conteúdo ----- */
.hero-content{
  position:relative;z-index:3;
  display:flex;flex-direction:column;justify-content:center;
  padding:calc(var(--nav-h) + 2rem) 4.5rem 3.5rem;
}

/* Eyebrow */
.hero-tag{
  display:inline-flex;align-items:center;gap:1rem;
  margin-bottom:1.5rem;
  opacity:0;transform:translateY(20px);
  animation:fadeUp .9s var(--ease-out-expo) .55s forwards;
}
.hero-tag-line{
  display:block;width:42px;height:1px;background:var(--copper-400);
}
.hero-tag-text{
  font-family:var(--font-body);font-size:.7rem;font-weight:600;
  letter-spacing:.34em;text-transform:uppercase;color:var(--copper-300);
}

/* Headline — 3 linhas, peso 300, acento serifado em cobre */
.hero-title{
  font-family:var(--font-display);font-weight:300;
  font-size:clamp(2.2rem,4.4vw,4.2rem);
  line-height:1.04;letter-spacing:.02em;
  text-transform:uppercase;color:var(--white);
  margin-bottom:1.4rem;
}
.hero-title>span{
  display:block;
  opacity:0;transform:translateY(60px);
}
.hero-title>span:nth-child(1){animation:fadeUp 1s var(--ease-out-expo) .85s forwards;}
.hero-title>span:nth-child(2){animation:fadeUp 1s var(--ease-out-expo) 1s   forwards;}
.hero-title>span:nth-child(3){animation:fadeUp 1s var(--ease-out-expo) 1.15s forwards;}
.hero-title .italic{
  display:inline;
  font-size:.86em;
  text-transform:none;
  letter-spacing:.005em;
  font-weight:500;
  /* baseline alinhado com Jost UPPERCASE */
  vertical-align:baseline;
  position:relative;
  top:.02em;
}

/* Letra vazada cobre — assinatura visual do hero (espelha o design system) */
.hero-title .title-stroke{
  display:inline-block;
  color:transparent;
  -webkit-text-stroke:1.2px var(--copper-300);
          text-stroke:1.2px var(--copper-300);
  /* sombra cobre sutilíssima pra ganhar corpo no fundo preto */
  text-shadow:0 0 24px rgba(206,142,99,.18);
  margin-right:.18em; /* respiro entre vazada e palavra sólida vizinha */
}

/* Subheadline */
.hero-desc{
  font-family:var(--font-body);font-size:1rem;line-height:1.7;
  color:var(--text-muted);max-width:460px;
  margin-bottom:1.8rem;
  opacity:0;transform:translateY(20px);
  animation:fadeUp .8s var(--ease-out-expo) 1.4s forwards;
}

/* CTAs */
.hero-actions{
  display:flex;align-items:center;gap:1.8rem;flex-wrap:wrap;
  opacity:0;transform:translateY(20px);
  animation:fadeUp .8s var(--ease-out-expo) 1.6s forwards;
}

.btn-primary{
  display:inline-flex;align-items:center;gap:.85rem;
  background:var(--copper-500);color:var(--black);
  padding:1.05rem 2.3rem;border-radius:var(--r-full);
  font-family:var(--font-body);font-size:.74rem;font-weight:700;
  letter-spacing:.22em;text-transform:uppercase;
  position:relative;overflow:hidden;
  box-shadow:var(--shadow-copper);
  transition:box-shadow .4s var(--ease-out-expo),
             transform .4s var(--ease-out-expo);
}
.btn-primary::before{
  content:'';position:absolute;inset:0;
  background:var(--copper-300);
  transform:translateX(-101%);
  transition:transform .45s var(--ease-out-expo);
}
.btn-primary::after{
  content:'';position:absolute;top:0;left:-60%;
  width:40%;height:100%;
  background:linear-gradient(120deg,transparent,rgba(255,255,255,.45),transparent);
  transform:skewX(-20deg);
  pointer-events:none;
}
.btn-primary:hover{box-shadow:var(--glow-copper);transform:translateY(-1px);}
.btn-primary:focus-visible{box-shadow:var(--glow-copper);}
.btn-primary:hover::before{transform:translateX(0);}
.btn-primary:hover::after{animation:shimmer .9s var(--ease-out-quart);}
.btn-primary>*{position:relative;z-index:1;}
.btn-primary .iconify{font-size:1.05rem;}
@keyframes shimmer{to{left:130%;}}

.btn-outline{
  display:inline-flex;align-items:center;gap:.7rem;
  font-family:var(--font-body);font-size:.72rem;font-weight:600;
  letter-spacing:.16em;text-transform:uppercase;
  color:var(--white-dim);
  padding:.6rem 0; /* aumenta área de toque */
  transition:color .3s ease;
}
.btn-outline .iconify,.btn-outline svg{
  font-size:1.15rem;width:1.15em;height:1.15em;
  transition:transform .35s var(--ease-out-expo);
}
.btn-outline:hover,.btn-outline:focus-visible{color:var(--copper-300);}
.btn-outline:hover .iconify,.btn-outline:focus-visible .iconify,
.btn-outline:hover svg,.btn-outline:focus-visible svg{transform:translateX(5px);}

/* Pílulas qualitativas (Plano B — stats não confirmados) */
.hero-pills{
  display:flex;flex-wrap:wrap;gap:.5rem;
  margin-top:1.8rem;
  opacity:0;transform:translateY(20px);
  animation:fadeUp .8s var(--ease-out-expo) 1.8s forwards;
}
.hero-pill{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:.55rem 1rem;
  border:1px solid var(--border-strong);
  border-radius:var(--r-full);
  background:rgba(206,142,99,.05);
  font-family:var(--font-body);font-size:.7rem;font-weight:600;
  letter-spacing:.16em;text-transform:uppercase;
  color:var(--ink-300);
}
.hero-pill .dot{
  width:5px;height:5px;border-radius:50%;background:var(--copper-400);
  box-shadow:0 0 8px var(--copper-400);
}

/* Selo Google */
.hero-google{
  display:inline-flex;align-items:center;gap:.7rem;
  margin-top:.8rem;padding:.5rem .8rem;
  background:transparent;color:var(--text-muted);
  font-family:var(--font-body);font-size:.78rem;
  border-radius:var(--r-full);
  transition:color .3s ease,background .3s ease;
  width:fit-content;
  opacity:0;transform:translateY(20px);
  animation:fadeUp .8s var(--ease-out-expo) 1.95s forwards;
}
.hero-google:hover,.hero-google:focus-visible{
  color:var(--white);background:rgba(206,142,99,.06);
}
.hero-google .stars{display:inline-flex;gap:.1rem;color:var(--copper-300);font-size:.85rem;}
.hero-google strong{color:var(--white);font-weight:700;}
.hero-google em{color:var(--ink-400);font-style:normal;font-size:.74rem;letter-spacing:.05em;}

/* ----- Coluna direita — imagem (slideshow em loop) ----- */
.hero-image{
  position:relative;overflow:hidden;
  display:flex;align-items:center;justify-content:center;
}
.hero-slides{position:absolute;inset:0;}

.hero-image .case{
  position:absolute;inset:0;
  width:100%;height:100%;
  object-fit:cover;object-position:center 22%;
  opacity:0;
  transform:scale(1.04);
  filter:contrast(1.02) saturate(.96);
  transition:opacity 1.6s var(--ease-out-quart),
             transform 8s linear;
  will-change:opacity,transform;
}
/* Ken-Burns sutil: a foto ativa cresce devagar enquanto está visível */
.hero-image .case.is-active{
  opacity:.92;
  transform:scale(1.12);
}
/* Reveal inicial — só pra primeira foto, pra manter o drama do hero */
.hero-image .case.is-active.is-first{
  animation:heroImgReveal 1.8s var(--ease-out-expo) .45s forwards;
}
@keyframes heroImgReveal{
  from{opacity:0;transform:scale(1.22);}
  to  {opacity:.92;transform:scale(1.12);}
}

/* Máscara em gradiente (preto à esquerda + base) */
.hero-image::after{
  content:'';position:absolute;inset:0;z-index:2;pointer-events:none;
  background:
    linear-gradient(to right, var(--black) 0%, transparent 38%),
    linear-gradient(to top,   var(--black) 0%, transparent 22%);
}

/* Moldura cobre deslocada — refinamento de luxo */
.hero-frame{
  position:absolute;z-index:3;pointer-events:none;
  top:6%;right:6%;bottom:6%;left:14%;
  border:1px solid var(--copper-500);
  opacity:.35;
  transform:translate(12px,12px);
  transition:transform 1s var(--ease-out-expo);
}
.hero:hover .hero-frame{transform:translate(0,0);}

/* Glow cobre pulsante */
.hero-glow-orb{
  position:absolute;z-index:1;
  width:62%;aspect-ratio:1;border-radius:50%;
  top:6%;right:0;
  background:radial-gradient(circle,rgba(206,142,99,.55),rgba(189,117,82,.12) 55%,transparent 72%);
  filter:blur(14px);
  animation:glowPulse 6s ease-in-out infinite;
}
@keyframes glowPulse{
  0%,100%{transform:scale(1);opacity:.75;}
  50%    {transform:scale(1.12);opacity:1;}
}

/* Partículas */
.hero-sparks span{
  position:absolute;width:5px;height:5px;border-radius:50%;
  background:var(--copper-300);
  box-shadow:0 0 10px var(--copper-300);
  opacity:.7;z-index:3;
  animation:spark 5s ease-in-out infinite;
}
@keyframes spark{
  0%,100%{transform:translateY(0);opacity:.2;}
  50%    {transform:translateY(-24px);opacity:.9;}
}

/* Assinatura sobre a imagem */
.hero-signature{
  position:absolute;bottom:8%;right:8%;z-index:4;
  width:46%;max-width:280px;
  opacity:0;
  animation:fadeUp 1s var(--ease-out-expo) 2s forwards;
}

/* Indicador de scroll */
.scroll-cue{
  position:absolute;bottom:2rem;left:4.5rem;z-index:5;
  display:flex;align-items:center;gap:.8rem;
  font-family:var(--font-body);font-size:.62rem;
  letter-spacing:.28em;text-transform:uppercase;color:var(--ink-400);
  opacity:0;
  animation:fadeUp .8s ease 2.3s forwards;
}
.scroll-cue .bar{
  position:relative;display:block;
  width:1px;height:42px;
  background:linear-gradient(var(--copper-400),transparent);
  overflow:hidden;
}
.scroll-cue .bar::after{
  content:'';position:absolute;top:-50%;left:0;
  width:100%;height:50%;background:var(--copper-200);
  animation:scrollDown 1.8s var(--ease-out-quart) infinite;
}
@keyframes scrollDown{to{top:100%;}}

/* Animations base */
@keyframes fadeUp{
  from{opacity:0;transform:translateY(40px);}
  to  {opacity:1;transform:translateY(0);}
}

/* ============================== DOBRA 2 — BARRA DE CONFIANÇA =============== */
.trust{
  position:relative;
  background:var(--ink-900);
  border-bottom:1px solid var(--border);
}

/* --- Marquee --- */
.marquee{
  overflow:hidden;
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
  background:linear-gradient(
    180deg,
    rgba(11,10,9,1) 0%,
    rgba(26,23,20,1) 100%
  );
  position:relative;
}
/* Fades laterais (suavidade nas pontas) */
.marquee::before,
.marquee::after{
  content:'';position:absolute;top:0;bottom:0;width:140px;z-index:2;
  pointer-events:none;
}
.marquee::before{
  left:0;background:linear-gradient(90deg, var(--ink-900), transparent);
}
.marquee::after{
  right:0;background:linear-gradient(270deg, var(--ink-900), transparent);
}

.marquee-track{
  display:flex;width:max-content;
  animation:marqueeScroll 38s linear infinite;
  padding:1.6rem 0;
}
.marquee:hover .marquee-track{animation-play-state:paused;}

.marquee-item{
  display:flex;align-items:center;gap:2rem;
  padding:0 2rem;white-space:nowrap;
}
.marquee-item span{
  font-family:var(--font-display);
  font-weight:300;font-size:1.1rem;
  letter-spacing:.22em;text-transform:uppercase;
  color:var(--ink-300);
  transition:color .3s ease;
}
.marquee-item:hover span{color:var(--copper-200);}
.marquee-item .mdot{
  display:inline-block;
  width:5px;height:5px;border-radius:50%;
  background:var(--copper-400);
  box-shadow:0 0 8px rgba(206,142,99,.6);
  flex-shrink:0;
}
@keyframes marqueeScroll{
  from{transform:translateX(0);}
  to  {transform:translateX(-50%);}
}

/* --- Linha de selos --- */
.trust-inner{
  max-width:var(--container);
  margin:0 auto;
  padding:5rem 4.5rem;
}

.seals{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:1px;
  background:var(--border);
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  overflow:hidden;
}

.seal{
  position:relative;
  background:var(--ink-900);
  padding:2.4rem 1.6rem 2.2rem;
  display:flex;flex-direction:column;align-items:center;
  text-align:center;
  transition:background .4s var(--ease-out-expo);
  overflow:hidden;
}
/* Glow cobre sutil no canto superior, surge no hover */
.seal::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(circle at 50% 0%,
    rgba(206,142,99,.12) 0%, transparent 60%);
  opacity:0;
  transition:opacity .5s ease;
}
.seal:hover{background:var(--ink-800);}
.seal:hover::before{opacity:1;}

/* Ícone — caixa cobre suave */
.seal-icon{
  position:relative;z-index:1;
  width:56px;height:56px;
  display:grid;place-items:center;
  border-radius:var(--r-full);
  background:rgba(206,142,99,.08);
  border:1px solid var(--border);
  margin-bottom:1.4rem;
  transition:transform .45s var(--ease-out-expo),
             background .45s var(--ease-out-expo),
             border-color .45s var(--ease-out-expo),
             box-shadow .45s var(--ease-out-expo);
}
.seal-icon .iconify{
  font-size:1.6rem;color:var(--copper-300);
  transition:color .35s ease,transform .45s var(--ease-out-expo);
}
.seal:hover .seal-icon{
  transform:translateY(-3px) scale(1.06);
  background:rgba(206,142,99,.14);
  border-color:var(--copper-500);
  box-shadow:0 14px 30px -10px rgba(189,117,82,.45);
}
.seal:hover .seal-icon .iconify{color:var(--copper-200);transform:scale(1.08);}

.seal-label{
  position:relative;z-index:1;
  font-family:var(--font-body);font-weight:700;
  font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;
  color:var(--white);
  margin-bottom:.6rem;
}
.seal-note{
  position:relative;z-index:1;
  font-family:var(--font-body);font-size:.82rem;line-height:1.55;
  color:var(--text-subtle);
  max-width:230px;
}

/* Responsivo da Dobra 2 */
@media (max-width:1100px){
  .trust-inner{padding:4rem 2rem;}
  .seals{grid-template-columns:repeat(2,1fr);}
  .marquee::before,.marquee::after{width:80px;}
}
@media (max-width:640px){
  .trust-inner{padding:3rem 1.25rem;}
  .seals{grid-template-columns:1fr;border-radius:var(--r-md);}
  .seal{padding:2rem 1.4rem 1.8rem;}
  .seal-note{display:none;} /* simplifica no mobile, mantém só label + ícone */
  .marquee-item span{font-size:1rem;letter-spacing:.18em;}
  .marquee-item{gap:1.4rem;padding:0 1.4rem;}
}

/* ============================== DOBRA 3 — DIFERENCIAL ===================== */
/* Primeira virada de tema: dark → light/marfim. Texto à esquerda, imagem à
   direita com moldura cobre deslocada (espelha o .ba-frame do design system). */
.diferencial{
  position:relative;
  background:var(--ink-50);
  color:var(--ink-900);
  overflow:hidden;
}

/* Fundo sutil (orb marfim + grade cobre fininha) */
.dif-bg{position:absolute;inset:0;z-index:0;pointer-events:none;}
.dif-bg .dif-orb{
  position:absolute;width:680px;height:680px;border-radius:50%;
  top:-12%;left:-8%;
  background:radial-gradient(circle at 35% 35%,
    rgba(206,142,99,.16), rgba(206,142,99,.04) 55%, transparent 72%);
  filter:blur(60px);
  opacity:.9;
}
.dif-bg .dif-grid{
  position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(155,105,70,.05) 1px,transparent 1px),
    linear-gradient(90deg,rgba(155,105,70,.05) 1px,transparent 1px);
  background-size:72px 72px;
  mask-image:radial-gradient(circle at 70% 50%,#000,transparent 80%);
  -webkit-mask-image:radial-gradient(circle at 70% 50%,#000,transparent 80%);
}

.dif-inner{
  position:relative;z-index:1;
  max-width:var(--container-wide);
  margin:0 auto;
  padding:7rem 4.5rem;
  display:grid;
  grid-template-columns:1.05fr .95fr;
  gap:5rem;
  align-items:center;
}

/* --- Coluna texto --- */
.dif-text{max-width:560px;}

.dif-tag{
  display:inline-flex;align-items:center;gap:1rem;
  margin-bottom:1.4rem;
}
.dif-tag-line{
  display:block;width:38px;height:1px;background:var(--copper-500);
}
.dif-tag-text{
  font-family:var(--font-body);font-weight:700;
  font-size:.7rem;letter-spacing:.32em;text-transform:uppercase;
  color:var(--copper-600);
}

.dif-title{
  font-family:var(--font-display);font-weight:300;
  font-size:clamp(2rem,3.4vw,3.2rem);
  line-height:1.08;letter-spacing:.02em;
  text-transform:uppercase;
  color:var(--ink-900);
  margin-bottom:1.6rem;
}
/* Italic accent (Cormorant) — em cobre mais escuro pra contraste no marfim */
.dif-title .italic{
  font-family:var(--font-serif);font-style:italic;font-weight:500;
  color:var(--copper-600);
  display:inline;
  font-size:.92em;
  text-transform:none;
  letter-spacing:.005em;
  vertical-align:baseline;
  position:relative;top:.04em;
}
/* Letra vazada — variante light (stroke em cobre escuro, sem halo) */
.dif-title .title-stroke{
  display:inline-block;
  color:transparent;
  -webkit-text-stroke:1.2px var(--copper-600);
          text-stroke:1.2px var(--copper-600);
  margin-right:.06em;
}

.dif-desc{
  font-family:var(--font-body);font-size:1.05rem;line-height:1.75;
  color:var(--ink-700);
  margin-bottom:2.4rem;
}

/* Checklist */
.dif-list{
  display:flex;flex-direction:column;gap:1.25rem;
  margin-bottom:2.4rem;
}
.dif-item{
  display:grid;
  grid-template-columns:auto 1fr;
  gap:1.1rem;align-items:flex-start;
  padding:.4rem 0;
  transition:transform .4s var(--ease-out-expo);
}
.dif-item:hover{transform:translateX(3px);}
.dif-check{
  display:grid;place-items:center;
  width:30px;height:30px;
  border-radius:var(--r-full);
  background:rgba(206,142,99,.10);
  border:1px solid rgba(206,142,99,.22);
  transition:background .35s ease,border-color .35s ease,transform .4s var(--ease-out-expo);
  flex-shrink:0;
}
.dif-check .iconify{font-size:1.05rem;color:var(--copper-600);transition:color .3s ease;}
.dif-item:hover .dif-check{
  background:rgba(206,142,99,.18);
  border-color:var(--copper-500);
  transform:scale(1.06);
}
.dif-item-label{
  font-family:var(--font-display);font-weight:500;
  font-size:1.05rem;letter-spacing:.06em;text-transform:uppercase;
  color:var(--ink-900);
  margin-bottom:.25rem;
  line-height:1.3;
}
.dif-item-note{
  font-family:var(--font-body);font-size:.9rem;line-height:1.55;
  color:var(--ink-600);
}

/* CTA principal (botão sólido, mesma DNA do .btn-primary do hero, adaptado pro tema marfim) */
.dif-cta{
  display:inline-flex;align-items:center;gap:.85rem;
  background:var(--copper-500);color:var(--white);
  padding:1.05rem 2.2rem;border-radius:var(--r-full);
  font-family:var(--font-body);font-size:.74rem;font-weight:700;
  letter-spacing:.22em;text-transform:uppercase;
  position:relative;overflow:hidden;
  box-shadow:0 18px 40px -12px rgba(189,117,82,.55),
             0 2px 8px rgba(106,58,36,.18);
  transition:box-shadow .4s var(--ease-out-expo),
             transform .4s var(--ease-out-expo);
}
.dif-cta::before{
  content:'';position:absolute;inset:0;
  background:var(--copper-600);
  transform:translateX(-101%);
  transition:transform .45s var(--ease-out-expo);
  z-index:0;
}
.dif-cta::after{
  content:'';position:absolute;top:0;left:-60%;
  width:40%;height:100%;
  background:linear-gradient(120deg,transparent,rgba(255,255,255,.45),transparent);
  transform:skewX(-20deg);
  pointer-events:none;z-index:1;
}
.dif-cta:hover,.dif-cta:focus-visible{
  transform:translateY(-2px);
  box-shadow:0 22px 50px -10px rgba(189,117,82,.65),
             0 0 0 6px rgba(206,142,99,.15);
}
.dif-cta:hover::before{transform:translateX(0);}
.dif-cta:hover::after{animation:shimmer .9s var(--ease-out-quart);}
.dif-cta>*{position:relative;z-index:2;}
.dif-cta .iconify,
.dif-cta svg{
  font-size:1.1rem;width:1.1em;height:1.1em;
  transition:transform .35s var(--ease-out-expo);
}
.dif-cta:hover svg,.dif-cta:focus-visible svg{transform:translateX(5px);}

/* --- Coluna imagem (moldura cobre deslocada) --- */
.dif-media{position:relative;}

.frame-card{
  position:relative;
  margin:0;
  /* respiro pra moldura deslocada não vazar do container */
  padding-right:18px;padding-bottom:18px;
}
.frame-card img{
  width:100%;height:auto;display:block;
  border-radius:var(--r-lg);
  filter:grayscale(18%) contrast(1.02);
  box-shadow:var(--shadow-lg);
  transition:filter .6s var(--ease-out-expo),
             transform .6s var(--ease-out-expo);
}
.frame-card:hover img,.frame-card:focus-within img{
  filter:grayscale(0%) contrast(1.04);
  transform:translate(-2px,-2px);
}
.frame-mark{
  position:absolute;
  top:0;left:0;right:18px;bottom:18px;
  border:1px solid var(--copper-500);
  border-radius:var(--r-lg);
  transform:translate(18px,18px);
  pointer-events:none;
  opacity:.55;
  transition:transform .6s var(--ease-out-expo),opacity .4s ease;
}
.frame-card:hover .frame-mark{
  transform:translate(12px,12px);
  opacity:.75;
}

/* Responsivo da Dobra 3 */
@media (max-width:1100px){
  .dif-inner{
    grid-template-columns:1fr;
    gap:3rem;
    padding:5rem 2rem;
  }
  .dif-media{order:-1;max-width:520px;margin:0 auto;}
}
@media (max-width:640px){
  .dif-inner{padding:4rem 1.25rem;gap:2.4rem;}
  .dif-title{font-size:clamp(1.8rem,8vw,2.4rem);}
  .dif-desc{font-size:.98rem;margin-bottom:2rem;}
  .dif-list{gap:1rem;margin-bottom:2rem;}
  .dif-item-label{font-size:.98rem;}
  .dif-item-note{font-size:.86rem;}
  .frame-card{padding-right:12px;padding-bottom:12px;}
  .frame-mark{right:12px;bottom:12px;transform:translate(12px,12px);}
}

/* ============================== DOBRA 4 — TRATAMENTOS ===================== */
/* Continua tema marfim da Dobra 3, mas em layout de grade pra evitar monotonia.
   Cards brancos sobre fundo marfim, divididos por hairlines cobre. */
.tratamentos{
  position:relative;
  background:linear-gradient(
    180deg,
    var(--ink-50) 0%,
    var(--ink-100) 100%
  );
  color:var(--ink-900);
  overflow:hidden;
  border-top:1px solid rgba(155,105,70,.08);
}

/* Fundo sutil (orb cobre + grade fina) */
.trat-bg{position:absolute;inset:0;z-index:0;pointer-events:none;}
.trat-bg .trat-orb{
  position:absolute;width:720px;height:720px;border-radius:50%;
  bottom:-18%;right:-12%;
  background:radial-gradient(circle at 50% 50%,
    rgba(206,142,99,.14), rgba(206,142,99,.03) 55%, transparent 75%);
  filter:blur(70px);
}
.trat-bg .trat-grid{
  position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(155,105,70,.04) 1px,transparent 1px),
    linear-gradient(90deg,rgba(155,105,70,.04) 1px,transparent 1px);
  background-size:64px 64px;
  mask-image:radial-gradient(circle at 30% 60%,#000,transparent 80%);
  -webkit-mask-image:radial-gradient(circle at 30% 60%,#000,transparent 80%);
}

.trat-inner{
  position:relative;z-index:1;
  max-width:var(--container-wide);
  margin:0 auto;
  padding:6.5rem 4.5rem 7rem;
}

/* --- Cabeçalho da seção --- */
.trat-header{
  max-width:760px;
  margin-bottom:4rem;
}
.trat-tag{
  display:inline-flex;align-items:center;gap:1rem;
  margin-bottom:1.4rem;
}
.trat-title{
  font-family:var(--font-display);font-weight:300;
  font-size:clamp(2rem,3.4vw,3.2rem);
  line-height:1.08;letter-spacing:.02em;
  text-transform:uppercase;
  color:var(--ink-900);
  margin-bottom:1.2rem;
}
.trat-title .italic{
  font-family:var(--font-serif);font-style:italic;font-weight:500;
  color:var(--copper-600);
  display:inline;
  font-size:.92em;text-transform:none;letter-spacing:.005em;
  vertical-align:baseline;position:relative;top:.04em;
}
/* Letra vazada — variante light (mesma DNA da Dobra 3) */
.trat-title .title-stroke{
  display:inline-block;
  color:transparent;
  -webkit-text-stroke:1.2px var(--copper-600);
          text-stroke:1.2px var(--copper-600);
  margin-right:.06em;
}
.trat-intro{
  font-family:var(--font-body);font-size:1.05rem;line-height:1.7;
  color:var(--ink-700);
  max-width:620px;
}

/* --- Grade dos cards --- */
.services-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1px;
  background:rgba(155,105,70,.18);     /* hairlines cobre */
  border:1px solid rgba(155,105,70,.18);
  border-radius:var(--r-lg);
  overflow:hidden;
  box-shadow:var(--shadow-lg);
}

.service-card{
  position:relative;
  background:var(--white);
  padding:2.6rem 2rem 2.2rem;
  display:flex;flex-direction:column;
  min-height:280px;
  transition:background .4s var(--ease-out-expo),
             transform .45s var(--ease-out-expo);
  overflow:hidden;
}
/* Wash cobre diagonal — surge no hover (igual .service-card do DS) */
.service-card::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,
    rgba(206,142,99,.10) 0%, transparent 55%);
  opacity:0;
  transition:opacity .5s var(--ease-out-expo);
  pointer-events:none;
}
.service-card:hover,
.service-card:focus-within{
  background:var(--ink-50);
  transform:translateY(-6px);
}
.service-card:hover::before,
.service-card:focus-within::before{opacity:1;}

/* Link cobrindo o card inteiro (stretched link pattern) */
.service-link{
  position:absolute;inset:0;z-index:3;
  text-indent:-9999px;overflow:hidden; /* esconde label sem afetar a11y */
}
.service-link:focus-visible{
  outline:2px solid var(--copper-500);
  outline-offset:-2px;
  border-radius:var(--r-md);
}

/* Ícone (caixa redonda cobre, ícone Solar) */
.service-icon{
  position:relative;z-index:1;
  width:60px;height:60px;
  display:grid;place-items:center;
  border-radius:var(--r-full);
  background:rgba(206,142,99,.08);
  border:1px solid rgba(206,142,99,.18);
  margin-bottom:1.6rem;
  transition:transform .45s var(--ease-out-expo),
             background .45s var(--ease-out-expo),
             border-color .45s var(--ease-out-expo),
             box-shadow .45s var(--ease-out-expo);
}
.service-icon .iconify{
  font-size:1.8rem;color:var(--copper-500);
  transition:color .35s ease,transform .45s var(--ease-out-expo);
}
.service-card:hover .service-icon,
.service-card:focus-within .service-icon{
  transform:translateY(-2px) scale(1.06);
  background:rgba(206,142,99,.16);
  border-color:var(--copper-500);
  box-shadow:0 12px 26px -8px rgba(189,117,82,.35);
}
.service-card:hover .service-icon .iconify,
.service-card:focus-within .service-icon .iconify{
  color:var(--copper-700);transform:scale(1.06);
}

.service-name{
  position:relative;z-index:1;
  font-family:var(--font-display);font-weight:500;
  font-size:1.18rem;letter-spacing:.08em;text-transform:uppercase;
  color:var(--ink-900);
  margin-bottom:.7rem;line-height:1.25;
}
.service-desc{
  position:relative;z-index:1;
  font-family:var(--font-body);font-size:.9rem;line-height:1.65;
  color:var(--ink-700);
  margin-bottom:1.6rem;
  flex:1; /* empurra a seta pro rodapé do card */
}

/* "Conhecer →" — tipográfico, cobre, seta desliza no hover */
.service-arrow{
  position:relative;z-index:1;
  display:inline-flex;align-items:center;gap:.55rem;
  font-family:var(--font-body);font-weight:700;
  font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--copper-600);
  margin-top:auto;
  transition:color .3s ease;
}
.service-arrow svg{
  width:1.05em;height:1.05em;
  transition:transform .35s var(--ease-out-expo);
}
.service-card:hover .service-arrow,
.service-card:focus-within .service-arrow{
  color:var(--copper-700);
}
.service-card:hover .service-arrow svg,
.service-card:focus-within .service-arrow svg{
  transform:translateX(6px);
}

/* Responsivo da Dobra 4 */
@media (max-width:1100px){
  .trat-inner{padding:5rem 2rem 5.5rem;}
  .trat-header{margin-bottom:3rem;}
  .services-grid{grid-template-columns:repeat(2,1fr);}
  .service-card{min-height:auto;padding:2.2rem 1.6rem 2rem;}
}
@media (max-width:640px){
  .trat-inner{padding:4rem 1.25rem 4.5rem;}
  .trat-title{font-size:clamp(1.8rem,8vw,2.4rem);}
  .trat-intro{font-size:.98rem;}
  .services-grid{
    grid-template-columns:1fr;
    border-radius:var(--r-md);
  }
  .service-card{padding:2rem 1.5rem 1.8rem;min-height:auto;}
  .service-name{font-size:1.05rem;}
  .service-desc{font-size:.88rem;}
}

/* ============================== DOBRA 5 — COMO FUNCIONA =================== */
/* Volta ao tema escuro. 4 passos numerados ligados por uma linha cobre fina,
   sugerindo progressão. CTA WhatsApp centralizado fecha a dobra. */
.steps{
  position:relative;
  background:var(--black);
  color:var(--white);
  overflow:hidden;
  border-top:1px solid var(--border);
}

/* Fundo: aurora cobre no topo + grade fininha sutil */
.steps-bg{position:absolute;inset:0;z-index:0;pointer-events:none;}
.steps-bg .steps-aurora{
  position:absolute;top:-20%;left:50%;transform:translateX(-50%);
  width:1100px;height:600px;
  background:radial-gradient(ellipse at 50% 30%,
    rgba(206,142,99,.18),
    rgba(189,117,82,.05) 50%,
    transparent 70%);
  filter:blur(40px);
  animation:auroraDrift 26s var(--ease-out-quart) infinite alternate;
}
.steps-bg .steps-grid-lines{
  position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(206,142,99,.11) 1px,transparent 1px),
    linear-gradient(90deg,rgba(206,142,99,.11) 1px,transparent 1px);
  background-size:64px 64px;
  /* Máscara ampla — grade aparece em quase toda a dobra, esmaece nas bordas */
  mask-image:radial-gradient(ellipse at 50% 50%,#000 55%,rgba(0,0,0,.7) 75%,transparent 100%);
  -webkit-mask-image:radial-gradient(ellipse at 50% 50%,#000 55%,rgba(0,0,0,.7) 75%,transparent 100%);
}

.steps-inner{
  position:relative;z-index:1;
  max-width:var(--container-wide);
  margin:0 auto;
  padding:7rem 4.5rem 7rem;
}

/* --- Cabeçalho --- */
.steps-header{
  text-align:center;
  max-width:760px;
  margin:0 auto 4rem;
}
.steps-tag{
  display:inline-flex;align-items:center;gap:1rem;
  margin-bottom:1.4rem;
}
.steps-tag-line{
  display:block;width:38px;height:1px;background:var(--copper-400);
}
.steps-tag-text{
  font-family:var(--font-body);font-weight:700;
  font-size:.7rem;letter-spacing:.34em;text-transform:uppercase;
  color:var(--copper-300);
}
.steps-title{
  font-family:var(--font-display);font-weight:300;
  font-size:clamp(2rem,3.6vw,3.4rem);
  line-height:1.06;letter-spacing:.025em;
  text-transform:uppercase;
  color:var(--white);
  margin:0;
}
.steps-title .italic{
  font-family:var(--font-serif);font-style:italic;font-weight:500;
  color:var(--copper-300);
  display:inline;
  font-size:.92em;text-transform:none;letter-spacing:.005em;
  vertical-align:baseline;position:relative;top:.04em;
}

/* --- 4 passos --- */
.steps-list{
  position:relative;
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:1.8rem;
  margin-bottom:4.5rem;
}

.step-card{
  position:relative;
  background:linear-gradient(180deg,
    rgba(26,23,20,.6) 0%,
    rgba(11,10,9,.85) 100%);
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  padding:2.4rem 1.8rem 2.2rem;
  display:flex;flex-direction:column;
  backdrop-filter:blur(4px);
  -webkit-backdrop-filter:blur(4px);
  transition:transform .45s var(--ease-out-expo),
             border-color .45s var(--ease-out-expo),
             box-shadow .45s var(--ease-out-expo),
             background .45s var(--ease-out-expo);
  overflow:hidden;
}
.step-card::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(circle at 50% 0%,
    rgba(206,142,99,.10) 0%, transparent 60%);
  opacity:0;
  transition:opacity .5s ease;
  pointer-events:none;
}
.step-card:hover,
.step-card:focus-within{
  transform:translateY(-5px);
  border-color:var(--copper-500);
  box-shadow:var(--shadow-lg),0 0 40px -10px rgba(206,142,99,.35);
}
.step-card:hover::before{opacity:1;}

/* Conector cobre entre cards (desktop) */
.step-card::after{
  content:'';
  position:absolute;top:64px;right:-1.9rem;
  width:2.1rem;height:1px;
  background:linear-gradient(90deg,
    var(--copper-500),
    rgba(206,142,99,.2));
  z-index:2;
}
.step-card:last-child::after{display:none;}
/* Bolinha decorativa no início do conector */
.step-card:not(:last-child)::after{
  background:linear-gradient(90deg,
    var(--copper-400) 0%,
    var(--copper-500) 30%,
    rgba(206,142,99,.15) 100%);
  box-shadow:0 0 8px rgba(206,142,99,.5);
}

/* Número grande vazado cobre (mesma DNA das headlines) */
.step-number{
  display:block;
  font-family:var(--font-display);font-weight:300;
  font-size:3rem;line-height:1;letter-spacing:.04em;
  color:transparent;
  -webkit-text-stroke:1.2px var(--copper-400);
          text-stroke:1.2px var(--copper-400);
  margin-bottom:1.4rem;
  transition:color .4s ease,-webkit-text-stroke-color .4s ease;
}
.step-card:hover .step-number{
  color:var(--copper-300);
  -webkit-text-stroke-color:transparent;
}

/* Ícone (caixa redonda cobre) */
.step-icon{
  width:54px;height:54px;
  display:grid;place-items:center;
  border-radius:var(--r-full);
  background:rgba(206,142,99,.10);
  border:1px solid rgba(206,142,99,.20);
  margin-bottom:1.4rem;
  transition:transform .45s var(--ease-out-expo),
             background .45s var(--ease-out-expo),
             border-color .45s var(--ease-out-expo);
}
.step-icon .iconify{
  font-size:1.5rem;color:var(--copper-300);
  transition:color .35s ease,transform .45s var(--ease-out-expo);
}
.step-card:hover .step-icon{
  background:rgba(206,142,99,.18);
  border-color:var(--copper-400);
  transform:scale(1.05);
}
.step-card:hover .step-icon .iconify{
  color:var(--copper-200);transform:scale(1.06);
}

.step-name{
  font-family:var(--font-display);font-weight:500;
  font-size:1.08rem;letter-spacing:.08em;text-transform:uppercase;
  color:var(--white);
  margin-bottom:.7rem;line-height:1.3;
}
.step-desc{
  font-family:var(--font-body);font-size:.88rem;line-height:1.65;
  color:var(--text-muted);
}

/* --- Fecho + CTA centralizado --- */
.steps-cta{
  text-align:center;
  max-width:560px;
  margin:0 auto;
}
.steps-tagline{
  margin-bottom:1.8rem;
  font-family:var(--font-serif);font-style:italic;
  font-size:1.5rem;line-height:1.5;
  color:var(--copper-300);
}
.steps-tagline .italic{
  font-family:var(--font-serif);font-style:italic;font-weight:500;
  color:var(--copper-300);
}
.steps-cta .btn-primary{display:inline-flex;}

/* Responsivo da Dobra 5 */
@media (max-width:1100px){
  .steps-inner{padding:5rem 2rem;}
  .steps-list{
    grid-template-columns:repeat(2,1fr);
    gap:1.6rem;
    margin-bottom:3.5rem;
  }
  /* Conector horizontal apenas entre 1-2 e 3-4 (mesma row) */
  .step-card::after{display:none;}
  .step-card:nth-child(1)::after,
  .step-card:nth-child(3)::after{
    display:block;right:-1.7rem;width:1.9rem;
  }
}
@media (max-width:640px){
  .steps-inner{padding:4rem 1.25rem;}
  .steps-list{grid-template-columns:1fr;gap:1.2rem;margin-bottom:3rem;}
  .step-card{padding:2rem 1.6rem 1.8rem;}
  /* Sem conector no mobile — a numeração 01..04 já comunica a progressão */
  .step-card::after,
  .step-card:nth-child(1)::after,
  .step-card:nth-child(3)::after{display:none;}
  .step-number{font-size:2.6rem;margin-bottom:1.1rem;}
  .steps-tagline{font-size:1.25rem;margin-bottom:1.5rem;}
}

/* ============================== DOBRA 6 — ANTES & DEPOIS ================== */
/* Ponto mais fiscalizado do site. Toda imagem é placeholder enquanto não temos
   pares reais com TCLE — usamos gradientes cobre + ícones pra mostrar layout
   sem expor imagem de paciente sem autorização. */
.cases{
  position:relative;
  background:var(--ink-900);
  color:var(--white);
  overflow:hidden;
  border-top:1px solid var(--border);
}

/* Fundo: aurora cobre sutil + grade fininha */
.cases-bg{position:absolute;inset:0;z-index:0;pointer-events:none;}
.cases-bg .cases-aurora{
  position:absolute;top:-20%;right:-15%;
  width:900px;height:700px;
  background:radial-gradient(ellipse at 50% 50%,
    rgba(206,142,99,.16),
    rgba(189,117,82,.04) 55%,
    transparent 75%);
  filter:blur(50px);
}
.cases-bg .cases-grid-lines{
  position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(206,142,99,.07) 1px,transparent 1px),
    linear-gradient(90deg,rgba(206,142,99,.07) 1px,transparent 1px);
  background-size:72px 72px;
  mask-image:radial-gradient(ellipse at 50% 50%,#000 45%,rgba(0,0,0,.6) 75%,transparent 100%);
  -webkit-mask-image:radial-gradient(ellipse at 50% 50%,#000 45%,rgba(0,0,0,.6) 75%,transparent 100%);
}

.cases-inner{
  position:relative;z-index:1;
  max-width:var(--container-wide);
  margin:0 auto;
  padding:7rem 4.5rem;
}

/* --- Cabeçalho centralizado --- */
.cases-header{
  text-align:center;
  max-width:760px;
  margin:0 auto 2.2rem;
}
.cases-tag{
  display:inline-flex;align-items:center;gap:1rem;
  margin-bottom:1.4rem;
}
.cases-title{
  font-family:var(--font-display);font-weight:300;
  font-size:clamp(2rem,3.6vw,3.4rem);
  line-height:1.06;letter-spacing:.025em;
  text-transform:uppercase;
  color:var(--white);
  margin:0;
}
.cases-title .italic{
  font-family:var(--font-serif);font-style:italic;font-weight:500;
  color:var(--copper-300);
  display:inline;
  font-size:.92em;text-transform:none;letter-spacing:.005em;
  vertical-align:baseline;position:relative;top:.04em;
}

/* --- Intro --- */
.cases-intro{
  font-family:var(--font-body);font-size:1.02rem;line-height:1.7;
  color:var(--text-muted);
  max-width:560px;margin:1.4rem auto 0;
}

/* --- Carrossel de casos --- */
.cases-carousel{
  position:relative;
  max-width:560px;
  margin:3rem auto 3.5rem;
  padding-right:14px;padding-bottom:14px;
}
/* Moldura cobre deslocada (mesma DNA da Dobra 3) */
.cases-carousel::after{
  content:'';
  position:absolute;inset:0 14px 14px 0;
  border:1px solid var(--copper-500);
  border-radius:var(--r-lg);
  transform:translate(14px,14px);
  pointer-events:none;
  opacity:.5;
  transition:transform .6s var(--ease-out-expo),opacity .4s ease;
}
.cases-carousel:hover::after{transform:translate(8px,8px);opacity:.7;}

.carousel-viewport{
  position:relative;
  overflow:hidden;
  border-radius:var(--r-lg);
  border:1px solid var(--border-strong);
  background:var(--ink-900);
  box-shadow:var(--shadow-xl);
}

.carousel-track{
  display:flex;
  transform:translateX(calc(var(--idx, 0) * -100%));
  transition:transform .65s var(--ease-out-expo);
  list-style:none;
  margin:0;padding:0;
}

.carousel-slide{
  flex:0 0 100%;
  min-width:0;
  position:relative;
  list-style:none;
}

.carousel-figure{
  position:relative;
  margin:0;
  display:flex;flex-direction:column;
}
.carousel-figure img{
  width:100%;
  aspect-ratio:1/1;
  object-fit:contain;       /* preserva geometria antes/depois sem cortar */
  display:block;
  filter:contrast(1.02) saturate(.98);
  /* Backdrop cobre suave aparece quando a imagem não preenche (letterbox) */
  background:
    radial-gradient(circle at 50% 50%,
      rgba(206,142,99,.10),
      rgba(0,0,0,0) 65%),
    var(--black);
}

/* Legenda — strip abaixo da imagem (não obscurece o antes/depois) */
.carousel-caption{
  display:flex;align-items:center;justify-content:space-between;
  gap:.8rem;
  padding:.95rem 1.2rem;
  background:linear-gradient(180deg,
    rgba(26,23,20,.95) 0%,
    rgba(11,10,9,.98) 100%);
  border-top:1px solid var(--border);
}
.carousel-caption .badge{
  font-family:var(--font-body);font-weight:700;
  font-size:.62rem;letter-spacing:.22em;text-transform:uppercase;
  padding:.4rem .9rem;border-radius:var(--r-full);
  border:1px solid var(--copper-400);
  color:var(--copper-200);
  background:rgba(206,142,99,.06);
}
.carousel-note{
  font-family:var(--font-body);font-size:.74rem;
  font-style:italic;color:var(--ink-300);
  letter-spacing:.02em;
  margin:0;
}

/* Setas (prev/next) — desktop sobrepostas; mobile abaixo do viewport */
.carousel-nav{
  position:absolute;top:50%;
  transform:translateY(-50%);
  width:48px;height:48px;border-radius:var(--r-full);
  display:grid;place-items:center;
  background:rgba(11,10,9,.7);
  border:1px solid var(--border-strong);
  color:var(--copper-200);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
  cursor:pointer;
  z-index:5;
  transition:background .3s ease,
             color .3s ease,
             border-color .3s ease,
             transform .35s var(--ease-out-expo),
             box-shadow .35s ease;
}
.carousel-nav:hover,
.carousel-nav:focus-visible{
  background:var(--copper-500);
  border-color:var(--copper-500);
  color:var(--black);
  box-shadow:0 0 0 6px rgba(206,142,99,.18),
             0 0 24px rgba(206,142,99,.4);
}
.carousel-prev{left:-1.5rem;}
.carousel-next{right:-1.5rem;}
.carousel-prev:hover{transform:translateY(-50%) translateX(-2px);}
.carousel-next:hover{transform:translateY(-50%) translateX(2px);}
.carousel-nav:disabled{opacity:.35;cursor:not-allowed;}
.carousel-nav:disabled:hover{
  background:rgba(11,10,9,.7);color:var(--copper-200);
  border-color:var(--border-strong);box-shadow:none;
  transform:translateY(-50%);
}

/* Rodapé do carrossel — counter + dots */
.carousel-footer{
  margin-top:1.4rem;
  display:flex;align-items:center;justify-content:space-between;
  gap:1rem;
}
.carousel-counter{
  font-family:var(--font-display);font-weight:300;
  font-size:.86rem;letter-spacing:.14em;
  color:var(--ink-400);
}
.carousel-counter strong{
  font-weight:500;color:var(--copper-300);
  margin-right:.2em;
}

.carousel-dots{
  display:flex;gap:.5rem;list-style:none;margin:0;padding:0;
}
.carousel-dots button{
  width:24px;height:6px;border-radius:var(--r-full);
  background:rgba(206,142,99,.25);
  border:none;cursor:pointer;
  transition:background .3s ease,width .35s var(--ease-out-expo);
}
.carousel-dots button[aria-current="true"]{
  background:var(--copper-400);
  width:36px;
  box-shadow:0 0 10px rgba(206,142,99,.5);
}
.carousel-dots button:hover{background:var(--copper-300);}
.carousel-dots button:focus-visible{outline:2px solid var(--copper-300);outline-offset:3px;}

/* --- Blindagem legal + CTA --- */
.cases-disclaimer{
  max-width:760px;margin:0 auto 2.5rem;
  font-family:var(--font-body);font-size:.82rem;line-height:1.65;
  color:var(--ink-400);
  text-align:center;
  padding:1.1rem 1.4rem;
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
}
.cases-disclaimer strong{color:var(--ink-200);font-weight:700;}
.cases-disclaimer em{color:var(--copper-200);font-style:italic;}

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

/* Responsivo da Dobra 6 */
@media (max-width:1100px){
  .cases-inner{padding:5rem 2rem;}
}
@media (max-width:640px){
  .cases-inner{padding:4rem 1.25rem;}
  .cases-carousel{margin:2.4rem auto 2.4rem;padding-right:8px;padding-bottom:8px;}
  .cases-carousel::after{inset:0 8px 8px 0;transform:translate(8px,8px);}
  /* setas viram menores e descem pro rodapé do carrossel */
  .carousel-nav{
    position:static;
    transform:none;
    width:42px;height:42px;
  }
  .carousel-prev,.carousel-next{position:absolute;top:38%;}
  .carousel-prev{left:.4rem;}
  .carousel-next{right:.4rem;}
  .carousel-footer{flex-direction:column-reverse;gap:.8rem;margin-top:1rem;}
  .cases-disclaimer{font-size:.78rem;}
}

/* ============================== DOBRA 7 — SOBRE O DR. CARLOS ============= */
/* Volta ao tema claro/marfim — autoridade. Retrato à esquerda (frame-card
   reaproveitado da Dobra 3) · bio + checklist 2×2 + assinatura + CTA. */
.sobre{
  position:relative;
  background:var(--ink-50);
  color:var(--ink-900);
  overflow:hidden;
  border-top:1px solid rgba(155,105,70,.08);
}

.sobre-bg{position:absolute;inset:0;z-index:0;pointer-events:none;}
.sobre-bg .sobre-orb{
  position:absolute;width:720px;height:720px;border-radius:50%;
  top:-10%;right:-12%;
  background:radial-gradient(circle at 50% 50%,
    rgba(206,142,99,.16),rgba(206,142,99,.04) 55%,transparent 72%);
  filter:blur(60px);
}
.sobre-bg .sobre-grid{
  position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(155,105,70,.04) 1px,transparent 1px),
    linear-gradient(90deg,rgba(155,105,70,.04) 1px,transparent 1px);
  background-size:72px 72px;
  mask-image:radial-gradient(circle at 30% 50%,#000,transparent 80%);
  -webkit-mask-image:radial-gradient(circle at 30% 50%,#000,transparent 80%);
}

.sobre-inner{
  position:relative;z-index:1;
  max-width:var(--container-wide);
  margin:0 auto;
  padding:7rem 4.5rem;
  display:grid;
  grid-template-columns:.95fr 1.05fr;  /* foto um pouco menor, texto um pouco maior */
  gap:5rem;
  align-items:center;
}

/* --- Retrato (reaproveita .frame-card da Dobra 3) --- */
.sobre-media{max-width:520px;}

/* --- Coluna texto --- */
.sobre-text{max-width:580px;}

.sobre-tag{
  display:inline-flex;align-items:center;gap:1rem;
  margin-bottom:1.4rem;
}

.sobre-title{
  font-family:var(--font-display);font-weight:300;
  font-size:clamp(2rem,3.4vw,3.2rem);
  line-height:1.08;letter-spacing:.02em;
  text-transform:uppercase;
  color:var(--ink-900);
  margin-bottom:1.6rem;
}
.sobre-title .italic{
  font-family:var(--font-serif);font-style:italic;font-weight:500;
  color:var(--copper-600);
  display:inline;
  font-size:.92em;text-transform:none;letter-spacing:.005em;
  vertical-align:baseline;position:relative;top:.04em;
}
.sobre-title .title-stroke{
  display:inline-block;
  color:transparent;
  -webkit-text-stroke:1.2px var(--copper-600);
          text-stroke:1.2px var(--copper-600);
  margin-right:.06em;
}

.sobre-bio{
  font-family:var(--font-body);font-size:1.02rem;line-height:1.75;
  color:var(--ink-700);
  margin-bottom:2.4rem;
}
.sobre-bio strong{color:var(--ink-900);font-weight:700;}

/* Checklist 2×2 — áreas de atuação */
.sobre-list{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:1rem 1.6rem;
  margin-bottom:2.4rem;
}
.sobre-item{
  display:flex;align-items:center;gap:.85rem;
  padding:.4rem 0;
  transition:transform .35s var(--ease-out-expo);
}
.sobre-item:hover{transform:translateX(2px);}
.sobre-check{
  display:grid;place-items:center;
  width:28px;height:28px;border-radius:var(--r-full);
  background:rgba(206,142,99,.10);
  border:1px solid rgba(206,142,99,.22);
  flex-shrink:0;
  transition:background .35s ease,border-color .35s ease,transform .35s var(--ease-out-expo);
}
.sobre-check .iconify{
  font-size:1rem;color:var(--copper-600);
  transition:color .3s ease,transform .35s var(--ease-out-expo);
}
.sobre-item:hover .sobre-check{
  background:rgba(206,142,99,.18);
  border-color:var(--copper-500);
  transform:scale(1.06);
}
.sobre-item > span:last-child{
  font-family:var(--font-display);font-weight:500;
  font-size:.94rem;letter-spacing:.06em;text-transform:uppercase;
  color:var(--ink-900);
}

/* Assinatura — carimbo de autoria (logo cobre + nome Allura) */
.sobre-signature{
  display:flex;align-items:center;gap:1rem;
  padding:1.2rem 0;
  margin-bottom:2rem;
  border-top:1px solid rgba(155,105,70,.18);
  border-bottom:1px solid rgba(155,105,70,.18);
}
.sobre-signature .sobre-tooth{
  width:auto;height:48px;
  filter:drop-shadow(0 4px 10px rgba(189,117,82,.25));
}
.sobre-signature .sobre-name{
  font-family:var(--font-script);font-size:1.9rem;line-height:1;
  color:var(--copper-600);
}

/* CTA (botão sólido — mesma DNA do .dif-cta da Dobra 3) */
.sobre-cta{
  display:inline-flex;align-items:center;gap:.85rem;
  background:var(--copper-500);color:var(--white);
  padding:1.05rem 2.2rem;border-radius:var(--r-full);
  font-family:var(--font-body);font-size:.74rem;font-weight:700;
  letter-spacing:.22em;text-transform:uppercase;
  position:relative;overflow:hidden;
  box-shadow:0 18px 40px -12px rgba(189,117,82,.55),
             0 2px 8px rgba(106,58,36,.18);
  transition:box-shadow .4s var(--ease-out-expo),
             transform .4s var(--ease-out-expo);
}
.sobre-cta::before{
  content:'';position:absolute;inset:0;
  background:var(--copper-600);
  transform:translateX(-101%);
  transition:transform .45s var(--ease-out-expo);
  z-index:0;
}
.sobre-cta::after{
  content:'';position:absolute;top:0;left:-60%;
  width:40%;height:100%;
  background:linear-gradient(120deg,transparent,rgba(255,255,255,.45),transparent);
  transform:skewX(-20deg);
  pointer-events:none;z-index:1;
}
.sobre-cta:hover,.sobre-cta:focus-visible{
  transform:translateY(-2px);
  box-shadow:0 22px 50px -10px rgba(189,117,82,.65),
             0 0 0 6px rgba(206,142,99,.15);
}
.sobre-cta:hover::before{transform:translateX(0);}
.sobre-cta:hover::after{animation:shimmer .9s var(--ease-out-quart);}
.sobre-cta>*{position:relative;z-index:2;}
.sobre-cta .iconify{font-size:1.1rem;}

/* Responsivo da Dobra 7 */
@media (max-width:1100px){
  .sobre-inner{
    grid-template-columns:1fr;
    gap:3rem;
    padding:5rem 2rem;
  }
  .sobre-media{order:-1;max-width:460px;margin:0 auto;}
  .sobre-text{max-width:none;}
}
@media (max-width:640px){
  .sobre-inner{padding:4rem 1.25rem;gap:2.4rem;}
  .sobre-title{font-size:clamp(1.8rem,8vw,2.4rem);}
  .sobre-bio{font-size:.98rem;}
  .sobre-list{grid-template-columns:1fr;gap:.8rem;margin-bottom:2rem;}
  .sobre-item > span:last-child{font-size:.9rem;}
  .sobre-signature{gap:.8rem;}
  .sobre-signature .sobre-tooth{height:42px;}
  .sobre-signature .sobre-name{font-size:1.6rem;}
  .sobre-cta{width:100%;justify-content:center;}
}

/* ============================== DOBRA 8 — AVALIAÇÕES DO GOOGLE =========== */
/* Continua marfim (mesma família da Dobra 7) mas com layout distinto:
   header centralizado → rating card horizontal em destaque → grade 3×
   testimonials → CTAs. Estrutura pronta pra integrar widget Google Business. */
.reviews{
  position:relative;
  background:linear-gradient(180deg,
    var(--ink-100) 0%,
    var(--ink-50)  100%);
  color:var(--ink-900);
  overflow:hidden;
  border-top:1px solid rgba(155,105,70,.08);
}

.reviews-bg{position:absolute;inset:0;z-index:0;pointer-events:none;}
.reviews-bg .reviews-orb{
  position:absolute;width:760px;height:760px;border-radius:50%;
  top:-10%;left:-12%;
  background:radial-gradient(circle at 50% 50%,
    rgba(206,142,99,.14),rgba(206,142,99,.04) 55%,transparent 75%);
  filter:blur(70px);
}
.reviews-bg .reviews-grid-lines{
  position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(155,105,70,.04) 1px,transparent 1px),
    linear-gradient(90deg,rgba(155,105,70,.04) 1px,transparent 1px);
  background-size:72px 72px;
  mask-image:radial-gradient(circle at 70% 60%,#000,transparent 85%);
  -webkit-mask-image:radial-gradient(circle at 70% 60%,#000,transparent 85%);
}

.reviews-inner{
  position:relative;z-index:1;
  max-width:var(--container-wide);
  margin:0 auto;
  padding:6.5rem 4.5rem 7rem;
}

/* --- Header centralizado --- */
.reviews-header{
  text-align:center;
  max-width:760px;
  margin:0 auto 3rem;
}
.reviews-tag{
  display:inline-flex;align-items:center;gap:1rem;
  margin-bottom:1.4rem;
}
.reviews-title{
  font-family:var(--font-display);font-weight:300;
  font-size:clamp(2rem,3.4vw,3.2rem);
  line-height:1.08;letter-spacing:.02em;
  text-transform:uppercase;
  color:var(--ink-900);
  margin:0;
}
.reviews-title .italic{
  font-family:var(--font-serif);font-style:italic;font-weight:500;
  color:var(--copper-600);
  display:inline;
  font-size:.92em;text-transform:none;letter-spacing:.005em;
  vertical-align:baseline;position:relative;top:.04em;
}

/* --- Rating card em destaque --- */
.rating-card{
  display:grid;
  grid-template-columns:auto 1fr;
  gap:2.4rem;
  align-items:center;
  max-width:760px;
  margin:0 auto 3rem;
  padding:2rem 2.4rem;
  background:var(--white);
  border:1px solid rgba(155,105,70,.18);
  border-radius:var(--r-lg);
  box-shadow:0 18px 40px -18px rgba(155,105,70,.25),
             0 2px 8px rgba(106,58,36,.06);
  position:relative;overflow:hidden;
}
/* sombra cobre sutil em torno */
.rating-card::after{
  content:'';position:absolute;inset:-1px;
  border-radius:inherit;
  background:linear-gradient(135deg,
    rgba(206,142,99,.22) 0%,
    transparent 35%,
    transparent 65%,
    rgba(206,142,99,.18) 100%);
  z-index:-1;
  filter:blur(1px);
}
.rating-left{
  text-align:center;
  border-right:1px solid rgba(155,105,70,.16);
  padding-right:2.4rem;
}
.rating-number{
  display:block;
  font-family:var(--font-display);font-weight:300;
  font-size:4.4rem;line-height:1;letter-spacing:0;
  color:var(--ink-900);
  margin-bottom:.6rem;
}
.rating-stars{
  display:flex;justify-content:center;gap:.2rem;
  color:var(--copper-500);
  font-size:1.05rem;
}
.rating-stars .iconify{filter:drop-shadow(0 1px 2px rgba(189,117,82,.3));}

.rating-right{
  display:flex;flex-direction:column;align-items:flex-start;gap:.6rem;
}
.rating-source{
  display:inline-flex;align-items:center;gap:.55rem;
  font-family:var(--font-display);font-weight:400;
  font-size:.95rem;letter-spacing:.06em;text-transform:uppercase;
  color:var(--ink-900);
}
.rating-glogo{display:inline-block;flex-shrink:0;}
.rating-note{
  font-family:var(--font-body);font-size:.86rem;line-height:1.55;
  color:var(--ink-600);
  margin:0;
}
.rating-link{
  display:inline-flex;align-items:center;gap:.55rem;
  font-family:var(--font-body);font-weight:700;
  font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--copper-600);
  padding:.4rem 0;
  border-bottom:1px solid transparent;
  transition:color .3s ease,border-color .3s ease;
}
.rating-link svg{
  width:1em;height:1em;
  transition:transform .35s var(--ease-out-expo);
}
.rating-link:hover,.rating-link:focus-visible{
  color:var(--copper-700);
  border-bottom-color:var(--copper-500);
}
.rating-link:hover svg{transform:translateX(4px);}

/* --- Aviso de build (provisório, removível) --- */
.reviews-note{
  display:flex;align-items:flex-start;gap:.85rem;
  max-width:760px;margin:0 auto 2.5rem;
  padding:.95rem 1.25rem;
  background:rgba(201,150,47,.08);
  border:1px dashed rgba(201,150,47,.45);
  border-radius:var(--r-md);
  font-family:var(--font-body);font-size:.84rem;line-height:1.55;
  color:#9F7918;
}
.reviews-note .iconify{font-size:1.15rem;color:#B8861A;flex-shrink:0;margin-top:.1rem;}
.reviews-note strong{color:#7A5C13;font-weight:700;}

/* --- Grade de testimonials (skeleton até widget chegar) --- */
.reviews-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1.5rem;
  margin-bottom:3.5rem;
}

.tcard{
  background:var(--white);
  border:1px solid rgba(155,105,70,.16);
  border-radius:var(--r-xl);
  padding:2.2rem 1.9rem 1.8rem;
  display:flex;flex-direction:column;gap:1.2rem;
  transition:transform .45s var(--ease-out-expo),
             border-color .45s var(--ease-out-expo),
             box-shadow .45s var(--ease-out-expo);
  position:relative;
}
.tcard:hover{
  transform:translateY(-3px);
  border-color:rgba(206,142,99,.4);
  box-shadow:0 18px 40px -18px rgba(155,105,70,.3);
}
.tcard-stars{
  display:flex;gap:.18rem;
  color:var(--copper-500);
  font-size:1rem;
}
.tcard-quote{
  font-family:var(--font-serif);font-style:italic;
  font-size:1.05rem;line-height:1.65;
  color:var(--ink-800);
  margin:0;
  flex:1;
  /* aspas decorativas */
  position:relative;padding-left:1.1rem;
}
.tcard-quote::before{
  content:'\201C';
  position:absolute;left:-.2rem;top:-.8rem;
  font-family:var(--font-serif);font-style:normal;font-weight:500;
  font-size:3rem;line-height:1;color:var(--copper-300);
  pointer-events:none;
}
.tcard-placeholder{
  color:var(--ink-500);
  opacity:.85;
}
.tcard-foot{
  display:flex;align-items:center;gap:.8rem;
  padding-top:.9rem;
  border-top:1px solid rgba(155,105,70,.14);
}
.tcard-avatar{
  display:grid;place-items:center;
  width:38px;height:38px;
  border-radius:var(--r-full);
  background:rgba(206,142,99,.12);
  border:1px solid rgba(206,142,99,.22);
  font-family:var(--font-display);font-weight:500;
  color:var(--copper-600);font-size:1rem;
  flex-shrink:0;
}
.tcard-meta{
  display:flex;flex-direction:column;gap:.15rem;
  min-width:0;
}
.tcard-who{
  font-family:var(--font-display);font-weight:500;
  font-size:.88rem;letter-spacing:.04em;
  color:var(--ink-900);
  display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;
  line-height:1.2;
}
.tcard-when{
  font-family:var(--font-body);font-size:.7rem;
  font-style:italic;color:var(--ink-500);
  margin-top:.2rem;
}

/* Tag opcional ao lado do nome (ex.: Local Guide do Google) */
.tcard-tag{
  display:inline-flex;align-items:center;gap:.3rem;
  font-family:var(--font-body);font-weight:600;
  font-size:.6rem;letter-spacing:.16em;text-transform:uppercase;
  padding:.18rem .5rem;
  border-radius:var(--r-full);
  background:rgba(206,142,99,.10);
  border:1px solid rgba(206,142,99,.25);
  color:var(--copper-700);
  white-space:nowrap;
}
.tcard-tag .iconify{font-size:.8rem;color:var(--copper-500);}

/* --- CTAs --- */
.reviews-cta{
  display:flex;align-items:center;justify-content:center;
  gap:1.4rem;flex-wrap:wrap;
}
/* Variante outline do botão pra tema light */
.btn-outline-light{
  display:inline-flex;align-items:center;gap:.7rem;
  padding:1.05rem 1.8rem;
  border:1px solid var(--copper-500);
  border-radius:var(--r-full);
  background:transparent;
  color:var(--copper-700);
  font-family:var(--font-body);font-weight:700;
  font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;
  transition:background .35s ease,color .35s ease,box-shadow .35s ease,
             transform .35s var(--ease-out-expo);
}
.btn-outline-light svg{
  width:1.1em;height:1.1em;
  color:var(--copper-600);
  transition:color .3s ease;
}
.btn-outline-light:hover,.btn-outline-light:focus-visible{
  background:rgba(206,142,99,.08);
  color:var(--copper-800);
  box-shadow:0 0 0 4px rgba(206,142,99,.10);
  transform:translateY(-1px);
}

/* Responsivo da Dobra 8 */
@media (max-width:1100px){
  .reviews-inner{padding:5rem 2rem;}
  .reviews-grid{grid-template-columns:repeat(2,1fr);}
  .reviews-grid > :nth-child(3){grid-column:span 2;max-width:560px;margin:0 auto;}
}
@media (max-width:640px){
  .reviews-inner{padding:4rem 1.25rem;}
  .rating-card{
    grid-template-columns:1fr;
    gap:1.2rem;
    padding:1.6rem 1.5rem;
    text-align:center;
  }
  .rating-left{
    border-right:none;
    border-bottom:1px solid rgba(155,105,70,.16);
    padding:0 0 1.2rem;
  }
  .rating-right{align-items:center;text-align:center;}
  .rating-number{font-size:3.6rem;}
  .reviews-grid{grid-template-columns:1fr;gap:1.2rem;}
  .reviews-grid > :nth-child(3){grid-column:span 1;max-width:none;}
  .reviews-cta{flex-direction:column;align-items:stretch;width:100%;}
  .btn-outline-light,.reviews-cta .sobre-cta{
    width:100%;justify-content:center;
  }
}

/* ============================== DOBRA 9 — LOCALIZAÇÃO ==================== */
/* Volta ao tema escuro (contraste com a Dobra 8 marfim). 2 colunas: mapa do
   Google embutido + bloco de infos. NAP idêntico ao perfil oficial. */
.local{
  position:relative;
  background:var(--black);
  color:var(--white);
  overflow:hidden;
  border-top:1px solid var(--border);
}

.local-bg{position:absolute;inset:0;z-index:0;pointer-events:none;}
.local-bg .local-aurora{
  position:absolute;top:-15%;left:-10%;
  width:900px;height:600px;
  background:radial-gradient(ellipse at 50% 50%,
    rgba(206,142,99,.16),
    rgba(189,117,82,.04) 55%,
    transparent 75%);
  filter:blur(50px);
}
.local-bg .local-grid-lines{
  position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(206,142,99,.07) 1px,transparent 1px),
    linear-gradient(90deg,rgba(206,142,99,.07) 1px,transparent 1px);
  background-size:72px 72px;
  mask-image:radial-gradient(ellipse at 70% 50%,#000 50%,rgba(0,0,0,.6) 75%,transparent 100%);
  -webkit-mask-image:radial-gradient(ellipse at 70% 50%,#000 50%,rgba(0,0,0,.6) 75%,transparent 100%);
}

.local-inner{
  position:relative;z-index:1;
  max-width:var(--container-wide);
  margin:0 auto;
  padding:6.5rem 4.5rem 7rem;
}

/* --- Header --- */
.local-header{
  text-align:center;
  max-width:760px;
  margin:0 auto 4rem;
}
.local-tag{
  display:inline-flex;align-items:center;gap:1rem;
  margin-bottom:1.4rem;
}
.local-title{
  font-family:var(--font-display);font-weight:300;
  font-size:clamp(2rem,3.4vw,3.2rem);
  line-height:1.06;letter-spacing:.025em;
  text-transform:uppercase;
  color:var(--white);
  margin:0;
}
.local-title .italic{
  font-family:var(--font-serif);font-style:italic;font-weight:500;
  color:var(--copper-300);
  display:inline;
  font-size:.92em;text-transform:none;letter-spacing:.005em;
  vertical-align:baseline;position:relative;top:.04em;
}

/* --- Grid 2 col --- */
.local-grid{
  display:grid;
  grid-template-columns:1.05fr .95fr;
  gap:3.5rem;
  align-items:center;
}

/* --- Coluna mapa --- */
.local-map{position:relative;}

.map-frame{
  position:relative;
  margin:0;
  padding-right:18px;padding-bottom:18px;
}
.map-frame iframe{
  width:100%;
  aspect-ratio:5/4;
  height:auto;
  display:block;
  border:0;
  border-radius:var(--r-lg);
  background:var(--ink-900);
  /* Levemente dessaturada na cor pra casar melhor com o tema escuro/cobre */
  filter:grayscale(15%) contrast(.96);
  transition:filter .6s var(--ease-out-expo);
  position:relative;z-index:1;
}
.map-frame:hover iframe{filter:grayscale(0) contrast(1);}
/* Moldura cobre deslocada (mesma DNA da Dobra 3 .frame-card) */
.map-frame .frame-mark{
  position:absolute;
  top:0;left:0;right:18px;bottom:18px;
  border:1px solid var(--copper-500);
  border-radius:var(--r-lg);
  transform:translate(18px,18px);
  pointer-events:none;
  opacity:.55;
  transition:transform .6s var(--ease-out-expo),opacity .4s ease;
  z-index:0;
}
.map-frame:hover .frame-mark{
  transform:translate(12px,12px);
  opacity:.75;
}

/* --- Coluna infos --- */
.local-info{
  display:flex;flex-direction:column;
  gap:2.5rem;
}

.info-list{
  display:flex;flex-direction:column;
  gap:1.5rem;
  list-style:none;margin:0;padding:0;
}
.info-item{
  display:grid;
  grid-template-columns:auto 1fr;
  gap:1.1rem;
  align-items:flex-start;
}
.info-icon{
  display:grid;place-items:center;
  width:46px;height:46px;
  border-radius:var(--r-full);
  background:rgba(206,142,99,.10);
  border:1px solid rgba(206,142,99,.22);
  flex-shrink:0;
  transition:background .35s ease,border-color .35s ease,transform .35s var(--ease-out-expo);
}
.info-icon .iconify{
  font-size:1.25rem;color:var(--copper-300);
  transition:color .3s ease,transform .35s var(--ease-out-expo);
}
.info-item:hover .info-icon{
  background:rgba(206,142,99,.18);
  border-color:var(--copper-400);
  transform:scale(1.04);
}
.info-item:hover .info-icon .iconify{color:var(--copper-200);}

.info-body{min-width:0;}
.info-label{
  font-family:var(--font-body);font-weight:700;
  font-size:.65rem;letter-spacing:.28em;text-transform:uppercase;
  color:var(--copper-300);
  margin-bottom:.4rem;
}
.info-value{
  font-family:var(--font-body);font-size:.98rem;line-height:1.55;
  color:var(--white-dim);
  margin:0;
}
.info-link{
  color:var(--white);
  font-weight:500;
  border-bottom:1px solid rgba(206,142,99,.3);
  transition:color .3s ease,border-color .3s ease;
}
.info-link:hover,.info-link:focus-visible{
  color:var(--copper-200);
  border-bottom-color:var(--copper-400);
}

/* Tabela de horários (definition list compacta) */
.info-hours{
  display:flex;flex-direction:column;
  gap:.45rem;
  margin:0;
  font-family:var(--font-body);font-size:.94rem;
  color:var(--white-dim);
}
.hours-row{
  display:grid;
  grid-template-columns:auto 1fr;
  gap:1rem;
  align-items:baseline;
}
.hours-row dt{
  font-weight:600;
  color:var(--ink-300);
  letter-spacing:.04em;
  white-space:nowrap;
  font-size:.86rem;
}
.hours-row dd{
  margin:0;
  font-variant-numeric:tabular-nums;
  color:var(--white-dim);
  text-align:right;
  position:relative;
}
/* leader dotteds (linhinha discreta ligando dia → horário) */
.hours-row dd::before{
  content:'';
  display:inline-block;
  width:calc(100% - 5.5rem);
  max-width:80px;
  height:1px;
  margin-right:.6rem;
  vertical-align:middle;
  background:repeating-linear-gradient(
    to right,
    rgba(206,142,99,.22) 0 3px,
    transparent 3px 7px
  );
}
.hours-row.hours-closed dd{
  color:var(--ink-400);
  font-style:italic;
}
.hours-row.hours-closed dt{color:var(--ink-400);}

/* Badge soft pro tema escuro */
.badge-soft-dark{
  display:inline-flex;align-items:center;
  font-family:var(--font-body);font-weight:700;
  font-size:.62rem;letter-spacing:.2em;text-transform:uppercase;
  padding:.4rem .85rem;
  border-radius:var(--r-full);
  background:rgba(206,142,99,.10);
  border:1px solid rgba(206,142,99,.30);
  color:var(--copper-200);
}

/* CTAs lado a lado */
.local-cta{
  display:flex;align-items:center;gap:1rem;
  flex-wrap:wrap;
}

/* Variante outline do botão pro tema escuro (mirror do .btn-outline-light) */
.btn-outline-dark{
  display:inline-flex;align-items:center;gap:.7rem;
  padding:1.05rem 1.8rem;
  border:1px solid var(--copper-500);
  border-radius:var(--r-full);
  background:transparent;
  color:var(--copper-200);
  font-family:var(--font-body);font-weight:700;
  font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;
  transition:background .35s ease,color .35s ease,box-shadow .35s ease,
             transform .35s var(--ease-out-expo);
}
.btn-outline-dark .iconify{
  font-size:1.1rem;color:var(--copper-300);
  transition:color .3s ease;
}
.btn-outline-dark:hover,.btn-outline-dark:focus-visible{
  background:rgba(206,142,99,.08);
  color:var(--copper-100);
  box-shadow:0 0 0 4px rgba(206,142,99,.12),
             0 0 24px rgba(206,142,99,.25);
  transform:translateY(-1px);
}
.btn-outline-dark:hover .iconify{color:var(--copper-200);}

/* Responsivo da Dobra 9 */
@media (max-width:1100px){
  .local-inner{padding:5rem 2rem;}
  .local-grid{
    grid-template-columns:1fr;
    gap:2.5rem;
  }
  .map-frame iframe{aspect-ratio:4/3;}
}
@media (max-width:640px){
  .local-inner{padding:4rem 1.25rem;}
  .map-frame{padding-right:10px;padding-bottom:10px;}
  .map-frame .frame-mark{right:10px;bottom:10px;transform:translate(10px,10px);}
  .map-frame iframe{aspect-ratio:1/1;}
  .info-item{gap:.9rem;}
  .info-icon{width:42px;height:42px;}
  .info-value{font-size:.92rem;}
  .info-hours{font-size:.88rem;}
  .hours-row dd::before{display:none;} /* sem leader no mobile */
  .local-cta{flex-direction:column;align-items:stretch;}
  .btn-outline-dark,.local-cta .btn-primary{
    width:100%;justify-content:center;
  }
}

/* ============================== DOBRA 10 — FAQ =========================== */
/* Tema claro/marfim. Acordeão centralizado pra derrubar últimas objeções.
   Animação smooth via grid-template-rows trick (puro CSS). */
.faq{
  position:relative;
  background:var(--ink-50);
  color:var(--ink-900);
  overflow:hidden;
  border-top:1px solid rgba(155,105,70,.08);
}

.faq-bg{position:absolute;inset:0;z-index:0;pointer-events:none;}
.faq-bg .faq-orb{
  position:absolute;width:740px;height:740px;border-radius:50%;
  bottom:-15%;right:-10%;
  background:radial-gradient(circle at 50% 50%,
    rgba(206,142,99,.16),rgba(206,142,99,.04) 55%,transparent 75%);
  filter:blur(70px);
}
.faq-bg .faq-grid-lines{
  position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(155,105,70,.04) 1px,transparent 1px),
    linear-gradient(90deg,rgba(155,105,70,.04) 1px,transparent 1px);
  background-size:72px 72px;
  mask-image:radial-gradient(circle at 30% 50%,#000,transparent 80%);
  -webkit-mask-image:radial-gradient(circle at 30% 50%,#000,transparent 80%);
}

.faq-inner{
  position:relative;z-index:1;
  max-width:880px;
  margin:0 auto;
  padding:6.5rem 4.5rem 7rem;
}

/* --- Header --- */
.faq-header{
  text-align:center;
  margin-bottom:3.5rem;
}
.faq-tag{
  display:inline-flex;align-items:center;gap:1rem;
  margin-bottom:1.4rem;
}
.faq-title{
  font-family:var(--font-display);font-weight:300;
  font-size:clamp(2rem,3.4vw,3.2rem);
  line-height:1.08;letter-spacing:.02em;
  text-transform:uppercase;
  color:var(--ink-900);
  margin:0;
}
.faq-title .italic{
  font-family:var(--font-serif);font-style:italic;font-weight:500;
  color:var(--copper-600);
  display:inline;
  font-size:.92em;text-transform:none;letter-spacing:.005em;
  vertical-align:baseline;position:relative;top:.04em;
}

/* --- Acordeão --- */
.faq-list{
  list-style:none;margin:0;padding:0;
  display:flex;flex-direction:column;
  background:var(--white);
  border:1px solid rgba(155,105,70,.18);
  border-radius:var(--r-lg);
  overflow:hidden;
  box-shadow:0 18px 40px -18px rgba(155,105,70,.20);
  margin-bottom:3rem;
}

.faq-item{
  border-bottom:1px solid rgba(155,105,70,.12);
  transition:background .3s ease;
}
.faq-item:last-child{border-bottom:none;}
.faq-item.is-open{background:rgba(206,142,99,.04);}

/* Botão da pergunta (toda a linha clicável) */
.faq-q{
  display:flex;align-items:center;justify-content:space-between;
  width:100%;
  padding:1.4rem 1.8rem;
  background:transparent;
  border:none;
  cursor:pointer;
  text-align:left;
  gap:1.2rem;
  font-family:var(--font-body);font-weight:600;
  font-size:1.02rem;line-height:1.4;letter-spacing:.005em;
  color:var(--ink-900);
  transition:color .3s ease,background .3s ease;
}
.faq-q:hover,.faq-q:focus-visible{
  color:var(--copper-700);
  background:rgba(206,142,99,.05);
}
.faq-q:focus-visible{
  outline:2px solid var(--copper-400);
  outline-offset:-2px;
}
.faq-item.is-open .faq-q{color:var(--copper-700);}
.faq-q-text{flex:1;}

/* Ícone +/− animado (duas linhas, a vertical escala pra 0 ao abrir) */
.faq-icon{
  position:relative;
  width:22px;height:22px;flex-shrink:0;
  display:inline-block;
  border-radius:var(--r-full);
  border:1px solid rgba(206,142,99,.35);
  transition:border-color .35s ease,transform .35s var(--ease-out-expo);
}
.faq-icon-h,.faq-icon-v{
  position:absolute;
  background:var(--copper-600);
  transition:transform .35s var(--ease-out-expo),background .3s ease;
}
.faq-icon-h{
  top:50%;left:25%;right:25%;height:1.5px;
  transform:translateY(-50%);
  border-radius:1px;
}
.faq-icon-v{
  left:50%;top:25%;bottom:25%;width:1.5px;
  transform:translateX(-50%);
  border-radius:1px;
}
.faq-item.is-open .faq-icon{
  border-color:var(--copper-500);
  background:rgba(206,142,99,.10);
  transform:rotate(180deg);
}
.faq-item.is-open .faq-icon-v{
  transform:translateX(-50%) scaleY(0);
}

/* Painel de resposta — animação suave via grid-template-rows */
.faq-a{
  display:grid;
  grid-template-rows:0fr;
  transition:grid-template-rows .45s var(--ease-out-expo);
}
.faq-item.is-open .faq-a{grid-template-rows:1fr;}
.faq-a-inner{
  overflow:hidden;
  min-height:0; /* permite o conteúdo encolher dentro do grid track */
}
.faq-a-inner p{
  font-family:var(--font-body);
  font-size:.98rem;line-height:1.75;
  color:var(--ink-700);
  margin:0;
  padding:0 1.8rem 1.6rem;
  /* fade-in suave do conteúdo */
  opacity:0;
  transform:translateY(-6px);
  transition:opacity .35s ease .15s,transform .35s var(--ease-out-expo) .15s;
}
.faq-item.is-open .faq-a-inner p{
  opacity:1;
  transform:translateY(0);
}

/* --- Fecho + CTA --- */
.faq-cta{
  text-align:center;
  max-width:520px;
  margin:0 auto;
}
.faq-tagline{
  margin:0 0 1.4rem;
  font-family:var(--font-serif);font-style:italic;
  font-size:1.3rem;line-height:1.5;
  color:var(--copper-700);
}
.faq-tagline .italic{
  font-family:var(--font-serif);font-style:italic;font-weight:500;
  color:var(--copper-700);
}
.faq-cta .sobre-cta{display:inline-flex;}

/* Responsivo da Dobra 10 */
@media (max-width:1100px){
  .faq-inner{padding:5rem 2rem;}
}
@media (max-width:640px){
  .faq-inner{padding:4rem 1.25rem;}
  .faq-header{margin-bottom:2.5rem;}
  .faq-q{
    padding:1.2rem 1.3rem;
    font-size:.95rem;gap:.9rem;
  }
  .faq-a-inner p{
    padding:0 1.3rem 1.3rem;
    font-size:.92rem;
  }
  .faq-tagline{font-size:1.15rem;}
  .faq-cta .sobre-cta{width:100%;justify-content:center;}
}

/* ============================== DOBRA 11 — CTA FINAL / CONTATO =========== */
/* Fechamento dramático. Tema escuro, painel centralizado, botão grande com
   halo cobre pulsante — eco da energia do hero. Sem formulário (atrito zero,
   foco total no WhatsApp). */
.contact{
  position:relative;
  background:var(--black);
  color:var(--white);
  overflow:hidden;
  border-top:1px solid var(--border);
}

.contact-bg{position:absolute;inset:0;z-index:0;pointer-events:none;}
.contact-bg .contact-aurora{
  position:absolute;inset:-10%;
  background:
    radial-gradient(40% 50% at 50% 50%,rgba(206,142,99,.30),transparent 60%),
    radial-gradient(30% 40% at 30% 75%,rgba(189,117,82,.22),transparent 65%),
    radial-gradient(30% 40% at 75% 28%,rgba(219,163,125,.18),transparent 65%);
  filter:blur(8px);
  animation:auroraDrift 26s var(--ease-out-quart) infinite alternate;
}
.contact-bg .contact-grid-lines{
  position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(206,142,99,.07) 1px,transparent 1px),
    linear-gradient(90deg,rgba(206,142,99,.07) 1px,transparent 1px);
  background-size:64px 64px;
  mask-image:radial-gradient(ellipse at 50% 50%,#000 40%,rgba(0,0,0,.55) 70%,transparent 100%);
  -webkit-mask-image:radial-gradient(ellipse at 50% 50%,#000 40%,rgba(0,0,0,.55) 70%,transparent 100%);
}
/* Faíscas decorativas */
.contact-spark{
  position:absolute;width:5px;height:5px;border-radius:50%;
  background:var(--copper-300);
  box-shadow:0 0 12px var(--copper-300);
  opacity:.6;
  animation:spark 6s ease-in-out infinite;
}
.contact-spark.s1{top:20%;left:18%;animation-delay:.4s;}
.contact-spark.s2{top:70%;left:78%;animation-delay:1.6s;}
.contact-spark.s3{top:35%;left:82%;animation-delay:2.8s;}
.contact-spark.s4{top:78%;left:22%;animation-delay:1.1s;}

.contact-inner{
  position:relative;z-index:1;
  max-width:760px;
  margin:0 auto;
  padding:8rem 4.5rem 7rem;
  text-align:center;
}

/* --- Header --- */
.contact-header{margin-bottom:2.4rem;}
.contact-tag{
  display:inline-flex;align-items:center;gap:1rem;
  margin-bottom:1.4rem;
}
.contact-title{
  font-family:var(--font-display);font-weight:300;
  font-size:clamp(2.2rem,4vw,3.8rem);
  line-height:1.06;letter-spacing:.025em;
  text-transform:uppercase;
  color:var(--white);
  margin:0 0 1.6rem;
}
.contact-title .italic{
  font-family:var(--font-serif);font-style:italic;font-weight:500;
  color:var(--copper-300);
  display:inline;
  font-size:.92em;text-transform:none;letter-spacing:.005em;
  vertical-align:baseline;position:relative;top:.04em;
}
.contact-sub{
  font-family:var(--font-body);font-size:1.05rem;line-height:1.75;
  color:var(--text-muted);
  max-width:540px;
  margin:0 auto;
}

/* --- Botão grande com halo --- */
.contact-btn-wrap{
  position:relative;
  display:inline-flex;
  margin:3rem 0 3.5rem;
}
.contact-halo{
  position:absolute;
  inset:-60% -40%;
  background:radial-gradient(circle at 50% 50%,
    rgba(206,142,99,.45) 0%,
    rgba(206,142,99,.18) 30%,
    transparent 65%);
  filter:blur(28px);
  z-index:0;
  pointer-events:none;
  animation:contactHaloPulse 5s ease-in-out infinite;
}
@keyframes contactHaloPulse{
  0%,100%{opacity:.7;transform:scale(1);}
  50%   {opacity:1;transform:scale(1.08);}
}
.contact-btn-wrap .btn-primary{
  position:relative;z-index:1;
}
/* Variante XL do .btn-primary — específico desta dobra */
.btn-xl{
  padding:1.35rem 3rem;
  font-size:.86rem;
  letter-spacing:.26em;
  gap:1rem;
}
.btn-xl .iconify{font-size:1.3rem;}

/* CTA secundário "ou prefere ligar?" — fica logo abaixo do botão grande */
.contact-alt{
  display:inline-flex;align-items:center;
  gap:1rem;flex-wrap:wrap;justify-content:center;
  margin:-1rem 0 3.5rem;
}
.contact-alt-text{
  font-family:var(--font-serif);font-style:italic;
  font-size:1rem;
  color:var(--ink-400);
}
.contact-alt-text .italic{
  font-family:var(--font-serif);font-style:italic;font-weight:500;
  color:var(--ink-300);
}

/* Variante mais compacta do .btn-outline-dark */
.btn-tight{
  padding:.75rem 1.4rem;
  font-size:.7rem;
  letter-spacing:.18em;
}
.btn-tight .iconify{font-size:1rem;}

/* --- Linha de contato --- */
.contact-strip{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:0;
  margin:0 0 2.5rem;
  padding:2rem 0;
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
  list-style:none;
}
.contact-line{
  display:flex;align-items:center;gap:.85rem;
  justify-content:center;
  padding:0 1rem;
  text-align:left;
  position:relative;
}
.contact-line + .contact-line::before{
  content:'';
  position:absolute;left:0;top:50%;
  transform:translateY(-50%);
  width:1px;height:60%;
  background:var(--border);
}
.contact-line .iconify{
  font-size:1.4rem;color:var(--copper-300);
  flex-shrink:0;
}
.contact-line-body{
  display:flex;flex-direction:column;gap:.15rem;
  min-width:0;
}
.contact-line-body strong{
  font-family:var(--font-body);font-weight:700;
  font-size:.84rem;letter-spacing:.04em;
  color:var(--white);
  line-height:1.3;
}
.contact-line-body span{
  font-family:var(--font-body);font-size:.72rem;
  letter-spacing:.06em;
  color:var(--ink-400);
}
.contact-line-body a{
  color:var(--white);
  transition:color .3s ease;
  border-bottom:1px solid transparent;
}
.contact-line-body a:hover,
.contact-line-body a:focus-visible{
  color:var(--copper-200);
  border-bottom-color:var(--copper-500);
}

/* --- Assinatura Allura de fechamento --- */
.contact-signature{
  margin:0;
  font-family:var(--font-script);
  font-size:2.4rem;line-height:1;
  color:var(--copper-400);
  opacity:.75;
  text-shadow:0 0 24px rgba(206,142,99,.4);
}

/* Responsivo da Dobra 11 */
@media (max-width:1100px){
  .contact-inner{padding:6rem 2rem 5rem;}
  .contact-strip{
    grid-template-columns:1fr;
    gap:1.4rem;
    padding:2rem 0;
  }
  .contact-line + .contact-line::before{display:none;}
  .contact-line{justify-content:flex-start;padding:0;}
}
@media (max-width:640px){
  .contact-inner{padding:5rem 1.25rem 4rem;}
  .contact-sub{font-size:.98rem;}
  .contact-btn-wrap{display:flex;width:100%;}
  .contact-btn-wrap .btn-primary{width:100%;justify-content:center;}
  .btn-xl{padding:1.2rem 2rem;font-size:.78rem;letter-spacing:.22em;}
  .contact-alt{
    flex-direction:column;gap:.6rem;
    margin:-.5rem 0 2.5rem;
  }
  .btn-tight{width:100%;justify-content:center;}
  .contact-signature{font-size:2rem;}
}

/* ============================== FOOTER (LEGAL) =========================== */
/* Última peça estrutural — navegação completa + dados obrigatórios CFO/CRO.
   Tema preto com orb cobre discreto, tipografia tranquila. Sem CTA extra. */
.footer{
  position:relative;
  background:var(--ink-900);
  color:var(--ink-300);
  overflow:hidden;
  border-top:1px solid var(--border);
}

.footer-bg{position:absolute;inset:0;z-index:0;pointer-events:none;}
.footer-bg .footer-orb{
  position:absolute;width:600px;height:600px;border-radius:50%;
  bottom:-20%;left:-10%;
  background:radial-gradient(circle at 50% 50%,
    rgba(206,142,99,.10),rgba(206,142,99,.03) 60%,transparent 80%);
  filter:blur(60px);
}

.footer-inner{
  position:relative;z-index:1;
  max-width:var(--container-wide);
  margin:0 auto;
  padding:5rem 4.5rem 2.5rem;
}

/* --- 4 colunas --- */
.footer-top{
  display:grid;
  grid-template-columns:1.5fr 1fr 1fr 1.2fr;
  gap:3.5rem;
  margin-bottom:3.5rem;
  padding-bottom:3rem;
  border-bottom:1px solid var(--border);
}

.footer-col-title{
  font-family:var(--font-display);font-weight:400;
  font-size:.78rem;letter-spacing:.28em;text-transform:uppercase;
  color:var(--copper-300);
  margin-bottom:1.4rem;
  position:relative;
  padding-bottom:.85rem;
}
.footer-col-title::after{
  content:'';position:absolute;left:0;bottom:0;
  width:28px;height:1px;
  background:var(--copper-500);
}

.footer-col ul{
  list-style:none;margin:0;padding:0;
  display:flex;flex-direction:column;gap:.6rem;
}
.footer-col ul a{
  font-family:var(--font-body);font-size:.88rem;
  color:var(--ink-300);
  transition:color .3s ease,padding-left .35s var(--ease-out-expo);
  display:inline-block;
}
.footer-col ul a:hover,
.footer-col ul a:focus-visible{
  color:var(--copper-300);
  padding-left:.4rem;
}

/* --- Coluna marca --- */
.footer-brand{
  display:flex;flex-direction:column;
  align-items:flex-start;
  gap:1.2rem;
}
.footer-logo{
  display:block;
  transition:opacity .3s ease;
}
.footer-logo img{
  width:auto;height:88px;
  filter:drop-shadow(0 8px 20px rgba(189,117,82,.3));
}
.footer-logo:hover{opacity:.85;}
.footer-tagline{
  font-family:var(--font-body);font-size:.88rem;line-height:1.6;
  color:var(--ink-400);
  max-width:300px;
  margin:0;
}

.footer-redes{
  display:flex;gap:.6rem;
  margin-top:.4rem;
}
.footer-redes a{
  display:grid;place-items:center;
  width:40px;height:40px;
  border-radius:var(--r-full);
  border:1px solid var(--border-strong);
  color:var(--copper-300);
  transition:background .35s ease,
             color .35s ease,
             border-color .35s ease,
             box-shadow .35s ease,
             transform .35s var(--ease-out-expo);
}
.footer-redes .iconify{font-size:1.15rem;}
.footer-redes a:hover,.footer-redes a:focus-visible{
  background:var(--copper-500);
  color:var(--black);
  border-color:var(--copper-500);
  box-shadow:var(--glow-copper);
  transform:translateY(-2px);
}

/* --- Coluna contato (com ícones) --- */
.footer-contact{gap:.9rem !important;}
.footer-contact li{
  display:flex;align-items:flex-start;gap:.7rem;
  font-family:var(--font-body);font-size:.86rem;line-height:1.55;
  color:var(--ink-300);
}
.footer-contact li .iconify{
  font-size:1.1rem;color:var(--copper-400);
  flex-shrink:0;margin-top:.15rem;
}
.footer-contact li a{
  color:var(--ink-200);
  border-bottom:1px solid transparent;
  transition:color .3s ease,border-color .3s ease;
}
.footer-contact li a:hover,
.footer-contact li a:focus-visible{
  color:var(--copper-200);
  border-bottom-color:var(--copper-500);
}

/* --- Barra legal --- */
.footer-bottom{
  text-align:center;
}
.footer-legal{
  font-family:var(--font-body);font-size:.74rem;line-height:1.8;
  color:var(--ink-500);
  margin:0 0 .85rem;
  letter-spacing:.02em;
}
.footer-legal strong{
  color:var(--ink-300);
  font-weight:700;
}
.footer-legal-sep{
  color:var(--copper-700);
  margin:0 .15rem;
}
.footer-disclaimer{
  font-family:var(--font-serif);font-style:italic;
  font-size:.82rem;
  color:var(--copper-400);
  margin:0;
  letter-spacing:.01em;
}

/* Responsivo */
@media (max-width:1100px){
  .footer-inner{padding:4rem 2rem 2rem;}
  .footer-top{
    grid-template-columns:1fr 1fr;
    gap:2.5rem;
  }
  .footer-brand{grid-column:span 2;}
}
@media (max-width:640px){
  .footer-inner{padding:3.5rem 1.25rem 2rem;}
  .footer-top{
    grid-template-columns:1fr;
    gap:2.2rem;
    text-align:left;
  }
  .footer-brand{grid-column:span 1;}
  .footer-logo img{height:72px;}
  .footer-legal{font-size:.7rem;}
  .footer-legal-sep{display:inline-block;}
  .footer-disclaimer{font-size:.78rem;}
}

/* ============================== STICKY MOBILE CTA ========================== */
.cta-sticky{
  position:fixed;left:1rem;right:1rem;bottom:1rem;
  z-index:var(--z-cta-sticky);
  display:none; /* habilitada via @media */
  background:var(--copper-500);color:var(--black);
  border-radius:var(--r-full);
  padding:1.05rem 1.4rem;
  font-family:var(--font-body);font-size:.78rem;font-weight:700;
  letter-spacing:.22em;text-transform:uppercase;
  align-items:center;justify-content:center;gap:.7rem;
  box-shadow:var(--shadow-lg),var(--glow-copper);
  transition:transform .35s var(--ease-out-expo),opacity .35s ease;
}
.cta-sticky .iconify{font-size:1.1rem;}
.cta-sticky.hidden{transform:translateY(120%);opacity:0;pointer-events:none;}

/* ============================== RESPONSIVO ================================= */
@media (max-width:1100px){
  .hero{grid-template-columns:1fr;min-height:auto;}
  .hero-content{
    padding:calc(var(--nav-h) + 2.5rem) 2rem 3rem;
    order:2;
  }
  .hero-image{
    order:1;height:54vh;min-height:380px;
    border-bottom:1px solid var(--border);
  }
  .hero-frame{display:none;}
  .scroll-cue{display:none;}
  .nav{padding:1rem 1.5rem;}
  .nav.scrolled{padding:.75rem 1.5rem;}
  .nav-links{display:none;}
  .nav-cta{display:none;}      /* WhatsApp pill esconde no mobile */
  .nav-call{                    /* mas o telefone fica — ligação one-tap é o mais importante no mobile */
    width:38px;height:38px;
  }
  .nav-hamburger{display:flex;}
  .cta-sticky{display:inline-flex;}
}

@media (max-width:640px){
  .nav-wordmark{font-size:.92rem;letter-spacing:.22em;}
  .nav-mark{height:34px;}
  .nav.scrolled .nav-mark{height:30px;}
  .hero-content{padding:calc(var(--nav-h) + 1.5rem) 1.25rem 2rem;}
  .hero-tag{margin-bottom:1.4rem;}
  .hero-title{font-size:clamp(2.4rem,11vw,3.6rem);}
  .hero-desc{font-size:1rem;line-height:1.7;margin-bottom:2rem;}
  .hero-actions{gap:1.2rem;}
  .btn-primary{padding:1.05rem 1.8rem;font-size:.72rem;width:100%;justify-content:center;}
  .btn-outline{width:100%;justify-content:center;padding:.85rem 0;}
  .hero-pills{margin-top:2rem;}
  .hero-image{height:60vh;min-height:320px;}
  .hero-signature{width:55%;}
  .hero-google{font-size:.72rem;}
}

/* Telas muito largas — não esticar conteúdo */
@media (min-width:1600px){
  .hero-content{padding:calc(var(--nav-h) + 3rem) 6rem 4rem 8rem;}
  .hero-title{font-size:clamp(2.6rem,3.6vw,4.6rem);}
}

/* Telas com altura reduzida (laptops 13"/14") — comprime mais */
@media (max-height:820px) and (min-width:1101px){
  .hero-content{padding:calc(var(--nav-h) + 1rem) 4rem 2rem;}
  .hero-title{font-size:clamp(2rem,3.6vw,3.6rem);margin-bottom:1.1rem;}
  .hero-tag{margin-bottom:1.1rem;}
  .hero-desc{margin-bottom:1.4rem;font-size:.95rem;line-height:1.65;}
  .hero-pills{margin-top:1.3rem;}
  .hero-google{margin-top:.6rem;}
}

/* ============================== ACESSIBILIDADE ============================= */
/* Reduzir movimento — desliga animações decorativas */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:.01ms !important;
    animation-iteration-count:1 !important;
    transition-duration:.01ms !important;
    scroll-behavior:auto !important;
  }
  .hero-tag,.hero-title>span,.hero-desc,.hero-actions,
  .hero-pills,.hero-google,.hero-signature,.scroll-cue{
    opacity:1 !important;transform:none !important;
  }
  /* slideshow vira foto única — primeiro slide visível, demais ocultos */
  .hero-image .case{opacity:0 !important;transform:none !important;}
  .hero-image .case.is-active{opacity:.92 !important;}
  .hero-aurora,.hero-glow-orb,.hero-sparks span{display:none;}
}
