/* ============================================================
   ELORA Obstetrícia — estilos
   Paleta clara: verde-sálvia/oliva (logo) + tons creme, suaves
   ============================================================ */

:root{
  --green:       #A1994A;   /* oliva/dourado da marca (primária) */
  --green-600:   #877F3C;
  --green-700:   #6B642E;
  --green-soft:  #DAD6B0;   /* oliva clarinho */
  --clay:        #BE9079;   /* terracota suave (acento quente) */
  --clay-600:    #A87C63;
  --clay-soft:   #E1CBBA;

  --cream:       #F3ECDD;   /* fundo claro principal (um pouco mais quente) */
  --cream-2:     #EBE0CC;   /* alternância */
  --sand:        #DFD3BA;
  --ink:         #433D31;   /* texto/títulos escuros quentes (não preto) */
  --ink-2:       #363025;
  --text:        #524A3D;
  --muted:       #8C806E;
  --white:       #ffffff;
  --wpp:         #25D366;

  --shadow-sm:   0 4px 16px rgba(74,67,55,.06);
  --shadow-md:   0 18px 44px rgba(74,67,55,.10);
  --shadow-lg:   0 30px 70px rgba(74,67,55,.14);

  --radius:      20px;
  --radius-lg:   30px;
  --maxw:        1180px;

  --ff-serif: "Fraunces", Georgia, serif;
  --ff-sans:  "Manrope", system-ui, -apple-system, sans-serif;

  --ease: cubic-bezier(.22,.61,.36,1);
}

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

html{ scroll-behavior:smooth; scroll-padding-top:88px; }

body{
  margin:0;
  font-family:var(--ff-sans);
  color:var(--text);
  background:var(--cream);
  line-height:1.65;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}

img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }

.container{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:24px; }

h1,h2,h3,h4{ font-family:var(--ff-serif); font-weight:400; color:var(--ink); line-height:1.12; letter-spacing:-.01em; }
h1 em,h2 em,h3 em{ font-style:italic; color:var(--green-600); }

.section{ padding:96px 0; }

