/* ============================================================
   GEOVANA MARCHEZAN · Landing Page · v2 (rebuild limpa)
   ============================================================ */

:root{
  /* Paleta */
  --mustard:#c9a861;        /* fundo principal */
  --mustard-deep:#b39455;   /* hover/realce */
  --mustard-soft:#d8bd80;
  --mustard-band:#a98a4b;   /* faixa de marca-texto */
  --ink:#171615;            /* preto profundo (CTAs, headings) */
  --ink-soft:#2d2a26;
  --ink-faint:rgba(23,22,21,.62);
  --cream:#f4ece0;          /* fundo da seção de reviews */
  --cream-2:#faf5ec;
  --gold:#a98a4b;
  --gold-light:#d6b67a;
  --white:#ffffff;
  --green:#1fbd5b;
  --green-deep:#17a04c;
  --line-on-mustard:rgba(23,22,21,.18);
  --line-on-cream:rgba(23,22,21,.12);
  --container:1280px;
}

*{box-sizing:border-box;margin:0;padding:0}
noscript{display:none!important}
html,body{
  background:var(--mustard);
  color:var(--ink);
  font-family:"Jost",system-ui,-apple-system,sans-serif;
  font-weight:400;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
html{scroll-behavior:smooth}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer}

/* ---------- Container & utilities ---------- */
.container{max-width:var(--container);margin:0 auto;padding:0 32px}
@media(max-width:640px){ .container{padding:0 22px} }

.reveal{opacity:0;transform:translateY(20px);transition:opacity .9s ease,transform .9s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}

/* ---------- Type system ---------- */
.serif-block,
.big-serif,
.galeria-h,
.clientes-h,
.merece-h,
.final-h,
.solucao-h,
.quote-h{
  font-family:"Cormorant Garamond",serif;
  font-weight:500;
  letter-spacing:-.01em;
  line-height:1.05;
  color:var(--ink);
  text-wrap:balance;
}
.serif-block.italic, em{
  font-style:italic;
  font-weight:500;
}
em{ color:inherit }

.hand-block,
.hand-band,
.hand{
  font-family:"Shadows Into Light Two", "Caveat", cursive;
  font-weight:400;
  color:var(--white);
  letter-spacing:0;
  font-style:normal;
  line-height:1.0;
}
.hand.big{ font-size:1.05em }
.hand-band{ color:var(--mustard-deep); display:inline-block; padding:0 .08em }

/* highlighter band (semi-transparent block under handwritten text) */
.hl-band{
  position:relative;
  display:inline-block;
  padding:0 .14em;
  isolation:isolate;
}
.hl-band::before{
  content:"";
  position:absolute;
  left:-.04em;right:-.04em;
  top:.16em;bottom:.12em;
  background:var(--mustard-band);
  z-index:-1;
  border-radius:1px;
}
.hl-band.light::before{
  background:var(--mustard-deep);
  opacity:.55;
}

/* eyebrow */
.section-eyebrow,
.eyebrow{
  font-family:"Jost",sans-serif;
  font-size:13px;
  letter-spacing:.32em;
  text-transform:uppercase;
  color:var(--ink);
  font-weight:500;
  display:inline-flex;
  align-items:center;
  gap:18px;
}
.eyebrow-rule{
  display:inline-block;width:46px;height:1.2px;background:var(--ink);opacity:.65;
}

/* ============================================================
   HEADER
   ============================================================ */
.site{
  position:sticky;top:0;z-index:50;
  background:var(--mustard);
  border-bottom:1px solid transparent;
  transition:background .3s ease, border-color .3s ease, box-shadow .3s ease;
}
.site.scrolled{
  background:rgba(201,168,97,.94);
  backdrop-filter:saturate(1.15) blur(8px);
  -webkit-backdrop-filter:saturate(1.15) blur(8px);
  border-bottom-color:var(--line-on-mustard);
  box-shadow:0 10px 30px -22px rgba(23,22,21,.4);
}
.site .row{
  display:flex;align-items:center;justify-content:space-between;
  gap:32px;padding:18px 0;
}
.site .logo{display:flex;align-items:center}
.site .logo img{height:64px;width:auto;object-fit:contain;filter:brightness(0) invert(1)}

/* Nav menu */
.nav-menu{display:flex;align-items:center;gap:42px;flex:1;justify-content:center}
.nav-link{
  font-family:"Jost",sans-serif;
  font-size:12.5px;letter-spacing:.28em;text-transform:uppercase;
  color:var(--ink)!important;       /* fix do hover com cor errada do tema */
  font-weight:500;
  padding:8px 0;
  position:relative;
  transition:color .25s ease;
}
.nav-link::after{
  content:"";position:absolute;left:0;right:100%;bottom:2px;height:1.2px;
  background:var(--ink);transition:right .35s cubic-bezier(.2,.7,.2,1);
}
.nav-link:hover{ color:var(--ink-soft)!important }
.nav-link:hover::after{ right:0 }

