
/* ═══════════════════════════════════════════
   DESIGN TOKENS (importados do Design System BDG)
   ═══════════════════════════════════════════ */
:root{
  /* Gold Scale */
  --gold-50:#FBF6E6; --gold-100:#F6ECCC; --gold-200:#ECD89A; --gold-300:#E3C467;
  --gold-400:#DAB035; --gold-500:#D2A01E; --gold-600:#B8850E; --gold-700:#8F6714;
  --gold-800:#5F4509; --gold-900:#382805;

  /* Sand (warm neutrals) */
  --sand-50:#FDFBF7; --sand-100:#FAF7F2; --sand-200:#F1EEE7; --sand-300:#E4DED1;
  --sand-400:#D4CFC2; --sand-500:#B5AE9E;

  /* Ink */
  --ink-50:#F5F5F5; --ink-100:#E5E5E5; --ink-200:#D4D4D4; --ink-300:#A3A3A3;
  --ink-600:#525252; --ink-700:#3A3A3A; --ink-800:#262626; --ink-900:#1A1A1A;

  /* Tricolor França */
  --fr-blue:#0055A4; --fr-white:#FFFFFF; --fr-red:#EF4135;

  /* Semantic */
  --bg:#FFFFFF;
  --surface:#FFFFFF;
  --border:rgba(26,26,26,.08);
  --text-primary:var(--ink-900);
  --text-muted:var(--ink-600);
  --text-soft:var(--ink-300);

  /* Spacing */
  --s-1:4px; --s-2:8px; --s-3:12px; --s-4:16px; --s-5:24px; --s-6:32px;
  --s-8:48px; --s-10:64px; --s-12:96px; --s-16:128px;

  /* Typography */
  --font-display:'Space Grotesk',system-ui,sans-serif;
  --font-ui:'Archivo',system-ui,sans-serif;
  --font-accent:'Playfair Display',Georgia,serif;

  /* Radius */
  --r-sm:8px; --r-md:12px; --r-pill:999px;

  /* Shadows */
  --shadow-sm:0 1px 3px rgba(26,26,26,.06);
  --shadow-md:0 4px 16px rgba(26,26,26,.08);
  --shadow-lg:0 12px 40px rgba(26,26,26,.12);

  /* Easing */
  --ease-spring:cubic-bezier(.16,1,.3,1);
  --ease-out-expo:cubic-bezier(.19,1,.22,1);
  --ease-fabric:cubic-bezier(.76,0,.24,1);

  /* Container */
  --container:1240px;
}

/* ═══════════════════════════════════════════
   RESET
   ═══════════════════════════════════════════ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--font-ui);
  font-size:16px;
  line-height:1.6;
  color:var(--text-primary);
  background:var(--bg);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
button{font-family:inherit;cursor:pointer;border:none;background:none}
a{color:inherit;text-decoration:none}

:focus{outline:none}
:focus-visible{outline:2px solid var(--gold-600);outline-offset:3px;border-radius:4px}

.skip-link{position:absolute;top:-40px;left:12px;background:var(--ink-900);color:#fff;padding:10px 16px;border-radius:0 0 8px 8px;font-size:.78rem;font-weight:600;z-index:9999;transition:top .2s}
.skip-link:focus{top:0}

@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms !important;transition-duration:.01ms !important;scroll-behavior:auto !important}
}

.container{max-width:var(--container);margin:0 auto;padding:0 20px}
@media(min-width:768px){.container{padding:0 40px}}
.container-wide{max-width:1320px}
@media(min-width:1440px){.container-wide{max-width:1400px}}

/* ═══════════════════════════════════════════
   BDG LOGO OFICIAL
   ═══════════════════════════════════════════ */
.bdg-logo{
  display:inline-block;
  background:url("_source/ds-assets/bdg-logo-oficial.png") center/contain no-repeat;
  vertical-align:middle;text-indent:-9999px;overflow:hidden;font-size:0;line-height:0;
  width:80px;height:auto;aspect-ratio:1/1;
}
.bdg-logo.xs{width:40px}
.bdg-logo.sm{width:56px}
.bdg-logo.lg{width:120px}
.bdg-logo.xl{width:200px}
.bdg-logo.white{filter:brightness(0) invert(1)}

/* ═══════════════════════════════════════════
   HEADER (upgrade v2)
   ═══════════════════════════════════════════ */
.site-header{
  position:fixed;
  top:0;left:0;right:0;
  z-index:100;
  background:linear-gradient(180deg,rgba(246,236,204,.75) 0%,rgba(250,247,242,.85) 100%);
  backdrop-filter:blur(16px) saturate(160%);
  -webkit-backdrop-filter:blur(16px) saturate(160%);
  border-bottom:1px solid rgba(210,160,30,.18);
  transition:all .4s var(--ease-spring);
}
.site-header::after{
  content:"";
  position:absolute;
  bottom:0;left:0;right:0;
  height:2px;
  background:linear-gradient(90deg,var(--fr-blue) 0%,var(--fr-blue) 33.33%,#fff 33.33%,#fff 66.66%,var(--fr-red) 66.66%,var(--fr-red) 100%);
  opacity:.5;
  transition:opacity .4s;
}
.site-header::before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg,rgba(251,246,230,.4) 0%,rgba(250,247,242,0) 100%);
  pointer-events:none;
  opacity:1;
  transition:opacity .4s;
}
.site-header.scrolled{
  background:linear-gradient(180deg,rgba(246,236,204,.92) 0%,rgba(250,247,242,.96) 100%);
  border-bottom-color:var(--border);
  box-shadow:0 1px 24px rgba(26,26,26,.05);
}
.site-header.scrolled::before{opacity:0}

.header-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
  height:118px;
  transition:height .4s var(--ease-spring);
  position:relative;
}
.site-header.scrolled .header-inner{height:84px}

/* Brand */
.header-brand{
  display:flex;
  align-items:center;
  gap:10px;
  transition:transform .3s var(--ease-spring);
}
.header-brand:hover{transform:translateY(-1px)}
.header-logo{
  width:110px;
  height:80px;
  aspect-ratio:auto;
  
  
  
  transition:width .4s var(--ease-spring),height .4s var(--ease-spring),filter .3s ease;
  object-fit:contain;object-position:left center;
}
.site-header.scrolled .header-logo{width:82px;height:60px}
.header-brand:hover .header-logo{filter:brightness(.85) contrast(1.4) saturate(1.6) drop-shadow(0 3px 8px rgba(26,26,26,.2))}
.header-brand-text{display:flex;flex-direction:column;line-height:1}
.header-brand-name{
  font-family:var(--font-display);
  font-size:.92rem;
  font-weight:800;
  letter-spacing:-.015em;
  color:var(--ink-900);
  text-transform:lowercase;
}
.header-brand-tag{
  font-family:var(--font-ui);
  font-size:.58rem;
  font-weight:700;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--gold-700);
}

/* Nav */
.header-nav{
  display:none;
  align-items:center;
  gap:38px;
}
@media(min-width:980px){.header-nav{display:flex}}

.nav-link{
  font-family:var(--font-ui);
  font-size:.95rem;
  font-weight:500;
  color:var(--ink-700);
  position:relative;
  padding:8px 0;
  transition:color .25s var(--ease-spring);
}
.nav-link::after{
  content:"";
  position:absolute;
  left:0;right:0;bottom:2px;
  height:1.5px;
  background:var(--gold-500);
  transform:scaleX(0);
  transform-origin:left;
  transition:transform .4s var(--ease-out-expo);
}
.nav-link:hover{color:var(--ink-900)}
.nav-link:hover::after{transform:scaleX(1)}
.nav-link.active{color:var(--gold-700);font-weight:600}
.nav-link.active::after{transform:scaleX(1);background:var(--gold-600);height:2px}

/* CTA */
.header-actions{display:flex;align-items:center;gap:10px}

.header-cta{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:11px 22px;
  background:linear-gradient(135deg,#25D366 0%,#128C7E 100%);
  color:#fff;
  font-family:var(--font-ui);
  font-size:.82rem;
  font-weight:700;
  letter-spacing:.01em;
  border-radius:var(--r-pill);
  transition:all .3s var(--ease-spring);
  position:relative;
  overflow:hidden;
  box-shadow:0 2px 12px rgba(37,211,102,.3),inset 0 1px 0 rgba(255,255,255,.2);
}
.header-cta::before{
  content:"";
  position:absolute;
  top:0;bottom:0;left:-60%;
  width:50%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.25),transparent);
  transform:skewX(-20deg);
  transition:left .7s var(--ease-out-expo);
}
.header-cta:hover::before{left:120%}
.header-cta:hover{
  background:linear-gradient(135deg,#2BE370 0%,#16A589 100%);
  transform:translateY(-1px);
  box-shadow:0 8px 24px rgba(37,211,102,.4),inset 0 1px 0 rgba(255,255,255,.25);
}
.header-cta svg{width:16px;height:16px;flex-shrink:0}
.cta-text-full{display:none}
.cta-text-short{display:inline}
@media(min-width:560px){
  .cta-text-full{display:inline}
  .cta-text-short{display:none}
}

/* Mobile trigger */
.header-menu-btn{
  display:flex;
  align-items:center;
  justify-content:center;
  width:42px;height:42px;
  color:var(--ink-900);
  cursor:pointer;
  border-radius:10px;
  transition:all .2s;
}
.header-menu-btn:hover{background:rgba(26,26,26,.06)}
.header-menu-btn:active{transform:scale(.95)}
.header-menu-btn svg{width:22px;height:22px}
@media(min-width:980px){.header-menu-btn{display:none}}

/* Tricolor strip (bottom, aparece ao scrollar) */
.tricolor-strip{
  display:flex;
  height:2px;
  width:100%;
  position:absolute;
  bottom:0;left:0;right:0;
  opacity:0;
  transition:opacity .5s;
}
.site-header.scrolled .tricolor-strip{opacity:.6}
.tricolor-strip > div{flex:1}

/* ═══════════════════════════════════════════
   MOBILE MENU
   ═══════════════════════════════════════════ */
.mobile-menu-backdrop{
  position:fixed;inset:0;
  background:rgba(26,26,26,.5);
  backdrop-filter:blur(6px);
  z-index:105;
  opacity:0;
  pointer-events:none;
  transition:opacity .35s;
}
.mobile-menu-backdrop.open{opacity:1;pointer-events:auto}

.mobile-menu{
  position:fixed;
  top:0;right:0;bottom:0;
  width:min(340px,86vw);
  background:var(--sand-50);
  box-shadow:-24px 0 64px rgba(26,26,26,.15);
  z-index:110;
  transform:translateX(100%);
  transition:transform .45s var(--ease-spring);
  display:flex;
  flex-direction:column;
}
.mobile-menu.open{transform:translateX(0)}

.mobile-menu-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:22px 24px;
  border-bottom:1px solid var(--border);
}
.mobile-menu-close{
  width:38px;height:38px;
  display:flex;align-items:center;justify-content:center;
  border-radius:10px;
  color:var(--ink-900);
  transition:all .2s;
}
.mobile-menu-close:hover{background:rgba(26,26,26,.06)}
.mobile-menu-close svg{width:20px;height:20px}