.section-tag{
  display:inline-block; font-size:.78rem; letter-spacing:.22em; text-transform:uppercase;
  color:var(--green-600); font-weight:600; margin-bottom:16px;
}
.section-title{ font-size:clamp(2rem,4vw,3.1rem); margin:0 0 18px; }
.section-sub{ color:var(--muted); max-width:60ch; margin:0 auto; }
.section-head{ text-align:center; max-width:760px; margin:0 auto 56px; }
.section-head .section-sub{ font-size:1.05rem; }
.section-head a{ color:var(--green-600); font-weight:600; }

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:9px;
  font-family:var(--ff-sans); font-weight:600; font-size:.98rem;
  padding:14px 28px; border-radius:999px; cursor:pointer; border:none;
  transition:transform .3s var(--ease), box-shadow .3s var(--ease), background .3s, color .3s;
  white-space:nowrap;
}
.btn-primary{ background:var(--green-600); color:#fff; box-shadow:0 12px 26px rgba(107,110,72,.30); }
.btn-primary:hover{ background:var(--green-700); transform:translateY(-3px); box-shadow:0 18px 34px rgba(86,88,57,.38); }
.btn-ghost{ background:transparent; color:var(--ink); border:1.5px solid rgba(74,67,55,.22); }
.btn-ghost:hover{ border-color:var(--green-600); color:var(--green-700); transform:translateY(-3px); }
.btn-lg{ padding:18px 40px; font-size:1.06rem; }

/* ============================================================
   HEADER
   ============================================================ */
.site-header{
  position:fixed; inset:0 0 auto 0; z-index:100;
  padding:18px 0;
  transition:background .4s var(--ease), padding .4s var(--ease), box-shadow .4s var(--ease);
}
.site-header.scrolled{
  background:rgba(250,245,236,.9);
  backdrop-filter:blur(12px);
  padding:11px 0;
  box-shadow:0 8px 30px rgba(74,67,55,.12);
}
.header-inner{ display:flex; align-items:center; justify-content:space-between; gap:24px; }

/* logo recolorível (PNG branco usado como máscara) */
.brand-logo{
  display:block; height:42px; aspect-ratio:300 / 118;
  background-color:var(--green-600);
  -webkit-mask:url(../img/logo-horizontal-negativo.png) left center / contain no-repeat;
          mask:url(../img/logo-horizontal-negativo.png) left center / contain no-repeat;
  transition:height .4s var(--ease);
}
.site-header.scrolled .brand-logo{ height:34px; }

.nav{ display:flex; align-items:center; gap:30px; }
.nav>a{
  color:var(--text); font-size:.95rem; font-weight:500; position:relative;
  transition:color .25s;
}
.nav>a:not(.btn)::after{
  content:""; position:absolute; left:0; bottom:-6px; height:2px; width:0;
  background:var(--green); transition:width .3s var(--ease);
}
.nav>a:not(.btn):hover{ color:var(--green-700); }
.nav>a:not(.btn):hover::after{ width:100%; }

.btn-wpp-nav{ background:var(--wpp); color:#fff; padding:10px 20px; font-size:.9rem; box-shadow:0 8px 20px rgba(37,211,102,.3); }
.btn-wpp-nav:hover{ transform:translateY(-2px); filter:brightness(1.05); }

.nav-toggle{ display:none; flex-direction:column; gap:5px; background:none; border:none; cursor:pointer; padding:8px; }
.nav-toggle span{ width:26px; height:2px; background:var(--ink); border-radius:2px; transition:.3s var(--ease); }
.nav-toggle.open span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.nav-toggle.open span:nth-child(2){ opacity:0; }
.nav-toggle.open span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

/* ============================================================
   HERO
   ============================================================ */
.hero{ position:relative; padding:150px 0 90px; overflow:hidden; background:var(--cream); }
.hero-bg{
  position:absolute; inset:0; z-index:0;
  background:
    radial-gradient(900px 600px at 85% -10%, rgba(161,153,74,.18), transparent 60%),
    radial-gradient(720px 520px at 0% 112%, rgba(190,144,121,.18), transparent 55%),
    linear-gradient(165deg,#F4EDDD 0%, #EEE4D0 55%, #E7DBC3 100%);
}
.hero-grid{ position:relative; z-index:1; display:grid; grid-template-columns:1.05fr .95fr; gap:60px; align-items:center; }

.hero-logo{
  display:block; height:52px; aspect-ratio:300 / 118; width:auto; margin-bottom:20px;
  background-color:var(--green);
  -webkit-mask:url(../img/logo-horizontal-negativo.png) left center / contain no-repeat;
          mask:url(../img/logo-horizontal-negativo.png) left center / contain no-repeat;
  animation:floatSoft 4.5s ease-in-out infinite;
}
.eyebrow{ display:inline-block; color:var(--green-600); letter-spacing:.18em; text-transform:uppercase; font-size:.76rem; font-weight:600; margin-bottom:22px; }
.hero-text h1{ color:var(--ink); font-size:clamp(2.5rem,5.2vw,4.2rem); margin:0 0 24px; }
.hero-text h1 em{ color:var(--green-600); }
.hero-lead{ color:var(--text); font-size:1.12rem; max-width:46ch; margin:0 0 34px; }
.hero-actions{ display:flex; gap:16px; flex-wrap:wrap; margin-bottom:42px; }

.hero-trust{ list-style:none; display:flex; gap:38px; padding:0; margin:0; }
.hero-trust li{ display:flex; flex-direction:column; }
.hero-trust strong{ color:var(--ink); font-family:var(--ff-serif); font-size:1.25rem; }
.hero-trust span{ color:var(--muted); font-size:.86rem; }

.hero-media{ position:relative; }
.hero-photo{
  border-radius:var(--radius-lg); overflow:hidden; box-shadow:var(--shadow-lg);
  border:6px solid #fff; position:relative;
}
.hero-photo img{ width:100%; height:560px; object-fit:cover; object-position:center top; }
.hero-names{
  position:absolute; left:0; right:0; bottom:0; z-index:2; display:flex; gap:10px;
  padding:64px 16px 22px;
  background:linear-gradient(to top, rgba(43,36,33,.85), rgba(43,36,33,.25) 55%, transparent);
}
.hero-names span{
  flex:1; text-align:center; color:#fff; font-family:var(--ff-serif);
  font-size:1.18rem; letter-spacing:.01em; text-shadow:0 2px 14px rgba(0,0,0,.55);
}
.hero-badge{
  margin:66px auto 0; width:max-content; max-width:100%; background:#fff;
  border-radius:999px; padding:12px 24px; display:flex; align-items:center; gap:12px;
  box-shadow:var(--shadow-md); animation:floatSoft 3.6s ease-in-out infinite;
}
@keyframes floatSoft{ 0%,100%{ transform:translateY(0); } 50%{ transform:translateY(-6px); } }
.hero-badge img{ width:34px; height:34px; }
.hero-badge span{ font-family:var(--ff-serif); font-size:1.06rem; line-height:1.1; color:var(--ink); }

.scroll-cue{ position:absolute; left:50%; bottom:24px; transform:translateX(-50%); z-index:2; width:26px; height:42px; border:2px solid rgba(74,67,55,.3); border-radius:14px; }
.scroll-cue span{ position:absolute; left:50%; top:8px; width:4px; height:8px; background:var(--green); border-radius:2px; transform:translateX(-50%); animation:scrolldot 1.6s infinite; }
@keyframes scrolldot{ 0%{ opacity:0; top:8px;} 40%{opacity:1;} 80%{opacity:0; top:22px;} 100%{opacity:0;} }

/* ---------- Ticker ---------- */
.ticker{ background:var(--green-600); color:#fff; overflow:hidden; padding:14px 0; }
.ticker-track{ display:flex; gap:28px; align-items:center; white-space:nowrap; width:max-content; animation:ticker 28s linear infinite; }
.ticker-track span{ font-family:var(--ff-serif); font-style:italic; font-size:1.15rem; }
.ticker-track i{ display:inline-flex; align-items:center; font-style:normal; }
.ticker-track i img{ height:18px; width:auto; display:block; opacity:.92; }
@keyframes ticker{ from{ transform:translateX(0);} to{ transform:translateX(-50%);} }

/* ============================================================
   SOBRE
   ============================================================ */
.sobre{ background:var(--cream); }
.sobre-grid{ display:grid; grid-template-columns:1.15fr .85fr; gap:64px; align-items:center; }
.sobre p{ font-size:1.06rem; margin:0 0 18px; }

.sobre-quote{
  background:linear-gradient(160deg,var(--green-soft),#E8E6D0);
  color:var(--ink); border-radius:var(--radius-lg); padding:48px 42px; box-shadow:var(--shadow-md); position:relative;
}
.sobre-quote::before{ content:"“"; position:absolute; top:6px; left:26px; font-family:var(--ff-serif); font-size:6rem; color:var(--green); opacity:.4; }
.sobre-quote blockquote{ margin:24px 0 18px; font-family:var(--ff-serif); font-style:italic; font-size:1.5rem; line-height:1.4; }
.sobre-quote-sign{ color:var(--green-700); font-size:.92rem; letter-spacing:.04em; }

/* ============================================================
   DIFERENCIAIS
   ============================================================ */
.diferenciais{ background:var(--cream-2); }
.diff-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:24px; }
.diff-card{
  background:#fff; border-radius:var(--radius); padding:36px 28px; box-shadow:var(--shadow-sm);
  border:1px solid rgba(126,129,90,.16);
  transition:transform .4s var(--ease), box-shadow .4s var(--ease);
}
.diff-card:hover{ transform:translateY(-8px); box-shadow:var(--shadow-md); }
.diff-icon{
  width:78px; height:78px; border-radius:50%; background:var(--sand);
  display:grid; place-items:center; margin-bottom:22px;
  transition:transform .45s var(--ease), background .45s var(--ease), box-shadow .45s var(--ease), opacity .45s var(--ease);
}
.diff-icon img{ width:46px; height:46px; filter:saturate(1.45) contrast(1.3) brightness(.72); transition:filter .45s var(--ease); }

/* ao passar o mouse na grade, os outros ícones recuam levemente */
.diff-grid:hover .diff-icon{ transform:scale(.9); opacity:.55; }
/* o ícone do card sob o mouse ganha destaque: maior, mais colorido e com sombra */
.diff-grid .diff-card:hover .diff-icon{
  transform:scale(1.16); opacity:1;
  background:var(--clay-soft);
  box-shadow:0 16px 32px rgba(185,138,114,.42);
}
.diff-grid .diff-card:hover .diff-icon img{
  filter:saturate(1.6) contrast(1.35) brightness(.68) drop-shadow(0 5px 10px rgba(152,105,79,.55));
}
.diff-card h3{ font-size:1.22rem; margin:0 0 10px; }
.diff-card p{ color:var(--muted); font-size:.96rem; margin:0; }

/* ============================================================
   SERVIÇOS
   ============================================================ */
.servicos{ background:var(--cream); }
.serv-list{ display:flex; flex-direction:column; max-width:920px; margin:0 auto; }
.serv-item{
  display:flex; align-items:center; gap:28px; padding:30px 8px;
  border-top:1px solid rgba(74,67,55,.1);
  transition:padding .35s var(--ease), background .35s;
}
.serv-list .serv-item:last-child{ border-bottom:1px solid rgba(74,67,55,.1); }
.serv-item:hover{ background:rgba(126,129,90,.07); padding-left:24px; padding-right:24px; border-radius:16px; }
.serv-num{ font-family:var(--ff-serif); font-size:1.5rem; color:var(--green); min-width:48px; }
.serv-body{ flex:1; }
.serv-body h3{ font-size:1.5rem; margin:0 0 4px; }
.serv-body p{ margin:0; color:var(--muted); }
.serv-link{
  flex-shrink:0; display:grid; place-items:center; padding:0; border:none; background:none;
  transition:transform .35s var(--ease), filter .35s var(--ease);
}
.serv-link .serv-stork-img{ width:92px; height:auto; display:block; }
.serv-link:hover{ transform:scale(1.12) rotate(-3deg); filter:drop-shadow(0 6px 12px rgba(74,67,55,.2)); }

/* ============================================================
   EQUIPE
   ============================================================ */
.equipe{ background:linear-gradient(180deg,var(--cream-2),var(--sand)); }
.equipe .section-title{ color:var(--ink); }
.equipe .section-tag{ color:var(--green-600); }
.equipe .section-sub{ color:var(--muted); }

.team-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:34px; }
.team-card{
  background:#fff; border-radius:var(--radius-lg); overflow:hidden; box-shadow:var(--shadow-md);
  display:grid; grid-template-columns:0.85fr 1.15fr;
  transition:transform .4s var(--ease);
}
.team-card:hover{ transform:translateY(-6px); }
.team-photo{ overflow:hidden; }
.team-photo img{ width:100%; height:100%; min-height:340px; object-fit:cover; transition:transform .7s var(--ease); }
.team-card:hover .team-photo img{ transform:scale(1.06); }
.team-info{ padding:30px 28px; }
.team-info h3{ font-size:1.34rem; margin:0 0 4px; }
.team-crm{ display:inline-block; background:var(--green-soft); color:var(--green-700); font-size:.74rem; font-weight:700; letter-spacing:.06em; padding:4px 12px; border-radius:999px; margin-bottom:14px; }
.team-role{ color:var(--green-600); font-weight:600; font-size:.96rem; margin:0 0 16px; }
.team-edu{ list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:10px; }
.team-edu li{ position:relative; padding-left:20px; font-size:.9rem; color:var(--muted); line-height:1.45; }
.team-edu li::before{ content:""; position:absolute; left:0; top:9px; width:8px; height:8px; border-radius:50%; background:var(--clay); }

/* ============================================================
   CARROSSEL (genérico)
   ============================================================ */
.carousel{ position:relative; }
.carousel-viewport{ overflow:hidden; padding:10px 0; }
.carousel-track{ display:flex; gap:24px; transition:transform .55s var(--ease); padding-inline:24px; will-change:transform; }
.carousel-track>*{ flex:0 0 auto; }

.carousel-btn{
  position:absolute; top:42%; transform:translateY(-50%); z-index:5;
  width:52px; height:52px; border-radius:50%; border:none; cursor:pointer;
  background:#fff; color:var(--green-700); font-size:1.6rem; line-height:1;
  box-shadow:var(--shadow-md); transition:.3s var(--ease); display:grid; place-items:center;
}
.carousel-btn:hover{ background:var(--green-600); color:#fff; }
.carousel-btn.prev{ left:18px; }
.carousel-btn.next{ right:18px; }
.carousel-btn:disabled{ opacity:.35; cursor:default; }

.carousel-dots{ display:flex; flex-wrap:wrap; justify-content:center; gap:9px; margin-top:30px; padding-inline:24px; }
.carousel-dots button{ width:9px; height:9px; border-radius:50%; border:none; background:var(--green-soft); cursor:pointer; transition:.3s; padding:0; }
.carousel-dots button.active{ background:var(--green-600); width:26px; border-radius:6px; }

/* ---------- Instagram ---------- */
.instagram{ background:var(--cream-2); }
.ig-post{
  width:300px; height:380px; border-radius:22px; overflow:hidden; position:relative;
  box-shadow:var(--shadow-sm); transition:transform .4s var(--ease), box-shadow .4s var(--ease);
}
.ig-post:hover{ transform:translateY(-8px); box-shadow:var(--shadow-md); }
.ig-post.photo img{ width:100%; height:100%; object-fit:cover; }
.ig-post.photo::after{ content:""; position:absolute; inset:0; background:linear-gradient(to top, rgba(43,36,33,.7), transparent 55%); }
.ig-tag{ position:absolute; top:14px; left:14px; z-index:2; background:rgba(255,255,255,.92); color:var(--ink); font-size:.74rem; font-weight:700; padding:5px 12px; border-radius:999px; }
.ig-caption{ position:absolute; left:16px; right:16px; bottom:16px; z-index:2; color:#fff; font-size:.95rem; font-family:var(--ff-serif); }

.ig-post.card{ display:flex; flex-direction:column; justify-content:center; gap:14px; padding:32px 28px; color:#fff; }
.ig-post.card .ig-kicker{ font-size:.74rem; letter-spacing:.16em; text-transform:uppercase; font-weight:700; opacity:.85; }
.ig-post.card .ig-quote{ font-family:var(--ff-serif); font-size:1.32rem; line-height:1.32; margin:0; }
.ig-post.card .ig-handle{ font-size:.82rem; opacity:.8; margin-top:auto; }
.card-1{ background:linear-gradient(155deg,var(--green),var(--green-600)); }
.card-2{ background:linear-gradient(155deg,var(--clay),var(--clay-600)); }
.card-3{ background:linear-gradient(155deg,var(--green-soft),#C7C28C); color:var(--ink); }
.card-3 .ig-handle{ color:var(--ink-2); }
.card-4{ background:linear-gradient(155deg,var(--clay-soft),var(--clay)); color:var(--ink); }
.card-4 .ig-handle{ color:var(--ink-2); }

/* ---------- Depoimentos ---------- */
.depoimentos{ background:var(--cream); }
.dep-card{
  width:380px; background:#fff; border-radius:var(--radius); padding:34px 32px;
  box-shadow:var(--shadow-sm); border:1px solid rgba(126,129,90,.16); margin:0;
  display:flex; flex-direction:column; gap:16px;
}
.dep-stars{ color:#D9A65B; letter-spacing:2px; font-size:1.05rem; }
.dep-card blockquote{ margin:0; font-size:1.06rem; color:var(--text); line-height:1.6; flex:1; }
.dep-card figcaption{ display:flex; flex-direction:column; border-top:1px solid rgba(74,67,55,.08); padding-top:16px; }
.dep-card figcaption strong{ color:var(--ink); font-family:var(--ff-serif); font-size:1.05rem; }
.dep-card figcaption span{ color:var(--muted); font-size:.85rem; }

/* ============================================================
   CTA band
   ============================================================ */
.cta-band{ background:linear-gradient(150deg,var(--green),var(--green-600)); padding:84px 0; text-align:center; }
.cta-feet{ display:inline-block; width:74px; margin-bottom:16px; animation:floatSoft 4s ease-in-out infinite; }
.cta-feet img{ width:100%; height:auto; display:block; }
.cta-inner h2{ color:#fff; font-size:clamp(1.9rem,4vw,2.9rem); margin:0 0 12px; }
.cta-inner h2 em{ color:#fff; text-decoration:underline; text-decoration-color:rgba(255,255,255,.5); text-underline-offset:6px; }
.cta-inner p{ color:rgba(255,255,255,.92); font-size:1.12rem; margin:0 0 30px; }
.cta-band .btn-primary{ background:#fff; color:var(--green-700); }
.cta-band .btn-primary:hover{ background:var(--ink); color:#fff; }

/* ============================================================
   CONTATO
   ============================================================ */
.contato{ background:var(--cream-2); }
.contato-grid{ display:grid; grid-template-columns:1fr 1fr; gap:54px; align-items:center; }
.contato-list{ list-style:none; padding:0; margin:24px 0 32px; display:flex; flex-direction:column; gap:22px; }
.contato-list li{ display:flex; gap:16px; align-items:flex-start; }
.contato-ico{ width:46px; height:46px; border-radius:12px; background:var(--sand); display:grid; place-items:center; font-size:1.2rem; flex-shrink:0; }
.contato-list strong{ display:block; color:var(--ink); font-family:var(--ff-serif); font-size:1.08rem; margin-bottom:2px; }
.contato-list a{ color:var(--green-700); font-weight:600; }
.contato-list a:hover{ text-decoration:underline; }
.contato-list .contato-endereco{ color:var(--text); font-weight:400; text-decoration:none; }
.contato-list .contato-endereco:hover{ color:var(--green-700); text-decoration:none; }
.contato-rota{ display:inline-block; margin-top:10px; color:var(--green-700); font-weight:700; font-size:.9rem; }
.contato-list .contato-endereco:hover .contato-rota{ text-decoration:underline; }
.contato-map{ border-radius:var(--radius-lg); overflow:hidden; box-shadow:var(--shadow-md); height:430px; }
.contato-map iframe{ width:100%; height:100%; border:0; }

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{ background:#54502C; color:rgba(255,255,255,.78); padding-top:64px; }
.footer-grid{ display:grid; grid-template-columns:1.4fr 1fr 1.3fr; gap:40px; padding-bottom:48px; }
.footer-brand img{ height:40px; margin-bottom:18px; }
.footer-brand p{ font-family:var(--ff-serif); font-style:italic; font-size:1.1rem; color:var(--green-soft); max-width:30ch; }
.site-footer h4{ color:#fff; font-family:var(--ff-sans); font-size:.84rem; letter-spacing:.14em; text-transform:uppercase; margin:0 0 18px; }
.footer-nav{ display:flex; flex-direction:column; gap:11px; }
.footer-nav a{ color:rgba(255,255,255,.78); font-size:.95rem; transition:color .25s, padding .25s; }
.footer-nav a:hover{ color:#fff; padding-left:5px; }
.footer-contact p{ font-size:.92rem; line-height:1.6; margin:0 0 14px; }
.footer-contact a{ display:block; color:var(--green-soft); font-weight:600; font-size:.95rem; margin-bottom:6px; }
.footer-contact a:hover{ color:#fff; }
.footer-bottom{ border-top:1px solid rgba(255,255,255,.14); padding:22px 0; }
.footer-bottom .container{ display:flex; justify-content:space-between; gap:14px; flex-wrap:wrap; font-size:.82rem; color:rgba(255,255,255,.55); }

/* ============================================================
   Floating WhatsApp
   ============================================================ */
.fab-wpp{
  position:fixed; right:22px; bottom:22px; z-index:90;
  width:62px; height:62px; border-radius:50%; background:var(--wpp); color:#fff;
  display:grid; place-items:center; box-shadow:0 12px 30px rgba(37,211,102,.45);
  transition:transform .3s var(--ease);
}
.fab-wpp::before{ content:""; position:absolute; inset:0; border-radius:50%; background:var(--wpp); opacity:.55; animation:pulse 2.2s ease-out infinite; z-index:-1; }
.fab-wpp:hover{ transform:scale(1.1); }
@keyframes pulse{ 0%{ transform:scale(1); opacity:.5;} 100%{ transform:scale(1.8); opacity:0;} }

/* ============================================================
   Scroll reveal
   ============================================================ */
.reveal{ opacity:0; transform:translateY(34px); transition:opacity .8s var(--ease), transform .8s var(--ease); }
.reveal-left{ transform:translateX(-48px); }
.reveal-right{ transform:translateX(48px); }
.reveal-scale{ transform:scale(.9); }
.reveal.in{ opacity:1; transform:none; }

@media (prefers-reduced-motion:reduce){
  *{ animation:none !important; transition:none !important; scroll-behavior:auto; }
  .reveal{ opacity:1; transform:none; }
}

/* ============================================================
   RESPONSIVO
   ============================================================ */
@media (max-width:980px){
  .hero-grid{ grid-template-columns:1fr; gap:48px; }
  .hero-photo img{ height:440px; }
  .sobre-grid{ grid-template-columns:1fr; gap:40px; }
  .diff-grid{ grid-template-columns:repeat(2,1fr); }
  .team-grid{ grid-template-columns:1fr; }
  .contato-grid{ grid-template-columns:1fr; gap:34px; }
  .footer-grid{ grid-template-columns:1fr 1fr; }
}

@media (max-width:760px){
  body{ font-size:16px; }
  .section{ padding:72px 0; }

  /* mobile nav */
  .nav{
    position:fixed; inset:0 0 0 auto; width:min(82vw,330px);
    background:rgba(250,245,236,.98); backdrop-filter:blur(14px);
    flex-direction:column; align-items:flex-start; justify-content:center; gap:26px;
    padding:60px 40px; transform:translateX(100%); transition:transform .4s var(--ease);
    box-shadow:-20px 0 60px rgba(74,67,55,.18);
  }
  .nav.open{ transform:none; }
  .nav>a{ font-size:1.1rem; }
  .nav-toggle{ display:flex; }
  .site-header{ background:rgba(250,245,236,.92); backdrop-filter:blur(10px); }

  .hero{ padding:120px 0 70px; }
  .hero-trust{ gap:24px; }
  .hero-badge{ padding:11px 20px; }
  .hero-names span{ font-size:1rem; }
  .diff-grid{ grid-template-columns:1fr; }
  .team-card{ grid-template-columns:1fr; }
  .team-photo img{ min-height:300px; }
  .serv-item{ flex-wrap:wrap; gap:14px; }
  .serv-body h3{ font-size:1.25rem; }
  .footer-grid{ grid-template-columns:1fr; gap:30px; }
  .footer-bottom .container{ flex-direction:column; }

  .carousel-track{ padding-inline:18px; }
  .ig-post{ width:78vw; max-width:300px; }
  .dep-card{ width:84vw; max-width:360px; }
  .carousel-btn{ display:none; }
}
