/* Home Garantia — CSS isolado */
@font-face { font-family:'Gotham'; src:url('/wp-content/uploads/fonts/Gotham-Book.otf')   format('opentype'); font-weight:400;     font-style:normal; font-display:swap; }
  @font-face { font-family:'Gotham'; src:url('/wp-content/uploads/fonts/Gotham-Medium.otf') format('opentype'); font-weight:500 600; font-style:normal; font-display:swap; }
  @font-face { font-family:'Gotham'; src:url('/wp-content/uploads/fonts/Gotham-Bold.otf')   format('opentype'); font-weight:700;     font-style:normal; font-display:swap; }
  @font-face { font-family:'Gotham'; src:url('/wp-content/uploads/fonts/Gotham-Black.otf')  format('opentype'); font-weight:800 900; font-style:normal; font-display:swap; }

#elementor-popup-modal-607 {
        display: none !important;
        visibility: hidden !important;
    }

/* ================================================
   GARANTIA — Nova Home · Protótipo Hi-Fi
   Mobile-first · responsive desktop
   ──────────────────────────────────────────────
   Fontes: Gotham (base) + Arista 2.0 (display)
   Paleta: dark #0A0A0A · light #FAFAFA · red #E60000
================================================ */

@font-face {
  font-family: 'Arista';
  src: url('/wp-content/uploads/fonts/Arista2.0Alternate.ttf') format('truetype');
  font-weight: 400 900;
  font-style: normal;
  font-display: swap;
}

/* ---------- Reset ---------- */
.gz-home,
.gz-home *,
.gz-home *::before,
.gz-home *::after { box-sizing: border-box !important; margin: 0 !important; padding: 0 !important; }
.gz-home { scroll-behavior: smooth !important; }
.gz-home {
  font-family: 'Gotham', system-ui, -apple-system, sans-serif !important;
  font-weight: 400 !important;
  font-size: 16px !important;
  line-height: 1.5 !important;
  background: var(--bg-light) !important;
  color: var(--ink-light) !important;
  -webkit-font-smoothing: antialiased !important;
  -moz-osx-font-smoothing: grayscale !important;
  overflow-x: hidden !important;
}
.gz-home img,
.gz-home svg { display: block !important; max-width: 100% !important; }
.gz-home button { font: inherit !important; cursor: pointer; border: 0 !important; background: 0 !important; color: inherit !important; }
.gz-home a { color: inherit !important; text-decoration: none !important; }

/* Emojis com estética nativa de cada SO (Apple no iPhone/Mac, etc.) */
.gz-home .diff__num,
.gz-home .diff__ico {
  font-family: "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji", sans-serif !important;
}

/* ---------- Tokens ---------- */
.gz-home {
  /* color */
  --bg-dark:       #0A0A0A !important;
  --bg-dark-2:     #141414;
  --bg-light:      #FAFAFA;
  --bg-light-2:    #F2EFE9;
  --ink-light:     #0A0A0A;
  --ink-dark:      #FFFFFF;
  --mute-dark:     rgba(255,255,255,0.82);
  --mute-light:    #6B6B6B;
  --line-dark:     rgba(255,255,255,0.16);
  --line-light:    rgba(0,0,0,0.10);
  --red:           #E60000;
  --red-2:         #C70000;
  --red-soft:      #FFEEEE;

  /* type */
  --f-display:     'Gotham', system-ui, sans-serif !important;
  --f-ui:          'Gotham', system-ui, sans-serif;
  --f-accent:      'Arista', 'Gotham', system-ui, sans-serif;
  --f-mono:        'JetBrains Mono', ui-monospace, monospace;

  /* fluid scale */
  --fs-eyebrow:    11px !important;
  --fs-body:       clamp(15px, 1.6vw, 17px);
  --fs-h3:         clamp(20px, 2.2vw, 26px);
  --fs-h2:         clamp(32px, 5.5vw, 56px);
  --fs-h1:         clamp(40px, 9vw, 92px);

  /* radii */
  --r-sm:          8px !important;
  --r-md:          14px;
  --r-lg:          22px;
  --r-pill:        999px;

  /* spacing */
  --pad-x:         clamp(20px, 5vw, 80px) !important;
  --pad-y:         clamp(56px, 9vw, 120px);
  --container:     1240px;
}

/* ---------- Layout primitives ---------- */
.gz-home .container {
  max-width: var(--container) !important;
  margin-inline: auto !important;
  padding-inline: var(--pad-x) !important;
}

.gz-home section { position: relative !important; }

.gz-home .section-pad { padding-block: var(--pad-y) !important; }

