/* =========================================================================
   Espaço Bem Estar Centro Estético — Americana/SP
   Design System: "Orgânico Premium" (tokens TRAVADOS no Portão 1)
   Fonte da verdade: design-system/MASTER.md
   ========================================================================= */

/* ---------- FORÇA MODO CLARO (regra 10) ---------- */
html{color-scheme:only light}

/* ---------- TOKENS ---------- */
:root{
  /* cores — paleta real da marca (verde-folha + creme da recepção) */
  --cream:#F7F1E8; --surface:#FFFFFF; --cream-deep:#ECE3D4;
  --green:#2F5C4A; --green-deep:#244A3B;   /* primário (botão/header) — texto branco passa ≥7:1 */
  --sage:#7FA98F;                          /* acento CLARO: só ícone/decor, nunca texto sobre claro */
  --sage-ink:#3D6B57;                      /* acento p/ TEXTO (eyebrow) — passa ≥5:1 sobre creme */
  --gold:#C2A04E;                          /* dourado champagne: detalhe/decor/borda */
  --wa:#0B7D63; --wa-deep:#096451;         /* verde WhatsApp escurecido (texto branco passa) */
  --ink:#2B2A26; --muted:#6E685E; --line:#E7DDCE;

  /* tipografia */
  --font-display:'Fraunces',Georgia,serif;
  --font-body:'Hanken Grotesk',system-ui,sans-serif;
  --font-script:'Dancing Script',cursive;
  --fs-h1:clamp(2.4rem,5vw,3.6rem);
  --fs-h2:clamp(1.9rem,3.5vw,2.6rem);
  --fs-h3:1.35rem;
  --fs-lead:1.15rem;
  --fs-body:1rem;
  --fs-small:.875rem;

  /* espaçamento (escala de 8) */
  --sp-1:8px; --sp-2:16px; --sp-3:24px; --sp-4:32px;
  --sp-5:48px; --sp-6:64px; --sp-7:96px; --sp-8:120px;

  /* formas */
  --r-sm:12px; --r-md:18px; --r-lg:28px; --r-band:46px;
  --shadow:0 18px 50px -24px rgba(47,92,74,.20);
  --shadow-sm:0 8px 24px -16px rgba(47,92,74,.24);
  --container:1180px;
}

/* ---------- RESET / BASE ---------- */
*{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%;overflow-x:clip}
html{scroll-behavior:smooth}
body{
  font-family:var(--font-body);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%;height:auto}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:0;background:none}
ul{list-style:none}

/* força-claro: se o SO pedir dark, reusa as cores claras (regra 10 — vem DEPOIS da base) */
@media(prefers-color-scheme:dark){
  html,body{background:var(--cream);color:var(--ink)}
}

/* ---------- TIPOGRAFIA ---------- */
h1,h2,h3{font-family:var(--font-display);font-weight:500;line-height:1.1;color:var(--ink)}
h1{font-size:var(--fs-h1);letter-spacing:-.01em}
h2{font-size:var(--fs-h2);letter-spacing:-.01em}
h3{font-size:var(--fs-h3);font-weight:600}
.lead{font-size:var(--fs-lead);color:var(--muted)}
.eyebrow{font-size:var(--fs-small);font-weight:700;letter-spacing:.14em;
  text-transform:uppercase;color:var(--sage-ink)}
.script{font-family:var(--font-script);font-weight:600;color:var(--green)}
.hl{color:var(--green)} /* palavra de destaque */

/* ---------- LAYOUT ---------- */
.container{width:100%;max-width:var(--container);margin-inline:auto;padding-inline:24px}
section{padding-block:56px;position:relative}
@media(min-width:768px){section{padding-block:88px}}
@media(min-width:1024px){section{padding-block:120px}}
.section-head{max-width:640px;margin-bottom:var(--sp-5)}
.section-head .lead{margin-top:var(--sp-2)}

.band{background:var(--cream-deep);border-radius:var(--r-band);overflow:hidden;position:relative}

/* ---------- BOTÕES ---------- */
.btn{display:inline-flex;align-items:center;gap:10px;padding:15px 26px;border-radius:999px;
  font-weight:700;font-size:1rem;will-change:transform;position:relative;overflow:hidden;z-index:0;
  transition:transform .3s cubic-bezier(.22,1,.36,1),background .3s,box-shadow .3s,color .3s}
