.elementor-4158 .elementor-element.elementor-element-b95ba97{--display:flex;--flex-direction:row;--container-widget-width:initial;--container-widget-height:100%;--container-widget-flex-grow:1;--container-widget-align-self:stretch;--flex-wrap-mobile:wrap;--justify-content:center;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-4158 .elementor-element.elementor-element-83495c2{--display:flex;--flex-direction:row;--container-widget-width:initial;--container-widget-height:100%;--container-widget-flex-grow:1;--container-widget-align-self:stretch;--flex-wrap-mobile:wrap;}.elementor-4158 .elementor-element.elementor-element-83495c2:not(.elementor-motion-effects-element-type-background), .elementor-4158 .elementor-element.elementor-element-83495c2 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:#21BA57;}.elementor-4158 .elementor-element.elementor-element-cdf2b80{--display:flex;--flex-direction:row;--container-widget-width:initial;--container-widget-height:100%;--container-widget-flex-grow:1;--container-widget-align-self:stretch;--flex-wrap-mobile:wrap;--justify-content:center;}.elementor-4158 .elementor-element.elementor-element-b70df47{--display:flex;--flex-direction:row;--container-widget-width:initial;--container-widget-height:100%;--container-widget-flex-grow:1;--container-widget-align-self:stretch;--flex-wrap-mobile:wrap;}.elementor-4158 .elementor-element.elementor-element-b70df47:not(.elementor-motion-effects-element-type-background), .elementor-4158 .elementor-element.elementor-element-b70df47 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:#0C1F11;}.elementor-4158 .elementor-element.elementor-element-ff91922{--display:flex;--flex-direction:row;--container-widget-width:initial;--container-widget-height:100%;--container-widget-flex-grow:1;--container-widget-align-self:stretch;--flex-wrap-mobile:wrap;--justify-content:center;}.elementor-4158 .elementor-element.elementor-element-7a1056d{--display:flex;--flex-direction:row;--container-widget-width:initial;--container-widget-height:100%;--container-widget-flex-grow:1;--container-widget-align-self:stretch;--flex-wrap-mobile:wrap;--justify-content:center;}.elementor-4158 .elementor-element.elementor-element-7a1056d:not(.elementor-motion-effects-element-type-background), .elementor-4158 .elementor-element.elementor-element-7a1056d > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:#F5F5F5;}.elementor-4158 .elementor-element.elementor-element-2cee8fe{--display:flex;--flex-direction:row;--container-widget-width:initial;--container-widget-height:100%;--container-widget-flex-grow:1;--container-widget-align-self:stretch;--flex-wrap-mobile:wrap;--justify-content:center;}.elementor-4158 .elementor-element.elementor-element-735c708{--display:flex;--flex-direction:row;--container-widget-width:initial;--container-widget-height:100%;--container-widget-flex-grow:1;--container-widget-align-self:stretch;--flex-wrap-mobile:wrap;--justify-content:center;}.elementor-4158 .elementor-element.elementor-element-735c708:not(.elementor-motion-effects-element-type-background), .elementor-4158 .elementor-element.elementor-element-735c708 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:#F5F5F5;}.elementor-4158 .elementor-element.elementor-element-65cf2d0{--display:flex;--flex-direction:row;--container-widget-width:initial;--container-widget-height:100%;--container-widget-flex-grow:1;--container-widget-align-self:stretch;--flex-wrap-mobile:wrap;--justify-content:center;}.elementor-4158 .elementor-element.elementor-element-f8c5a18:not(.elementor-motion-effects-element-type-background), .elementor-4158 .elementor-element.elementor-element-f8c5a18 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:#F5F5F5;}.elementor-4158 .elementor-element.elementor-element-f8c5a18 > .elementor-container{max-width:1100px;}.elementor-4158 .elementor-element.elementor-element-f8c5a18{overflow:hidden;transition:background 0.3s, border 0.3s, border-radius 0.3s, box-shadow 0.3s;margin-top:0px;margin-bottom:0px;padding:80px 0px 90px 0px;}.elementor-4158 .elementor-element.elementor-element-f8c5a18 > .elementor-background-overlay{transition:background 0.3s, border-radius 0.3s, opacity 0.3s;}.elementor-4158 .elementor-element.elementor-element-021ed39 > .elementor-element-populated{padding:0px 0px 0px 0px;}.elementor-4158 .elementor-element.elementor-element-a78d680 > .elementor-widget-container{padding:0px 0px 23px 0px;}.elementor-4158 .elementor-element.elementor-element-84d3751{width:100%;max-width:100%;}.elementor-4158 .elementor-element.elementor-element-84d3751 > .elementor-widget-container{padding:0px 0px 43px 0px;}.elementor-4158 .elementor-element.elementor-element-84d3751 .title-area{text-align:left;margin:0px 0px 20px 0px;}.elementor-4158 .elementor-element.elementor-element-84d3751 .th-title{font-size:35px;padding:0px 0px 2px 0px;}.elementor-4158 .elementor-element.elementor-element-1d72e8d{width:100%;max-width:100%;}.elementor-4158 .elementor-element.elementor-element-1d72e8d.elementor-element{--flex-grow:0;--flex-shrink:0;}.elementor-4158 .elementor-element.elementor-element-e4c6511.elementor-column > .elementor-widget-wrap{justify-content:flex-end;}.elementor-4158 .elementor-element.elementor-element-e4c6511 > .elementor-element-populated{padding:0px 0px 0px 50px;}@media(max-width:1024px){.elementor-4158 .elementor-element.elementor-element-f8c5a18{padding:80px 0px 80px 0px;}.elementor-4158 .elementor-element.elementor-element-e4c6511 > .elementor-element-populated{margin:0px 0px 40px 0px;--e-column-margin-right:0px;--e-column-margin-left:0px;padding:0px 36px 0px 36px;}}@media(max-width:767px){.elementor-4158 .elementor-element.elementor-element-021ed39 > .elementor-element-populated{margin:0px 0px 0px 0px;--e-column-margin-right:0px;--e-column-margin-left:0px;padding:0px 0px 0px 0px;}.elementor-4158 .elementor-element.elementor-element-e4c6511 > .elementor-element-populated{padding:0px 12px 0px 12px;}}@media(min-width:768px){.elementor-4158 .elementor-element.elementor-element-cdf2b80{--content-width:1140px;}.elementor-4158 .elementor-element.elementor-element-b70df47{--content-width:1140px;}.elementor-4158 .elementor-element.elementor-element-ff91922{--content-width:1140px;}.elementor-4158 .elementor-element.elementor-element-7a1056d{--content-width:1140px;}.elementor-4158 .elementor-element.elementor-element-2cee8fe{--content-width:1101px;}.elementor-4158 .elementor-element.elementor-element-735c708{--content-width:1140px;}.elementor-4158 .elementor-element.elementor-element-65cf2d0{--content-width:1140px;}.elementor-4158 .elementor-element.elementor-element-021ed39{width:40%;}.elementor-4158 .elementor-element.elementor-element-e4c6511{width:60%;}}@media(max-width:1024px) and (min-width:768px){.elementor-4158 .elementor-element.elementor-element-021ed39{width:100%;}.elementor-4158 .elementor-element.elementor-element-e4c6511{width:100%;}}/* Start custom CSS for html, class: .elementor-element-6daef0a *//* ===========================
   HERO — FULL WIDTH
   =========================== */
.hero,
.hero *,
.hero *::before,
.hero *::after {
  box-sizing: border-box;
}

.hero {
  position: relative;
  min-height: 100vh;
  width: 100vw;
  margin-left: calc(-50vw + 50%);
  display: flex;
  align-items: center;
  overflow: hidden;
}

.hero__bg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  z-index: 0;
}