/* Header CTA */
.nav-cta{
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 26px;
  border:1.5px solid var(--ink);
  font-family:"Jost",sans-serif;font-size:12.5px;letter-spacing:.28em;text-transform:uppercase;font-weight:500;
  color:var(--ink);
  transition:.3s ease;
  white-space:nowrap;
}
.nav-cta:hover{ background:var(--ink); color:var(--mustard) }

@media(max-width:900px){
  .site .row{padding:14px 0;gap:14px}
  .site .logo img{height:50px}
  .nav-menu{display:none}
  .nav-cta{padding:11px 18px;font-size:11px;letter-spacing:.22em}
}
@media(max-width:520px){
  .site .logo img{height:42px}
  .nav-cta{padding:10px 14px;font-size:10.5px;letter-spacing:.18em}
}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:16px;
  font-family:"Jost",sans-serif;font-weight:500;
  letter-spacing:.26em;text-transform:uppercase;
  font-size:13.5px;
  padding:22px 36px;
  border:1.5px solid transparent;
  cursor:pointer;
  transition:transform .3s cubic-bezier(.2,.7,.2,1), background .3s ease, color .3s ease, box-shadow .3s ease;
  position:relative;overflow:hidden;
  text-align:center;
}
.btn .arrow{display:inline-block;transition:transform .35s cubic-bezier(.2,.7,.2,1)}
.btn:hover .arrow{transform:translateX(6px)}
.btn-dark{
  background:linear-gradient(180deg,#1f1d1b 0%, #100f0e 100%);
  color:var(--gold-light);
  border-color:#0a0908;
  box-shadow:0 14px 34px -18px rgba(23,22,21,.65);
}
.btn-dark:hover{
  background:linear-gradient(180deg,#262320 0%, #161413 100%);
  color:var(--white);
  transform:translateY(-2px);
  box-shadow:0 22px 48px -18px rgba(23,22,21,.75);
}
.btn-hero{ padding:24px 42px; font-size:14px }
.btn-big{ padding:28px 56px; font-size:15px; letter-spacing:.30em }
.btn-big-wide{ width:100%; padding:28px 32px; font-size:14.5px; letter-spacing:.30em }

/* WhatsApp green CTA */
.btn-wa{
  background:#25d366;
  color:#fff;
  border:3px solid #94da77;
  outline-offset:6px;
  box-shadow:0 18px 40px -16px rgba(37,211,102,.6);
  padding:22px 32px;
  font-size:14.5px;letter-spacing:.20em;
}
.btn-wa:hover{
  background:#1fbd5b;border-color:#7fcf5f;
  transform:translateY(-2px);
  box-shadow:0 24px 52px -16px rgba(37,211,102,.72);
}
.btn-wa svg{flex-shrink:0}

/* link arrow-down */
.link-arrow-down{
  display:inline-flex;align-items:center;gap:12px;
  font-family:"Jost",sans-serif;font-size:13.5px;letter-spacing:.28em;text-transform:uppercase;font-weight:500;
  color:var(--ink);padding:10px 4px;
  position:relative;
}
.link-arrow-down::after{
  content:"";position:absolute;left:4px;right:30px;bottom:6px;height:1px;background:var(--ink);transform:scaleX(.65);transform-origin:left center;transition:transform .35s ease;
}
.link-arrow-down:hover::after{transform:scaleX(1)}
.link-arrow-down .arrow-down{transition:transform .25s ease}
.link-arrow-down:hover .arrow-down{transform:translateY(4px)}

/* ============================================================
   HERO
   ============================================================ */
.hero{ padding:64px 0 80px; position:relative }
.hero-grid{
  display:grid;
  grid-template-columns:1.05fr 1fr;
  gap:80px;
  align-items:center;
  min-height:74vh;
}
.hero-copy h1{
  font-family:"Cormorant Garamond",serif;
  font-weight:500;
  font-size:clamp(48px, 6.6vw, 96px);
  line-height:1.0;
  color:var(--ink);
  margin:32px 0 36px;
  letter-spacing:-.012em;
}
.hero-copy h1 .serif-block,
.hero-copy h1 .hand-block{ display:block }
.hero-copy h1 .serif-block.italic{ font-style:italic }
.hero-copy h1 .hand-block{
  font-family:"Shadows Into Light Two", cursive;
  color:var(--white);
  font-size:.92em;
  margin-top:.10em;
}
.hero .eyebrow{ margin-bottom:8px }
.hero p.lead{
  font-family:"Jost",sans-serif;
  font-size:18px;
  color:var(--ink-soft);
  margin:0 0 44px;
  max-width:540px;
}
.hero-ctas{display:flex;align-items:center;gap:32px;flex-wrap:wrap}

.hero-img-wrap{position:relative}
.hero-img{
  position:relative;overflow:hidden;
  aspect-ratio: 4/5;
  background:#d3d2cc;
  border-radius:0;
  box-shadow:0 30px 60px -28px rgba(23,22,21,.45);
}
.hero-img img{ width:100%;height:100%;object-fit:cover;object-position:center top }
.hero-caption{
  position:absolute;left:24px;bottom:24px;
  padding:12px 22px;
  background:rgba(17,16,15,.78);
  backdrop-filter:blur(3px);
  color:var(--white);
  font-family:"Cormorant Garamond",serif;font-size:18px;letter-spacing:.02em;
  font-weight:400;
}
.hero-caption em{font-style:italic;color:var(--white);font-weight:400}

.hero-stamp{
  margin-top:48px;
  font-family:"Cormorant Garamond",serif;font-style:italic;
  font-size:18px;color:var(--ink-soft);
  border-top:1px solid var(--line-on-mustard);
  padding-top:24px;
  letter-spacing:.005em;
}
.hero-stamp strong{ font-style:normal; color:var(--ink); font-weight:600 }

@media(max-width:1024px){
  .hero{padding:40px 0 60px}
  .hero-grid{grid-template-columns:1fr;gap:48px}
  .hero-img{aspect-ratio:4/4.5;max-height:520px}
  .hero-copy h1{font-size:clamp(40px, 9vw, 64px)}
}
@media(max-width:520px){
  .hero p.lead{font-size:16.5px;margin-bottom:32px}
  .btn-hero{padding:20px 26px;font-size:12.5px;letter-spacing:.22em}
  .hero-ctas{gap:18px}
  .link-arrow-down{font-size:12px;letter-spacing:.22em}
}

/* ============================================================
   A VERDADE
   ============================================================ */
.verdade{padding:120px 0 100px;position:relative}
.verdade .section-eyebrow{margin-bottom:24px}
.big-serif{
  font-family:"Cormorant Garamond",serif;font-weight:500;
  font-size:clamp(36px,4.6vw, 64px);
  line-height:1.06;
  color:var(--ink);
  letter-spacing:-.008em;
  max-width:1100px;
}
.big-serif em{font-style:italic;color:var(--ink)}
.verdade .big-serif{margin-bottom:80px}

/* Accordion */
.acc-list{display:flex;flex-direction:column;border-top:1px solid var(--line-on-mustard)}
.acc-item{ border-bottom:1px solid var(--line-on-mustard) }
.acc-head{
  display:grid;
  grid-template-columns:90px 1fr 56px;
  gap:24px;
  align-items:center;
  width:100%;text-align:left;
  padding:30px 4px;
  font-family:"Cormorant Garamond",serif;
  transition:padding .25s ease;
}
.acc-num{
  font-family:"Cormorant Garamond",serif;font-style:italic;font-weight:400;
  font-size:32px;color:var(--mustard-deep);line-height:1;
}
.acc-title{
  font-family:"Cormorant Garamond",serif;
  font-weight:500;
  font-size:clamp(20px, 2.2vw, 28px);
  line-height:1.2;color:var(--ink);
  letter-spacing:-.005em;
}
.acc-plus{
  width:42px;height:42px;border-radius:50%;border:1.5px solid var(--ink);
  position:relative;display:inline-block;transition:.3s ease;justify-self:end;
}
.acc-plus::before,.acc-plus::after{
  content:"";position:absolute;left:50%;top:50%;background:var(--ink);
  transform:translate(-50%,-50%);transition:.3s ease;
}
.acc-plus::before{width:14px;height:1.8px}
.acc-plus::after{width:1.8px;height:14px}
.acc-head[aria-expanded="true"] .acc-plus{background:var(--ink);border-color:var(--ink)}
.acc-head[aria-expanded="true"] .acc-plus::before,
.acc-head[aria-expanded="true"] .acc-plus::after{background:var(--mustard)}
.acc-head[aria-expanded="true"] .acc-plus::after{transform:translate(-50%,-50%) rotate(90deg);opacity:0}
.acc-head[aria-expanded="true"] .acc-title{color:var(--ink-soft)}

.acc-body{ display:grid; grid-template-rows:0fr; transition:grid-template-rows .45s cubic-bezier(.4,0,.2,1) }
.acc-body > p{
  overflow:hidden;
  padding:0 56px 0 114px;
  font-family:"Jost",sans-serif;font-size:17px;
  color:var(--ink-soft);line-height:1.65;
  max-width:760px;
}
.acc-body.open{ grid-template-rows:1fr }
.acc-body.open > p{padding-bottom:30px}

@media(max-width:640px){
  .acc-head{grid-template-columns:54px 1fr 38px;gap:14px;padding:22px 0}
  .acc-num{font-size:22px}
  .acc-title{font-size:18px;line-height:1.25}
  .acc-plus{width:34px;height:34px}
  .acc-body > p{padding:0 0 0 68px;font-size:15.5px}
}

/* ============================================================
   A SOLUÇÃO
   ============================================================ */
.solucao{padding:120px 0 110px}
.solucao .section-eyebrow{margin-bottom:32px}
.solucao-h{
  font-family:"Cormorant Garamond",serif;font-weight:500;
  font-size:clamp(40px, 5.6vw, 84px);
  line-height:1.02;
  color:var(--ink);
  letter-spacing:-.012em;
  margin-bottom:54px;
  text-wrap:balance;
}
.solucao-h em{font-style:italic;color:var(--ink)}
.solucao-h .hand{
  font-family:"Shadows Into Light Two", cursive;
  font-style:normal;font-weight:400;color:var(--white);
  font-size:.96em;
}

.solucao-intro{
  max-width:880px;margin-bottom:80px;
  font-family:"Jost",sans-serif;font-size:18px;color:var(--ink-soft);
  display:flex;flex-direction:column;gap:18px;line-height:1.65;
}
.solucao-intro strong{color:var(--ink);font-weight:600}

/* Promessa block */
.promessa{
  position:relative;
  padding:64px 70px 58px;
  margin-bottom:80px;
  max-width:1080px;
}
.promessa-corners .c{position:absolute;width:28px;height:28px;border:1.5px solid var(--ink)}
.c-tl{top:0;left:0;border-right:0;border-bottom:0}
.c-tr{top:0;right:0;border-left:0;border-bottom:0}
.c-bl{bottom:0;left:0;border-right:0;border-top:0}
.c-br{bottom:0;right:0;border-left:0;border-top:0}
.promessa-eyebrow{
  font-family:"Jost",sans-serif;font-size:13px;letter-spacing:.36em;text-transform:uppercase;
  color:var(--ink);font-weight:500;margin-bottom:38px;opacity:.82;
}
.promessa-body{
  font-family:"Cormorant Garamond",serif;
  font-weight:400;
  font-style:italic;
  font-size:clamp(26px, 2.9vw, 42px);
  line-height:1.5;
  color:var(--ink);
  letter-spacing:-.005em;
  max-width:none;
}
.promessa-body strong{font-weight:700;font-style:italic;color:var(--ink)}

@media(max-width:640px){
  .promessa{padding:42px 30px 38px}
  .promessa-body{font-size:22px;line-height:1.4}
  .promessa-eyebrow{margin-bottom:26px;font-size:11.5px;letter-spacing:.28em}
  .promessa-corners .c{width:18px;height:18px}
}

/* Etapas */
.etapas{
  list-style:none;
  display:grid;grid-template-columns:repeat(2,1fr);
  gap:22px 32px;
  margin-top:30px;
  border-top:1px solid var(--line-on-mustard);
  padding-top:42px;
}
.etapas li{
  display:grid;grid-template-columns:64px 1fr;gap:22px;
  padding:22px 0;
  border-bottom:1px solid var(--line-on-mustard);
}
.etapas li:nth-last-child(-n+2){border-bottom:none}
.e-num{
  font-family:"Cormorant Garamond",serif;font-style:italic;font-weight:400;
  font-size:34px;color:var(--mustard-deep);line-height:1;
}
.etapas h4{
  font-family:"Cormorant Garamond",serif;font-weight:600;
  font-size:22px;line-height:1.2;color:var(--ink);margin-bottom:8px;
}
.etapas p{
  font-family:"Jost",sans-serif;font-size:15.5px;color:var(--ink-soft);line-height:1.6;
}
@media(max-width:780px){
  .etapas{grid-template-columns:1fr;padding-top:30px}
  .etapas li:nth-last-child(2){border-bottom:1px solid var(--line-on-mustard)}
  .etapas li:last-child{border-bottom:none}
}

/* ============================================================
   MERECE
   ============================================================ */
.merece{padding:120px 0 140px;text-align:center;position:relative}
.merece-h{
  font-family:"Cormorant Garamond",serif;font-weight:500;
  font-size:clamp(42px, 6.2vw, 86px);
  line-height:1.04;
  color:var(--ink);
  margin-bottom:50px;
  letter-spacing:-.012em;
  text-wrap:balance;
}
.merece-h .serif-block,
.merece-h .hand-block{display:block}
.merece-h .serif-block.italic{font-style:italic}
.merece-h .hand-block{
  font-family:"Shadows Into Light Two", cursive;
  color:var(--white);font-size:.92em;margin:.04em 0;
}
.merece-body{ max-width:720px;margin:0 auto;display:flex;flex-direction:column;gap:30px;align-items:center }
.merece-body p{
  font-family:"Cormorant Garamond",serif;font-weight:400;
  font-size:clamp(20px,2.0vw,26px);color:var(--ink-soft);line-height:1.45;
  font-style:italic;
}
.merece-body p strong{color:var(--ink);font-weight:500;font-style:normal}
.merece-meta{
  font-family:"Cormorant Garamond",serif;font-size:14px;letter-spacing:.32em;text-transform:uppercase;
  color:var(--ink);font-weight:500;
}

/* ============================================================
   GALERIA
   ============================================================ */
.galeria{padding:80px 0 120px}
.galeria-h{
  font-family:"Cormorant Garamond",serif;font-weight:500;
  font-size:clamp(40px, 5.6vw, 84px);
  line-height:1.04;color:var(--ink);
  margin-bottom:60px;letter-spacing:-.01em;text-wrap:balance;
}
.galeria-h .serif-block,.galeria-h .hand-block{display:block}
.galeria-h .hand-block{font-family:"Shadows Into Light Two",cursive;color:var(--white);font-size:.96em;margin-top:.04em}

.galeria-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  grid-auto-rows:280px;
  gap:16px;
}
.g-item{
  overflow:hidden;display:block;background:#a99166;
  position:relative;cursor:pointer;
  grid-column:span 1;
}
.g-item img{width:100%;height:100%;object-fit:cover;transition:transform .8s cubic-bezier(.2,.7,.2,1)}
.g-item:hover img{transform:scale(1.05)}

/* Magazine 4×4 layout — 8 photos
   Row 1-2: tall(2×2)  |  normal  |  normal
   Row 2  : tall cont. |  wide-2 spans both right cols
   Row 3  : wide-2 left  |  normal  |  normal
   Row 4  : full-wide (all 4 cols) */
.galeria-grid .g-item:nth-child(1){grid-column:span 2;grid-row:span 2}
.galeria-grid .g-item:nth-child(4){grid-column:span 2}
.galeria-grid .g-item:nth-child(5){grid-column:span 2}
.galeria-grid .g-item:nth-child(8){grid-column:span 4;grid-row:span 1}

@media(max-width:980px){
  .galeria-grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:240px;gap:12px}
  .galeria-grid .g-item:nth-child(1){grid-column:span 2;grid-row:span 2}
  .galeria-grid .g-item:nth-child(4),
  .galeria-grid .g-item:nth-child(5){grid-column:span 2}
  .galeria-grid .g-item:nth-child(8){grid-column:span 2;grid-row:span 1}
  .galeria-grid .g-item:nth-child(2),
  .galeria-grid .g-item:nth-child(3),
  .galeria-grid .g-item:nth-child(6),
  .galeria-grid .g-item:nth-child(7){grid-column:span 1}
}
@media(max-width:560px){
  .galeria-grid{grid-template-columns:1fr;grid-auto-rows:260px;gap:12px}
  .galeria-grid .g-item,
  .galeria-grid .g-item:nth-child(1),
  .galeria-grid .g-item:nth-child(4),
  .galeria-grid .g-item:nth-child(5),
  .galeria-grid .g-item:nth-child(8){grid-column:span 1;grid-row:span 1}
}

