/* ============================================================
   CLÍNICA SEIVA · Dermatologia & Estética (DEMO)
   Direção: "Seiva Botânica Terrosa" (A+C) — orgânico premium + terroso
   Fonte da verdade dos tokens. Fraunces + Figtree.
   ============================================================ */

/* ---------- TOKENS ---------- */
:root{
  /* cor */
  --cream:#F2EADD;            /* fundo dominante */
  --cream-2:#FAF5EC;          /* superfícies/cards */
  --cream-3:#EFE5D4;          /* faixa alternada */
  --olive:#3A4736;            /* títulos (verde-oliva profundo) */
  --olive-deep:#2E3A2B;       /* seções escuras */
  --sage:#8A9A7B;             /* secundário / decor */
  --clay:#BE7050;             /* acento (terracota/argila) — só fundo/ícone/decor */
  --clay-deep:#9A4E32;        /* acento p/ TEXTO sobre claro (passa contraste) */
  --ink:#332A22;             /* corpo de texto */
  --muted:#6E6456;            /* texto secundário */
  --line:#DBCEB9;            /* divisórias/bordas */
  --wa:#0B7D63;              /* WhatsApp (contraste OK) */
  --wa-deep:#096451;
  --gold:#C99A5B;            /* brilho/foco sutil */

  /* tipografia */
  --font-display:'Fraunces',Georgia,serif;
  --font-sans:'Figtree',system-ui,-apple-system,'Segoe UI',sans-serif;
  --font-script:'Dancing Script',cursive;

  /* escala fixa (clamp) */
  --fs-hero:clamp(2.7rem,6.4vw,5.3rem);
  --fs-h2:clamp(2rem,4.2vw,3.3rem);
  --fs-h3:clamp(1.3rem,2.1vw,1.7rem);
  --fs-lead:clamp(1.08rem,1.5vw,1.3rem);
  --fs-body:1.02rem;
  --fs-small:.86rem;

  /* espaçamento (escala 8) */
  --s1:8px; --s2:16px; --s3:24px; --s4:32px; --s5:48px; --s6:64px; --s7:96px; --s8:128px;

  /* raio / sombra */
  --r-sm:14px; --r-md:22px; --r-lg:34px; --r-xl:46px;
  --sh-sm:0 8px 24px rgba(58,55,38,.08);
  --sh-md:0 18px 50px rgba(58,55,38,.12);
  --sh-lg:0 30px 80px rgba(46,42,30,.16);
  --maxw:1180px;
}

/* ---------- RESET / BASE ---------- */
*{box-sizing:border-box;margin:0;padding:0}
html{overflow-x:clip;scroll-behavior:smooth;color-scheme:only light}  /* site é SÓ claro: pede aos navegadores p/ não forçar dark mode */
body{
  font-family:var(--font-sans);
  font-size:var(--fs-body);
  line-height:1.65;
  color:var(--ink);
  background:var(--cream);
  -webkit-font-smoothing:antialiased;
  overflow-x:clip;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:var(--font-display);font-weight:500;line-height:1.06;color:var(--olive);letter-spacing:-.01em}
h1{font-size:var(--fs-hero);font-weight:400}
h2{font-size:var(--fs-h2)}
h3{font-size:var(--fs-h3)}
p{max-width:62ch}
section{position:relative}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--s3);position:relative;z-index:2}
.sec{padding:var(--s7) 0}
.eyebrow{font-family:var(--font-sans);font-weight:600;font-size:.78rem;letter-spacing:.22em;
  text-transform:uppercase;color:var(--clay-deep);display:inline-flex;align-items:center;gap:10px}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--clay)}
.lead{font-size:var(--fs-lead);color:var(--muted);max-width:60ch}
.script{font-family:var(--font-script);color:var(--clay-deep);font-size:1.9rem;font-weight:600}
.center{text-align:center}
.center .lead{margin-inline:auto}
.center .eyebrow::after{content:"";width:26px;height:1px;background:var(--clay)}

/* ---------- BOTÕES ---------- */
.btn{position:relative;overflow:hidden;z-index:0;display:inline-flex;align-items:center;gap:10px;
  font-family:var(--font-sans);font-weight:600;font-size:.98rem;cursor:pointer;border:none;
  padding:16px 30px;border-radius:999px;will-change:transform;
  transition:transform .3s cubic-bezier(.22,1,.36,1),background .3s,box-shadow .3s,color .3s}