.hero__bg-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
  display: block;
}

.hero__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    105deg,
    rgba(5, 30, 15, 0.93) 0%,
    rgba(5, 30, 15, 0.82) 40%,
    rgba(5, 30, 15, 0.45) 65%,
    rgba(5, 30, 15, 0.10) 100%
  );
}

.hero__container {
  position: relative;
  z-index: 1;
  width: 100%;
  padding: 60px 60px 80px;
  display: grid;
  grid-template-columns: 1fr 440px;
  gap: 60px;
  align-items: center;
}



/* ===========================
   COLUNA ESQUERDA
   =========================== */
.hero__left {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  /* SEM width: fit-content — deixa a coluna occupar o espaço do grid */
}

.hero__badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: rgba(29, 185, 84, 0.15);
  border: 1px solid rgba(29, 185, 84, 0.35);
  color: #4ade80;
  font-size: 0.72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .1em;
  padding: 7px 16px;
  border-radius: 50px;
  margin-bottom: 24px;
}

.hero__title {
  font-size: clamp(2rem, 3.2vw, 3rem);
  font-weight: 800;
  color: #ffffff;
  line-height: 1.25;
  margin: 0 0 20px;
  letter-spacing: -0.02em;
}

.hero__title--green {
  color: #1db954;
}