/* ============================================================
   CLIENTES / DEPOIMENTOS
   ============================================================ */
.clientes{background:var(--cream);padding:120px 0 140px}
.clientes-h{
  font-family:"Cormorant Garamond",serif;font-weight:500;
  font-size:clamp(42px,5.6vw, 82px);
  line-height:1.04;color:var(--ink);margin-bottom:60px;
  letter-spacing:-.012em;text-wrap:balance;
}
.clientes-h .serif-block{display:block}
.clientes-h .hand-band{
  font-family:"Shadows Into Light Two",cursive;
  font-style:normal;color:var(--mustard-deep);
  background:rgba(201,168,97,.32);
  padding:0 .18em .04em;
}

/* Video (stories portrait 9:16) */
.video-wrap{
  position:relative;
  max-width:380px;
  margin:0 auto 80px;
  background:#000;
  aspect-ratio:9/16;
  border-radius:8px;
  overflow:hidden;
  box-shadow:0 30px 80px -30px rgba(0,0,0,.55);
}
.video-wrap video{width:100%;height:100%;object-fit:cover;display:block;background:#000}
.video-play{
  position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  width:96px;height:96px;border-radius:50%;
  background:rgba(255,255,255,.92);color:var(--ink);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;transition:.3s ease;
  box-shadow:0 22px 48px -16px rgba(0,0,0,.55);
}
.video-play:hover{transform:translate(-50%,-50%) scale(1.08);background:#fff}
.video-play svg{margin-left:6px}
.video-wrap.playing .video-play{opacity:0;pointer-events:none}

/* Quote head */
.depoimentos-head{text-align:center;max-width:1080px;margin:0 auto 70px}
.depoimentos-head .section-eyebrow{margin-bottom:24px}
.quote-h{
  font-family:"Cormorant Garamond",serif;
  font-weight:400;font-style:italic;
  font-size:clamp(28px, 3.2vw, 46px);
  line-height:1.15;
  color:var(--mustard-deep);
  letter-spacing:-.005em;
  margin-bottom:18px;
  text-wrap:balance;
}
.quote-h em{font-style:italic;color:var(--mustard-deep)}
.quote-sub{
  font-family:"Cormorant Garamond",serif;font-style:italic;
  font-size:17px;color:var(--ink-soft);margin-bottom:30px;
}

/* Google pill */
.google-pill{
  display:inline-flex;align-items:center;gap:14px;
  background:#fff;padding:14px 24px;border-radius:999px;
  box-shadow:0 14px 40px -16px rgba(23,22,21,.18);
}
.g-stars{color:#f5a623;font-size:18px;letter-spacing:.06em}
.g-rating{font-family:"Cormorant Garamond",serif;font-style:italic;font-size:22px;color:var(--mustard-deep)}
.g-sep{color:var(--ink-faint)}
.g-label{font-family:"Jost",sans-serif;font-size:12px;letter-spacing:.32em;text-transform:uppercase;color:var(--ink-soft);font-weight:500}

/* Reviews grid */
.reviews-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:32px;
}
.review-card{
  background:var(--cream-2);
  padding:38px 32px 32px;
  display:flex;flex-direction:column;gap:24px;
  border:1px solid rgba(23,22,21,.06);
  box-shadow:0 14px 40px -28px rgba(23,22,21,.18);
}
.rstars{color:#f5a623;font-size:17px;letter-spacing:.08em}
.rquote{
  font-family:"Cormorant Garamond",serif;font-style:italic;font-weight:400;
  font-size:20px;line-height:1.45;color:var(--ink-soft);
  flex:1;
}
.rfoot{padding-top:22px;border-top:1px solid var(--line-on-cream)}
.rname{
  font-family:"Cormorant Garamond",serif;font-weight:600;font-size:15px;
  letter-spacing:.16em;text-transform:uppercase;color:var(--mustard-deep);margin-bottom:6px;
}
.rrole{font-family:"Jost",sans-serif;font-size:13px;color:var(--ink-faint)}

@media(max-width:900px){
  .reviews-grid{grid-template-columns:1fr;gap:18px}
  .video-wrap{max-width:300px}
}

/* ============================================================
   FINAL CTA
   ============================================================ */
.final{
  padding:100px 0 120px;
  background:var(--mustard);
}
.final-grid{
  display:grid;grid-template-columns:0.85fr 1.5fr;gap:80px;align-items:center;
}
.fp-frame{
  position:relative;
  padding:18px;
}
.fp-frame::before{
  content:"";position:absolute;inset:0;
  border:1.5px solid rgba(255,255,255,.78);
  pointer-events:none;
}
.fp-frame img{
  width:100%;aspect-ratio:3/4;object-fit:cover;
  filter:none;display:block;
}
.final-h{
  font-family:"Cormorant Garamond",serif;font-weight:500;
  font-size:clamp(34px, 4.6vw, 64px);line-height:1.06;
  color:var(--ink);letter-spacing:-.01em;text-wrap:balance;
}
.final-h .hand-band.big{
  font-family:"Shadows Into Light Two",cursive;font-size:1.0em;
  color:var(--white);background:transparent;
  position:relative;display:inline;padding:0 .04em;
}
.final-h .hand-band.big::before{
  content:"";position:absolute;left:-.02em;right:-.02em;top:.20em;bottom:.10em;
  background:var(--mustard-deep);opacity:.45;z-index:-1;border-radius:1px;
}
.final-rule{width:64px;height:1px;background:var(--ink);margin:24px 0 28px;opacity:.5}
.final-lead{
  font-family:"Cormorant Garamond",serif;font-style:italic;font-weight:400;
  font-size:clamp(20px,1.9vw,26px);line-height:1.45;color:rgba(244,236,224,.78);
  max-width:640px;margin-bottom:40px;
}
.final-lead strong{font-weight:500;font-style:italic;color:var(--white)}
.final-ctas{display:flex;flex-direction:column;gap:18px;max-width:640px}

@media(max-width:900px){
  .final-grid{grid-template-columns:1fr;gap:40px}
  .fp-frame{max-width:320px;margin:0 auto}
}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{
  background:#1a1815;color:#ddd2bc;padding:80px 0 30px;
}
.foot-grid{
  display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:60px;padding-bottom:48px;border-bottom:1px solid rgba(255,255,255,.08);
}
.foot-logo{height:64px;width:auto;margin-bottom:24px;filter:brightness(0) invert(1);opacity:.85}
.site-footer p{font-family:"Jost",sans-serif;font-size:14.5px;color:rgba(255,255,255,.6);line-height:1.7;max-width:380px}
.site-footer h6{
  font-family:"Jost",sans-serif;font-size:11.5px;letter-spacing:.32em;text-transform:uppercase;
  color:#d6b67a;font-weight:500;margin-bottom:18px;
}
.site-footer a{
  display:block;font-family:"Cormorant Garamond",serif;font-size:18px;
  color:#ddd2bc;margin-bottom:8px;transition:color .25s ease;
}
.site-footer a:hover{color:#fff}
.foot-bottom{
  padding-top:24px;display:flex;justify-content:space-between;
  font-family:"Jost",sans-serif;font-size:12px;color:rgba(255,255,255,.45);letter-spacing:.05em;
}
.foot-bottom a{display:inline;color:rgba(255,255,255,.7)}
@media(max-width:780px){
  .foot-grid{grid-template-columns:1fr;gap:40px}
  .foot-bottom{flex-direction:column;gap:8px}
}

/* ============================================================
   QUALIFICATION MODAL
   ============================================================ */
.qm-backdrop{
  position:fixed;inset:0;z-index:100;
  background:rgba(15,14,12,.62);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
  display:flex;align-items:center;justify-content:center;
  padding:30px 20px;
  opacity:0;visibility:hidden;transition:opacity .35s ease, visibility .35s ease;
}
.qm-backdrop.open{opacity:1;visibility:visible}
.qm{
  background:var(--cream-2);color:var(--ink);
  max-width:560px;width:100%;padding:42px 40px 36px;
  position:relative;
  box-shadow:0 60px 120px -30px rgba(0,0,0,.45);
  transform:translateY(20px);transition:transform .5s cubic-bezier(.2,.7,.2,1);
}
.qm-backdrop.open .qm{transform:none}
.qm-close{
  position:absolute;top:16px;right:18px;width:36px;height:36px;border-radius:50%;
  background:transparent;border:1px solid var(--line-on-cream);font-size:24px;line-height:1;color:var(--ink);
  display:flex;align-items:center;justify-content:center;
}
.qm-close:hover{background:rgba(23,22,21,.08)}
.qm-head h3{
  font-family:"Cormorant Garamond",serif;font-weight:500;font-size:30px;line-height:1.15;color:var(--ink);margin:14px 0 8px;
}
.qm-head h3 em{font-style:italic;color:var(--mustard-deep)}
.qm-head p{font-family:"Jost",sans-serif;font-size:14px;color:var(--ink-faint);margin-bottom:24px}

.qm-progress{display:flex;gap:6px;margin-bottom:28px}
.qm-progress span{flex:1;height:3px;background:rgba(23,22,21,.1);border-radius:2px;transition:.3s ease}
.qm-progress span.on{background:var(--ink)}

.qm-step{display:none}
.qm-step.on{display:block}
.qm-step label{
  font-family:"Jost",sans-serif;font-size:11.5px;letter-spacing:.32em;text-transform:uppercase;
  color:var(--mustard-deep);font-weight:500;margin-bottom:6px;display:block;
}
.qm-step h4{
  font-family:"Cormorant Garamond",serif;font-weight:500;font-size:24px;line-height:1.2;color:var(--ink);margin-bottom:22px;
}
.qm-step h4 em{font-style:italic;color:var(--mustard-deep)}
.qm-step input[type=text],.qm-step input[type=tel]{
  width:100%;border:0;border-bottom:1.5px solid var(--ink);background:transparent;
  padding:12px 4px;font-family:"Jost",sans-serif;font-size:18px;color:var(--ink);
  outline:none;transition:border-color .25s ease;
}
.qm-step input.err{border-bottom-color:#b04a2f}
.qm-step input::placeholder{color:rgba(23,22,21,.32)}
.qm-step input:focus{border-bottom-color:var(--mustard-deep)}
.qm-err{font-family:"Jost",sans-serif;font-size:12.5px;color:#b04a2f;margin-top:8px;min-height:16px}

.qm-options{display:flex;flex-direction:column;gap:10px}
.qm-opt{
  display:flex;align-items:center;gap:14px;
  border:1.2px solid var(--line-on-cream);
  padding:14px 18px;cursor:pointer;
  font-family:"Jost",sans-serif;font-size:15px;color:var(--ink);
  transition:.25s ease;
}
.qm-opt:hover{border-color:var(--mustard-deep);background:#f2e8d6}
.qm-opt .bul{width:14px;height:14px;border-radius:50%;border:1.5px solid var(--ink);flex-shrink:0;position:relative}
.qm-opt.selected{border-color:var(--ink);background:#efe5d0}
.qm-opt.selected .bul{background:var(--ink);box-shadow:inset 0 0 0 3px #efe5d0}

.qm-foot{
  display:flex;align-items:center;justify-content:space-between;
  margin-top:28px;padding-top:24px;border-top:1px solid var(--line-on-cream);
}
.qm-btn{
  font-family:"Jost",sans-serif;font-size:13px;letter-spacing:.24em;text-transform:uppercase;font-weight:500;
  padding:14px 26px;cursor:pointer;transition:.25s ease;
}
.qm-btn.sec{color:var(--ink-faint);background:transparent;border:0}
.qm-btn.sec:hover{color:var(--ink)}
.qm-btn.prim{
  background:var(--ink);color:var(--gold-light);border:0;
}
.qm-btn.prim:hover{background:#0d0c0b;color:#fff}
.qm-btn.prim:disabled{opacity:.7;cursor:wait}

.qm-sent{text-align:center;padding:30px 0}
.qm-sent .check{
  width:64px;height:64px;border-radius:50%;background:var(--mustard-deep);color:#fff;
  display:flex;align-items:center;justify-content:center;font-size:36px;margin:0 auto 18px;
}
.qm-sent h3{
  font-family:"Cormorant Garamond",serif;font-weight:500;font-size:28px;color:var(--ink);margin-bottom:8px;
}
.qm-sent p{font-family:"Jost",sans-serif;font-size:15px;color:var(--ink-soft);margin-bottom:24px}

@media(max-width:520px){
  .qm{padding:30px 22px}
  .qm-head h3{font-size:24px}
  .qm-step h4{font-size:20px}
}

/* ============================================================
   FLOATING WHATSAPP CTA — sempre visível, mobile e desktop
   ============================================================ */
.wa-float{
  position:fixed;
  right:22px;bottom:22px;
  z-index:60;
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 22px 14px 18px;
  background:#25d366;
  color:#fff;
  border:0;
  border-radius:999px;
  font-family:"Jost",sans-serif;
  font-size:13.5px;letter-spacing:.22em;text-transform:uppercase;font-weight:600;
  box-shadow:0 18px 40px -14px rgba(37,211,102,.55), 0 0 0 6px rgba(37,211,102,.18);
  cursor:pointer;
  transition:transform .25s ease, box-shadow .25s ease, background .25s ease;
  animation:waBobble 4.5s ease-in-out infinite;
}
.wa-float:hover{
  background:#1fbd5b;
  transform:translateY(-3px);
  box-shadow:0 24px 50px -14px rgba(37,211,102,.7), 0 0 0 8px rgba(37,211,102,.22);
}
.wa-float-icn{
  width:32px;height:32px;border-radius:50%;
  background:rgba(255,255,255,.25);
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
}
.wa-float-txt{white-space:nowrap}
@keyframes waBobble{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-4px)}
}
@media(max-width:520px){
  .wa-float{
    right:14px;bottom:14px;
    padding:12px 18px 12px 14px;
    font-size:12px;letter-spacing:.18em;
  }
  .wa-float-icn{width:28px;height:28px}
  .wa-float-icn svg{width:18px;height:18px}
}

/* ============================================================
   MOBILE: tipo do hero/headlines respira melhor em telas pequenas
   ============================================================ */
@media(max-width:520px){
  .hero{padding:48px 0 60px}
  .hero-copy h1{font-size:64px;line-height:1.0;margin:22px 0 28px}
  .hero p.lead{font-size:17px}
  .merece-h{font-size:56px;line-height:1.04}
  .galeria-h,.clientes-h{font-size:54px;line-height:1.04}
  .solucao-h{font-size:54px;line-height:1.04}
  .final-h{font-size:48px;line-height:1.06}
  .big-serif{font-size:44px;line-height:1.06}
  .metodo-h{font-size:58px;line-height:1.0;display:block}
  .metodo-h .hand{display:block;margin-bottom:.12em}
  .metodo-h em{display:block}
}
@media(max-width:400px){
  .hero-copy h1{font-size:54px}
  .merece-h,.galeria-h,.clientes-h,.solucao-h{font-size:46px}
  .final-h{font-size:42px}
  .metodo-h{font-size:50px}
}

/* ============================================================
   MÉTODO (8 etapas, fundo cream, cards brancos)
   ============================================================ */
.metodo{
  background:var(--cream);
  padding:120px 0 140px;
  position:relative;
}
.metodo-head{
  max-width:1280px;margin:0 auto 64px;
  display:flex;flex-direction:column;gap:24px;
}
.metodo-head .section-eyebrow{color:var(--mustard-deep)}
.metodo-head .eyebrow-rule{background:var(--mustard-deep);opacity:.6}
.metodo-h{
  font-family:"Cormorant Garamond",serif;font-weight:500;
  font-size:clamp(52px, 8vw, 132px);
  line-height:.96;
  color:var(--ink);
  letter-spacing:-.018em;
  display:flex;flex-wrap:wrap;align-items:baseline;
  gap:.28em;
}
.metodo-h em{font-style:italic;color:var(--ink);font-weight:500}
.metodo-h .hand{
  font-family:"Shadows Into Light Two",cursive;
  font-style:normal;font-weight:400;
  color:var(--mustard-deep);
  font-size:1em;line-height:1;
}
.hl-band.cream::before{
  background:#e8dcc1;opacity:1;
}

/* Method accordion — white cards, gold accents, light gap */
.metodo-acc{
  border-top:0;
  display:flex;flex-direction:column;gap:14px;
  max-width:1280px;margin:0 auto;
}
.metodo-acc .acc-item{
  background:#fff;
  border:1px solid rgba(184,148,82,.16);
  border-left:3px solid var(--mustard-deep);
  transition:box-shadow .25s ease, transform .25s ease;
}
.metodo-acc .acc-item:hover{
  box-shadow:0 18px 40px -22px rgba(23,22,21,.18);
  transform:translateY(-1px);
}
.metodo-acc .acc-head{
  padding:28px 32px;
  grid-template-columns:80px 1fr 46px;
  border-top:0;
}
.metodo-acc .acc-num{
  font-family:"Cormorant Garamond",serif;font-style:italic;font-weight:400;
  font-size:28px;color:var(--mustard-deep);
}
.metodo-acc .acc-title{
  font-family:"Cormorant Garamond",serif;font-weight:500;
  font-size:clamp(20px, 1.9vw, 26px);
  line-height:1.25;color:var(--ink);
  letter-spacing:-.003em;
}
.metodo-acc .acc-plus{display:none}
.metodo-acc .acc-head{cursor:default;grid-template-columns:80px 1fr}
.metodo-acc .acc-body{display:none}

@media(max-width:640px){
  .metodo{padding:80px 0 100px}
  .metodo-h{font-size:48px}
  .metodo-acc .acc-head{grid-template-columns:54px 1fr;gap:14px;padding:22px 18px}
  .metodo-acc .acc-num{font-size:20px}
  .metodo-acc .acc-title{font-size:17px;line-height:1.25}
}