.btn svg{width:20px;height:20px}
.btn-primary{background:var(--wa);color:#fff;box-shadow:0 12px 30px rgba(11,125,99,.28)}
.btn-primary:hover{background:var(--wa-deep);box-shadow:0 16px 40px rgba(11,125,99,.36)}
.btn-clay{background:var(--clay);color:#fff;box-shadow:0 12px 30px rgba(190,112,80,.28)}
.btn-clay:hover{background:var(--clay-deep)}
.btn-ghost{background:transparent;color:var(--olive);border:1.5px solid var(--line)}
.btn-ghost:hover{border-color:var(--olive);background:rgba(58,71,54,.04)}
/* brilho deslizante — contínuo em TODO CTA de destaque */
.btn::before{content:"";position:absolute;top:0;left:0;height:100%;width:0;opacity:0;z-index:-1;
  background:#fff;box-shadow:0 0 30px 20px rgba(255,255,255,.6);transform:skewX(-30deg);
  mix-blend-mode:plus-lighter;pointer-events:none}
.btn-primary::before,.btn-clay::before,.btn-cta::before{animation:brilho 3.4s linear infinite}
.btn:hover::before{animation:brilho 1.1s linear}
@keyframes brilho{0%{opacity:0;left:0}50%{opacity:1}100%{opacity:0;left:100%}}

/* ---------- HEADER ---------- */
#hdr{position:fixed;top:0;left:0;right:0;z-index:50;transition:background .4s,box-shadow .4s,padding .4s;
  padding:18px 0}
#hdr.scrolled{background:rgba(242,234,221,.86);backdrop-filter:blur(12px);box-shadow:0 6px 24px rgba(58,55,38,.08);padding:10px 0}
.nav{display:flex;align-items:center;justify-content:space-between;gap:var(--s3)}
.brand{display:flex;align-items:center;gap:11px;font-family:var(--font-display);font-size:1.45rem;color:var(--olive);font-weight:500}
.brand .mark{width:38px;height:38px;border-radius:50%;background:var(--olive);color:var(--cream);
  display:grid;place-items:center;font-size:1.1rem;flex:none}
.brand small{display:block;font-family:var(--font-sans);font-size:.6rem;letter-spacing:.24em;
  text-transform:uppercase;color:var(--clay-deep);font-weight:600;margin-top:-2px}
.nav-links{display:flex;align-items:center;gap:var(--s4);list-style:none}
.nav-links a{font-size:.95rem;color:var(--ink);font-weight:500;transition:color .25s;position:relative}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-5px;width:0;height:1.5px;background:var(--clay);transition:width .3s}
.nav-links a:hover{color:var(--olive)}
.nav-links a:hover::after{width:100%}
.nav-cta{display:flex;align-items:center;gap:14px}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px}
.burger span{width:26px;height:2px;background:var(--olive);transition:.3s}
.burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* mobile nav — overlay tela cheia centralizado (padrão da esteira) */
.mnav{position:fixed;inset:0;z-index:49;background:var(--cream);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--s4);padding:var(--s5);
  transform:translateX(100%);transition:transform .45s cubic-bezier(.22,1,.36,1)}
.mnav.open{transform:none}
.mnav a{font-family:var(--font-display);font-size:1.6rem;color:var(--olive)}
.mnav .btn{margin-top:var(--s2);font-size:1.05rem;font-family:var(--font-sans);align-self:center;width:auto}
.mnav .btn-primary{color:#fff}   /* vence o .mnav a (senão o texto fica escuro/sem contraste no verde) */
.mnav-back{position:fixed;inset:0;background:rgba(46,42,30,.4);z-index:48;opacity:0;pointer-events:none;transition:opacity .4s}
.mnav-back.open{opacity:1;pointer-events:auto}

/* ---------- HERO ---------- */
.hero{min-height:100svh;display:flex;align-items:center;padding:100px 0 44px;overflow:clip}
.hero .wrap{width:100%}
.hero-grid{display:grid;grid-template-columns:1.08fr .92fr;gap:var(--s5);align-items:center}
.hero h1{margin:var(--s2) 0;font-size:clamp(2.1rem,4.3vw,3.85rem)}  /* menor: cabe em 100svh sem cortar */
.hero h1 .word{display:inline-block;overflow:hidden;padding-bottom:.06em}
.hero .lead{font-size:clamp(1rem,1.3vw,1.16rem)}
.hero .em{font-style:italic;color:var(--clay-deep)}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px;margin-top:var(--s3)}
.hero-figure{position:relative;height:min(500px,62svh);overflow:hidden;
  border-radius:50% 50% var(--r-lg) var(--r-lg) / 26% 26% 6% 6%;box-shadow:var(--sh-lg)}