.hero__subtitle {
  font-size: 1.02rem;
  color: rgba(255,255,255,0.78);
  line-height: 1.7;
  margin: 0 0 32px;
  max-width: 500px;
}

/* ===========================
   BOTÕES
   =========================== */
.hero-btns {
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;       /* nunca quebra linha */
  gap: 14px;
  align-items: center;
  margin-bottom: 16px;     /* espaço entre botões e stats */
  width: fit-content;      /* largura natural dos 2 botões */
}

/* ===========================
   STATS — mesma largura dos botões
   =========================== */
.hero__stats {
  display: flex;
  align-items: center;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 14px;
  padding: 16px 20px;
  /* Espelha exatamente a largura dos botões */
  width: fit-content;
  min-width: fit-content;
  /* Sem max-width fixo — se adapta aos botões */
}

/* Wrapper que sincroniza largura btns ↔ stats */
.hero__btns-wrapper {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  width: fit-content;
}

.hero__btns-wrapper .hero-btns {
  margin-bottom: 16px;
  width: 100%;
}

.hero__btns-wrapper .hero__stats {
  width: 100%; /* ocupa a largura do wrapper (= largura dos btns) */
}

/* Stats internos */
.hero__stat {
  display: flex;
  flex-direction: column;
  align-items: center;
  flex: 1;
  padding: 0 8px;
}

.hero__stat strong {
  font-size: 1.4rem;
  font-weight: 800;
  color: #1db954;
  line-height: 1;
}

.hero__stat span {
  font-size: 0.68rem;
  color: rgba(255,255,255,0.55);
  margin-top: 4px;
  text-align: center;
  white-space: nowrap;
}

.hero__stat-divider {
  width: 1px;
  height: 32px;
  background: rgba(255,255,255,0.15);
  flex-shrink: 0;
}

/* ===========================
   COLUNA DIREITA — CARD
   =========================== */
.hero__right {
  display: flex;
  justify-content: flex-end;
  align-items: center;
}

.hero__card {
  background: rgba(8, 32, 18, 0.85);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
  border: 1px solid rgba(29,185,84,0.22);
  border-radius: 20px;
  padding: 32px 30px;   /* ← mais espaçoso (era 28px 26px) */
  width: 100%;
  box-shadow: 0 20px 60px rgba(0,0,0,0.45);
}

.hero__card-title {
  font-size: 1rem;        /* ← era 0.92rem */
  font-weight: 700;
  color: #fff;
  margin: 0 0 22px;
}

.hero__card-list {
  list-style: none;
  padding: 0;
  margin: 0 0 20px;
  display: flex;
  flex-direction: column;
  gap: 16px;              /* ← era 14px */
}

.hero__card-list li {
  display: flex;
  align-items: center;   /* ← centraliza ícone 3D com o texto */
  gap: 14px;             /* ← era 12px */
}

/* Ícone 3D — container da imagem */
.hero__card-icon {
  width: 42px;            /* ← era 34px */
  height: 42px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  /* Remove fundo/borda — a img 3D já tem visual próprio */
  background: transparent;
  border: none;
  border-radius: 0;
}

/* Imagem 3D dentro do ícone */
.hero__card-icon img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
}

.hero__card-list li strong {
  display: block;
  font-size: 0.92rem;    /* ← era 0.85rem */
  font-weight: 700;
  color: #fff;
  line-height: 1.3;
}

.hero__card-list li small {
  display: block;
  font-size: 0.78rem;    /* ← era 0.72rem */
  color: rgba(255,255,255,0.55); /* ← um pouco mais visível */
  margin-top: 3px;
}

.hero__card-footer {
  display: flex;
  align-items: center;
  gap: 8px;
  padding-top: 16px;
  border-top: 1px solid rgba(255,255,255,0.08);
  font-size: 0.76rem;    /* ← era 0.74rem */
  color: rgba(255,255,255,0.45);
}

/* ===========================
   RESPONSIVO ATUALIZADO
   =========================== */