.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{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%}}
@media(prefers-reduced-motion:reduce){.btn::before{display:none}}
.btn-primary{background:var(--green);color:#fff;box-shadow:var(--shadow-sm)}
.btn-primary:hover{background:var(--green-deep);box-shadow:var(--shadow)}
.btn-ghost{background:transparent;color:var(--green);border:1.5px solid var(--line)}
.btn-ghost:hover{border-color:var(--green);background:var(--surface)}
.btn svg{width:20px;height:20px}

/* ---------- HELPERS DE GRAFISMO / COMPOSIÇÃO ---------- */
.wrap{position:relative;z-index:2}
.decor{position:absolute;pointer-events:none;z-index:1;opacity:.9}
.decor.soft{opacity:.45}
.arch{border-radius:50% 50% 22px 22px / 30% 30% 5% 5%}
.blob{border-radius:62% 38% 46% 54% / 56% 44% 56% 44%}
.ghost{position:absolute;font-family:var(--font-display);font-weight:300;opacity:.06;
  line-height:.8;z-index:1;pointer-events:none;user-select:none;color:var(--green);
  font-size:clamp(14rem,28vw,28rem)}
.ic-circle{width:64px;height:64px;border-radius:50%;background:var(--surface);
  border:1px solid var(--line);display:grid;place-items:center;color:var(--sage-ink)}
.ic-circle svg{width:28px;height:28px}

/* ---------- KIT PREMIUM (base) ---------- */
html.lenis,html.lenis body{height:auto}
.lenis.lenis-smooth{scroll-behavior:auto!important}
.media{overflow:hidden;border-radius:var(--r-md)}
.media img{transition:transform 1s cubic-bezier(.22,1,.36,1)}
.media:hover img{transform:scale(1.06)}
.hero-figure{position:relative;height:min(600px,74vh);overflow:hidden}
.hero-figure img{width:100%;height:118%;object-fit:cover}
h1 .word{display:inline-block;overflow:hidden;padding-bottom:.06em}
.stat-num{font-variant-numeric:tabular-nums;font-family:var(--font-display)}

@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}

/* =========================================================================
   COMPONENTES / SEÇÕES
   ========================================================================= */

/* ---------- HEADER ---------- */
.hdr{position:fixed;inset:0 0 auto 0;z-index:50;transition:background .35s,box-shadow .35s,padding .35s;padding-block:14px}
.hdr.scrolled{background:rgba(247,241,232,.88);backdrop-filter:blur(10px);box-shadow:0 1px 0 var(--line)}
.hdr-in{display:flex;align-items:center;gap:20px}
.brand{display:flex;align-items:center;gap:12px;font-weight:700}
.brand-mark{display:grid;place-items:center;width:44px;height:44px;border-radius:50%;
  background:var(--green);color:var(--cream);flex:none}
.brand-mark svg{width:24px;height:24px}
.brand-name{font-family:var(--font-display);font-size:1.15rem;color:var(--ink);line-height:1.05}
.brand-name small{display:block;font-family:var(--font-body);font-weight:500;font-size:.66rem;
  letter-spacing:.18em;text-transform:uppercase;color:var(--sage-ink)}