/* parallax via object-position (pinta, sempre recortado pelo raio) — NÃO transform: o arco não vira quadrado */
.hero-figure img{width:100%;height:100%;object-fit:cover;object-position:50% 38%}
/* folha atrás da foto, na área creme acima/à direita da moldura (não em cima da foto, não escondida) */
.hero .decor.leaf{z-index:1;width:clamp(120px,14vw,215px);opacity:.6}
.hero-badge{position:absolute;left:20px;bottom:20px;z-index:3;background:rgba(250,245,236,.82);
  backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.5);border-radius:var(--r-md);
  padding:14px 20px;box-shadow:var(--sh-sm);max-width:230px}
.hero-badge strong{font-family:var(--font-display);color:var(--olive);font-size:1.05rem;display:block}
.hero-badge span{font-size:.8rem;color:var(--muted)}

/* decor */
.decor{position:absolute;pointer-events:none;z-index:1;user-select:none}
.decor.leaf{width:clamp(150px,22vw,330px);opacity:.5;mix-blend-mode:multiply}
.ghost{position:absolute;font-family:var(--font-display);font-weight:300;opacity:.05;
  line-height:.8;z-index:0;pointer-events:none;user-select:none;color:var(--olive);
  font-size:clamp(13rem,26vw,26rem)}

/* ---------- STATS / TRUST strip ---------- */
.trust{background:var(--olive-deep);color:var(--cream)}
.trust .wrap{display:flex;flex-wrap:wrap;justify-content:space-around;gap:var(--s4);padding:var(--s5) var(--s3);text-align:center}
.trust .ti strong{font-family:var(--font-display);font-size:clamp(1.4rem,2.4vw,2rem);color:#fff;display:block}
.trust .ti>span{font-size:.84rem;color:#CBD3C0;letter-spacing:.04em}  /* só o subtítulo (span direto), não o .stat-num dentro do <strong> */
.trust .ti .stat-num{font-size:inherit;color:#fff}                    /* o número herda o tamanho grande do strong */

/* ---------- SOBRE ---------- */
.sobre-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:var(--s6);align-items:center}
.sobre-fig{position:relative}
.sobre-fig .media{border-radius:var(--r-lg) var(--r-lg) var(--r-lg) 90px;box-shadow:var(--sh-md)}
.sobre-fig .blob{position:absolute;inset:auto -6% -8% auto;width:62%;height:70%;z-index:-1;
  background:var(--sage);opacity:.4;border-radius:62% 38% 46% 54% / 56% 44% 56% 44%}
.media{overflow:hidden;border-radius:var(--r-md)}
.media img{transition:transform 1s cubic-bezier(.22,1,.36,1);width:100%}
.media:hover img{transform:scale(1.06)}
.sobre h2{margin:var(--s2) 0 var(--s3)}
.sobre .sig{margin-top:var(--s3)}
.sobre .sig small{display:block;color:var(--muted);font-size:.82rem;letter-spacing:.12em;text-transform:uppercase}

/* ---------- MÉTODO ---------- */
.metodo{background:var(--cream-3)}
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s4);margin-top:var(--s6)}
.step{background:var(--cream-2);border-radius:var(--r-md);padding:var(--s5) var(--s4);position:relative;
  box-shadow:var(--sh-sm);transition:transform .4s,box-shadow .4s}
.step:hover{transform:translateY(-6px);box-shadow:var(--sh-md)}
.step .num{font-family:var(--font-display);font-size:3rem;color:var(--clay);opacity:.5;line-height:1}
.step h3{margin:var(--s2) 0 10px}

/* ---------- SERVIÇOS ---------- */
.serv-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--s4);margin-top:var(--s6)}
.serv{background:var(--cream-2);border:1px solid var(--line);border-radius:var(--r-md);
  padding:var(--s5);transition:transform .4s,box-shadow .4s,border-color .4s}