@media (max-width: 1024px) {
  .hero__container {
    grid-template-columns: 1fr 400px; /* ← era 360px */
    padding: 60px 40px 60px;
    gap: 40px;
  }
}

@media (max-width: 860px) {
  .hero__container {
    grid-template-columns: 1fr;
    padding: 70px 28px 60px;
    gap: 36px;
  }

  .hero__right {
    justify-content: center;
  }

  .hero__btns-wrapper {
    width: 100%;
  }
}

@media (max-width: 500px) {
  .hero__title {
    font-size: 1.65rem;
  }

  .hero-btns {
    flex-direction: column;
    align-items: stretch;
    width: 100%;
  }

  .hero-btns .btn-primary,
  .hero-btns .btn-outline {
    text-align: center;
    justify-content: center;
    width: 100%;
    display: flex;
  }

  .hero__container {
    padding: 70px 20px 50px;
  }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-943fa42 *//* ===== TICKER ===== */
.ticker { background: var(--green); padding: 0px 0; overflow: hidden; }
.ticker-track {
  display: flex; width: max-content;
  animation: ticker 35s linear infinite;
}
.ticker-item {
  white-space: nowrap; padding: 0 15px; /* ⬅ menos espaço entre frases */
  font-size: 15px; font-weight: 500; color: #fff; letter-spacing: .5px; /* ⬅ font maior */
  display: flex; align-items: center; gap: 6px;
}
.ticker-item::before { content: none; }
.ticker-item span {
  font-size: 1.3rem; /* ⬅ emoji maior */
  line-height: 1;
}
@keyframes ticker {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-6a1eae3 *//* ===== PARA QUEM É ===== */
.for-who { padding: 90px 0; background: #fff; }
.for-who-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; margin-top: 48px;
}
.for-who-card {
  background: var(--gray); border-radius: 14px; padding: 28px;
  border-top: 4px solid transparent;
  transition: border-color .3s, transform .3s, box-shadow .3s;
}
.for-who-card:hover {
  border-color: var(--green); transform: translateY(-5px);
  box-shadow: 0 12px 30px rgba(29,185,84,.12);
}
.for-who-card .icon-wrap {
  width: 52px; height: 52px; border-radius: 12px;
  background: var(--green-light); color: var(--green);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.25rem; margin-bottom: 16px;
}
.for-who-card h4 { font-size: 1rem; font-weight: 700; margin-bottom: 8px; }
.for-who-card p  { font-size: .87rem; color: var(--text-muted); line-height: 1.65; }

/* Icon wrap adaptado para imagens 3D */
.icon-wrap.icon-img {
  width: 80px;
  height: 80px;
  border-radius: 16px;
  background: transparent;
  padding: 0;
  overflow: visible;
  margin-bottom: 16px;
}

.icon-wrap.icon-img img {
  width: 80px;
  height: 80px;
  object-fit: contain;
  display: block;
  transition: transform .3s ease;
}

.for-who-card:hover .icon-wrap.icon-img img {
  transform: scale(1.1) translateY(-4px);
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-b3fe410 *//* ===== BENEFÍCIOS ===== */

.benefits { padding: 90px 0; background: #0c1f11; }
.benefits .section-tag { background: rgba(29,185,84,.18); }
.benefits .section-title { color: #fff; }
.benefits .section-sub  { color: rgba(255,255,255,.6); }

.ben-grid {
  display: grid; grid-template-columns: repeat(2, 1fr); gap: 24px; margin-top: 52px;
}

.ben-card {
  background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.09);
  border-radius: 14px; padding: 28px; transition: background .3s, transform .3s;
}
.ben-card:hover { background: rgba(29,185,84,.1); transform: translateY(-4px); }

.ben-card .ben-icon {
  width: 56px;
  height: 56px;
  margin-bottom: 18px;
  background: transparent;
  border-radius: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}

.ben-card .ben-icon img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.ben-card h4 { color: #fff; font-size: 1.05rem; font-weight: 700; margin-bottom: 10px; }
.ben-card p  { color: rgba(255,255,255,.65); font-size: .88rem; line-height: 1.7; }

.ben-list {
  list-style: none; margin-top: 12px; display: flex; flex-direction: column; gap: 6px;
}
.ben-list li { font-size: .85rem; color: rgba(255,255,255,.65); display: flex; gap: 8px; align-items: center; }
.ben-list li i { color: var(--green); font-size: .8rem; }

.ben-card .tag {
  display: inline-block; margin-top: 14px;
  background: rgba(29,185,84,.2); color: var(--green);
  font-size: .72rem; font-weight: 700; letter-spacing: 1px;
  text-transform: uppercase; padding: 3px 10px; border-radius: 50px;
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-e2ebdc0 *//* ===== DOCUMENTOS ===== */


.docs { padding: 90px 0; background: #fff; }
.docs-grid {
  display: grid; grid-template-columns: repeat(2, 1fr); gap: 20px; margin-top: 48px;
}
.doc-card {
  display: flex; gap: 16px; align-items: flex-start;
  background: var(--gray); border-radius: 12px; padding: 22px;
  transition: transform .3s, box-shadow .3s;
}
.doc-card:hover { transform: translateY(-3px); box-shadow: var(--shadow); }

/* ⬅ Ícone 3D substituindo o número */
.doc-icon {
  width: 58px;
  height: 58px;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}
.doc-icon img {
  width: 58px;
  height: 58px;
  object-fit: contain;
  filter: drop-shadow(0 4px 8px rgba(0,0,0,0.15));
  transition: transform .3s;
}
.doc-card:hover .doc-icon img {
  transform: scale(1.12) translateY(-3px);
}

.doc-card h4 { font-size: .95rem; font-weight: 700; margin-bottom: 5px; }
.doc-card p  { font-size: .83rem; color: var(--text-muted); line-height: 1.55; }/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-5ad26a3 *//* ===== COMO FUNCIONA ===== */
.how {
  padding-top: 0;
  padding-bottom: 0;
  background: #f5f5f5;
}

.how .container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 60px 10px;
}

/* Outer */
#steps-outer {
  position: relative;
}

/* Sticky */
#steps-sticky {
  position: sticky;
  top: 0;
  height: 100vh;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  justify-content: center;
  background: #f5f5f5;
  padding: 0;
  gap: 0;
}

/* Barra de progresso */
.steps-line {
  width: 100%;
  height: 3px;
  margin: 0 0 28px 0;
  background: #e0e0e0;
  position: relative;
  overflow: hidden;
  flex-shrink: 0;
}

.steps-line .steps-line-fill {
  position: absolute;
  left: 0; top: 0;
  height: 100%;
  width: 0%;
  background: linear-gradient(90deg, #1db954, #17a349);
  transition: width 0.08s linear;
}

/* Track dos cards */
.steps-scroll {
  display: flex;
  gap: 24px;
  padding: 0 60px;
  will-change: transform;
  overflow: visible;
  flex-shrink: 0;
  width: max-content;
}

/* ===== CARDS ===== */
.step-card {
  flex: 0 0 auto;
  width: 320px;
  background: #fff;
  border-radius: 20px;
  padding: 28px 28px 28px;
  box-shadow: 0 2px 12px rgba(0,0,0,.06), 0 8px 32px rgba(0,0,0,.04);
  position: relative;
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 0.5s ease, transform 0.5s ease, box-shadow 0.3s ease;
  border: 1px solid rgba(0,0,0,.04);
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}

.step-card.visible {
  opacity: 1;
  transform: translateY(0);
}

.step-card:hover {
  box-shadow: 0 12px 40px rgba(29,185,84,.18), 0 2px 8px rgba(0,0,0,.06);
  transform: translateY(-4px);
}

/* Divisor decorativo — ajuste o "top" se mudar o tamanho do ícone */
/* fórmula: top = padding-top(28) + tamanho-ícone + margin-bottom-dot(16) + folga(8) */
/* ex: ícone 110px → top: 28 + 110 + 16 + 8 = 162px */
.step-card::after {
  content: '';
  display: block;
  position: absolute;
  top: 162px;        /* ⬅️ AJUSTE AQUI SE MUDAR O ÍCONE */
  left: 28px;
  right: 28px;
  height: 1px;
  background: linear-gradient(90deg, transparent, #eee, transparent);
}

/* ================================================
   🎯 TAMANHO DOS ÍCONES — EDITE APENAS AQUI
   Valor atual: 110px
   Sugestões:   100px | 110px | 120px | 130px
   Lembre de atualizar o "top" do ::after acima!
   ================================================ */
.step-dot {
  --icon-size: 110px;   /* ⬅️ MUDE ESTE VALOR PARA TESTAR */

  width: var(--icon-size);
  height: var(--icon-size);
  min-width: var(--icon-size);
  min-height: var(--icon-size);
  background: transparent;
  border: none;
  box-shadow: none;
  border-radius: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  margin: 0 auto 16px;
  position: relative;
  z-index: 2;
}

.step-dot img {
  width: var(--icon-size) !important;
  height: var(--icon-size) !important;
  min-width: var(--icon-size) !important;
  min-height: var(--icon-size) !important;
  max-width: var(--icon-size) !important;
  max-height: var(--icon-size) !important;
  object-fit: contain;
  filter: drop-shadow(0 6px 14px rgba(0,0,0,0.18));
  transition: transform 0.3s ease;
  display: block;
}

.step-dot span {
  display: none;
}

.step-card:hover .step-dot img {
  transform: scale(1.12) rotate(-4deg);
}

/* ===== LABELS ===== */
.step-label {
  display: inline-block;
  background: #e8f8ee;
  color: #1db954;
  font-size: 0.70rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .07em;
  padding: 4px 12px;
  border-radius: 20px;
  margin-bottom: 14px;
}

/* ===== TEXTOS ===== */
.step-body {
  width: 100%;
}

.step-body h4 {
  font-size: 1.08rem;
  font-weight: 700;
  margin: 0 0 10px;
  color: #1a1a1a;
  line-height: 1.3;
}

.step-body p {
  font-size: 0.90rem;
  color: #666;
  line-height: 1.6;
  margin: 0;
}

/* ===== CARD FINAL ===== */
.step-card--final {
  background: linear-gradient(145deg, #0d2418, #163529);
  border: 1.5px solid rgba(29,185,84,0.45);
  box-shadow: 0 8px 32px rgba(29,185,84,0.20), 0 2px 8px rgba(0,0,0,.20);
  overflow: hidden;
}

.step-card--final::before {
  content: '';
  position: absolute;
  top: -50%; left: -60%;
  width: 55%; height: 200%;
  background: linear-gradient(105deg, transparent 35%, rgba(29,185,84,0.10) 50%, transparent 65%);
  animation: cardShine 4s ease-in-out infinite;
  pointer-events: none;
}

.step-card--final::after {
  display: none;
}

@keyframes cardShine {
  0%   { left: -60%; }
  60%  { left: 130%; }
  100% { left: 130%; }
}

.step-card--final .step-label {
  background: rgba(29,185,84,0.15);
  color: #4ade80;
  border: 1px solid rgba(29,185,84,0.25);
}

.step-card--final .step-body h4 { color: #ffffff; }
.step-card--final .step-body p  { color: #8fbfa0; }

.step-card--final .step-dot img {
  filter: drop-shadow(0 6px 18px rgba(255, 200, 0, 0.45));
}

.step-card--final:hover {
  box-shadow: 0 16px 48px rgba(29,185,84,0.35), 0 2px 8px rgba(0,0,0,.20);
  transform: translateY(-4px);
}

/* ===== DOTS DE NAVEGAÇÃO ===== */
.steps-dots {
  display: flex;
  justify-content: center;
  gap: 8px;
  margin-top: 20px;
  flex-shrink: 0;
}

.steps-dots .sdot {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: #ccc;
  cursor: pointer;
  transition: background 0.3s, transform 0.3s;
}

.steps-dots .sdot.active {
  background: #1db954;
  transform: scale(1.4);
}

/* ===== HINT ===== */
.steps-hint {
  text-align: center;
  font-size: 0.78rem;
  color: #aaa;
  margin-top: 10px;
  flex-shrink: 0;
  opacity: 1;
  transition: opacity 0.5s;
}

.steps-hint.hidden {
  opacity: 0;
}

/* ===== MOBILE ===== */
@media (max-width: 768px) {
  .how { padding: 60px 0 80px; }

  #steps-outer  { height: auto !important; }

  #steps-sticky {
    position: relative !important;
    height: auto !important;
    overflow: visible !important;
  }

  .steps-scroll {
    flex-direction: column;
    padding: 10px 20px 40px;
    transform: none !important;
    width: 100%;
  }

  .step-card {
    width: 100%;
    opacity: 1 !important;
    transform: none !important;
  }

  .steps-line,
  .steps-dots,
  .steps-hint { display: none; }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-36cdbeb *//* ===== DIFERENCIAIS ===== */

.diff { padding: 90px 0; background: #fff; }

.diff-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 52px;
  align-items: center;
  margin-top: 48px;
}

.diff-list { display: flex; flex-direction: column; gap: 18px; }

.diff-item {
  display: flex; gap: 16px; align-items: flex-start;
  background: var(--gray); border-radius: 12px; padding: 20px;
  transition: transform .3s, box-shadow .3s;
}
.diff-item:hover { transform: translateY(-2px); box-shadow: var(--shadow); }

.diff-item .icon {
  width: 52px;
  height: 52px;
  border-radius: 10px;
  background: var(--green-light);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.icon-3d {
  width: 45px;
  height: 45px;
  object-fit: contain;
}

.diff-item h4 { font-size: .95rem; font-weight: 700; margin-bottom: 4px; }
.diff-item p  { font-size: .83rem; color: var(--text-muted); line-height: 1.55; }

/* IMAGEM DIREITA */
.diff-image-wrap {
  border-radius: 20px;
  overflow: hidden;
  box-shadow: 0 24px 60px rgba(0,0,0,.12);
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
}

.diff-image {
  width: 80%;
  height: 80%;
  object-fit: contain;
  display: block;
}/* End custom CSS */
/* Start custom CSS for container, class: .elementor-element-735c708 *//* ===== DEPOIMENTOS ===== */
.testimonials { padding: 90px 0; background: var(--gray); }
.testi-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; margin-top: 48px;
}
.testi-card {
  background: #fff; border-radius: 14px; padding: 28px;
  border-bottom: 3px solid var(--green);
  box-shadow: 0 2px 16px rgba(0,0,0,.07); transition: transform .3s;
}
.testi-card:hover { transform: translateY(-5px); }
.stars { color: #f5a623; font-size: .9rem; margin-bottom: 14px; }
.testi-card p { font-size: .9rem; color: #444; line-height: 1.72; margin-bottom: 20px; font-style: italic; }
.testi-author { display: flex; align-items: center; gap: 12px; }
.avatar {
  width: 44px; height: 44px; border-radius: 50%;
  background: var(--green); color: #fff; font-weight: 800;
  display: flex; align-items: center; justify-content: center; font-size: .95rem;
}
.testi-author h5 { font-size: .9rem; font-weight: 700; }
.testi-author span { font-size: .78rem; color: var(--text-muted); }/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-3e2a179 *//* ===== FAQ ===== */
.section-tag {
  display: inline-flex;
  align-items: center;
  gap: 10px;
}

.tag-icon {
  width: 30px;
  height: 30px;
  object-fit: contain;
  flex-shrink: 0;
}

.faq { padding: 90px 0; background: #fff; }
.faq-list { max-width: 760px; margin: 48px auto 0; display: flex; flex-direction: column; gap: 12px; }
details {
  background: var(--gray); border-radius: 12px;
  box-shadow: 0 2px 10px rgba(0,0,0,.05); overflow: hidden;
}

summary {
  padding: 20px 24px;
  font-weight: 700;
  font-size: .95rem;
  cursor: pointer;
  display: flex !important;
  justify-content: space-between;
  align-items: center;
  list-style: none;
  gap: 16px; /* 👈 espaço entre texto e o + */
}

summary::-webkit-details-marker { display: none; }

summary::after {
  content: '+';
  font-size: 1.4rem;
  color: var(--green);
  font-weight: 300;
  flex-shrink: 0; /* 👈 impede que o + encolha */
  margin-left: auto; /* 👈 empurra o + para o final */
}

details[open] summary::after { content: '−'; }
details[open] summary { color: var(--green); }


.faq-body { padding: 0 24px 20px; font-size: .9rem; color: var(--text-muted); line-height: 1.72; }/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-1d72e8d */.contact-items { display: flex; flex-direction: column; gap: 14px; }
.contact-item {
  display: flex; gap: 14px; align-items: center;
  background: #fff; border-radius: 10px; padding: 14px 18px;
  box-shadow: 0 2px 8px rgba(0,0,0,.06);
}
.contact-item i { font-size: 1.1rem; color: var(--green); width: 20px; text-align: center; }
.contact-item span { font-size: .9rem; font-weight: 600; }/* End custom CSS */