.gz-home .bg-dark { background: var(--bg-dark) !important;   color: var(--ink-dark) !important; }
.gz-home .bg-dark-2 { background: var(--bg-dark-2) !important; color: var(--ink-dark) !important; }
.gz-home .bg-light { background: var(--bg-light) !important;  color: var(--ink-light) !important; }
.gz-home .bg-light-2 { background: var(--bg-light-2) !important;color: var(--ink-light) !important; }
.gz-home .bg-red { background: var(--red) !important;       color: #fff !important; }

/* ---------- Type ---------- */
.gz-home .eyebrow {
  font-family: var(--f-mono) !important;
  font-size: var(--fs-eyebrow) !important;
  letter-spacing: 0.18em !important;
  text-transform: uppercase !important;
  font-weight: 600 !important;
  color: var(--red) !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 10px !important;
}
.gz-home .eyebrow::before {
  content: "";
  display: inline-block !important;
  width: 28px !important;
  height: 1px !important;
  background: currentColor !important;
}
.gz-home .eyebrow--ink { color: inherit !important; opacity: 0.55 !important; }

.gz-home .h1 {
  font-family: var(--f-display) !important;
  font-weight: 900 !important;
  font-size: var(--fs-h1) !important;
  line-height: 0.98 !important;
  letter-spacing: -0.025em !important;
  text-wrap: balance !important;
}
.gz-home .h2 {
  font-family: var(--f-display) !important;
  font-weight: 800 !important;
  font-size: var(--fs-h2) !important;
  line-height: 1.02 !important;
  letter-spacing: -0.02em !important;
  text-wrap: balance !important;
}
.gz-home .h3 {
  font-family: var(--f-ui) !important;
  font-weight: 700 !important;
  font-size: var(--fs-h3) !important;
  line-height: 1.2 !important;
  letter-spacing: -0.015em !important;
}
.gz-home .body {
  font-family: var(--f-ui) !important;
  font-size: var(--fs-body) !important;
  line-height: 1.6 !important;
  color: var(--mute-light) !important;
}
.gz-home .bg-dark .body,
.gz-home .bg-dark-2 .body { color: var(--mute-dark) !important; }

.gz-home .mono {
  font-family: var(--f-mono) !important;
  font-size: var(--fs-eyebrow) !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
  font-weight: 500 !important;
}

/* Nome da marca "Garantia" sempre em Arista 2.0 */
.gz-home .brand {
  font-family: var(--f-accent) !important;
  text-transform: none !important;
  letter-spacing: -0.005em !important;
  font-size: 1.2em !important;
}

.gz-home .accent-red { color: var(--red) !important; }

/* ---------- Buttons ---------- */
.gz-home .btn {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
  padding: 16px 26px !important;
  border-radius: var(--r-pill) !important;
  font-family: var(--f-ui) !important;
  font-weight: 700 !important;
  font-size: 14px !important;
  letter-spacing: 0.02em !important;
  transition: transform .15s, box-shadow .2s, background .2s;
  white-space: nowrap !important;
  position: relative !important;
  overflow: hidden !important;
}
.gz-home .btn--primary {
  background: var(--red) !important;
  color: #fff !important;
  box-shadow: 0 6px 18px rgba(230,0,0,0.32) !important;
}
.gz-home .btn--primary:hover {
  background: var(--red-2) !important;
  transform: translateY(-1px);
  box-shadow: 0 10px 28px rgba(230,0,0,0.42) !important;
}
.gz-home .btn--white {
  background: #fff !important;
  color: var(--ink-light) !important;
}
.gz-home .btn--white:hover {
  background: #fff !important;
  transform: translateY(-1px);
  box-shadow: 0 8px 24px rgba(0,0,0,0.16) !important;
}
.gz-home .btn--ghost {
  background: transparent !important;
  border: 1.5px solid currentColor !important;
  padding: 14px 24px !important;
}
.gz-home .btn--outline-white {
  background: transparent !important;
  border: 1.5px solid rgba(255,255,255,0.5) !important;
  color: #fff !important;
  padding: 10px 18px !important;
  font-size: 13px !important;
  transition: background .2s, border-color .2s;
}
.gz-home .btn--outline-white:hover {
  background: rgba(255,255,255,0.1) !important;
  border-color: rgba(255,255,255,0.8) !important;
}
.gz-home .btn--link {
  padding: 0 !important;
  border-bottom: 1.5px solid currentColor !important;
  border-radius: 0 !important;
  background: 0 !important;
  font-weight: 600 !important;
  font-size: 13px !important;
  letter-spacing: 0.04em !important;
}
.gz-home .btn--block { width: 100% !important; }

/* shine sweep */
.gz-home .btn--primary::after {
  content: "";
  position: absolute !important;
  inset: 0 !important;
  background: linear-gradient(110deg, transparent 30%, rgba(255,255,255,0.18) 50%, transparent 70%) !important;
  transform: translateX(-120%);
  transition: transform .7s ease;
}
.gz-home .btn--primary:hover::after { transform: translateX(120%); }

/* ---------- NAV ---------- */
.gz-home .nav {
  position: fixed !important;
  inset: 0 0 auto !important;
  z-index: 100 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  padding: 14px var(--pad-x) !important;
  background: rgba(10,10,10,0.4) !important;
  backdrop-filter: blur(14px) saturate(140%) !important;
  -webkit-backdrop-filter: blur(14px) saturate(140%) !important;
  color: #fff !important;
  transition: background .25s, padding .25s, border-color .25s, transform .3s ease;
  border-bottom: 1px solid transparent !important;
}
.gz-home .nav.is-hidden {
  transform: translateY(-100%);
}
.gz-home .nav.is-scrolled {
  background: rgba(10,10,10,0.92) !important;
  border-bottom-color: var(--line-dark) !important;
  padding-block: 10px !important;
}

.gz-home .nav__logo {
  display: inline-flex !important;
  align-items: center !important;
  flex-shrink: 0 !important;
  font-family: var(--f-accent) !important;
  font-weight: 900 !important;
  font-size: 22px !important;
  letter-spacing: -0.02em !important;
}
.gz-home .nav__logo span { color: var(--red) !important; }
.gz-home .nav__logo img {
  display: block !important;
  height: 26px !important;
  width: auto !important;
  max-width: none !important;
  object-fit: contain !important;
  flex-shrink: 0 !important;
  /* logo já é branco — sem filtro extra */
}
.gz-home .nav.is-scrolled .nav__logo img { height: 22px !important; transition: height .25s; }
.gz-home .footer__brand-logo img { height: 32px !important; }

.gz-home .nav__links {
  display: none !important;
}
.gz-home .nav__actions {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
}

.gz-home .nav__icon-btn {
  width: 38px !important;
  height: 38px !important;
  border-radius: 50% !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  color: #fff !important;
  border: 1px solid var(--line-dark) !important;
  transition: background .2s, border-color .2s;
}
.gz-home .nav__icon-btn:hover {
  background: rgba(255,255,255,0.06) !important;
  border-color: rgba(255,255,255,0.25) !important;
}
.gz-home .nav__icon-btn svg { width: 16px !important; height: 16px !important; }

/* Selo BACEN — credencial, NÃO botão: sem caixa/borda, ícone dourado em destaque */
.gz-home .nav__seal {
  display: inline-flex !important;
  align-items: center !important;
  gap: 7px !important;
  padding: 0 !important;
  border: 0 !important;
  background: none !important;
  color: #fff !important;
  cursor: default;
  pointer-events: none !important;
}
.gz-home .nav__seal svg {
  width: 25px !important;
  height: 25px !important;
  flex-shrink: 0 !important;
  color: #E3C16A !important;
  filter: drop-shadow(0 0 5px rgba(227,193,106,0.45)) !important;
}
.gz-home .nav__seal-text {
  font-family: var(--f-mono) !important;
  font-size: 8px !important;
  line-height: 1.15 !important;
  letter-spacing: 0.09em !important;
  text-transform: uppercase !important;
  color: rgba(255,255,255,0.72) !important;
  white-space: nowrap !important;
}
.gz-home .nav__seal-text strong {
  color: #E3C16A !important;
  font-weight: 700 !important;
  letter-spacing: 0.12em !important;
}

@media (max-width: 560px) {
  .gz-home .nav__seal-text { display: none !important; }
  .gz-home .nav__seal { padding: 0 !important; gap: 0 !important; }
  .gz-home .nav__seal svg { width: 23px !important; height: 23px !important; }
  .gz-home .nav__actions { gap: 6px !important; }
  .gz-home .nav__logo { flex-shrink: 0 !important; }
  .gz-home .nav__logo img { height: 18px !important; width: auto !important; max-width: none !important; object-fit: contain !important; flex-shrink: 0 !important; }
  .gz-home .nav__actions .nav__portal-btn { font-size: 9.5px !important; padding: 6px 9px !important; letter-spacing: 0 !important; }
  .gz-home .nav__icon-btn { width: 31px !important; height: 31px !important; }
  .gz-home .nav__icon-btn svg { width: 14px !important; height: 14px !important; }
}

.gz-home .nav__cta {
  display: none !important;
}

.gz-home .nav__hamburger {
  width: 38px !important;
  height: 38px !important;
  border-radius: 50% !important;
  border: 1px solid var(--line-dark) !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex-direction: column !important;
  gap: 4px !important;
}
.gz-home .nav__hamburger span {
  display: block !important;
  width: 16px !important;
  height: 1.5px !important;
  background: #fff !important;
  transition: transform .2s, opacity .2s;
}
.gz-home .nav.is-open .nav__hamburger span:nth-child(1) {
  transform: translateY(2.75px) rotate(45deg);
}
.gz-home .nav.is-open .nav__hamburger span:nth-child(2) {
  opacity: 0 !important;
}
.gz-home .nav.is-open .nav__hamburger span:nth-child(3) {
  transform: translateY(-2.75px) rotate(-45deg);
}

.gz-home .nav__drawer {
  position: fixed !important;
  inset: 60px 0 0 !important;
  background: rgba(10,10,10,0.97) !important;
  backdrop-filter: blur(14px) !important;
  padding: 32px var(--pad-x) 48px !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 4px !important;
  opacity: 0 !important;
  pointer-events: none !important;
  transform: translateY(-8px);
  transition: opacity .25s, transform .25s;
  z-index: 99 !important;
}
.gz-home .nav.is-open + .nav__drawer {
  opacity: 1 !important;
  pointer-events: auto !important;
  transform: translateY(0);
}
.gz-home .nav__drawer a {
  display: block !important;
  padding: 14px 0 !important;
  font-family: var(--f-display) !important;
  font-weight: 700 !important;
  font-size: 28px !important;
  border-bottom: 1px solid var(--line-dark) !important;
  color: #fff !important;
}
.gz-home .nav__drawer .btn { margin-top: 24px !important; }
.gz-home .nav__drawer-icons {
  display: flex !important;
  gap: 8px !important;
  padding: 16px 0 0 !important;
  border-top: 1px solid rgba(255,255,255,0.12) !important;
  margin-top: 8px !important;
}
.gz-home .nav__portal-btn {
  font-size: 12px !important;
  padding: 10px 16px !important;
  white-space: nowrap !important;
}

/* ---------- HERO (full-bleed photo · mobile-first) ---------- */
.gz-home .hero {
  position: relative !important;
  min-height: 100svh !important;
  background: var(--bg-dark) !important;
  color: #fff !important;
  display: flex !important;
  align-items: flex-end !important;
  overflow: hidden !important;
}
.gz-home .hero__photo {
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  max-width: none !important;
  object-fit: cover !important;
  object-position: 50% 25% !important;
  filter: contrast(1.03) saturate(1.04) !important;
}
.gz-home .hero__scrim {
  position: absolute !important;
  inset: 0 !important;
  pointer-events: none !important;
  background:
    linear-gradient(180deg,
      rgba(10,10,10,0.62) 0%,
      rgba(10,10,10,0.08) 26%,
      rgba(10,10,10,0.10) 46%,
      rgba(10,10,10,0.74) 78%,
      rgba(10,10,10,0.96) 100%) !important;
}

.gz-home .hero__container {
  position: relative !important;
  z-index: 2 !important;
  width: 100% !important;
  padding-top: 110px !important;
  padding-bottom: clamp(34px, 7vh, 64px) !important;
  text-align: center !important;
}

.gz-home .hero__copy {
  max-width: 760px !important;
  margin-inline: auto !important;
}

.gz-home .hero__credit {
  display: inline-block !important;
  font-family: var(--f-mono) !important;
  font-size: 10px !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
  color: rgba(255,255,255,0.78) !important;
  border: 1px solid rgba(255,255,255,0.28) !important;
  padding: 5px 11px !important;
  border-radius: var(--r-pill) !important;
  margin-bottom: 20px !important;
  -webkit-backdrop-filter: blur(4px) !important;
  backdrop-filter: blur(4px) !important;
}

.gz-home .hero__eyebrow { margin-bottom: 12px !important; }

.gz-home .hero__title {
  color: #fff !important;
  font-family: var(--f-accent) !important;
  font-weight: 900 !important;
  font-size: clamp(27px, 7.4vw, 36px) !important;
  line-height: 1.0 !important;
  letter-spacing: -0.02em !important;
  margin-bottom: 14px !important;
}
.gz-home .hero__title em {
  color: #fff !important;
  display: block !important;
  font-family: var(--f-ui) !important;
  font-size: clamp(14px, 3.7vw, 17px) !important;
  font-weight: 800 !important;
  font-style: normal !important;
  letter-spacing: 0.04em !important;
  line-height: 1.18 !important;
  margin-top: 6px !important;
  text-transform: uppercase !important;
}
.gz-home .hero__title,
.gz-home .hero__title em {
  white-space: nowrap !important;
}
.gz-home .hero__sub {
  max-width: 36ch !important;
  margin-left: auto !important;
  margin-right: auto !important;
  margin-bottom: 22px !important;
  font-size: 13px !important;
  line-height: 1.45 !important;
  color: rgba(255,255,255,0.78) !important;
}
.gz-home .hero__actions {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 16px !important;
  margin-bottom: 22px !important;
}
.gz-home .hero__actions .btn--primary {
  font-size: 13px !important;
  padding: 13px 22px !important;
}
.gz-home .hero__actions .btn--link {
  color: #fff !important;
  border-bottom-color: rgba(255,255,255,0.4) !important;
}
.gz-home .hero__chips {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 8px 18px !important;
  padding-top: 18px !important;
  border-top: 1px solid rgba(255,255,255,0.16) !important;
}
.gz-home .hero__chip {
  display: inline-flex !important;
  align-items: center !important;
  gap: 7px !important;
  font-family: var(--f-mono) !important;
  font-size: 10px !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
  color: rgba(255,255,255,0.62) !important;
}
.gz-home .hero__chip::before {
  content: "";
  width: 5px !important; height: 5px !important;
  border-radius: 50% !important;
  background: var(--red) !important;
}

/* ---------- PORTAL (light section — contrast com Hero/Passos escuros) ---------- */
.gz-home .portal {
  background: var(--bg-light-2) !important;
  color: var(--ink-light) !important;
  padding-block: clamp(28px, 4vw, 44px) !important;
  position: relative !important;
  border-top: 1px solid var(--line-light) !important;
}
.gz-home .portal__inner {
  display: grid !important;
  gap: 24px !important;
}
.gz-home .portal__card {
  background: #fff !important;
  border: 1px solid var(--line-light) !important;
  border-radius: var(--r-lg) !important;
  padding: 18px 20px !important;
  position: relative !important;
  overflow: hidden !important;
  box-shadow: 0 1px 0 rgba(0,0,0,0.02), 0 18px 40px -28px rgba(0,0,0,0.12) !important;
}
.gz-home .portal__card::before {
  content: "";
  position: absolute !important;
  inset: 0 0 auto 0 !important;
  height: 1px !important;
  background: linear-gradient(90deg, transparent, rgba(230,0,0,0.7), transparent) !important;
  animation: sweep 4s ease-in-out infinite;
}
@keyframes sweep {
  0%, 100% { transform: translateX(-100%); opacity: 0; }
  50% { transform: translateX(100%); opacity: 1; }
}
.gz-home .portal__head {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  margin-bottom: 14px !important;
}
/* Botão "Entrar no portal" — preto, sem seta, sem sheen/blur vermelho */
.gz-home .portal__btn {
  background: #0A0A0A !important;
  color: #fff !important;
  box-shadow: 0 6px 18px rgba(0,0,0,0.18) !important;
}
.gz-home .portal__btn:hover {
  background: #1a1a1a !important;
  box-shadow: 0 10px 28px rgba(0,0,0,0.24) !important;
}
.gz-home .portal__btn::after { display: none !important; animation: none !important; }
.gz-home .portal__pulse {
  width: 8px !important;
  height: 8px !important;
  background: var(--red) !important;
  border-radius: 50% !important;
  animation: pulse 1.8s ease-in-out infinite;
}
@keyframes pulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(230,0,0,0.7); }
  50% { box-shadow: 0 0 0 10px rgba(230,0,0,0); }
}
.gz-home .portal__title {
  font-family: var(--f-display) !important;
  font-weight: 800 !important;
  font-size: clamp(17px, 2.6vw, 22px) !important;
  line-height: 1.15 !important;
  letter-spacing: -0.02em !important;
  margin-bottom: 14px !important;
}
.gz-home .portal__title em { font-style: normal !important; color: var(--red) !important; }
.gz-home .portal__actions {
  display: flex !important;
  flex-wrap: wrap !important;
  align-items: center !important;
  gap: 10px 16px !important;
}
.gz-home .portal__url {
  font-family: var(--f-mono) !important;
  font-size: 10px !important;
  color: var(--mute-light) !important;
}