.nav{display:none;gap:28px;margin-left:auto}
.nav a{font-weight:600;font-size:.95rem;color:var(--ink);position:relative;padding-block:4px}
.nav a::after{content:"";position:absolute;left:0;bottom:0;width:0;height:2px;background:var(--sage);transition:width .3s}
.nav a:hover::after{width:100%}
.hdr-cta{display:none;padding:11px 20px;font-size:.95rem}
.burger{margin-left:auto;display:grid;gap:5px;padding:8px}
.burger span{width:24px;height:2px;background:var(--ink);border-radius:2px;transition:.3s}
.burger[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger[aria-expanded="true"] span:nth-child(2){opacity:0}
.burger[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
@media(min-width:980px){.nav{display:flex}.hdr-cta{display:inline-flex}.burger{display:none}}

/* mobile nav overlay */
.mnav{position:fixed;inset:0;z-index:49;background:var(--cream);display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:22px;padding:24px}
.mnav[hidden]{display:none}
@media(min-width:980px){.mnav{display:none}}
.mnav a{font-family:var(--font-display);font-size:1.5rem;color:var(--ink)}
.mnav .btn{margin-top:10px;font-size:1.05rem;font-family:var(--font-body)}
.mnav .btn-primary{color:#fff}

/* ---------- HERO ---------- */
.hero{padding-top:120px;padding-bottom:48px;overflow:hidden;background:
  radial-gradient(60% 50% at 12% 8%, rgba(127,169,143,.14), transparent 70%),
  radial-gradient(50% 45% at 95% 30%, rgba(194,160,78,.08), transparent 70%)}
.hero-decor{top:-30px;right:-40px;width:min(46vw,420px);transform:rotate(8deg)}
.hero-grid{display:grid;gap:40px;align-items:center}
.hero-copy h1{margin:14px 0 18px}
.hero .lead{max-width:46ch}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px;margin:28px 0 14px}
.hero-micro{font-size:var(--fs-small);color:var(--muted)}
.hero-figure-wrap{position:relative;max-width:480px;justify-self:center}
.hero-figure{box-shadow:var(--shadow)}
.hero-badge{position:absolute;left:-8px;bottom:24px;background:var(--surface);border:1px solid var(--line);
  border-radius:var(--r-md);padding:14px 18px;box-shadow:var(--shadow);display:grid;gap:2px;text-align:left}
.hero-badge strong{font-family:var(--font-display);font-size:1.05rem}
.hero-badge span{font-size:var(--fs-small);color:var(--muted)}
.stars{color:var(--gold);letter-spacing:2px;font-size:.95rem}
@media(min-width:980px){
  .hero{padding-top:148px;padding-bottom:80px}
  .hero-grid{grid-template-columns:1.05fr .95fr;gap:64px}
  .hero-figure-wrap{justify-self:end}
}

/* ---------- FAIXA DE NÚMEROS ---------- */
.stats{padding-block:32px}
.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;
  background:var(--cream-deep);border-radius:var(--r-lg);padding:36px 28px;text-align:center}
.stat{display:grid;gap:4px}
.stat-num,.stat-big{font-family:var(--font-display);font-size:clamp(2.2rem,5vw,3rem);font-weight:500;color:var(--green);line-height:1}
.stat small{color:var(--muted);font-size:var(--fs-small)}
@media(min-width:768px){.stats-grid{grid-template-columns:repeat(4,1fr);padding:40px}}

/* ---------- SOBRE ---------- */
.sobre-grid{display:grid;gap:44px;align-items:center}
.sobre-media{position:relative}
.blob-frame{border-radius:var(--r-lg)}
.sobre-decor{bottom:-40px;right:-20px;width:120px;transform:rotate(-12deg)}
.sobre-copy h2{margin:12px 0 18px}
.sobre-copy p+p{margin-top:14px}
.assinatura{font-size:2rem;margin-top:18px}
@media(min-width:980px){.sobre-grid{grid-template-columns:1fr 1.05fr;gap:72px}}

/* ---------- DOR ---------- */
.dor-band{padding:48px 28px;text-align:center}
.dor-in{max-width:720px;margin-inline:auto}
.dor .ghost{top:-30px;left:50%;transform:translateX(-50%)}
.dor-list{display:grid;gap:14px;margin:28px 0 8px;text-align:left;max-width:560px;margin-inline:auto}
.dor-list li{position:relative;padding-left:34px;color:var(--ink)}
.dor-list li::before{content:"";position:absolute;left:0;top:6px;width:18px;height:18px;border-radius:50%;
  background:var(--sage);opacity:.22}
.dor-list li::after{content:"✓";position:absolute;left:4px;top:2px;color:var(--sage-ink);font-weight:700;font-size:.85rem}
.dor-foot{font-family:var(--font-display);font-size:1.25rem;color:var(--green);margin-top:18px}
@media(min-width:768px){.dor-band{padding:72px 56px}}

/* ---------- SERVIÇOS ---------- */
.serv-grid{display:grid;grid-template-columns:1fr;gap:20px}
.serv-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);
  padding:28px;transition:box-shadow .35s,transform .35s;transform-style:preserve-3d}
.serv-card:hover{box-shadow:var(--shadow)}
.serv-card h3{margin:16px 0 8px}
.serv-card p{color:var(--muted);font-size:.96rem}
.serv-tag{display:inline-block;margin-top:14px;font-size:.78rem;font-weight:700;letter-spacing:.08em;
  text-transform:uppercase;color:var(--sage-ink)}