.serv:hover{transform:translateY(-5px);box-shadow:var(--sh-md);border-color:transparent}
.serv .ic-circle{width:62px;height:62px;border-radius:50%;background:var(--cream-3);
  display:grid;place-items:center;margin-bottom:var(--s3);color:var(--clay-deep)}
.serv .ic-circle svg{width:28px;height:28px}
.serv h3{margin-bottom:10px}
.serv p{color:var(--muted);font-size:.97rem}

/* ---------- DIFERENCIAIS ---------- */
.dif{background:var(--olive-deep);color:var(--cream);overflow:hidden}
.dif h2{color:#fff}
.dif .eyebrow{color:#D9B79A}
.dif .eyebrow::before,.dif .eyebrow::after{background:var(--clay)}
.dif-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--s4) var(--s6);margin-top:var(--s6)}
.dif-item{display:flex;gap:18px}
.dif-item .ic-circle{width:58px;height:58px;border-radius:50%;flex:none;
  background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.16);display:grid;place-items:center;color:#E4C3A6}
.dif-item .ic-circle svg{width:26px;height:26px}
.dif-item h3{color:#fff;font-size:1.2rem;margin-bottom:6px}
.dif-item p{color:#CBD3C0;font-size:.95rem}

/* ---------- MARQUEE ---------- */
.marquee{overflow:hidden;background:var(--clay-deep);padding:0}
.marquee__track{display:inline-flex;align-items:center;white-space:nowrap;will-change:transform;animation:marquee 36s linear infinite}
.marquee__track>span{font-family:var(--font-display);font-size:1.3rem;letter-spacing:.16em;
  text-transform:uppercase;color:#FBEFE6;padding:18px 0}
.marquee__sep{color:#E9B98F;padding:0 26px;font-size:.9rem}
@keyframes marquee{to{transform:translateX(-50%)}}
.marquee:hover .marquee__track{animation-play-state:paused}

/* ---------- DEPOIMENTOS ---------- */
.depo .swiper{padding:var(--s5) 4px var(--s6);margin-top:var(--s4)}
.depo-card{background:var(--cream-2);border-radius:var(--r-md);padding:var(--s5);box-shadow:var(--sh-sm);height:100%}
.depo-card .quote{font-family:var(--font-display);font-size:3rem;color:var(--clay);opacity:.35;line-height:.5}
.depo-card p{font-size:1.08rem;color:var(--ink);margin:var(--s2) 0 var(--s3)}
.depo-card .who{display:flex;align-items:center;gap:12px}
.depo-card .av{width:44px;height:44px;border-radius:50%;background:var(--sage);color:#fff;display:grid;place-items:center;font-family:var(--font-display);font-weight:600}
.depo-card .who strong{color:var(--olive);font-size:.96rem}
.depo-card .stars{color:var(--clay);font-size:.8rem;letter-spacing:2px}
.swiper-pagination-bullet{background:var(--olive)}
.swiper-pagination-bullet-active{background:var(--clay)}

/* ---------- INSTAGRAM ---------- */
.insta-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:var(--s5);margin-top:var(--s5);align-items:center}
.insta-profile{display:flex;align-items:center;gap:16px;margin-bottom:var(--s4)}
.insta-profile .av{width:64px;height:64px;border-radius:50%;background:linear-gradient(135deg,var(--clay),var(--sage));
  display:grid;place-items:center;color:#fff;font-family:var(--font-display);font-size:1.5rem;flex:none}
.insta-profile strong{color:var(--olive);font-size:1.1rem;display:block}
.insta-profile span{color:var(--muted);font-size:.86rem}
.insta-posts{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.insta-posts a{aspect-ratio:1;overflow:hidden;border-radius:var(--r-sm);position:relative}
.insta-posts img{width:100%;height:100%;object-fit:cover;transition:transform .8s}
.insta-posts a:hover img{transform:scale(1.08)}
.insta-feature{border-radius:var(--r-lg) 90px var(--r-lg) var(--r-lg);overflow:hidden;box-shadow:var(--sh-md)}
.insta-feature img{width:100%;height:100%;object-fit:cover}

/* ---------- LOCALIZAÇÃO ---------- */
.local{background:var(--cream-3)}
.local-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:var(--s6);align-items:stretch;margin-top:var(--s5)}
.local-info{display:flex;flex-direction:column;gap:var(--s3)}
.info-row{display:flex;gap:14px;align-items:flex-start}
.info-row .ic-circle{width:48px;height:48px;border-radius:50%;background:var(--cream-2);display:grid;place-items:center;color:var(--clay-deep);flex:none;box-shadow:var(--sh-sm)}
.info-row .ic-circle svg{width:22px;height:22px}
.info-row strong{color:var(--olive);display:block;font-size:1rem}
.info-row span{color:var(--muted);font-size:.94rem}
.local-map{border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh-md);min-height:340px}
.local-map iframe{width:100%;height:100%;min-height:340px;border:0;display:block}

/* ---------- CTA FINAL ---------- */
.cta-final{background:var(--olive-deep);color:var(--cream);text-align:center;overflow:hidden}
.cta-final h2{color:#fff;max-width:18ch;margin:var(--s2) auto var(--s3)}
.cta-final .em{color:var(--gold);font-style:italic}
.cta-final p{color:#CBD3C0;margin:0 auto var(--s5)}
.cta-final .hero-cta{justify-content:center}

/* ---------- FOOTER ---------- */
footer{background:#26301F;color:#C9D0BF;padding:var(--s7) 0 var(--s4)}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:var(--s5)}
footer .brand{color:var(--cream)}
footer p{color:#A9B29C;font-size:.92rem;margin-top:var(--s2)}
.foot-col h4{color:var(--cream);font-family:var(--font-sans);font-size:.8rem;letter-spacing:.16em;text-transform:uppercase;margin-bottom:var(--s2)}
.foot-col a{display:block;color:#A9B29C;font-size:.94rem;padding:5px 0;transition:color .25s}
.foot-col a:hover{color:var(--cream)}
.foot-bottom{border-top:1px solid rgba(255,255,255,.1);margin-top:var(--s6);padding-top:var(--s4);
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:14px;font-size:.82rem;color:#8B9580}
.demo-tag{background:rgba(201,154,91,.16);color:#E4C3A6;border:1px solid rgba(201,154,91,.3);
  border-radius:999px;padding:6px 14px;font-size:.78rem}

/* ---------- FAB ---------- */
.fab-wa{position:fixed;right:20px;bottom:20px;z-index:60;display:flex;align-items:center;
  height:60px;width:60px;border-radius:999px;background:var(--wa);color:#fff;overflow:hidden;
  white-space:nowrap;filter:drop-shadow(0 10px 26px rgba(0,0,0,.28));
  transform:translateY(28px);opacity:0;pointer-events:none;
  transition:width .42s cubic-bezier(.22,1,.36,1),background .3s,transform .5s,opacity .5s}
.fab-wa.visible{transform:none;opacity:1;pointer-events:auto;animation:fab-pulse 3s ease-out infinite}
.fab-wa svg{width:30px;height:30px;flex:none;margin:0 15px}
.fab-wa .fab-label{font-weight:700;opacity:0;transition:opacity .3s;padding-right:0}
.fab-wa:hover{width:208px;background:var(--wa-deep);animation:none}
.fab-wa:hover .fab-label{opacity:1;padding-right:22px}
.fab-wa:focus-visible{outline:3px solid var(--gold);outline-offset:3px}
@keyframes fab-pulse{0%{box-shadow:0 0 0 0 rgba(11,125,99,.45)}70%{box-shadow:0 0 0 16px rgba(11,125,99,0)}100%{box-shadow:0 0 0 0 rgba(11,125,99,0)}}

/* ---------- SCROLL SNAP (seções de conteúdo em tela cheia, desktop) ---------- */
html{scroll-snap-type:y proximity}
.snap{min-height:100svh;display:flex;flex-direction:column;justify-content:center;
  scroll-snap-align:start;padding-top:80px;padding-bottom:32px}
.snap>*{min-width:0}        /* flex item pode encolher (corrige overflow do Swiper). NÃO usar max-width:100% aqui — sobrescreve o max-width:1180 do .wrap */
.snap>.wrap{width:100%}    /* no flex-column, fixa o .wrap à largura do container (senão dimensiona pelo conteúdo do Swiper e estoura no mobile). max-width:1180 + margin:auto seguem valendo no desktop */
.hero{scroll-snap-align:start}
/* caber em 100svh: enxuga as seções mais altas (só desktop; mobile rola livre) */
@media(min-width:769px){
  .snap.sec{padding-top:80px;padding-bottom:32px}
  .sobre-fig .media{aspect-ratio:4/5;max-height:56svh}
  .sobre-fig .media img{height:100%;object-fit:cover}
  .servicos .serv{padding:var(--s4)}
  .servicos .serv-grid{gap:var(--s3)}
  .servicos .serv .ic-circle{margin-bottom:var(--s2)}
  .servicos .serv-grid,.metodo .steps,.dif-grid{margin-top:var(--s5)}
  .insta-posts{max-width:430px}
  .insta-feature{max-height:58svh}
}

/* ============================================================
   FASE 6 — micro-interações por seção (subtil, desktop, off em reduced-motion)
   ============================================================ */
/* Diferenciais (escura): halo que segue o cursor + ícones reagem no hover */
.dif-glow{position:absolute;width:520px;height:520px;border-radius:50%;pointer-events:none;z-index:0;
  left:0;top:0;opacity:0;transition:opacity .45s;will-change:transform;
  background:radial-gradient(circle, rgba(228,195,166,.20), rgba(228,195,166,0) 68%)}
.dif.glow-on .dif-glow{opacity:1}
.dif-item .ic-circle{transition:transform .35s cubic-bezier(.22,1,.36,1),background .35s,border-color .35s}
.dif-item:hover .ic-circle{transform:translateY(-4px) scale(1.07);background:rgba(228,195,166,.18);border-color:rgba(228,195,166,.5)}

/* Localização: linhas reagem no hover */
.info-row{transition:transform .35s cubic-bezier(.22,1,.36,1)}
.info-row:hover{transform:translateX(6px)}
.info-row .ic-circle{transition:transform .35s,box-shadow .35s}
.info-row:hover .ic-circle{transform:scale(1.08);box-shadow:var(--sh-md)}

/* Método: número grande reage no hover do card */
.step .num{transition:transform .4s cubic-bezier(.22,1,.36,1),color .4s,opacity .4s}
.step:hover .num{transform:translateY(-3px);color:var(--clay-deep);opacity:.85}

/* ============================================================
   RESPONSIVO — mobile DESENHADO (não encolhido)
   ============================================================ */
@media(max-width:900px){
  .hero-grid,.sobre-grid,.insta-grid,.local-grid{grid-template-columns:1fr}
  .hero-figure{height:min(440px,56vh);order:-1}
  .sobre-fig{order:-1;max-width:480px;margin-inline:auto}
  .steps,.serv-grid,.dif-grid,.foot-grid{grid-template-columns:1fr}
  .steps{gap:var(--s3)}
  .local-map{min-height:300px}
}
@media(max-width:768px){
  :root{--s7:64px;--s8:80px}
  html{scroll-snap-type:none}                       /* mobile: rolagem livre (conteúdo empilhado é mais alto que a tela) */
  .snap{display:block;min-height:auto;padding-top:var(--s7);padding-bottom:var(--s7)}  /* block no mobile: evita o flex item dimensionar pelo conteúdo do Swiper (que estourava a viewport) */
  .nav-links{display:none}
  .nav-cta .btn{display:none}             /* esconde o WhatsApp do header no mobile (padrão: só o burger; WhatsApp fica no menu + FAB) */
  .burger{display:flex}
  .hero{min-height:auto;padding:96px 0 var(--s5)}
  .serv-grid{grid-template-columns:1fr}
  .fab-wa{right:16px;bottom:calc(16px + env(safe-area-inset-bottom))}
  .fab-wa:hover{width:60px}
  .fab-wa:hover .fab-label{opacity:0;padding-right:0}
  .foot-bottom{flex-direction:column}
}

/* ---------- ACESSIBILIDADE ---------- */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation:none!important;transition:none!important;scroll-behavior:auto!important}
}
:focus-visible{outline:3px solid var(--clay);outline-offset:2px;border-radius:4px}

/* FORÇA MODO CLARO — mantém as cores ORIGINAIS mesmo se o navegador estiver em dark mode.
   Reusa as mesmas cores claras dentro do @media dark: o site fica idêntico ao claro. */
@media (prefers-color-scheme: dark){
  html,body{background:var(--cream);color:var(--ink)}
}