.gz-home .portal__channels {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 10px !important;
}
.gz-home .portal__channel {
  border: 1px solid var(--line-light) !important;
  border-radius: var(--r-md) !important;
  padding: 14px !important;
  background: #fff !important;
  transition: border-color .2s, background .2s, transform .2s;
}
.gz-home .portal__channel:hover {
  border-color: rgba(0,0,0,0.25) !important;
  background: #fff !important;
  transform: translateY(-1px);
}
.gz-home .portal__channel-tag {
  font-family: var(--f-mono) !important;
  font-size: 9px !important;
  letter-spacing: 0.1em !important;
  color: var(--red) !important;
  display: block !important;
  margin-bottom: 6px !important;
}
.gz-home .portal__channel-value {
  font-family: var(--f-ui) !important;
  font-weight: 700 !important;
  font-size: 13px !important;
  color: var(--ink-light) !important;
  margin-bottom: 4px !important;
}
.gz-home .portal__channel-sub {
  font-family: var(--f-mono) !important;
  font-size: 9px !important;
  color: var(--mute-light) !important;
  letter-spacing: 0.06em !important;
}

.gz-home .portal__channels-label {
  font-family: var(--f-mono) !important;
  font-size: 10px !important;
  letter-spacing: 0.14em !important;
  text-transform: uppercase !important;
  color: var(--mute-light) !important;
  margin-bottom: 12px !important;
  display: block !important;
}
.gz-home .portal__channels-title {
  font-family: var(--f-accent) !important;
  font-size: clamp(17px, 2.4vw, 22px) !important;
  font-weight: 800 !important;
  line-height: 1.15 !important;
  color: var(--ink-light) !important;
  letter-spacing: -0.02em !important;
}

/* CTA dos canais — texto à esquerda, botão vermelho vazado à direita */
.gz-home .portal__channels-cta {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 16px !important;
  flex-wrap: nowrap !important;
}
.gz-home .portal__channels-text { min-width: 0 !important; }
.gz-home .portal__canais-btn {
  flex-shrink: 0 !important;
  background: transparent !important;
  color: var(--red) !important;
  border: 1.5px solid var(--red) !important;
  box-shadow: none !important;
  font-size: 12px !important;
  padding: 11px 16px !important;
  white-space: nowrap !important;
}
.gz-home .portal__canais-btn:hover {
  background: var(--red) !important;
  color: #fff !important;
  transform: none;
  box-shadow: none !important;
}
.gz-home .portal__canais-btn::after { display: none !important; animation: none !important; }

/* ---------- TRUST ---------- */
.gz-home .trust {
  background: var(--bg-light) !important;
  padding-block: clamp(48px, 7vw, 80px) !important;
}
.gz-home .trust__grid {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 28px 18px !important;
  margin-bottom: 36px !important;
}
.gz-home .trust__cell {
  position: relative !important;
  padding-top: 14px !important;
}
.gz-home .trust__cell::before {
  content: "";
  position: absolute !important;
  top: 0 !important; left: 0 !important;
  width: 28px !important;
  height: 2px !important;
  background: var(--red) !important;
}
.gz-home .trust__big {
  font-family: var(--f-accent) !important;
  font-weight: 900 !important;
  font-size: clamp(38px, 6.5vw, 60px) !important;
  line-height: 0.95 !important;
  letter-spacing: -0.025em !important;
  margin-bottom: 6px !important;
}
.gz-home .trust__label {
  font-family: var(--f-mono) !important;
  font-size: 10px !important;
  letter-spacing: 0.14em !important;
  text-transform: uppercase !important;
  color: var(--mute-light) !important;
}
.gz-home .trust__seals {
  padding-top: 24px !important;
  border-top: 1px solid var(--line-light) !important;
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 10px !important;
}
.gz-home .trust__seal {
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
  border: 1px solid var(--line-light) !important;
  border-radius: var(--r-pill) !important;
  padding: 8px 14px !important;
  font-family: var(--f-mono) !important;
  font-size: 10px !important;
  letter-spacing: 0.1em !important;
  color: var(--mute-light) !important;
}
.gz-home .trust__seal-dot {
  width: 6px !important;
  height: 6px !important;
  border-radius: 50% !important;
  background: var(--red) !important;
}