.serv-cta{background:var(--green);color:var(--cream);display:flex;flex-direction:column;justify-content:center}
.serv-cta h3,.serv-cta p{color:var(--cream)}
.serv-cta .btn-ghost{color:#fff;border-color:rgba(255,255,255,.4);margin-top:14px;align-self:flex-start}
.serv-cta .btn-ghost:hover{background:rgba(255,255,255,.12);border-color:#fff}
@media(min-width:640px){.serv-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.serv-grid{grid-template-columns:repeat(3,1fr)}}

/* ---------- AVALIAÇÃO ---------- */
.aval-grid{display:grid;gap:40px}
.aval-copy h2{margin:12px 0 14px}
.aval-steps{display:grid;gap:8px;counter-reset:step}
.aval-steps li{display:flex;gap:18px;align-items:flex-start;padding:20px;border-radius:var(--r-md);
  transition:background .3s}
.aval-steps li:hover{background:var(--cream-deep)}
.aval-n{font-family:var(--font-display);font-size:1.5rem;color:var(--sage-ink);font-weight:600;flex:none;width:44px}
.aval-steps h3{margin-bottom:4px}
.aval-steps p{color:var(--muted);font-size:.96rem}
@media(min-width:980px){.aval-grid{grid-template-columns:.9fr 1.1fr;gap:64px;align-items:start}}

/* ---------- DEPOIMENTOS ---------- */
.depo{background:var(--cream-deep)}
.depoSwiper{padding-bottom:48px}
.depo-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);
  padding:32px;height:100%;display:flex;flex-direction:column;gap:14px;box-shadow:var(--shadow-sm)}
.depo-card p{font-family:var(--font-display);font-size:1.15rem;line-height:1.5;color:var(--ink)}
.depo-card footer{margin-top:auto;color:var(--muted);font-size:var(--fs-small);font-weight:600}
.depoSwiper .swiper-pagination-bullet-active{background:var(--green)}

/* ---------- LOCALIZAÇÃO ---------- */
.local-grid{display:grid;gap:40px;align-items:center}
.local-copy h2{margin:12px 0 22px}
.local-list{display:grid;gap:18px;margin-bottom:28px}
.local-list li{display:grid;gap:2px}
.local-list strong{font-size:var(--fs-small);text-transform:uppercase;letter-spacing:.1em;color:var(--sage-ink)}
.local-list a{color:var(--green);font-weight:600}
.local-map{border-radius:var(--r-md);min-height:380px}
.local-map iframe{display:block}
@media(min-width:980px){.local-grid{grid-template-columns:1fr 1.1fr;gap:64px}}