.mobile-menu-nav{
  display:flex;
  flex-direction:column;
  padding:20px 14px;
  flex:1;
  gap:2px;
}
.mobile-menu-link{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:18px 16px;
  font-family:var(--font-display);
  font-size:1.15rem;
  font-weight:600;
  color:var(--ink-800);
  border-radius:12px;
  transition:all .25s var(--ease-spring);
  position:relative;
}
.mobile-menu-link::before{
  content:"";
  position:absolute;
  left:0;top:50%;transform:translateY(-50%);
  width:3px;height:0;
  background:var(--gold-500);
  border-radius:0 2px 2px 0;
  transition:height .3s var(--ease-spring);
}
.mobile-menu-link:hover{background:var(--gold-50);color:var(--gold-800);padding-left:22px}
.mobile-menu-link:hover::before{height:50%}
.mobile-menu-link svg{width:16px;height:16px;color:var(--text-soft);transition:all .2s}
.mobile-menu-link:hover svg{transform:translateX(4px);color:var(--gold-700)}

.mobile-menu-foot{
  padding:24px;
  border-top:1px solid var(--border);
  display:flex;
  flex-direction:column;
  gap:14px;
}
.mobile-menu-cta{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding:15px 20px;
  background:linear-gradient(135deg,#25D366 0%,#128C7E 100%);
  color:#fff;
  font-family:var(--font-ui);
  font-size:.9rem;
  font-weight:700;
  border-radius:var(--r-pill);
  transition:all .25s;
  box-shadow:0 4px 16px rgba(37,211,102,.35),inset 0 1px 0 rgba(255,255,255,.2);
}
.mobile-menu-cta svg{width:18px;height:18px}
.mobile-menu-cta:hover{background:linear-gradient(135deg,#2BE370 0%,#16A589 100%);transform:translateY(-1px)}
.mobile-menu-tricolor{display:flex;height:3px;border-radius:2px;overflow:hidden}
.mobile-menu-tricolor > div{flex:1}

/* ═══════════════════════════════════════════
   HERO SECTION
   ═══════════════════════════════════════════ */
.hero{
  position:relative;
  min-height:auto;
  padding:152px 0 48px;
  overflow:hidden;
  background:linear-gradient(180deg,#FFFFFF 0%,#FAFAFA 100%);
}
@media(min-width:560px){.hero{min-height:100vh;padding:110px 0 60px}}
@media(min-width:768px){
  .hero{padding:140px 0 100px}
}

/* Background orbs — estilo Design System (mais vibrantes) */
.hero-bg-orb{
  position:absolute;
  border-radius:50%;
  filter:blur(90px);
  pointer-events:none;
  z-index:0;
}
.hero-bg-orb.o1{
  width:520px;height:520px;
  background:rgba(210,160,30,.18);
  top:-15%;right:-8%;
  animation:floatA 12s ease-in-out infinite;
}
.hero-bg-orb.o2{
  width:380px;height:380px;
  background:rgba(0,85,164,.08);
  bottom:-10%;left:-5%;
  animation:floatB 15s ease-in-out infinite;
}
.hero-bg-orb.o3{
  width:260px;height:260px;
  background:rgba(239,65,53,.06);
  top:30%;left:50%;
  animation:floatC 10s ease-in-out infinite;
}
@keyframes floatA{0%,100%{transform:translate(0,0)}50%{transform:translate(-20px,30px)}}
@keyframes floatB{0%,100%{transform:translate(0,0)}50%{transform:translate(25px,-20px)}}
@keyframes floatC{0%,100%{transform:translate(-50%,0)}50%{transform:translate(calc(-50% + 15px),25px)}}

/* Grid overlay — estilo Design System (gold tint) */
.hero-grid{
  position:absolute;
  inset:0;
  z-index:0;
  background-image:
    linear-gradient(rgba(210,160,30,.06) 1px,transparent 1px),
    linear-gradient(90deg,rgba(210,160,30,.06) 1px,transparent 1px);
  background-size:60px 60px;
  pointer-events:none;
  mask-image:radial-gradient(ellipse 80% 60% at 50% 40%,black 20%,transparent 75%);
  -webkit-mask-image:radial-gradient(ellipse 80% 60% at 50% 40%,black 20%,transparent 75%);
}

.hero-inner{
  position:relative;
  z-index:2;
  display:grid;
  gap:32px;
  align-items:center;
}
@media(min-width:980px){
  .hero-inner{grid-template-columns:minmax(0,1.15fr) minmax(0,1fr);gap:60px;min-height:72vh}
}

/* Hero text */
.hero-headline{
  font-family:var(--font-display);
  font-size:clamp(2.2rem,5.2vw,4.2rem);
  font-weight:700;
  line-height:.98;
  letter-spacing:-.025em;
  color:var(--ink-900);
  margin-bottom:24px;
  opacity:0;
  transform:translateY(20px);
  animation:heroFadeUp 1.1s var(--ease-spring) .35s forwards;
}
.hero-headline .accent{
  color:var(--ink-900);
  position:relative;
  display:inline-block;
  white-space:nowrap;
}
.hero-headline .accent::after{
  content:"";
  position:absolute;
  left:0;right:0;bottom:.06em;
  height:10px;
  background:var(--gold-300);
  opacity:.55;
  z-index:-1;
  transform:scaleX(0);
  transform-origin:left;
  animation:headlineUnderline 1.2s var(--ease-out-expo) 1.2s forwards;
}
@keyframes headlineUnderline{to{transform:scaleX(1)}}
@keyframes heroFadeUp{to{opacity:1;transform:translateY(0)}}

.hero-sub{
  font-size:clamp(1rem,1.6vw,1.18rem);
  line-height:1.6;
  color:var(--text-muted);
  max-width:520px;
  margin-bottom:40px;
  opacity:0;
  transform:translateY(16px);
  animation:heroFadeUp 1s var(--ease-spring) .5s forwards;
}
.hero-sub strong{color:var(--ink-900);font-weight:600}

/* CTA cluster */
.hero-ctas{
  display:flex;
  gap:14px;
  flex-wrap:wrap;
  margin-bottom:32px;
  opacity:0;
  transform:translateY(16px);
  animation:heroFadeUp 1s var(--ease-spring) .65s forwards;
}
.btn{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:16px 28px;
  font-family:var(--font-ui);
  font-size:.82rem;
  font-weight:600;
  letter-spacing:.03em;
  border-radius:var(--r-pill);
  transition:all .3s var(--ease-spring);
  position:relative;
  overflow:hidden;
  border:1.5px solid transparent;
  cursor:pointer;
}
.btn svg{width:16px;height:16px;flex-shrink:0}
.btn-wa,.btn-wa-outline{padding:14px 24px;gap:10px}
.btn-wa svg,.btn-wa-outline svg{width:20px;height:20px}
/* WhatsApp buttons — verde oficial */
.btn-wa{
  background:linear-gradient(135deg,#25D366 0%,#128C7E 100%);
  color:#fff;
  box-shadow:0 4px 18px rgba(37,211,102,.35),inset 0 1px 0 rgba(255,255,255,.2);
  border-color:transparent;
}
.btn-wa::before{
  content:"";
  position:absolute;
  top:0;bottom:0;left:-60%;
  width:50%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.28),transparent);
  transform:skewX(-20deg);
  transition:left .8s var(--ease-out-expo);
}
.btn-wa:hover::before{left:120%}
.btn-wa:hover{
  background:linear-gradient(135deg,#2BE370 0%,#16A589 100%);
  transform:translateY(-2px);
  box-shadow:0 10px 32px rgba(37,211,102,.45),inset 0 1px 0 rgba(255,255,255,.25);
}
.btn-wa{font-size:.88rem;font-weight:700;letter-spacing:.02em}

.btn-wa-outline{
  background:#fff;
  color:#128C7E;
  border-color:#25D366;
}
.btn-wa-outline:hover{
  background:#F0FDF4;
  border-color:#128C7E;
  color:#075E54;
  transform:translateY(-2px);
  box-shadow:0 6px 22px rgba(37,211,102,.22);
}
.btn-wa-outline{font-size:.88rem;font-weight:700;letter-spacing:.02em}

/* Trust marks */
.hero-trust{
  display:flex;
  align-items:center;
  gap:28px;
  flex-wrap:wrap;
  border-top:1px solid var(--border);
  padding-top:22px;
  opacity:0;
  transform:translateY(16px);
  animation:heroFadeUp 1s var(--ease-spring) .85s forwards;
}
.hero-trust-item{
  display:flex;
  flex-direction:column;
  gap:2px;
  padding-right:28px;
  border-right:1px solid var(--border);
}
.hero-trust-item:last-child{border-right:none;padding-right:0}
.hero-trust-item strong{
  font-family:var(--font-display);
  font-size:1.1rem;
  font-weight:700;
  letter-spacing:-.01em;
  color:var(--ink-900);
  line-height:1;
}
.hero-trust-item span{
  font-family:var(--font-ui);
  font-size:.68rem;
  font-weight:500;
  color:var(--ink-600);
  letter-spacing:.02em;
}
@media(max-width:560px){
  .hero-trust{gap:18px}
  .hero-trust-item{padding-right:18px}
  .hero-trust-item strong{font-size:.98rem}
  .hero-trust-item span{font-size:.62rem}
}

/* Hero visual — composição estilo Design System (card único + mini-cards) */
.hero-visual{
  position:relative;
  display:flex;
  align-items:center;
  justify-content:center;
  animation:fadeUp 1.2s var(--ease-spring) .4s both;
}
@keyframes fadeUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}

/* Card principal — foto com carrossel */
.hero-photo-card{
  position:relative;
  width:100%;aspect-ratio:3/4;
  flex-shrink:0;
  background:var(--surface);
  border-radius:var(--r-md);
  box-shadow:0 24px 60px rgba(26,26,26,.18),0 8px 24px rgba(26,26,26,.1);
  overflow:hidden;
  transition:transform .5s var(--ease-spring);
}
/* Mini-cards só em desktop */
.hero-mini-card{display:none}
@media(min-width:980px){
  .hero-visual{min-height:480px}
  .hero-photo-card{width:340px;aspect-ratio:4/5;transform:rotate(-2deg)}
  .hero-photo-card:hover{transform:rotate(0deg) scale(1.02)}
  .hero-mini-card{display:flex}
}
.hero-photo-card::before{
  content:"";
  position:absolute;top:0;left:0;right:0;height:8px;
  background:linear-gradient(90deg,var(--fr-blue) 0%,var(--fr-blue) 33.33%,#fff 33.33%,#fff 66.66%,var(--fr-red) 66.66%,var(--fr-red) 100%);
  z-index:3;
}
.hero-photo-card-tag{
  position:absolute;
  bottom:16px;left:16px;right:16px;
  z-index:4;
  display:flex;justify-content:space-between;align-items:flex-end;
  padding:12px 14px;
  background:rgba(26,26,26,.78);
  backdrop-filter:blur(10px);
  border-radius:var(--r-sm);
}
.hero-photo-card-label{
  font-size:.58rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;
  color:rgba(255,255,255,.7);
}
.hero-photo-card-value{
  font-family:var(--font-display);font-size:.92rem;font-weight:700;color:#fff;
}

/* Mini-cards flutuantes */
.hero-mini-card{
  position:absolute;
  background:var(--surface);
  border-radius:var(--r-md);
  padding:10px 14px;
  box-shadow:0 8px 24px rgba(26,26,26,.12),0 2px 6px rgba(26,26,26,.06);
  font-family:var(--font-ui);
  font-size:.72rem;font-weight:600;
  display:flex;align-items:center;gap:8px;
  z-index:5;
  white-space:nowrap;
}
.hero-mini-card-1{
  top:8%;left:-6%;
  color:var(--fr-blue);
  --r:-4deg;
  transform:rotate(var(--r));
  animation:miniFloat 4s ease-in-out infinite;
}
.hero-mini-card-2{
  bottom:14%;right:-8%;
  color:var(--gold-700);
  --r:3deg;
  transform:rotate(var(--r));
  animation:miniFloat 5s ease-in-out infinite .8s;
}
.hero-mini-card svg{width:14px;height:14px;flex-shrink:0}
@keyframes miniFloat{
  0%,100%{transform:translateY(0) rotate(var(--r))}
  50%{transform:translateY(-8px) rotate(var(--r))}
}

/* Carrossel dentro da foto principal */
.hero-carousel{
  position:relative;
  width:100%;height:100%;
  overflow:hidden;
}
.hero-carousel-slide{
  position:absolute;
  top:0;left:0;
  width:100%;height:100%;
  opacity:0;
  transition:opacity 1.1s var(--ease-fabric);
  pointer-events:none;
}
.hero-carousel-slide.active{opacity:1;pointer-events:auto;z-index:1}
.hero-carousel-slide img{
  width:100%;height:100%;
  object-fit:cover;
  display:block;
}
.hero-carousel-slide.active img{
  animation:kenBurns 6s ease-out forwards;
}
@keyframes kenBurns{
  from{transform:scale(1.06)}
  to{transform:scale(1)}
}

/* Dots indicator */
.hero-carousel-dots{
  position:absolute;
  bottom:16px;left:50%;
  transform:translateX(-50%);
  display:flex;gap:7px;
  z-index:4;
  padding:6px 10px;
  background:rgba(26,26,26,.55);
  backdrop-filter:blur(8px);
  border-radius:var(--r-pill);
}
.hero-carousel-dot{
  width:22px;height:3px;
  background:rgba(255,255,255,.35);
  border-radius:2px;
  cursor:pointer;
  padding:0;
  position:relative;
  overflow:hidden;
  transition:background .3s;
}
.hero-carousel-dot.active{background:rgba(255,255,255,.15)}
.hero-carousel-dot.active::after{
  content:"";
  position:absolute;
  inset:0;
  background:var(--gold-400);
  transform:scaleX(0);
  transform-origin:left;
  animation:dotFill 4.5s linear forwards;
}
@keyframes dotFill{to{transform:scaleX(1)}}

@media (prefers-reduced-motion:reduce){
  .hero-photo-card,.hero-mini-card{animation:none !important}
}

/* Scroll indicator */
.hero-scroll{
  position:absolute;
  left:50%;transform:translateX(-50%);
  bottom:24px;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:8px;
  color:var(--text-soft);
  font-family:var(--font-ui);
  font-size:.6rem;
  font-weight:600;
  letter-spacing:.16em;
  text-transform:uppercase;
  animation:scrollBounce 2.5s ease-in-out infinite;
  z-index:2;
  opacity:0;
  animation:heroFadeUp 1s var(--ease-spring) 1.2s forwards,scrollBounce 2.5s ease-in-out 2s infinite;
}
.hero-scroll svg{width:14px;height:14px}
@keyframes scrollBounce{0%,100%{transform:translate(-50%,0)}50%{transform:translate(-50%,6px)}}
@media(max-width:767px){.hero-scroll{display:none !important}}

/* ═══════════════════════════════════════════
   PAGE SPACING
   ═══════════════════════════════════════════ */
main{padding-top:0}
.hero{padding-top:120px}

/* Placeholder section */
/* ═══════════════════════════════════════════
   SOBRE — Editorial split com paper grain
   ═══════════════════════════════════════════ */
.about{
  position:relative;
  padding:120px 0 140px;
  background:linear-gradient(180deg,#fff 0%,var(--sand-100) 40%,var(--sand-100) 100%);
  overflow:hidden;
}
.about::before{
  content:"";
  position:absolute;
  inset:0;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2'/><feColorMatrix values='0 0 0 0 .1 0 0 0 0 .08 0 0 0 0 .05 0 0 0 .35 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
  opacity:.4;
  mix-blend-mode:multiply;
  pointer-events:none;
}
.about::after{
  content:"";
  position:absolute;
  top:0;left:0;right:0;
  height:1px;
  background:linear-gradient(90deg,transparent 0%,var(--fr-blue) 20%,var(--fr-blue) 40%,var(--fr-white) 40%,var(--fr-white) 60%,var(--fr-red) 60%,var(--fr-red) 80%,transparent 100%);
  opacity:.45;
}

.about-inner{
  position:relative;
  z-index:2;
  display:grid;
  grid-template-columns:1fr;
  gap:60px;
}
@media(min-width:900px){
  .about-inner{grid-template-columns:minmax(0,1.1fr) minmax(0,1fr);gap:80px;align-items:start}
}

.about-headline{
  font-family:var(--font-display);
  font-size:clamp(2rem,4.2vw,3.4rem);
  font-weight:700;
  line-height:1.08;
  letter-spacing:-.02em;
  color:var(--ink-900);
  margin-bottom:28px;
  max-width:18ch;
}
.about-headline em{
  font-family:var(--font-accent);
  font-style:italic;
  font-weight:500;
  color:var(--gold-600);
}

.about-body{
  font-family:var(--font-ui);
  font-size:1.05rem;
  line-height:1.9;
  color:var(--ink-700);
  max-width:60ch;
  text-wrap:pretty;
}
.about-body p{margin-bottom:1.4em}
.about-body p:last-child{margin-bottom:0}
.about-body strong{color:var(--ink-900);font-weight:600}

/* Stack de benefícios do grupo VIP */
.about-stack{
  display:flex;
  flex-direction:column;
  gap:14px;
}
.about-benefit{
  position:relative;
  padding:24px 26px;
  background:#fff;
  border:1px solid var(--border);
  border-radius:var(--r-md);
  display:grid;
  grid-template-columns:auto 1fr;
  gap:20px;
  align-items:start;
  transition:all .4s var(--ease-spring);
  box-shadow:var(--shadow-sm);
}
.about-benefit::before{
  content:"";
  position:absolute;
  left:0;top:0;bottom:0;
  width:3px;
  background:var(--gold-500);
  transform:scaleY(0);
  transform-origin:top;
  transition:transform .5s var(--ease-spring);
}
.about-benefit:hover{
  transform:translateX(4px);
  box-shadow:var(--shadow-md);
  border-color:var(--gold-300);
}
.about-benefit:hover::before{transform:scaleY(1)}
.about-benefit:hover .about-benefit-icon{
  background:var(--gold-500);
  color:#fff;
  border-color:var(--gold-500);
}
.about-benefit-icon{
  width:48px;height:48px;
  border-radius:10px;
  background:var(--sand-50);
  border:1px solid var(--gold-200);
  display:flex;
  align-items:center;
  justify-content:center;
  color:var(--gold-700);
  transition:all .4s var(--ease-spring);
  flex-shrink:0;
}
.about-benefit-icon svg{width:22px;height:22px}
.about-benefit-body{
  display:flex;
  flex-direction:column;
  gap:6px;
  padding-top:2px;
}
.about-benefit-title{
  font-family:var(--font-display);
  font-size:1.08rem;
  font-weight:700;
  letter-spacing:-.005em;
  color:var(--ink-900);
  line-height:1.2;
}
.about-benefit-desc{
  font-family:var(--font-ui);
  font-size:.92rem;
  line-height:1.5;
  color:var(--ink-700);
  font-weight:400;
}

/* ═══════════════════════════════════════════
   COMO FUNCIONA — 3 passos
   ═══════════════════════════════════════════ */
.how{
  position:relative;
  padding:110px 0 120px;
  background:var(--sand-50);
  overflow:hidden;
}
.how::before{
  content:"";
  position:absolute;
  top:0;left:0;right:0;
  height:1px;
  background:linear-gradient(90deg,transparent 0%,var(--border) 50%,transparent 100%);
}

.how-head{
  text-align:center;
  max-width:640px;
  margin:0 auto 72px;
}
.how-title{
  font-family:var(--font-display);
  font-size:clamp(1.8rem,3.6vw,2.8rem);
  font-weight:700;
  line-height:1.15;
  letter-spacing:-.02em;
  color:var(--ink-900);
  margin-bottom:14px;
}
.how-title em{
  font-family:var(--font-accent);
  font-style:italic;
  font-weight:500;
  color:var(--gold-600);
}
.how-sub{
  font-family:var(--font-ui);
  font-size:1.02rem;
  line-height:1.6;
  color:var(--ink-600);
  max-width:48ch;
  margin:0 auto;
}

.how-steps{
  display:flex;
  flex-direction:column;
  gap:0;
  position:relative;
  max-width:520px;
  margin:0 auto;
}
/* Linha conectora vertical mobile */
.how-steps::before{
  content:"";
  position:absolute;
  top:52px;bottom:52px;
  left:39px;
  width:2px;
  background:linear-gradient(180deg,var(--gold-300) 0%,var(--gold-500) 50%,var(--gold-300) 100%);
  z-index:0;
}
@media(min-width:860px){
  .how-steps{
    flex-direction:row;
    max-width:none;
    gap:0;
  }
  .how-steps::before{
    top:39px;bottom:auto;
    left:16.66%;right:16.66%;
    width:auto;height:2px;
    background:linear-gradient(90deg,var(--gold-300) 0%,var(--gold-500) 50%,var(--gold-300) 100%);
  }
}

.how-step{
  position:relative;
  z-index:1;
  display:flex;
  flex-direction:row;
  align-items:flex-start;
  gap:20px;
  padding:20px 0;
}
@media(min-width:860px){
  .how-step{
    flex:1;
    flex-direction:column;
    align-items:center;
    text-align:center;
    padding:0 28px;
    gap:0;
  }
}

.how-step-num{
  width:80px;height:80px;
  min-width:80px;
  border-radius:50%;
  background:#fff;
  border:2px solid var(--gold-400);
  display:flex;
  align-items:center;
  justify-content:center;
  font-family:var(--font-display);
  font-size:1.6rem;
  font-weight:800;
  color:var(--gold-700);
  box-shadow:0 4px 24px rgba(210,160,30,.15);
  transition:all .5s var(--ease-spring);
  position:relative;
}
@media(min-width:860px){
  .how-step-num{margin-bottom:24px}
}
.how-step-num::before{
  content:"";
  position:absolute;
  inset:-6px;
  border-radius:50%;
  border:1px solid var(--gold-300);
  opacity:0;
  transition:all .4s var(--ease-spring);
}
.how-step:hover .how-step-num{
  background:var(--gold-500);
  color:#fff;
  border-color:var(--gold-500);
  transform:scale(1.06);
}
.how-step:hover .how-step-num::before{
  opacity:1;
  inset:-10px;
}

.how-step-icon{
  position:absolute;
  top:-8px;right:-8px;
  width:28px;height:28px;
  border-radius:50%;
  background:var(--ink-900);
  color:#fff;
  display:flex;align-items:center;justify-content:center;
  box-shadow:var(--shadow-sm);
}
.how-step-icon svg{width:14px;height:14px}

.how-step-body{flex:1}

.how-step-title{
  font-family:var(--font-display);
  font-size:1.18rem;
  font-weight:700;
  line-height:1.25;
  color:var(--ink-900);
  margin-bottom:6px;
  letter-spacing:-.01em;
}
.how-step-desc{
  font-family:var(--font-ui);
  font-size:.94rem;
  line-height:1.6;
  color:var(--ink-600);
  max-width:none;
}
@media(min-width:860px){
  .how-step-desc{max-width:28ch}
}

/* Mini CTA final da seção */
.how-footer{
  margin-top:68px;
  text-align:center;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:16px;
}
.how-footer-note{
  font-family:var(--font-ui);
  font-size:.84rem;
  color:var(--ink-600);
  max-width:40ch;
  line-height:1.5;
}

/* ═══════════════════════════════════════════
   PROOF STRIP — entre Como Funciona e Lojas
   ═══════════════════════════════════════════ */
.proof-strip{
  background:var(--ink-900);
  padding:28px 0;
  position:relative;
  overflow:hidden;
}
.proof-strip::before{
  content:"";
  position:absolute;
  top:0;left:0;right:0;
  height:2px;
  background:linear-gradient(90deg,var(--fr-blue) 0%,var(--fr-blue) 33.33%,#fff 33.33%,#fff 66.66%,var(--fr-red) 66.66%,var(--fr-red) 100%);
  opacity:.8;
}
.proof-strip-inner{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:18px;
  flex-wrap:wrap;
  text-align:center;
}
.proof-strip-stars{
  display:flex;
  align-items:center;
  gap:3px;
  color:var(--gold-400);
}
.proof-strip-stars svg{width:16px;height:16px;fill:currentColor}
.proof-strip-text{
  font-family:var(--font-display);
  font-size:clamp(.95rem,2vw,1.15rem);
  font-weight:600;
  color:#fff;
  letter-spacing:-.005em;
  line-height:1.4;
}
.proof-strip-text strong{color:var(--gold-400);font-weight:800}
.proof-strip-text span{
  display:block;
  font-family:var(--font-ui);
  font-size:.66rem;
  font-weight:500;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--sand-400);
  margin-top:4px;
}
@media(min-width:700px){
  .proof-strip-text span{display:inline;margin-top:0;margin-left:10px}
}

/* ═══════════════════════════════════════════
   5 LOJAS — mapa + grid de endereços
   ═══════════════════════════════════════════ */
.stores{
  position:relative;
  padding:110px 0 130px;
  background:var(--sand-100);
  overflow:hidden;
}
.stores::before{
  content:"";
  position:absolute;
  inset:0;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2'/><feColorMatrix values='0 0 0 0 .1 0 0 0 0 .08 0 0 0 0 .05 0 0 0 .3 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
  opacity:.35;
  mix-blend-mode:multiply;
  pointer-events:none;
}
.stores-inner{position:relative;z-index:2}

.stores-head{
  text-align:center;
  max-width:620px;
  margin:0 auto 56px;
}
.stores-title{
  font-family:var(--font-display);
  font-size:clamp(1.8rem,3.6vw,2.8rem);
  font-weight:700;
  line-height:1.15;
  letter-spacing:-.02em;
  color:var(--ink-900);
  margin-bottom:14px;
}
.stores-title em{
  font-family:var(--font-accent);
  font-style:italic;
  font-weight:500;
  color:var(--gold-600);
}
.stores-sub{
  font-family:var(--font-ui);
  font-size:1rem;
  line-height:1.6;
  color:var(--ink-600);
}

/* Mapa embed */
.stores-map{
  position:relative;
  width:100%;
  aspect-ratio:16/7;
  max-height:420px;
  border-radius:var(--r-md);
  overflow:hidden;
  box-shadow:0 8px 32px rgba(26,26,26,.08),0 1px 2px rgba(26,26,26,.04);
  border:1px solid var(--border);
  margin-bottom:44px;
  background:var(--sand-200);
}
.stores-map iframe{
  width:100%;
  height:100%;
  border:0;
  display:block;
  filter:saturate(.9) contrast(1.02);
}
@media(max-width:600px){
  .stores-map{aspect-ratio:4/5;max-height:520px}
}

/* Grid de lojas */
.stores-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:14px;
}
@media(min-width:680px){
  .stores-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media(min-width:960px){
  .stores-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
}
@media(min-width:1200px){
  .stores-grid{grid-template-columns:repeat(5,minmax(0,1fr));gap:14px}
  .store-card{padding:18px 16px 16px;gap:12px}
  /* Empilha header verticalmente — badge no topo */
  .store-head{flex-direction:column;align-items:flex-start;gap:10px}
  .store-badge{
    order:-1;
    font-size:.5rem;
    letter-spacing:.1em;
    padding:3px 7px;
    max-width:100%;
    overflow:hidden;
    text-overflow:ellipsis;
  }
  .store-name{font-size:1rem;line-height:1.15}
  .store-name small{font-size:.56rem;letter-spacing:.14em;margin-top:3px}
  .store-address{font-size:.78rem;line-height:1.45;gap:6px}
  .store-address svg{width:13px;height:13px;margin-top:1px}
  .store-meta{gap:8px 12px;padding-top:8px;font-size:.7rem}
  .store-rating,.store-phone{font-size:.7rem;gap:5px}
  .store-rating svg,.store-phone svg{width:12px;height:12px}
  .store-actions{flex-direction:column;gap:6px;padding-top:4px}
  .store-btn{padding:8px 10px;font-size:.66rem;gap:5px}
  .store-btn svg{width:12px;height:12px}
}
@media(min-width:1400px){
  .stores-grid{gap:16px}
  .store-card{padding:22px 18px 18px}
  .store-name{font-size:1.08rem}
  .store-badge{font-size:.54rem}
  .store-address{font-size:.82rem}
  .store-btn{padding:9px 12px;font-size:.7rem}
}

.store-card{
  position:relative;
  padding:26px 24px 22px;
  background:#fff;
  border:1px solid var(--border);
  border-radius:var(--r-md);
  display:flex;
  flex-direction:column;
  gap:14px;
  transition:all .4s var(--ease-spring);
  box-shadow:var(--shadow-sm);
  overflow:hidden;
}
.store-card::before{
  content:"";
  position:absolute;
  left:0;top:0;right:0;
  height:3px;
  background:var(--gold-500);
  transform:scaleX(0);
  transform-origin:left;
  transition:transform .5s var(--ease-spring);
}
.store-card:hover{
  transform:translateY(-3px);
  box-shadow:var(--shadow-md);
  border-color:var(--gold-300);
}
.store-card:hover::before{transform:scaleX(1)}

/* Cor da faixa por área */
.store-card[data-area="shopping"]::before{background:var(--fr-blue)}
.store-card[data-area="centro"]::before{background:var(--fr-red)}
.store-card[data-area="fabrica"]::before{background:var(--gold-500)}

.store-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
}
.store-name{
  font-family:var(--font-display);
  font-size:1.15rem;
  font-weight:700;
  letter-spacing:-.005em;
  color:var(--ink-900);
  line-height:1.2;
}
.store-name small{
  display:block;
  font-family:var(--font-ui);
  font-size:.62rem;
  font-weight:600;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--gold-700);
  margin-top:4px;
}
.store-badge{
  flex-shrink:0;
  font-family:var(--font-ui);
  font-size:.58rem;
  font-weight:700;
  letter-spacing:.14em;
  text-transform:uppercase;
  padding:5px 9px;
  border-radius:4px;
  background:var(--sand-50);
  color:var(--ink-700);
  border:1px solid var(--border);
  white-space:nowrap;
}
.store-card[data-area="shopping"] .store-badge{background:rgba(0,85,164,.08);color:var(--fr-blue);border-color:rgba(0,85,164,.2)}
.store-card[data-area="centro"] .store-badge{background:rgba(239,65,53,.08);color:var(--fr-red);border-color:rgba(239,65,53,.2)}
.store-card[data-area="fabrica"] .store-badge{background:var(--gold-50);color:var(--gold-700);border-color:var(--gold-200)}

.store-address{
  font-family:var(--font-ui);
  font-size:.88rem;
  line-height:1.5;
  color:var(--ink-700);
  display:flex;
  gap:8px;
  align-items:flex-start;
}
.store-address svg{
  width:16px;height:16px;
  flex-shrink:0;
  color:var(--gold-600);
  margin-top:2px;
}

.store-meta{
  display:flex;
  align-items:center;
  gap:14px;
  flex-wrap:wrap;
  padding-top:10px;
  border-top:1px dashed var(--border);
}
.store-rating{
  display:flex;
  align-items:center;
  gap:6px;
  font-family:var(--font-ui);
  font-size:.78rem;
  color:var(--ink-700);
}
.store-rating svg{
  width:14px;height:14px;
  color:var(--gold-500);
  fill:var(--gold-500);
}
.store-rating strong{color:var(--ink-900);font-weight:700}
.store-phone{
  display:flex;
  align-items:center;
  gap:6px;
  font-family:var(--font-ui);
  font-size:.78rem;
  color:var(--ink-700);
  text-decoration:none;
  transition:color .25s;
}
.store-phone:hover{color:var(--gold-700)}
.store-phone svg{width:14px;height:14px;color:var(--gold-600)}

.store-actions{
  display:flex;
  gap:8px;
  margin-top:auto;
  padding-top:6px;
}
.store-btn{
  flex:1;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:6px;
  padding:10px 12px;
  font-family:var(--font-ui);
  font-size:.74rem;
  font-weight:600;
  letter-spacing:.02em;
  border-radius:var(--r-sm);
  transition:all .25s var(--ease-spring);
  border:1.5px solid transparent;
  cursor:pointer;
  text-align:center;
}
.store-btn svg{width:14px;height:14px;flex-shrink:0}
.store-btn-map{
  background:var(--ink-900);
  color:#fff;
}
.store-btn-map:hover{background:var(--ink-800);transform:translateY(-1px)}
.store-btn-wa{
  background:#fff;
  color:#128C7E;
  border-color:#25D366;
}
.store-btn-wa:hover{background:#F0FDF4;border-color:#128C7E;color:#075E54;transform:translateY(-1px)}

/* ═══════════════════════════════════════════
   DEPOIMENTOS — mix de vídeo + prints + texto
   ═══════════════════════════════════════════ */
.testimonials{
  position:relative;
  padding:110px 0 130px;
  background:#fff;
  overflow:hidden;
}
.testimonials::before{
  content:"";
  position:absolute;
  top:0;left:0;right:0;
  height:1px;
  background:linear-gradient(90deg,transparent 0%,var(--border) 50%,transparent 100%);
}

.testimonials-head{
  text-align:center;
  max-width:640px;
  margin:0 auto 64px;
}
.testimonials-title{
  font-family:var(--font-display);
  font-size:clamp(1.8rem,3.6vw,2.8rem);
  font-weight:700;
  line-height:1.15;
  letter-spacing:-.02em;
  color:var(--ink-900);
  margin-bottom:14px;
}
.testimonials-title em{
  font-family:var(--font-accent);
  font-style:italic;
  font-weight:500;
  color:var(--gold-600);
}
.testimonials-sub{
  font-family:var(--font-ui);
  font-size:1rem;
  line-height:1.6;
  color:var(--ink-600);
}

.testimonials-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:20px;
}
@media(min-width:720px){
  .testimonials-grid{
    grid-template-columns:repeat(3,minmax(0,1fr));
    grid-auto-rows:minmax(0,auto);
  }
  .testimonial-video{grid-column:span 2}
  .testimonial-print{grid-row:span 2}
}

.testimonial-card{
  position:relative;
  border-radius:var(--r-md);
  overflow:hidden;
  transition:all .4s var(--ease-spring);
  box-shadow:var(--shadow-sm);
  border:1px solid var(--border);
}
.testimonial-card:hover{
  transform:translateY(-3px);
  box-shadow:var(--shadow-md);
}

/* Vídeo featured */
.testimonial-video{
  aspect-ratio:16/9;
  background:linear-gradient(135deg,var(--ink-900) 0%,var(--ink-800) 50%,#1f1f1f 100%);
  display:flex;
  align-items:flex-end;
  justify-content:flex-start;
  padding:24px 28px;
  cursor:pointer;
  color:#fff;
}
.testimonial-video::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(circle at 70% 40%,rgba(210,160,30,.18) 0%,transparent 50%),
    radial-gradient(circle at 20% 80%,rgba(0,85,164,.12) 0%,transparent 50%);
  pointer-events:none;
}
.testimonial-video::after{
  content:"";
  position:absolute;
  inset:0;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='4' height='4'><circle cx='1' cy='1' r='.5' fill='%23ffffff' opacity='.08'/></svg>");
  pointer-events:none;
}
.testimonial-video-play{
  position:absolute;
  top:50%;left:50%;
  transform:translate(-50%,-50%);
  width:80px;height:80px;
  border-radius:50%;
  background:rgba(255,255,255,.95);
  display:flex;
  align-items:center;
  justify-content:center;
  transition:all .4s var(--ease-spring);
  box-shadow:0 8px 32px rgba(0,0,0,.35),inset 0 1px 0 rgba(255,255,255,.8);
}
.testimonial-video-play::before{
  content:"";
  position:absolute;
  inset:-8px;
  border-radius:50%;
  border:2px solid rgba(210,160,30,.5);
  animation:ringPulse 2.2s ease-out infinite;
}
@keyframes ringPulse{
  0%{transform:scale(.85);opacity:.8}
  100%{transform:scale(1.4);opacity:0}
}
.testimonial-video-play svg{
  width:28px;height:28px;
  color:var(--ink-900);
  margin-left:4px;
  fill:currentColor;
}
.testimonial-video:hover .testimonial-video-play{
  transform:translate(-50%,-50%) scale(1.08);
  background:var(--gold-400);
}
.testimonial-video:hover .testimonial-video-play svg{color:var(--ink-900)}

.testimonial-video-meta{
  position:relative;
  z-index:2;
  display:flex;
  flex-direction:column;
  gap:6px;
}
.testimonial-video-badge{
  display:inline-flex;
  align-items:center;
  gap:6px;
  font-family:var(--font-ui);
  font-size:.58rem;
  font-weight:700;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--gold-400);
  width:fit-content;
}
.testimonial-video-badge::before{
  content:"";
  width:6px;height:6px;
  border-radius:50%;
  background:var(--gold-400);
  box-shadow:0 0 8px var(--gold-400);
  animation:dotBlink 1.6s ease-in-out infinite;
}
@keyframes dotBlink{
  0%,100%{opacity:1}
  50%{opacity:.3}
}
.testimonial-video-name{
  font-family:var(--font-display);
  font-size:1.1rem;
  font-weight:700;
  color:#fff;
  letter-spacing:-.005em;
}
.testimonial-video-name small{
  display:block;
  font-family:var(--font-ui);
  font-size:.72rem;
  font-weight:400;
  color:var(--sand-400);
  margin-top:2px;
  letter-spacing:.02em;
}

/* Print WhatsApp */
.testimonial-print{
  background:linear-gradient(180deg,#ECE5DD 0%,#D4CEC4 100%);
  display:flex;
  align-items:center;
  justify-content:center;
  position:relative;
  min-height:360px;
  padding:20px;
}
.testimonial-print::before{
  content:"";
  position:absolute;
  inset:0;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='60' height='60' viewBox='0 0 60 60'><path d='M0 30 Q15 15 30 30 T60 30 M0 45 Q15 30 30 45 T60 45 M0 15 Q15 0 30 15 T60 15' stroke='%23ffffff' stroke-width='.3' fill='none' opacity='.4'/></svg>");
  opacity:.4;
  pointer-events:none;
}
.testimonial-print-placeholder{
  position:relative;
  z-index:2;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:14px;
  text-align:center;
  padding:24px 20px;
  background:rgba(255,255,255,.88);
  border-radius:var(--r-sm);
  border:1.5px dashed rgba(18,140,126,.4);
  max-width:240px;
}
.testimonial-print-icon{
  width:52px;height:52px;
  border-radius:50%;
  background:linear-gradient(135deg,#25D366 0%,#128C7E 100%);
  display:flex;
  align-items:center;
  justify-content:center;
  color:#fff;
  box-shadow:0 4px 16px rgba(37,211,102,.35);
}
.testimonial-print-icon svg{width:26px;height:26px}
.testimonial-print-label{
  font-family:var(--font-ui);
  font-size:.62rem;
  font-weight:700;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:#128C7E;
}
.testimonial-print-name{
  font-family:var(--font-display);
  font-size:.98rem;
  font-weight:700;
  color:var(--ink-900);
  line-height:1.3;
}
.testimonial-print-note{
  font-family:var(--font-ui);
  font-size:.72rem;
  color:var(--ink-600);
  line-height:1.5;
  font-style:italic;
}

/* Quote cards */
.testimonial-quote{
  background:var(--sand-50);
  padding:28px 26px 24px;
  display:flex;
  flex-direction:column;
  gap:14px;
  position:relative;
}
.testimonial-quote::before{
  content:"\201C";
  position:absolute;
  top:-6px;
  right:22px;
  font-family:var(--font-accent);
  font-size:5rem;
  line-height:1;
  color:var(--gold-300);
  opacity:.6;
}
.testimonial-quote-stars{
  display:flex;
  align-items:center;
  gap:2px;
  color:var(--gold-500);
}
.testimonial-quote-stars svg{width:13px;height:13px;fill:currentColor}

.testimonial-quote-text{
  font-family:var(--font-display);
  font-size:.98rem;
  line-height:1.55;
  color:var(--ink-800);
  font-weight:500;
  letter-spacing:-.005em;
  flex:1;
}

.testimonial-quote-author{
  display:flex;
  align-items:center;
  gap:12px;
  padding-top:14px;
  border-top:1px solid var(--border);
}
.testimonial-quote-avatar{
  width:36px;height:36px;
  border-radius:50%;
  background:linear-gradient(135deg,var(--gold-300) 0%,var(--gold-600) 100%);
  display:flex;
  align-items:center;
  justify-content:center;
  font-family:var(--font-display);
  font-size:.92rem;
  font-weight:700;
  color:#fff;
  flex-shrink:0;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.2);
}
.testimonial-quote-info{
  display:flex;
  flex-direction:column;
  line-height:1.2;
}
.testimonial-quote-name{
  font-family:var(--font-ui);
  font-size:.82rem;
  font-weight:700;
  color:var(--ink-900);
}
.testimonial-quote-meta{
  font-family:var(--font-ui);
  font-size:.66rem;
  color:var(--ink-600);
  letter-spacing:.02em;
  margin-top:2px;
}

/* ═══════════════════════════════════════════
   CTA FINAL — dark + tricolor + último empurrão
   ═══════════════════════════════════════════ */
.cta-final{
  position:relative;
  padding:120px 0 130px;
  background:linear-gradient(180deg,var(--ink-900) 0%,#0E0E0E 100%);
  overflow:hidden;
  color:#fff;
}
.cta-final::before{
  content:"";
  position:absolute;
  top:0;left:0;right:0;
  height:3px;
  background:linear-gradient(90deg,var(--fr-blue) 0%,var(--fr-blue) 33.33%,#fff 33.33%,#fff 66.66%,var(--fr-red) 66.66%,var(--fr-red) 100%);
}
.cta-final::after{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(circle at 20% 30%,rgba(210,160,30,.12) 0%,transparent 50%),
    radial-gradient(circle at 85% 70%,rgba(210,160,30,.08) 0%,transparent 50%);
  pointer-events:none;
}

.cta-final-inner{
  position:relative;
  z-index:2;
  text-align:center;
  max-width:720px;
  margin:0 auto;
}

.cta-final-eyebrow{
  display:inline-flex;
  align-items:center;
  gap:10px;
  font-family:var(--font-ui);
  font-size:.62rem;
  font-weight:700;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--gold-400);
  margin-bottom:24px;
}
.cta-final-eyebrow::before,
.cta-final-eyebrow::after{
  content:"";
  width:32px;height:1px;
  background:var(--gold-500);
}

.cta-final-headline{
  font-family:var(--font-display);
  font-size:clamp(2rem,4.8vw,3.6rem);
  font-weight:700;
  line-height:1.1;
  letter-spacing:-.02em;
  color:#fff;
  margin-bottom:18px;
}
.cta-final-headline em{
  font-family:var(--font-accent);
  font-style:italic;
  font-weight:500;
  background:linear-gradient(135deg,var(--gold-300) 0%,var(--gold-500) 50%,var(--gold-400) 100%);
  -webkit-background-clip:text;
  background-clip:text;
  -webkit-text-fill-color:transparent;
}

.cta-final-sub{
  font-family:var(--font-ui);
  font-size:1.02rem;
  line-height:1.6;
  color:var(--sand-400);
  margin-bottom:40px;
  max-width:52ch;
  margin-left:auto;
  margin-right:auto;
}
.cta-final-sub strong{color:#fff;font-weight:600}

.cta-final-actions{
  display:flex;
  gap:12px;
  justify-content:center;
  flex-wrap:wrap;
  margin-bottom:30px;
}

.cta-final-btn{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:16px 28px;
  font-family:var(--font-ui);
  font-size:.9rem;
  font-weight:700;
  letter-spacing:.02em;
  border-radius:var(--r-pill);
  transition:all .3s var(--ease-spring);
  border:1.5px solid transparent;
  cursor:pointer;
  position:relative;
  overflow:hidden;
}
.cta-final-btn svg{width:20px;height:20px;flex-shrink:0}
.cta-final-btn-primary{
  background:linear-gradient(135deg,#25D366 0%,#128C7E 100%);
  color:#fff;
  box-shadow:0 6px 28px rgba(37,211,102,.42),inset 0 1px 0 rgba(255,255,255,.25);
}
.cta-final-btn-primary::before{
  content:"";
  position:absolute;
  top:0;bottom:0;left:-60%;
  width:50%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.35),transparent);
  transform:skewX(-20deg);
  transition:left .9s var(--ease-out-expo);
}
.cta-final-btn-primary:hover::before{left:120%}
.cta-final-btn-primary:hover{
  transform:translateY(-2px);
  background:linear-gradient(135deg,#2BE370 0%,#16A589 100%);
  box-shadow:0 12px 40px rgba(37,211,102,.55),inset 0 1px 0 rgba(255,255,255,.3);
}
.cta-final-btn-ghost{
  background:transparent;
  color:#fff;
  border-color:rgba(255,255,255,.25);
}
.cta-final-btn-ghost:hover{
  background:rgba(255,255,255,.08);
  border-color:#25D366;
  color:#25D366;
  transform:translateY(-2px);
}

.cta-final-note{
  font-family:var(--font-ui);
  font-size:.74rem;
  color:var(--ink-300);
  display:inline-flex;
  align-items:center;
  gap:8px;
}
.cta-final-note svg{width:14px;height:14px;color:#25D366}

/* ═══════════════════════════════════════════
   FOOTER
   ═══════════════════════════════════════════ */
.site-footer{
  position:relative;
  background:#0A0A0A;
  color:#fff;
  padding:72px 0 0;
  border-top:1px solid rgba(255,255,255,.05);
}
.site-footer::before{
  content:"";
  position:absolute;
  top:0;left:0;right:0;
  height:1px;
  background:linear-gradient(90deg,transparent 0%,rgba(210,160,30,.4) 50%,transparent 100%);
}

.footer-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:40px;
  padding-bottom:56px;
}
@media(min-width:680px){
  .footer-grid{grid-template-columns:1.3fr 1fr 1fr;gap:48px}
}
@media(min-width:960px){
  .footer-grid{grid-template-columns:1.4fr 1fr 1fr 1.1fr;gap:60px}
}

.footer-col-title{
  font-family:var(--font-ui);
  font-size:.6rem;
  font-weight:700;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--gold-400);
  margin-bottom:18px;
  display:inline-flex;
  align-items:center;
  gap:10px;
}
.footer-col-title::before{
  content:"";
  width:20px;height:1px;
  background:var(--gold-500);
}

/* Brand column */
.footer-brand-logo{
  width:120px;
  height:88px;
  /* logo via img tag now */
  filter:brightness(1.1) contrast(1.1) saturate(1.3);
  margin-bottom:20px;
}
.footer-brand-tag{
  font-family:var(--font-display);
  font-size:1.08rem;
  font-weight:600;
  line-height:1.4;
  color:#fff;
  margin-bottom:16px;
  max-width:28ch;
}
.footer-brand-tag em{
  font-family:var(--font-accent);
  font-style:italic;
  font-weight:500;
  color:var(--gold-400);
}
.footer-brand-desc{
  font-family:var(--font-ui);
  font-size:.86rem;
  line-height:1.6;
  color:var(--ink-300);
  max-width:36ch;
}

/* Links columns */
.footer-list{
  list-style:none;
  display:flex;
  flex-direction:column;
  gap:11px;
}
.footer-list a{
  font-family:var(--font-ui);
  font-size:.88rem;
  color:var(--sand-400);
  transition:all .25s;
  display:flex;
  flex-wrap:wrap;
  align-items:baseline;
  gap:0 8px;
  padding:2px 0;
  position:relative;
}
.footer-list a::before{
  content:"";
  width:0;height:1px;
  background:var(--gold-400);
  transition:width .3s var(--ease-spring);
  flex-basis:0;
}
.footer-list a:hover{color:var(--gold-400)}
.footer-list a:hover::before{width:12px}
.footer-list a small{
  display:block;
  width:100%;
  font-size:.66rem;
  color:var(--ink-300);
  margin-top:2px;
  font-weight:400;
}

/* Contact column */
.footer-contact-item{
  display:flex;
  align-items:flex-start;
  gap:12px;
  margin-bottom:14px;
  font-family:var(--font-ui);
  font-size:.86rem;
  color:var(--sand-400);
  transition:color .25s;
}
.footer-contact-item svg{
  width:16px;height:16px;
  flex-shrink:0;
  color:var(--gold-400);
  margin-top:2px;
}
.footer-contact-item:hover{color:#fff}
.footer-contact-item strong{color:#fff;font-weight:600;display:block;font-size:.82rem}
.footer-contact-item small{display:block;font-size:.72rem;color:var(--ink-300);margin-top:2px}

.footer-socials{
  display:flex;
  gap:8px;
  margin-top:18px;
}
.footer-social{
  width:36px;height:36px;
  border-radius:50%;
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.1);
  display:flex;
  align-items:center;
  justify-content:center;
  color:#fff;
  transition:all .3s var(--ease-spring);
}
.footer-social svg{width:16px;height:16px}
.footer-social:hover{
  background:var(--gold-500);
  border-color:var(--gold-500);
  color:var(--ink-900);
  transform:translateY(-2px);
}

/* Bottom bar */
.footer-bottom{
  position:relative;
  border-top:1px solid rgba(255,255,255,.08);
  padding:22px 0 28px;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:20px;
  flex-wrap:wrap;
}
.footer-bottom::before{
  content:"";
  position:absolute;
  top:-1px;left:50%;transform:translateX(-50%);
  width:220px;height:1px;
  background:linear-gradient(90deg,transparent 0%,var(--fr-blue) 25%,#fff 50%,var(--fr-red) 75%,transparent 100%);
  opacity:.5;
}
.footer-copy{
  font-family:var(--font-ui);
  font-size:.72rem;
  color:var(--ink-300);
}
.footer-copy strong{color:#fff;font-weight:600}
.footer-pertise{
  font-family:var(--font-ui);
  font-size:.82rem;
  color:var(--sand-400);
  display:inline-flex;
  align-items:center;
  gap:6px;
  transition:all .3s var(--ease-spring);
  padding:10px 20px;
  border:1px solid rgba(255,255,255,.1);
  border-radius:var(--r-pill);
  letter-spacing:.02em;
}
.footer-pertise:hover{color:#fff;border-color:var(--gold-500);background:rgba(210,160,30,.1)}
.footer-pertise strong{color:var(--gold-400);font-weight:800;letter-spacing:.04em;font-size:.88rem}

/* ═══════════════════════════════════════════
   CATEGORIAS — 4 estilos que a BDG veste
   ═══════════════════════════════════════════ */
.categories{
  position:relative;
  padding:80px 0 90px;
  background:#fff;
  overflow:hidden;
}
.categories::before{
  content:"";
  position:absolute;
  top:0;left:0;right:0;
  height:1px;
  background:linear-gradient(90deg,transparent 0%,var(--border) 50%,transparent 100%);
}

.categories-head{
  text-align:center;
  margin-bottom:44px;
}
.categories-eyebrow{
  display:inline-flex;
  align-items:center;
  gap:10px;
  font-family:var(--font-ui);
  font-size:.6rem;
  font-weight:700;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--gold-700);
  margin-bottom:14px;
}
.categories-eyebrow::before,
.categories-eyebrow::after{
  content:"";
  width:24px;height:1px;
  background:var(--gold-600);
}
.categories-title{
  font-family:var(--font-display);
  font-size:clamp(1.6rem,3vw,2.2rem);
  font-weight:700;
  line-height:1.2;
  letter-spacing:-.015em;
  color:var(--ink-900);
}
.categories-title em{
  font-family:var(--font-accent);
  font-style:italic;
  font-weight:500;
  color:var(--gold-600);
}

.categories-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:14px;
}
@media(min-width:720px){
  .categories-grid{grid-template-columns:repeat(4,minmax(0,1fr))}
}

.category-card{
  position:relative;
  padding:28px 22px 26px;
  background:var(--sand-50);
  border:1px solid var(--border);
  border-radius:var(--r-md);
  transition:all .4s var(--ease-spring);
  overflow:hidden;
  cursor:pointer;
  display:flex;
  flex-direction:column;
  gap:12px;
  text-align:left;
}
.category-card::before{
  content:"";
  position:absolute;
  left:0;top:0;bottom:0;
  width:3px;
  background:var(--gold-500);
  transform:scaleY(0);
  transform-origin:bottom;
  transition:transform .5s var(--ease-spring);
}
.category-card:hover{
  background:#fff;
  border-color:var(--gold-300);
  transform:translateY(-4px);
  box-shadow:var(--shadow-md);
}
.category-card:hover::before{transform:scaleY(1)}
.category-card:hover .category-icon{background:var(--gold-500);color:#fff;border-color:var(--gold-500)}

.category-card[data-accent="blue"]::before{background:var(--fr-blue)}
.category-card[data-accent="red"]::before{background:var(--fr-red)}

.category-icon{
  width:42px;height:42px;
  border-radius:10px;
  background:#fff;
  border:1px solid var(--gold-200);
  display:flex;
  align-items:center;
  justify-content:center;
  color:var(--gold-700);
  transition:all .4s var(--ease-spring);
  flex-shrink:0;
}
.category-icon svg{width:20px;height:20px}

.category-name{
  font-family:var(--font-display);
  font-size:1.08rem;
  font-weight:700;
  letter-spacing:-.005em;
  color:var(--ink-900);
  line-height:1.2;
}
.category-desc{
  font-family:var(--font-ui);
  font-size:.8rem;
  line-height:1.5;
  color:var(--ink-600);
  font-weight:400;
}
.category-arrow{
  display:inline-flex;
  align-items:center;
  gap:6px;
  margin-top:auto;
  padding-top:8px;
  font-family:var(--font-ui);
  font-size:.68rem;
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--gold-700);
  transition:all .3s var(--ease-spring);
}
.category-arrow svg{
  width:14px;height:14px;
  transition:transform .3s var(--ease-spring);
}
.category-card:hover .category-arrow{color:var(--gold-800)}
.category-card:hover .category-arrow svg{transform:translateX(4px)}

/* ═══════════════════════════════════════════
   FAQ — accordion
   ═══════════════════════════════════════════ */
.faq{
  position:relative;
  padding:100px 0 110px;
  background:var(--sand-100);
  overflow:hidden;
}
.faq::before{
  content:"";
  position:absolute;
  inset:0;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2'/><feColorMatrix values='0 0 0 0 .1 0 0 0 0 .08 0 0 0 0 .05 0 0 0 .3 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
  opacity:.3;
  mix-blend-mode:multiply;
  pointer-events:none;
}
.faq-inner{position:relative;z-index:2;max-width:780px;margin:0 auto}

.faq-head{text-align:center;margin-bottom:48px}
.faq-eyebrow{
  display:inline-flex;
  align-items:center;
  gap:10px;
  font-family:var(--font-ui);
  font-size:.6rem;
  font-weight:700;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--gold-700);
  margin-bottom:14px;
}
.faq-eyebrow::before,
.faq-eyebrow::after{
  content:"";
  width:24px;height:1px;
  background:var(--gold-600);
}
.faq-title{
  font-family:var(--font-display);
  font-size:clamp(1.8rem,3.4vw,2.6rem);
  font-weight:700;
  line-height:1.15;
  letter-spacing:-.02em;
  color:var(--ink-900);
}
.faq-title em{
  font-family:var(--font-accent);
  font-style:italic;
  font-weight:500;
  color:var(--gold-600);
}

.faq-list{
  display:flex;
  flex-direction:column;
  gap:10px;
}

.faq-item{
  background:#fff;
  border:1px solid var(--border);
  border-radius:var(--r-md);
  overflow:hidden;
  transition:all .4s var(--ease-spring);
  box-shadow:var(--shadow-sm);
}
.faq-item[open]{
  border-color:var(--gold-300);
  box-shadow:var(--shadow-md);
}
.faq-item:hover:not([open]){border-color:var(--gold-200)}

.faq-question{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  padding:20px 24px;
  cursor:pointer;
  list-style:none;
  font-family:var(--font-display);
  font-size:1.02rem;
  font-weight:600;
  color:var(--ink-900);
  letter-spacing:-.005em;
  transition:color .25s;
}
.faq-question::-webkit-details-marker{display:none}
.faq-item:hover .faq-question{color:var(--gold-700)}
.faq-item[open] .faq-question{color:var(--gold-700)}

.faq-icon{
  width:28px;height:28px;
  border-radius:50%;
  background:var(--sand-100);
  display:flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
  transition:all .4s var(--ease-spring);
  color:var(--gold-700);
}
.faq-icon svg{
  width:14px;height:14px;
  transition:transform .4s var(--ease-spring);
}
.faq-item[open] .faq-icon{
  background:var(--gold-500);
  color:#fff;
}
.faq-item[open] .faq-icon svg{transform:rotate(45deg)}

.faq-answer{
  padding:0 24px 22px;
  font-family:var(--font-ui);
  font-size:.94rem;
  line-height:1.65;
  color:var(--ink-700);
  animation:faqOpen .4s var(--ease-spring);
}
@keyframes faqOpen{
  from{opacity:0;transform:translateY(-6px)}
  to{opacity:1;transform:none}
}
.faq-answer p{margin-bottom:10px}
.faq-answer p:last-child{margin-bottom:0}
.faq-answer strong{color:var(--ink-900);font-weight:600}
.faq-answer a{color:var(--gold-700);border-bottom:1px solid var(--gold-300);transition:all .2s}
.faq-answer a:hover{color:var(--gold-800);border-bottom-color:var(--gold-600)}

/* ═══════════════════════════════════════════
   WHATSAPP FAB — botão flutuante
   ═══════════════════════════════════════════ */
.wa-fab{
  position:fixed;
  bottom:24px;right:24px;
  width:60px;height:60px;
  border-radius:50%;
  background:linear-gradient(135deg,#25D366 0%,#128C7E 100%);
  display:flex;
  align-items:center;
  justify-content:center;
  color:#fff;
  box-shadow:0 6px 24px rgba(37,211,102,.45),0 2px 8px rgba(0,0,0,.15),inset 0 1px 0 rgba(255,255,255,.25);
  z-index:90;
  transition:all .35s var(--ease-spring);
  opacity:0;
  transform:translateY(20px) scale(.9);
  pointer-events:none;
}
.wa-fab.visible{
  opacity:1;
  transform:translateY(0) scale(1);
  pointer-events:auto;
}
.wa-fab::before{
  content:"";
  position:absolute;
  inset:-6px;
  border-radius:50%;
  background:rgba(37,211,102,.4);
  z-index:-1;
  animation:fabPulse 2.4s ease-out infinite;
}
@keyframes fabPulse{
  0%{transform:scale(.8);opacity:.7}
  100%{transform:scale(1.5);opacity:0}
}
.wa-fab svg{
  width:30px;height:30px;
  position:relative;
  z-index:2;
}
.wa-fab:hover{
  transform:translateY(-4px) scale(1.05);
  box-shadow:0 14px 36px rgba(37,211,102,.6),0 4px 12px rgba(0,0,0,.2),inset 0 1px 0 rgba(255,255,255,.3);
  background:linear-gradient(135deg,#2BE370 0%,#16A589 100%);
}
.wa-fab-tooltip{
  position:absolute;
  right:calc(100% + 12px);
  top:50%;
  transform:translateY(-50%) translateX(8px);
  background:var(--ink-900);
  color:#fff;
  padding:10px 14px;
  border-radius:8px;
  font-family:var(--font-ui);
  font-size:.78rem;
  font-weight:600;
  white-space:nowrap;
  opacity:0;
  pointer-events:none;
  transition:all .25s var(--ease-spring);
  box-shadow:0 4px 16px rgba(0,0,0,.2);
}
.wa-fab-tooltip::after{
  content:"";
  position:absolute;
  right:-5px;top:50%;
  transform:translateY(-50%) rotate(45deg);
  width:10px;height:10px;
  background:var(--ink-900);
}
.wa-fab:hover .wa-fab-tooltip{
  opacity:1;
  transform:translateY(-50%) translateX(0);
}
@media(max-width:560px){
  .wa-fab{width:54px;height:54px;bottom:18px;right:18px}
  .wa-fab svg{width:26px;height:26px}
  .wa-fab-tooltip{display:none}
}

/* Reveal animations */
.reveal{
  opacity:0;
  transform:translateY(24px);
  transition:opacity .9s var(--ease-spring),transform .9s var(--ease-spring);
}
.reveal.visible{opacity:1;transform:none}
.reveal[data-delay="1"]{transition-delay:.1s}
.reveal[data-delay="2"]{transition-delay:.2s}
.reveal[data-delay="3"]{transition-delay:.3s}
.reveal[data-delay="4"]{transition-delay:.4s}
.reveal[data-delay="5"]{transition-delay:.5s}

/* ═══════════════════════════════════════════
   MOBILE — paddings, fontes e espaçamentos
   ═══════════════════════════════════════════ */
@media(max-width:767px){

  /* ── Paddings globais ── */
  .about{padding:56px 0 60px}
  .categories{padding:48px 0 52px}
  .how{padding:52px 0 56px}
  .stores{padding:52px 0 56px}
  .testimonials{padding:52px 0 56px}
  .faq{padding:48px 0 52px}
  .cta-final{padding:56px 0 60px}
  .site-footer{padding:48px 0 0}

  /* ── Títulos ── */
  .about-headline{font-size:1.7rem;margin-bottom:18px;max-width:none}
  .categories-title{font-size:1.5rem}
  .how-title{font-size:1.5rem;margin-bottom:10px}
  .stores-title{font-size:1.7rem}
  .testimonials-title{font-size:1.5rem;margin-bottom:10px}
  .faq-title{font-size:1.5rem}
  .cta-final-headline{font-size:1.7rem;margin-bottom:14px}

  /* ── Hero trust strip ── */
  .hero-trust{gap:0;justify-content:space-between;width:100%}
  .hero-trust-item{padding-right:0;flex:1;text-align:center;border-right:1px solid var(--border)}
  .hero-trust-item:last-child{border-right:none}
  .hero-trust-item strong{font-size:.88rem}
  .hero-trust-item span{font-size:.58rem}

  /* ── About ── */
  .about-inner{gap:28px}
  .about-headline{font-size:1.5rem;margin-bottom:14px}
  .about-body{font-size:.9rem;line-height:1.65;max-width:none}
  .about-body p{margin-bottom:.8em}
  .about-stack{gap:8px}
  .about-benefit{padding:14px 14px;gap:12px;grid-template-columns:36px 1fr}
  .about-benefit-icon{width:36px;height:36px;border-radius:8px}
  .about-benefit-icon svg{width:16px;height:16px}
  .about-benefit-title{font-size:.9rem}
  .about-benefit-desc{font-size:.8rem;line-height:1.4}

  /* ── Categorias ── */
  .categories-head{margin-bottom:28px}
  .categories-eyebrow{font-size:.55rem;margin-bottom:10px}
  .categories-grid{gap:10px}
  .category-card{padding:20px 16px 18px;gap:10px}
  .category-icon{width:36px;height:36px;border-radius:8px}
  .category-icon svg{width:16px;height:16px}
  .category-name{font-size:.95rem}
  .category-desc{font-size:.76rem;line-height:1.45}
  .category-arrow{font-size:.62rem;padding-top:6px}

  /* ── Como funciona ── */
  .how-head{margin-bottom:36px}
  .how-sub{font-size:.9rem;max-width:none}
  .how-steps{gap:0}
  .how-steps::before{left:27px}
  .how-step{padding:12px 0;gap:16px}
  .how-step-num{width:56px;height:56px;min-width:56px;font-size:1.1rem;border-width:1.5px}
  .how-step-num::before{display:none}
  .how-step-icon{width:20px;height:20px;top:-4px;right:-4px}
  .how-step-icon svg{width:10px;height:10px}
  .how-step-title{font-size:.98rem;margin-bottom:4px}
  .how-step-desc{font-size:.85rem;line-height:1.45;max-width:none}
  .how-footer{margin-top:28px;gap:12px}
  .how-footer-note{font-size:.78rem;max-width:none}

  /* ── Lojas ── */
  .stores-title{font-size:1.5rem;margin-bottom:8px}
  .stores-map{aspect-ratio:4/3;max-height:220px;margin-bottom:18px;border-radius:10px}
  .stores-grid{gap:8px}
  .store-card{padding:14px 12px 12px;gap:8px}
  .store-head{gap:6px}
  .store-name{font-size:.95rem}
  .store-name small{font-size:.52rem;margin-top:2px}
  .store-badge{font-size:.48rem;padding:2px 6px}
  .store-address{font-size:.78rem;line-height:1.4;gap:5px}
  .store-address svg{width:12px;height:12px}
  .store-meta{gap:6px;padding-top:6px}
  .store-rating,.store-phone{font-size:.7rem;gap:4px}
  .store-rating svg,.store-phone svg{width:11px;height:11px}
  .store-actions{gap:5px;padding-top:2px}
  .store-btn{padding:7px 8px;font-size:.66rem;gap:4px}
  .store-btn svg{width:12px;height:12px}

  /* ── Depoimentos ── */
  .testimonials-head{margin-bottom:24px}
  .testimonials-title{font-size:1.4rem;margin-bottom:8px}
  .testimonials-sub{font-size:.85rem}
  .testimonials-grid{gap:10px}
  .testimonial-video{padding:14px 16px;aspect-ratio:16/10}
  .testimonial-video-badge{font-size:.52rem}
  .testimonial-video-title{font-size:.85rem}
  .testimonial-print{min-height:200px;padding:14px}
  .testimonial-print-icon{width:36px;height:36px}
  .testimonial-print-icon svg{width:18px;height:18px}
  .testimonial-print-label{font-size:.52rem}
  .testimonial-print-name{font-size:.82rem}
  .testimonial-print-note{font-size:.66rem}
  .testimonial-quote{padding:16px 14px 14px;gap:8px}
  .testimonial-quote::before{font-size:2.5rem;top:10px;right:12px}
  .testimonial-quote-stars svg{width:11px;height:11px}
  .testimonial-quote-text{font-size:.85rem;line-height:1.45}
  .testimonial-quote-author{gap:8px;padding-top:8px}
  .testimonial-quote-avatar{width:28px;height:28px;font-size:.75rem}
  .testimonial-quote-name{font-size:.74rem}
  .testimonial-quote-meta{font-size:.58rem}

  /* ── FAQ ── */
  .faq-head{margin-bottom:24px}
  .faq-eyebrow{font-size:.5rem;margin-bottom:8px}
  .faq-title{font-size:1.4rem}
  .faq-list{gap:6px}
  .faq-question{padding:14px 14px;font-size:.88rem;gap:10px}
  .faq-icon{width:22px;height:22px}
  .faq-icon svg{width:11px;height:11px}
  .faq-answer{padding:0 14px 14px;font-size:.84rem;line-height:1.5}
  .faq-answer p{margin-bottom:6px}

  /* ── CTA Final ── */
  .cta-final-eyebrow{font-size:.52rem;margin-bottom:14px}
  .cta-final-headline{font-size:1.5rem;margin-bottom:12px}
  .cta-final-sub{font-size:.88rem;margin-bottom:24px;max-width:none}
  .cta-final-actions{gap:8px;margin-bottom:16px}
  .cta-final-btn{padding:12px 20px;font-size:.82rem;gap:8px}
  .cta-final-btn svg{width:18px;height:18px}

  /* ── Footer ── */
  .site-footer{padding:40px 0 0}
  .footer-grid{
    gap:20px;
    padding-bottom:24px;
    grid-template-columns:1fr 1fr;
    grid-template-rows:auto auto auto;
  }
  /* Brand ocupa linha inteira */
  .footer-grid > div:first-child{grid-column:1/-1}
  /* Contato ocupa linha inteira, layout horizontal */
  .footer-grid > div:last-child{grid-column:1/-1;display:flex;flex-wrap:wrap;align-items:flex-start;gap:12px 20px}
  .footer-grid > div:last-child .footer-col-title{width:100%;margin-bottom:0}
  .footer-contact-item{margin-bottom:0;flex:1;min-width:140px}
  .footer-socials{margin-top:0;align-items:center}
  .footer-brand-logo{width:64px;height:48px;margin-bottom:8px}
  .footer-brand-tag{font-size:.86rem;margin-bottom:6px;max-width:none}
  .footer-brand-desc{font-size:.76rem}
  .footer-col-title{font-size:.5rem;margin-bottom:8px}
  .footer-list{gap:5px}
  .footer-list a{font-size:.76rem}
  .footer-list a small{font-size:.56rem;margin-top:1px}
  .footer-contact-item{font-size:.76rem;margin-bottom:6px;gap:7px}
  .footer-contact-item svg{width:13px;height:13px}
  .footer-contact-item strong{font-size:.72rem}
  .footer-contact-item small{font-size:.62rem}
  .footer-socials{margin-top:10px;gap:5px}
  .footer-social{width:28px;height:28px}
  .footer-social svg{width:12px;height:12px}
  .footer-bottom{padding:12px 0 16px;gap:8px;flex-direction:column;align-items:center;text-align:center}
  .footer-copy{font-size:.6rem}
  .footer-pertise{font-size:.58rem;padding:8px 16px}
}

@media(max-width:400px){
  .hero-headline{font-size:1.8rem}
  .about-headline{font-size:1.45rem}
  .categories-title,.how-title,.stores-title,.testimonials-title,.faq-title{font-size:1.3rem}
  .cta-final-headline{font-size:1.4rem}
  .hero-trust-item strong{font-size:.78rem}
  .hero-trust-item span{font-size:.52rem}
  .how-step-num{width:42px;height:42px;font-size:.95rem;margin-bottom:10px}
  .category-card{padding:16px 14px 14px}
  .faq-question{padding:14px 16px;font-size:.86rem}
  .cta-final-btn{padding:12px 18px;font-size:.8rem}
}
/* ═══ MOBILE FIXES (debug 09/abr) ═══ */
@media(max-width:414px){
  /* Header menor */
  .header-inner{height:90px}
  .site-header.scrolled .header-inner{height:68px}
  .header-logo{width:72px;height:52px}
  .site-header.scrolled .header-logo{width:60px;height:44px}
  .header-cta{padding:9px 14px;font-size:.72rem}
  /* Hero trust strip: 3 itens, sem overflow */
  .hero-trust{flex-wrap:wrap;gap:4px 0}
  .hero-trust-item{flex:0 0 33.33%;text-align:center;padding:4px 2px}
  .hero-trust-item strong{font-size:.82rem}
  .hero-trust-item span{font-size:.55rem}
  /* Botões touch target mínimo 44px */
  .store-btn{min-height:44px;padding:10px 12px;font-size:.72rem}
  .footer-social{width:44px;height:44px}
  /* FAB WhatsApp posição segura */
  .wa-fab{bottom:16px;right:16px;width:52px;height:52px}
  .wa-fab svg{width:24px;height:24px}
  /* Font size floor */
  .category-desc{font-size:.78rem}
  .category-arrow{font-size:.65rem}
  .faq-question{padding:16px;font-size:.9rem}
  .faq-answer{padding:0 16px 16px;font-size:.86rem;line-height:1.6}
  /* Hero headline menor em 320px */
  .hero-headline{font-size:clamp(1.8rem,8vw,2.5rem);margin-bottom:16px}
  .hero-sub{font-size:.92rem;margin-bottom:28px}
  .hero{padding:120px 0 40px}
  /* Categories cards */
  .category-card{padding:16px 14px;gap:8px}
  .category-icon{width:34px;height:34px;border-radius:8px}
  .category-icon svg{width:16px;height:16px}
  .category-name{font-size:.88rem}
}
@media(max-width:359px){
  .hero-trust-item{flex:0 0 50%}
  .hero-trust-item:nth-child(3){flex:0 0 100%}
  .hero-headline{font-size:1.6rem}
  .categories-grid{grid-template-columns:1fr}
}