/* ---------- 3 PASSOS ---------- */
.gz-home .passos {
  background: var(--bg-dark) !important;
  color: #fff !important;
}
.gz-home .passos__head {
  margin-bottom: 40px !important;
}
.gz-home .passos__title { color: #fff !important; margin-top: 16px !important; margin-bottom: 12px !important; }
.gz-home .passos__sub { color: var(--mute-dark) !important; }

.gz-home .passos__list {
  display: grid !important;
  gap: 18px !important;
  counter-reset: passo !important;
  list-style: none !important;
}
.gz-home .passos__item {
  border: 1px solid var(--line-dark) !important;
  border-radius: var(--r-lg) !important;
  padding: 28px 24px !important;
  position: relative !important;
  background: rgba(255,255,255,0.015) !important;
  transition: border-color .25s, transform .25s, background .25s;
}
.gz-home .passos__item:hover {
  border-color: rgba(230,0,0,0.4) !important;
  background: rgba(255,255,255,0.03) !important;
}
.gz-home .passos__num {
  font-family: var(--f-mono) !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  letter-spacing: 0.15em !important;
  color: var(--red) !important;
  margin-bottom: 16px !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 10px !important;
}
.gz-home .passos__num::before {
  content: "";
  width: 22px !important;
  height: 22px !important;
  border-radius: 50% !important;
  border: 1.5px solid var(--red) !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  background: rgba(230,0,0,0.12) !important;
}
.gz-home .passos__item-title {
  font-family: var(--f-display) !important;
  font-weight: 700 !important;
  font-size: clamp(22px, 3vw, 26px) !important;
  line-height: 1.1 !important;
  margin-bottom: 12px !important;
  color: #fff !important;
}
.gz-home .passos__trophy {
  display: inline-block !important;
  font-family: "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji", sans-serif !important;
  font-size: 0.9em !important;
  line-height: 1 !important;
  transform: translateY(0.04em);
  filter: drop-shadow(0 0 5px rgba(255, 204, 51, 0.85))
          drop-shadow(0 0 14px rgba(255, 180, 0, 0.45)) !important;
}
.gz-home .passos__item-body {
  font-family: var(--f-ui) !important;
  font-size: 14px !important;
  line-height: 1.6 !important;
  color: var(--mute-dark) !important;
}
.gz-home .passos__item-body em {
  font-style: normal !important;
  color: #fff !important;
  font-weight: 600 !important;
  background: linear-gradient(180deg, transparent 60%, rgba(230,0,0,0.35) 60%) !important;
  padding: 0 2px !important;
}
.gz-home .passos__link {
  display: inline-block !important;
  margin-top: 36px !important;
  color: #fff !important;
  border-bottom: 1.5px solid #fff !important;
  font-weight: 600 !important;
  font-size: 13px !important;
  padding-bottom: 2px !important;
}

/* ---------- POR QUE ---------- */
.gz-home .porque {
  background: var(--bg-light) !important;
}
.gz-home .porque__head {
  display: grid !important;
  gap: 18px !important;
  margin-bottom: 40px !important;
}
.gz-home .porque__list {
  display: grid !important;
  gap: 0 !important;
  border-top: 1.5px solid var(--ink-light) !important;
}
.gz-home .porque__item {
  display: grid !important;
  grid-template-columns: 36px 1fr !important;
  gap: 14px !important;
  padding: 22px 0 !important;
  border-bottom: 1.5px solid var(--ink-light) !important;
  align-items: start !important;
}
.gz-home .porque__item-body {
  /* no mobile (2 colunas) ocupa a coluna do texto */
  grid-column: 2 / -1 !important;
}
.gz-home .porque__num {
  font-family: var(--f-mono) !important;
  font-weight: 700 !important;
  font-size: 12px !important;
  color: var(--red) !important;
  padding-top: 4px !important;
}
.gz-home .porque__item-title {
  font-family: var(--f-display) !important;
  font-weight: 700 !important;
  font-size: clamp(17px, 4.5vw, 26px) !important;
  line-height: 1.2 !important;
  margin-bottom: 6px !important;
  text-wrap: balance !important;
}
.gz-home .porque__item-body {
  font-family: var(--f-ui) !important;
  font-size: 14px !important;
  line-height: 1.55 !important;
  color: var(--mute-light) !important;
  max-width: 540px !important;
}
.gz-home .porque__item-body em {
  font-style: italic !important;
  color: var(--ink-light) !important;
}

/* ----- Diferenciais: contraste mercado × Garantia ----- */
.gz-home .diff__list {
  list-style: none !important;
  border-top: 1.5px solid var(--ink-light) !important;
}
.gz-home .diff__item {
  padding: 24px 0 !important;
  border-bottom: 1px solid var(--line-light) !important;
  display: grid !important;
  gap: 16px !important;
}
.gz-home .diff__lead {
  display: grid !important;
  grid-template-columns: 26px 1fr !important;
  gap: 8px !important;
  align-items: start !important;
}
.gz-home .diff__num {
  font-family: "Apple Color Emoji", "Segoe UI Emoji", "Noto Color Emoji", sans-serif !important;
  font-variant-emoji: emoji !important;
  font-weight: 600 !important;
  font-size: 22px !important;
  line-height: 1 !important;
  color: var(--red) !important;
  padding-top: 1px !important;
}
.gz-home .diff__title {
  font-family: var(--f-display) !important;
  font-weight: 700 !important;
  font-size: clamp(17px, 2.4vw, 21px) !important;
  line-height: 1.2 !important;
  letter-spacing: -0.01em !important;
  color: var(--ink-light) !important;
  text-wrap: balance !important;
}
.gz-home .diff__compare {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 10px !important;
  align-items: stretch !important;
}
.gz-home .diff__market,
.gz-home .diff__garantia {
  font-family: var(--f-ui) !important;
  font-size: 12.5px !important;
  line-height: 1.45 !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 8px !important;
  padding: 14px !important;
  border-radius: 14px !important;
  position: relative !important;
  z-index: 0 !important;
  overflow: hidden !important;
}
.gz-home .diff__tag {
  font-family: var(--f-mono) !important;
  font-size: 9px !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
  font-weight: 600 !important;
}
/* Garantia = card branco em destaque, com beam vermelho sutil girando devagar */
.gz-home .diff__garantia {
  order: 2 !important;
  background: #fff !important;
  color: var(--ink-light) !important;
  font-weight: 500 !important;
  border: 1px solid rgba(0,0,0,0.06) !important;
  box-shadow: 0 8px 22px -10px rgba(0,0,0,0.16), 0 1px 3px rgba(0,0,0,0.05) !important;
}
.gz-home .diff__garantia .diff__tag {
  color: var(--red) !important;
  font-family: var(--f-accent) !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
  font-size: 12px !important;
}
/* linha do tag + emoji inline (✅ / ❌ depois do texto) */
.gz-home .diff__tagline {
  display: inline-flex !important;
  align-items: center !important;
  gap: 7px !important;
}
.gz-home .diff__ico {
  position: relative !important;
  display: inline-grid !important;
  place-items: center !important;
  font-size: 15px !important;
  line-height: 1 !important;
  z-index: 1 !important;
}
.gz-home .diff__ico::before {
  content: "";
  position: absolute !important;
  inset: -7px !important;
  z-index: -1 !important;
  border-radius: 50% !important;
  filter: blur(5px) !important;
}
.gz-home .diff__ico--ok::before { background: radial-gradient(circle, rgba(21,163,58,0.55), transparent 68%) !important; }
.gz-home .diff__ico--no::before { background: radial-gradient(circle, rgba(230,0,0,0.6), transparent 68%) !important; }
/* Mercado = card preto (lado negativo), com sheen sutil no fundo */
.gz-home .diff__market {
  order: 1 !important;
  background: #0E0E0E !important;
  color: rgba(255,255,255,0.6) !important;
  border: 1px solid rgba(255,255,255,0.07) !important;
}
.gz-home .diff__market::after {
  content: "";
  position: absolute !important;
  z-index: -1 !important;
  inset: 0 !important;
  background: radial-gradient(120% 80% at 82% 0%, rgba(255,255,255,0.06), transparent 58%) !important;
  pointer-events: none !important;
}
.gz-home .diff__market .diff__tag { color: rgba(255,255,255,0.42) !important; }

.gz-home .diff__quote {
  margin-top: 36px !important;
  text-align: center !important;
  font-family: var(--f-display) !important;
  font-style: italic !important;
  font-weight: 600 !important;
  font-size: clamp(18px, 2.6vw, 24px) !important;
  line-height: 1.3 !important;
  color: var(--ink-light) !important;
  text-wrap: balance !important;
}

/* ---------- MERCADO ---------- */
.gz-home .mercado {
  background: var(--bg-dark) !important;
  color: #fff !important;
}
.gz-home .mercado__head {
  text-align: center !important;
  max-width: 760px !important;
  margin: 0 auto 40px !important;
}
.gz-home .mercado__title { color: #fff !important; margin-top: 16px !important; margin-bottom: 16px !important; }
.gz-home .mercado__sub { color: var(--mute-dark) !important; }

/* ----- novo: 2 cards lado a lado ----- */
.gz-home .mercado__cards {
  display: grid !important;
  gap: 20px !important;
  align-items: stretch !important;
}
.gz-home .mercado__card {
  border-radius: var(--r-lg) !important;
  padding: 32px 28px !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 14px !important;
  position: relative !important;
}
.gz-home .mercado__card--bad {
  background: rgba(255,255,255,0.025) !important;
  border: 1px solid var(--line-dark) !important;
  color: var(--mute-dark) !important;
}
.gz-home .mercado__card--good {
  background: #FAFAFA !important;
  border: 1px solid #FAFAFA !important;
  color: var(--ink-light) !important;
  box-shadow: 0 24px 60px -28px rgba(230,0,0,0.5), 0 1px 0 rgba(0,0,0,0.04) !important;
  position: relative !important;
}
.gz-home .mercado__card--good::before {
  content: "★";
  position: absolute !important;
  top: -14px !important;
  right: 22px !important;
  width: 28px !important;
  height: 28px !important;
  border-radius: 50% !important;
  background: var(--red) !important;
  color: #fff !important;
  font-size: 14px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-weight: 700 !important;
}
.gz-home .mercado__card-tag {
  font-family: var(--f-mono) !important;
  font-size: 10px !important;
  letter-spacing: 0.14em !important;
  text-transform: uppercase !important;
  font-weight: 700 !important;
}
.gz-home .mercado__card--bad  .mercado__card-tag { color: rgba(255,255,255,0.55) !important; }
.gz-home .mercado__card--good .mercado__card-tag { color: var(--red) !important; }

.gz-home .mercado__card-title {
  font-family: var(--f-display) !important;
  font-weight: 800 !important;
  letter-spacing: -0.02em !important;
  font-size: clamp(22px, 3vw, 28px) !important;
  line-height: 1.1 !important;
  margin-bottom: 4px !important;
}
.gz-home .mercado__card--bad  .mercado__card-title { color: rgba(255,255,255,0.92) !important; }
.gz-home .mercado__card--good .mercado__card-title { color: var(--ink-light) !important; }

.gz-home .mercado__list {
  list-style: none !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 12px !important;
  font-size: 14.5px !important;
  line-height: 1.5 !important;
}
.gz-home .mercado__card--bad .mercado__list li {
  position: relative !important;
  padding-left: 24px !important;
  font-style: italic !important;
  text-decoration: line-through !important;
  text-decoration-color: rgba(230,0,0,0.7) !important;
  text-decoration-thickness: 1.5px !important;
  color: rgba(255,255,255,0.6) !important;
}
.gz-home .mercado__card--bad .mercado__list li::before {
  content: "✕";
  position: absolute !important;
  left: 0 !important;
  top: 0 !important;
  color: var(--red) !important;
  font-weight: 700 !important;
  text-decoration: none !important;
  display: inline-block !important;
}
.gz-home .mercado__card--good .mercado__list li {
  position: relative !important;
  padding-left: 26px !important;
  color: var(--ink-light) !important;
  font-weight: 500 !important;
}
.gz-home .mercado__card--good .mercado__list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 7px;
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: var(--red);
  box-shadow: inset 0 0 0 4px var(--red);
  -webkit-mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'><circle cx='8' cy='8' r='8' fill='black'/><polyline points='4.5 8.5 7 11 11.5 5.5' fill='none' stroke='white' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'/></svg>") center/contain no-repeat;
          mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'><circle cx='8' cy='8' r='8' fill='black'/><polyline points='4.5 8.5 7 11 11.5 5.5' fill='none' stroke='white' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'/></svg>") center/contain no-repeat;
}

.gz-home .mercado__card-quote {
  margin-top: 8px !important;
  padding-top: 16px !important;
  border-top: 1px dashed rgba(0,0,0,0.12) !important;
  font-family: var(--f-display) !important;
  font-style: italic !important;
  font-weight: 600 !important;
  font-size: 15px !important;
  line-height: 1.4 !important;
  color: var(--red) !important;
}

/* ---------- DEPOIMENTOS — muro de contemplados (carousel) ---------- */
.gz-home .depo {
  background: var(--bg-dark) !important;
  color: #fff !important;
  overflow: hidden !important; /* carousel ultrapassa container mas a section corta */
}
.gz-home .depo__head-wrap { margin-bottom: 28px !important; }
.gz-home .depo__head {
  display: grid !important;
  gap: 14px !important;
}
.gz-home .depo__title { margin-bottom: 4px !important; color: #fff !important; }
.gz-home .depo__head .body { color: var(--mute-dark) !important; }

/* marquee track: 2x cards, animação loop infinito */
.gz-home .depo__marquee {
  position: relative !important;
  width: 100% !important;
  overflow: hidden !important;
  padding: 8px 0 !important;
  -webkit-mask-image: linear-gradient(90deg, transparent 0, #000 5%, #000 95%, transparent 100%) !important;
          mask-image: linear-gradient(90deg, transparent 0, #000 5%, #000 95%, transparent 100%) !important;
}
.gz-home .depo__track {
  display: flex !important;
  gap: 14px !important;
  width: max-content !important;
  padding-inline: var(--pad-x) !important;
  will-change: transform;
  cursor: grab;
  touch-action: pan-y !important;
  user-select: none !important;
  -webkit-user-select: none !important;
}
.gz-home .depo__track.is-dragging {
  cursor: grabbing;
}
.gz-home .depo__track.is-dragging .depo-card { pointer-events: none !important; }

.gz-home .depo-card {
  position: relative !important;
  flex: 0 0 auto !important;
  width: 66vw !important;
  max-width: 250px !important;
  aspect-ratio: 3 / 5 !important;
  border-radius: var(--r-lg) !important;
  overflow: hidden !important;
  background: #1a1a1a !important;
  box-shadow: 0 1px 0 rgba(0,0,0,0.04), 0 18px 36px -22px rgba(0,0,0,0.18) !important;
}
.gz-home .depo-card__photo {
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  max-width: none !important;
  object-fit: cover !important;
  display: block !important;
}
.gz-home .depo-card::after {
  content: "";
  position: absolute !important;
  inset: 0 !important;
  background: linear-gradient(180deg, rgba(10,10,10,0) 50%, rgba(10,10,10,0.88) 100%) !important;
  pointer-events: none !important;
}
.gz-home .depo-card__plate {
  position: absolute !important;
  left: 14px !important;
  right: 14px !important;
  bottom: 14px !important;
  z-index: 2 !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 2px !important;
  color: #fff !important;
}
.gz-home .depo-card__veh {
  font-family: var(--f-display) !important;
  font-weight: 700 !important;
  font-size: 16px !important;
  letter-spacing: -0.01em !important;
  line-height: 1.15 !important;
}
.gz-home .depo-card__time {
  font-family: var(--f-mono), "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji", sans-serif !important;
  font-size: 10px !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
  color: rgba(255,255,255,0.88) !important;
}

/* ---------- Card de vídeo (prova social) ---------- */
.gz-home .depo-card--video { cursor: pointer !important; }

.gz-home .depo-card__tag {
  position: absolute !important;
  top: 12px !important;
  left: 12px !important;
  z-index: 3 !important;
  padding: 5px 9px !important;
  border-radius: 999px !important;
  background: rgba(0,0,0,0.5) !important;
  -webkit-backdrop-filter: blur(4px) !important;
          backdrop-filter: blur(4px) !important;
  color: #fff !important;
  font-family: var(--f-mono) !important;
  font-size: 9px !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
}

.gz-home .depo-card__play {
  position: absolute !important;
  top: 50% !important;
  left: 50% !important;
  z-index: 3 !important;
  width: 60px !important;
  height: 60px !important;
  display: grid !important;
  place-items: center !important;
  border-radius: 50% !important;
  background: transparent !important;
  border: 2.5px solid #fff !important;
  color: #fff !important;
  transform: translate(-50%, -50%) !important;
  box-shadow: 0 2px 12px rgba(0,0,0,0.35) !important;
  transition: background .18s ease, transform .18s ease !important;
}
.gz-home .depo-card__play svg {
  width: 24px !important;
  height: 24px !important;
  margin-left: 3px !important;
  fill: #fff !important;
  filter: drop-shadow(0 1px 3px rgba(0,0,0,0.4)) !important;
}
.gz-home .depo-card--video:hover .depo-card__play {
  background: rgba(255,255,255,0.18) !important;
  transform: translate(-50%, -50%) scale(1.06) !important;
}

/* ---------- Lightbox player ---------- */
.gz-home .depo-lightbox {
  position: fixed !important;
  inset: 0 !important;
  z-index: 99999 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 20px !important;
  background: rgba(8,8,8,0.88) !important;
  -webkit-backdrop-filter: blur(6px) !important;
          backdrop-filter: blur(6px) !important;
  opacity: 0 !important;
  transition: opacity .2s ease !important;
}
.gz-home .depo-lightbox[hidden] { display: none !important; }
.gz-home .depo-lightbox.is-open { opacity: 1 !important; }

.gz-home .depo-lightbox__stage {
  position: relative !important;
  line-height: 0 !important;
}
.gz-home .depo-lightbox__video {
  display: block !important;
  width: auto !important;
  height: auto !important;
  max-width: min(92vw, 440px) !important;
  max-height: 86vh !important;
  border-radius: 20px !important;
  background: #000 !important;
  box-shadow: 0 30px 80px rgba(0,0,0,0.5) !important;
}
.gz-home .depo-lightbox__close {
  position: absolute !important;
  top: 8px !important;
  right: 8px !important;
  z-index: 2 !important;
  width: 38px !important;
  height: 38px !important;
  display: grid !important;
  place-items: center !important;
  border: none !important;
  border-radius: 50% !important;
  background: rgba(0,0,0,0.55) !important;
  color: #fff !important;
  font-size: 24px !important;
  line-height: 1 !important;
  cursor: pointer !important;
}
.gz-home .depo-lightbox__close:hover { background: rgba(0,0,0,0.78) !important; }

.gz-home .depo__more {
  display: block !important;
  text-align: center !important;
  margin-top: 32px !important;
  max-width: max-content !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

/* ---------- DÚVIDAS / FAQ ---------- */
.gz-home .faq {
  background: var(--bg-light) !important;
  color: var(--ink-light) !important;
}
.gz-home .faq__head { margin-bottom: 36px !important; }
.gz-home .faq__title { color: var(--ink-light) !important; margin-top: 16px !important; margin-bottom: 12px !important; }
.gz-home .faq__sub { color: var(--mute-light) !important; }

.gz-home .faq__list {
  border-top: 1px solid var(--line-light) !important;
}
.gz-home .faq__item {
  border-bottom: 1px solid var(--line-light) !important;
}
.gz-home .faq__q {
  display: flex !important;
  align-items: flex-start !important;
  justify-content: space-between !important;
  gap: 18px !important;
  padding: 22px 0 !important;
  cursor: pointer;
  text-align: left !important;
  width: 100% !important;
  max-width: 100% !important;
  white-space: normal !important;
  color: var(--ink-light) !important;
}
.gz-home .faq__q-num {
  font-family: var(--f-mono) !important;
  font-size: 11px !important;
  letter-spacing: 0.14em !important;
  color: var(--red) !important;
  flex-shrink: 0 !important;
  width: 32px !important;
}
.gz-home .faq__q-text {
  font-family: var(--f-ui) !important;
  font-weight: 700 !important;
  font-size: clamp(15px, 1.9vw, 18px) !important;
  line-height: 1.35 !important;
  flex: 1 1 auto !important;
  min-width: 0 !important;
  white-space: normal !important;
  overflow-wrap: anywhere !important;
}
.gz-home .faq__q-icon {
  width: 26px !important;
  height: 26px !important;
  border-radius: 50% !important;
  border: 1px solid var(--line-light) !important;
  flex-shrink: 0 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  transition: background .2s, border-color .2s, transform .25s;
}
.gz-home .faq__q-icon::before,
.gz-home .faq__q-icon::after {
  content: "";
  position: absolute !important;
  background: var(--ink-light) !important;
  border-radius: 1px !important;
  transition: transform .25s;
}
.gz-home .faq__q-icon::before { width: 10px !important; height: 1.5px !important; }
.gz-home .faq__q-icon::after { width: 1.5px !important; height: 10px !important; }
.gz-home .faq__q-icon { position: relative !important; }
.gz-home .faq__item.is-open .faq__q-icon {
  background: var(--red) !important;
  border-color: var(--red) !important;
}
.gz-home .faq__item.is-open .faq__q-icon::before,
.gz-home .faq__item.is-open .faq__q-icon::after { background: #fff !important; }
.gz-home .faq__item.is-open .faq__q-icon::after {
  transform: rotate(90deg);
  opacity: 0 !important;
}
.gz-home .faq__a {
  max-height: 0;
  overflow: hidden !important;
  transition: max-height .35s cubic-bezier(.22,.7,.3,1);
}
.gz-home .faq__a-inner {
  padding: 0 0 26px 50px !important;
  max-width: 720px !important;
  font-family: var(--f-ui) !important;
  font-size: 14px !important;
  line-height: 1.65 !important;
  color: var(--mute-light) !important;
}
.gz-home .faq__steps {
  list-style: none !important;
  counter-reset: faqstep !important;
  display: grid !important;
  gap: 14px !important;
  margin: 2px 0 0 !important;
}
.gz-home .faq__steps li {
  counter-increment: faqstep !important;
  position: relative !important;
  padding-left: 38px !important;
  min-height: 26px !important;
}
.gz-home .faq__steps li::before {
  content: counter(faqstep, decimal-leading-zero);
  position: absolute !important;
  left: 0 !important;
  top: 1px !important;
  font-family: var(--f-mono) !important;
  font-size: 11px !important;
  font-weight: 600 !important;
  color: var(--red) !important;
  letter-spacing: 0.04em !important;
}
.gz-home .faq__steps strong {
  color: var(--ink-light) !important;
  font-weight: 700 !important;
}

/* FAQ mobile: neutraliza larguras de .container vindas do tema/Elementor. */
@media (max-width: 639px) {
  .gz-home .faq { overflow-x: clip !important; }
  .gz-home .faq > .container {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    margin-inline: 0 !important;
    padding-left: max(20px, env(safe-area-inset-left)) !important;
    padding-right: max(20px, env(safe-area-inset-right)) !important;
  }
  .gz-home .faq__list,
.gz-home .faq__item,
.gz-home .faq__q,
.gz-home .faq__q-text,
.gz-home .faq__a,
.gz-home .faq__a-inner {
    min-width: 0 !important;
    max-width: 100% !important;
  }
  .gz-home .faq__q { box-sizing: border-box !important; }
  .gz-home .faq__q-text,
.gz-home .faq__a-inner { overflow-wrap: anywhere !important; }
}

/* ---------- CTA FINAL ---------- */
.gz-home .cta {
  background: #0A0A0A !important;                       /* preto: continua a prova social */
  color: #fff !important;
  padding-top: clamp(28px, 5vw, 48px) !important;       /* cola na seção de cima */
  padding-bottom: clamp(72px, 12vw, 140px) !important;
  text-align: center !important;
  position: relative !important;
  overflow: hidden !important;
}
/* aproxima a prova social desta seção (mesmo fundo escuro = parecem uma só) */
.gz-home .depo { padding-bottom: clamp(20px, 4vw, 44px) !important; }
.gz-home .cta::before {
  content: "";
  position: absolute !important;
  inset: 0 !important;
  /* degradê vermelho leve e longo: transparente abaixo do título → vermelho 31% no fim */
  background: linear-gradient(180deg, transparent 20%, rgba(230,0,0,0.31) 100%) !important;
  pointer-events: none !important;
}
.gz-home .cta::after { display: none !important; }
.gz-home .cta > .container { position: relative !important; z-index: 1 !important; }
.gz-home .h2.cta__title,
.gz-home .cta__title {
  color: #fff !important;
  margin-bottom: 18px !important;
  position: relative !important;
  font-family: var(--f-accent) !important;
}
.gz-home .cta__sub {
  color: rgba(255,255,255,0.85) !important;
  max-width: 520px !important;
  margin: 0 auto 36px !important;
  font-size: clamp(15px, 1.8vw, 18px) !important;
  position: relative !important;
}
.gz-home .cta__micro {
  margin-top: 18px !important;
  font-family: var(--f-mono) !important;
  font-size: 10px !important;
  line-height: 1.5 !important;
  letter-spacing: 0.1em !important;
  color: rgba(255,255,255,0.46) !important;
  text-transform: uppercase !important;
  position: relative !important;
}
.gz-home .trophy-glow {
  display: inline-block !important;
  font-family: "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji", sans-serif !important;
  font-variant-emoji: emoji !important;
  vertical-align: 0.02em !important;
  margin-left: 4px !important;
  filter: drop-shadow(0 0 8px rgba(255,215,0,0.55)) drop-shadow(0 0 16px rgba(255,165,0,0.25)) !important;
}
.gz-home .cta__btn {
  background: var(--red) !important;
  color: #fff !important;
  padding: 20px 36px !important;
  font-size: 15px !important;
  font-weight: 800 !important;
  box-shadow: 0 16px 40px rgba(0,0,0,0.25) !important;
  position: relative !important;
  transform: translate(var(--mx, 0px), var(--my, 0px));
  transition: transform .25s cubic-bezier(.2,.8,.2,1), box-shadow .25s ease;
}
.gz-home .cta__btn:hover {
  background: var(--red-2) !important;
  box-shadow: 0 24px 60px rgba(0,0,0,0.3) !important;
}

/* CTA · botão flutuando + halo branco pulsante. (transform + box-shadow num
   único botão = leve; preserva o magnético via var --mx/--my no float.) */
@keyframes cta-float {
  0%, 100% { transform: translate(var(--mx, 0px), var(--my, 0px)); }
  50%      { transform: translate(var(--mx, 0px), calc(var(--my, 0px) - 7px)); }
}
@keyframes cta-halo {
  0%   { box-shadow: 0 0 0 0 rgba(255,255,255,0.5), 0 16px 40px rgba(0,0,0,0.28); }
  70%  { box-shadow: 0 0 0 16px rgba(255,255,255,0), 0 16px 40px rgba(0,0,0,0.28); }
  100% { box-shadow: 0 0 0 0 rgba(255,255,255,0), 0 16px 40px rgba(0,0,0,0.28); }
}
.gz-home .cta__btn {
  animation: cta-float 3.2s ease-in-out infinite, cta-halo 2.6s ease-out infinite !important;
}
.gz-home .cta__btn-arrow {
  display: inline-block !important;
  margin-left: 4px !important;   /* seta parada, sem animação */
}
/* glow amarelo atrás do troféu (cor do emoji) */
.gz-home .cta__trophy {
  display: inline-block !important;
  filter: drop-shadow(0 0 9px rgba(255,200,40,0.9)) drop-shadow(0 0 22px rgba(255,170,0,0.55)) !important;
}
.gz-home .cta__micro {
  margin-top: 22px !important;
  font-family: var(--f-mono) !important;
  font-size: 10px !important;
  letter-spacing: 0.14em !important;
  color: #fff !important;
  position: relative !important;
}

/* ---------- FOOTER ---------- */
.gz-home .footer {
  background: #060606 !important;
  color: #fff !important;
  padding-block: 40px 28px !important;
}
.gz-home .footer__top {
  display: flex !important;
  flex-direction: column !important;
  gap: 22px !important;
}
.gz-home .footer__brand .nav__logo { font-size: 26px !important; }
.gz-home .footer__social {
  display: flex !important;
  gap: 10px !important;
}
.gz-home .footer__social a {
  width: 38px !important;
  height: 38px !important;
  border-radius: 12px !important;
  border: 1px solid var(--line-dark) !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  color: #fff !important;
  transition: background .2s, border-color .2s;
}
.gz-home .footer__social a:hover {
  background: var(--red) !important;
  border-color: var(--red) !important;
}
.gz-home .footer__social svg { width: 16px !important; height: 16px !important; }

.gz-home .footer__brand-actions {
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
  flex-wrap: wrap !important;
  margin-top: 12px !important;
}
.gz-home .footer__portal-btn {
  white-space: nowrap !important;
}

.gz-home .footer__addresses {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 24px !important;
}

.gz-home .footer__mini {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 8px 20px !important;
  margin-top: 20px !important;
}
.gz-home .footer__mini a {
  font-family: var(--f-mono) !important;
  font-size: 11px !important;
  letter-spacing: 0.06em !important;
  color: var(--mute-dark) !important;
  transition: color .2s;
}
.gz-home .footer__mini a:hover { color: #fff !important; }

.gz-home .footer__col-title {
  font-family: var(--f-mono) !important;
  font-size: 10px !important;
  letter-spacing: 0.14em !important;
  text-transform: uppercase !important;
  color: var(--red) !important;
  margin-bottom: 16px !important;
}
.gz-home .footer__col ul {
  list-style: none !important;
}
.gz-home .footer__col li {
  font-family: var(--f-ui) !important;
  font-size: 13px !important;
  line-height: 2 !important;
  color: var(--mute-dark) !important;
}
.gz-home .footer__col a:hover { color: #fff !important; }
.gz-home .footer__col .phone {
  color: #fff !important;
  font-weight: 700 !important;
  display: block !important;
  margin-top: 8px !important;
}
.gz-home .footer__col .wa-tag {
  color: var(--red) !important;
  font-family: var(--f-mono) !important;
  font-size: 9px !important;
  margin-left: 4px !important;
}

.gz-home .footer__bottom {
  margin-top: 20px !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 12px !important;
  font-family: var(--f-mono) !important;
  font-size: 10px !important;
  letter-spacing: 0.1em !important;
  color: rgba(255,255,255,0.4) !important;
}
.gz-home .footer__bottom-seals {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 10px !important;
}
.gz-home .footer__bottom-seals span {
  border: 1px solid var(--line-dark) !important;
  border-radius: var(--r-pill) !important;
  padding: 5px 12px !important;
  color: rgba(255,255,255,0.6) !important;
}

/* ---------- FOOTER mobile compacto ---------- */
@media (max-width: 639px) {
  .gz-home .footer {
    padding-block: 24px 16px !important;
  }
  .gz-home .footer__top {
    gap: 20px !important;
  }
  .gz-home .footer__brand {
    display: flex !important;
    flex-direction: column !important;
    gap: 14px !important;
  }
  .gz-home .footer__brand-actions {
    flex-direction: row !important;
    align-items: center !important;
    gap: 10px !important;
    margin-top: 0 !important;
  }
  .gz-home .footer__addresses {
    grid-template-columns: 1fr 1fr !important;
    gap: 16px !important;
  }
  .gz-home .footer__col--address .footer__col-title {
    font-size: 10px !important;
    letter-spacing: 0.08em !important;
    text-transform: uppercase !important;
    color: rgba(255,255,255,0.5) !important;
    margin-bottom: 8px !important;
  }
  .gz-home .footer__col--address ul li {
    font-size: 12px !important;
    line-height: 1.6 !important;
    color: rgba(255,255,255,0.65) !important;
  }
  .gz-home .footer__mini {
    margin-top: 14px !important;
    gap: 8px 14px !important;
  }
  .gz-home .footer__mini a { font-size: 10px !important; }
  .gz-home .footer__bottom {
    margin-top: 14px !important;
    flex-direction: row !important;
    flex-wrap: wrap !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 8px !important;
  }
}

.gz-home .hero__channels-btn {
  position: absolute !important;
  top: 80px !important;
  right: 20px !important;
  z-index: 10 !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 7px !important;
  padding: 10px 16px !important;
  border-radius: var(--r-pill) !important;
  background: rgba(255,255,255,0.12) !important;
  border: 1px solid rgba(255,255,255,0.28) !important;
  color: #fff !important;
  font-family: var(--f-mono) !important;
  font-size: 11px !important;
  letter-spacing: 0.06em !important;
  text-transform: uppercase !important;
  text-decoration: none !important;
  -webkit-backdrop-filter: blur(8px) !important;
  backdrop-filter: blur(8px) !important;
  transition: background .2s, border-color .2s;
}
.gz-home .hero__channels-btn:hover {
  background: rgba(255,255,255,0.22) !important;
  border-color: rgba(255,255,255,0.5) !important;
}
.gz-home .hero__channels-btn svg { flex-shrink: 0 !important; }

@media (min-width: 640px) {
  .gz-home .hero__channels-btn {
    top: 100px !important;
    right: 40px !important;
    font-size: 12px !important;
    padding: 12px 20px !important;
  }
}
.gz-home .placeholder {
  background:
    repeating-linear-gradient(135deg, rgba(255,255,255,0.05) 0 8px, rgba(255,255,255,0.02) 8px 16px) !important;
  border: 1px dashed rgba(255,255,255,0.2) !important;
  border-radius: var(--r-md) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-family: var(--f-mono) !important;
  font-size: 10px !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
  color: rgba(255,255,255,0.5) !important;
  text-align: center !important;
  padding: 16px !important;
}
.gz-home .placeholder--light {
  background:
    repeating-linear-gradient(135deg, rgba(0,0,0,0.04) 0 8px, rgba(0,0,0,0.015) 8px 16px) !important;
  border-color: rgba(0,0,0,0.15) !important;
  color: rgba(0,0,0,0.4) !important;
}

/* Evita renderizar seções distantes antes de entrarem perto da tela. */
@supports (content-visibility: auto) {
  .gz-home section:not(.hero) {
    content-visibility: auto;
    contain-intrinsic-size: auto 760px;
  }
}

/* ---------- Reveal on scroll ---------- */
.gz-home .reveal {
  opacity: 1 !important;
  transform: none;
  transition: opacity .7s ease, transform .7s cubic-bezier(.2,.7,.3,1);
  transition-delay: var(--rd, 0ms);
}
.gz-home.gz-motion-ready .reveal {
  opacity: 0 !important;
  transform: translateY(28px);
}
.gz-home.gz-motion-ready .reveal.is-visible {
  opacity: 1 !important;
  transform: translateY(0);
}

@media (prefers-reduced-motion: reduce) {
  .gz-home .reveal { opacity: 1 !important; transform: none; transition: none; }
  .gz-home .hero__bg::before,
.gz-home .hero__bg::after { animation: none; }
  .gz-home .portal__card::before { animation: none; }
  .gz-home .portal__pulse { animation: none; }
  .gz-home { scroll-behavior: auto !important; }
}

/* ================================================
   ► TABLET ≥ 640px
================================================ */
@media (min-width: 640px) {
  .gz-home .hero__actions {
    flex-direction: row !important;
    align-items: center !important;
  }
  .gz-home .hero__actions .btn--link { align-self: auto !important; }
  .gz-home .trust__grid { grid-template-columns: repeat(4, 1fr) !important; }

  .gz-home .passos__list { grid-template-columns: repeat(4, 1fr) !important; position: relative !important; }
  .gz-home .passos__list--5 {
    grid-template-columns: repeat(6, 1fr) !important;
    column-gap: 22px !important;
    row-gap: 36px !important;
  }
  .gz-home .passos__list--5 .passos__item { grid-column: span 2 !important; }
  .gz-home .passos__list--5 .passos__item:nth-child(4),
.gz-home .passos__list--5 .passos__item:nth-child(5) { grid-column: span 3 !important; }
  .gz-home .passos__list--5::before { display: none !important; }
  .gz-home .passos__list::before {
    content: "";
    position: absolute !important;
    top: 50px !important;
    left: 12% !important;
    right: 12% !important;
    height: 1px !important;
    background: linear-gradient(90deg, transparent, rgba(230,0,0,0.5), transparent) !important;
  }

  .gz-home .porque__item {
    grid-template-columns: 60px 1fr 1.6fr !important;
    gap: 32px !important;
    align-items: baseline !important;
  }
  .gz-home .porque__item-title { margin-bottom: 0 !important; }

  .gz-home .diff__item {
    grid-template-columns: 1fr 1.5fr !important;
    gap: 40px !important;
    align-items: start !important;
    padding: 28px 0 !important;
  }
  .gz-home .diff__compare {
    grid-template-columns: 1fr 1fr !important;
    gap: 16px !important;
  }
  .gz-home .diff__market,
.gz-home .diff__garantia {
    font-size: 14px !important;
    padding: 20px !important;
    gap: 10px !important;
  }

  .gz-home .mercado__cards { grid-template-columns: 1fr 1fr !important; gap: 28px !important; }

  .gz-home .depo-card { width: 240px !important; max-width: 260px !important; }
  .gz-home .depo__head {
    grid-template-columns: 1.4fr 1fr !important;
    align-items: end !important;
  }

  .gz-home .portal__inner { grid-template-columns: 1.2fr 1fr !important; align-items: center !important; gap: 32px !important; }
  .gz-home .portal__channels { grid-template-columns: 1fr 1fr !important; }

  .gz-home .footer__top {
    flex-direction: row !important;
    justify-content: space-between !important;
    align-items: flex-start !important;
    gap: 48px !important;
  }
  .gz-home .footer__addresses {
    gap: 40px !important;
  }
  .gz-home .footer__bottom {
    flex-direction: row !important;
    justify-content: space-between !important;
    align-items: center !important;
  }
}

/* ================================================
   ► DESKTOP ≥ 1024px
================================================ */
@media (min-width: 1024px) {
  .gz-home .nav__links {
    display: flex !important;
    gap: 28px !important;
    font-family: var(--f-ui) !important;
    font-size: 13px !important;
    font-weight: 500 !important;
    color: rgba(255,255,255,0.7) !important;
  }
  .gz-home .nav__links a {
    transition: color .2s;
    position: relative !important;
  }
  .gz-home .nav__links a::after {
    content: "";
    position: absolute !important;
    left: 50% !important;
    bottom: -6px !important;
    width: 0 !important;
    height: 1.5px !important;
    background: var(--red) !important;
    transition: width .25s, left .25s;
  }
  .gz-home .nav__links a:hover { color: #fff !important; }
  .gz-home .nav__links a:hover::after { width: 100% !important; left: 0 !important; }

  .gz-home .nav__cta { display: inline-flex !important; }
  .gz-home .nav__hamburger { display: none !important; }
  .gz-home .nav__drawer { display: none !important; }

  .gz-home .hero { min-height: 100svh !important; }
  .gz-home .hero__container {
    padding-top: 0 !important;
    padding-bottom: clamp(28px, 5vh, 56px) !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
  }
  .gz-home .hero__photo { object-position: 65% 24% !important; }
  .gz-home .hero__copy { max-width: 760px !important; }
  .gz-home .hero__title { font-size: clamp(44px, 5.2vw, 68px) !important; }
  .gz-home .hero__title em { font-size: clamp(20px, 2vw, 28px) !important; margin-top: 8px !important; }
  .gz-home .hero__sub { font-size: 16px !important; max-width: 42ch !important; }
  .gz-home .hero__actions .btn--primary { font-size: 14px !important; padding: 15px 28px !important; }

  .gz-home .porque__head {
    grid-template-columns: 1fr 1.4fr !important;
    gap: 56px !important;
    align-items: end !important;
  }

  .gz-home .faq__list {
    max-width: 920px !important;
    margin: 0 auto !important;
  }
  .gz-home .faq__head { text-align: center !important; }
  .gz-home .faq__head .eyebrow { justify-content: center !important; }
}


/* ═══════════════════════════════════════════════════════════════
   LOOP FX — efeitos nos elementos reais (não brilhos de fundo)
   Gated por prefers-reduced-motion
   ══════════════════════════════════════════════════════════════ */
@media (prefers-reduced-motion: no-preference) {

  /* ── BOTÕES · sheen de luz passando ── */
  @keyframes btn-sheen {
    0%   { transform: translateX(-130%) skewX(-22deg); }
    100% { transform: translateX(360%) skewX(-22deg); }
  }
  .gz-home .btn--primary,
.gz-home .cta__btn { position: relative !important; overflow: hidden !important; }
  .gz-home .btn--primary::after,
.gz-home .cta__btn::after {
    content: "";
    position: absolute !important;
    top: 0 !important; bottom: 0 !important; left: 0 !important;
    width: 35% !important;
    background: linear-gradient(90deg, transparent, rgba(255,255,255,0.38), transparent) !important;
    transform: translateX(-130%) skewX(-22deg);
    animation: btn-sheen 4.5s ease-in-out infinite;
    animation-delay: 1.8s;
    pointer-events: none !important;
  }
  /* CTA · shimmer mais largo e forte, varrendo o botão inteiro */
  .gz-home .cta__btn::after {
    width: 80% !important;
    background: linear-gradient(90deg, transparent, rgba(255,255,255,0.7), transparent) !important;
    animation-duration: 3.6s !important;
    animation-delay: 0.6s !important;
  }

  /* ── DIFERENCIAIS · tag "No Garantia" + emoji estáticos (sem loop) ── */

  /* shimmer "Garantia" foi movido p/ fora do @media (logo abaixo) */
}

/* ── Shimmer "Garantia" — prova social + "Por que escolher" ──
   Keyframe e regra no nível raiz: minificadores podem dropar
   @keyframes aninhado dentro de @media, matando a animação. */
/* Shimmer recortado nas letras DE VERDADE (usa o próprio elemento, sem cópia
   sobreposta) e que anima no iOS. O Safari do iPhone não repinta
   background-position em background-clip:text; então, em vez disso, animamos
   a POSIÇÃO do ponto branco DENTRO do gradiente via @property. O gradiente
   muda a cada frame → o iOS repinta → o brilho corre dentro das letras.
   (Safari 16.4+ / Chrome / Firefox. Em navegador sem @property, fica um
   gradiente estático — degradação suave.) */
@property --gz-shimmer {
  syntax: "<percentage>";
  inherits: false;
  initial-value: -20%;
}
@keyframes garantia-sweep {
  0%   { --gz-shimmer: -20%; }   /* começa fora, à esquerda */
  33%  { --gz-shimmer: 120%; }   /* passada (~1,5s do ciclo de 4,5s) */
  100% { --gz-shimmer: 120%; }   /* estacionado fora = pausa (~3s) */
}
.gz-home .depo__title .accent-red.brand,
.gz-home .porque__title .accent-red.brand {
  background-image: linear-gradient(100deg,
    var(--red)  0%,
    var(--red)  calc(var(--gz-shimmer) - 14%),
    #fff        var(--gz-shimmer),
    var(--red)  calc(var(--gz-shimmer) + 14%),
    var(--red)  100%) !important;
  -webkit-background-clip: text !important;
  background-clip: text !important;
  -webkit-text-fill-color: transparent !important;
  color: transparent !important;
  /* 1 passada (rápida, ease-out) + ~3s de pausa, em loop */
  animation: garantia-sweep 4.5s cubic-bezier(0.16, 1, 0.3, 1) infinite !important;
}

/* Custom property p/ animar o ângulo do border-beam (fora de @media) */
@property --beam-angle {
  syntax: "<angle>";
  initial-value: 0deg;
  inherits: false;
}