/* ---------- CTA FINAL ---------- */
.cta-band{background:var(--green);color:var(--cream);padding:56px 28px;text-align:center;overflow:hidden}
.cta-decor{top:-40px;right:-60px;width:min(34vw,260px);opacity:.16;filter:brightness(0) invert(1)}
.cta-in{max-width:640px;margin-inline:auto;position:relative}
.cta-band h2{color:#fff}
.cta-band .lead{color:rgba(255,255,255,.82);margin:16px auto 28px}
.btn-lg{padding:18px 34px;font-size:1.05rem}
.cta-band .btn-primary{background:var(--cream);color:var(--green)}
.cta-band .btn-primary:hover{background:#fff}
@media(min-width:768px){.cta-band{padding:88px 56px}}

/* ---------- FOOTER ---------- */
.ft{background:var(--ink);color:#cfc6b8;padding:56px 0 28px}
.ft-in{display:grid;gap:28px;margin-bottom:28px}
.ft .brand-mark{background:var(--cream);color:var(--green);margin-bottom:12px}
.ft-name{font-family:var(--font-display);color:#fff;font-size:1.2rem}
.ft-sub{font-size:var(--fs-small)}
.ft-contact{display:grid;gap:8px;font-size:.95rem}
.ft-contact a:hover{color:#fff}
.ft-copy{border-top:1px solid rgba(255,255,255,.1);padding-top:22px;text-align:center;font-size:var(--fs-small)}
@media(min-width:768px){.ft-in{grid-template-columns:1fr auto}}

/* =========================================================================
   GRAFISMO POR SEÇÃO + curva + mobile dedicado
   ========================================================================= */
.sobre,.stats,.servicos,.aval,.depo,.local,.insta{overflow:hidden}
.stats .container,.servicos .container,.aval .container,.depo .container,.local .container{position:relative;z-index:2}

.dec-stats{top:-26px;right:-10px;width:120px;opacity:.32;transform:rotate(18deg)}
.dec-serv{bottom:-50px;left:-50px;width:min(38vw,300px);opacity:.24;transform:rotate(-8deg)}
.dec-aval{top:-20px;right:-30px;width:130px;opacity:.3;transform:rotate(-14deg)}
.dec-depo{bottom:-40px;right:-40px;width:min(34vw,260px);opacity:.22;transform:rotate(160deg)}
.dec-local{top:40px;left:-30px;width:120px;opacity:.28;transform:rotate(24deg)}

.depo{border-radius:var(--r-band) var(--r-band) 0 0}

/* ---------- MOBILE DEDICADO ---------- */
@media(max-width:768px){
  .hero{padding-top:104px}
  .hero-decor{width:54vw;opacity:.28;top:-10px;right:-30px}
  .hero-figure-wrap{max-width:360px}
  .hero-badge{left:6px;bottom:10px;padding:11px 14px}
  .hero-badge strong{font-size:.95rem}
  .hero-cta .btn{flex:1 1 auto;justify-content:center}
  .brand-name{font-size:1.02rem}
  .stat-num,.stat-big{font-size:2rem}
  .dec-serv,.dec-depo{display:none}
  .dec-stats,.dec-aval,.dec-local{width:84px;opacity:.22}
  .aval-steps li{padding:14px 8px}
  .cta-band,.dor-band{padding:40px 22px}
  .ghost{font-size:clamp(8rem,38vw,12rem)}
}
@media(max-width:380px){
  .brand-name small{display:none}
}

/* ---------- FAB WhatsApp flutuante ---------- */
.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)}
}
@media(prefers-reduced-motion:reduce){
  .fab-wa{transition:opacity .3s;transform:none}
  .fab-wa.visible{animation:none}
}
@media(max-width:768px){ .fab-wa{right:16px;bottom:16px} .fab-wa:hover{width:60px} .fab-wa:hover .fab-label{opacity:0;padding-right:0} }

/* =========================================================================
   Faixa marquee, texto gradiente, seção Instagram, polish
   ========================================================================= */

/* ---------- Faixa marquee em gradiente ---------- */
.marquee{overflow:hidden;background:linear-gradient(90deg,var(--green),var(--green-deep) 60%,var(--green));position:relative}
.marquee__track{display:inline-flex;align-items:center;white-space:nowrap;will-change:transform;
  animation:marquee 34s linear infinite}
.marquee__track>span{font-family:var(--font-display);font-size:1.05rem;font-weight:500;
  letter-spacing:.2em;text-transform:uppercase;color:var(--cream);padding:18px 0}
.marquee__sep{color:var(--gold);padding:0 26px;font-size:.9rem}
@keyframes marquee{to{transform:translateX(-50%)}}
.marquee:hover .marquee__track{animation-play-state:paused}
@media(prefers-reduced-motion:reduce){.marquee__track{animation:none}}

/* ---------- Texto em gradiente (só sobre fundo escuro) ---------- */
.text-gradient{background:linear-gradient(90deg,#EAD9B2,var(--gold));
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent}

/* ---------- Seção Instagram ---------- */
.insta .container{position:relative;z-index:2}
.insta-grid{display:grid;gap:40px;align-items:center}
.insta-profile{display:flex;align-items:center;gap:14px;margin-bottom:18px}
.insta-avatar{width:62px;height:62px;border-radius:50%;object-fit:cover;border:2px solid var(--gold);flex:none}
.insta-handle{font-weight:700;font-size:1.05rem}
.insta-bio{font-size:.9rem;color:var(--muted);max-width:42ch}
.insta-posts{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:24px}
.insta-post{position:relative;aspect-ratio:1;border-radius:10px;overflow:hidden;background:var(--cream-deep)}
.insta-post img{width:100%;height:100%;object-fit:cover;transition:transform .8s cubic-bezier(.22,1,.36,1)}
.insta-post:hover img{transform:scale(1.08)}
.insta-social{display:flex;flex-wrap:wrap;gap:12px}
.insta-feature{position:relative}
.insta-feature .media{border-radius:var(--r-lg);box-shadow:var(--shadow)}
@media(min-width:980px){.insta-grid{grid-template-columns:1.05fr .95fr;gap:60px}}

/* ---------- Polish ---------- */
.decor.soft{opacity:.55}
.hero-decor{opacity:.5}
.dec-stats{opacity:.4}.dec-serv{opacity:.32}.dec-aval{opacity:.4}.dec-local{opacity:.4}
.sobre-decor{opacity:.6}
