/* Acrilsoft landing upgrade v1
   Camada visual isolada para a home pública. Mantém o CSS legado intacto. */

body.landing-page {
  --ink-deep: #081d3f;
  --ink-blue: #0d3d8f;
  --blueprint-line: rgba(31, 116, 255, 0.075);
  background:
    radial-gradient(circle at 14% 8%, rgba(84, 180, 255, 0.28), transparent 28%),
    radial-gradient(circle at 92% 14%, rgba(31, 116, 255, 0.16), transparent 25%),
    linear-gradient(180deg, #f7fbff 0%, #edf6ff 44%, #f9fcff 100%);
}

body.landing-page .site-shell::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  opacity: 0.7;
  background-image:
    linear-gradient(var(--blueprint-line) 1px, transparent 1px),
    linear-gradient(90deg, var(--blueprint-line) 1px, transparent 1px),
    linear-gradient(rgba(31, 116, 255, 0.045) 1px, transparent 1px),
    linear-gradient(90deg, rgba(31, 116, 255, 0.045) 1px, transparent 1px);
  background-size: 72px 72px, 72px 72px, 18px 18px, 18px 18px;
  mask-image: linear-gradient(180deg, #000 0%, rgba(0,0,0,.75) 45%, transparent 100%);
}

body.landing-page .topbar,
body.landing-page main {
  position: relative;
  z-index: 1;
}

body.landing-page .nav {
  background: rgba(255, 255, 255, 0.82);
  box-shadow: 0 18px 44px rgba(23, 80, 165, 0.11);
}

body.landing-page .hero {
  isolation: isolate;
  padding-top: 76px;
}

body.landing-page .hero::before {
  content: "";
  position: absolute;
  inset: 34px 4vw auto;
  height: 520px;
  border-radius: 48px;
  z-index: -1;
  background:
    linear-gradient(135deg, rgba(255,255,255,.74), rgba(231,244,255,.58)),
    radial-gradient(circle at 16% 20%, rgba(31,116,255,.15), transparent 26%),
    radial-gradient(circle at 84% 34%, rgba(124,199,255,.22), transparent 25%);
  border: 1px solid rgba(153,194,251,.28);
  box-shadow: 0 36px 100px rgba(34, 94, 180, 0.12);
}

body.landing-page .notice-pill {
  justify-content: center;
  text-align: center;
  color: #0e356c;
  background: rgba(255,255,255,.82);
  border-color: rgba(31,116,255,.22);
}

body.landing-page .eyebrow,
body.landing-page .section-tag {
  background: rgba(255,255,255,.92);
  border-color: rgba(31,116,255,.22);
}

body.landing-page .hero h1 {
  max-width: 11.6em;
  color: var(--ink-deep);
  text-wrap: balance;
}

body.landing-page .hero-text {
  color: #3d5f8d;
}

body.landing-page .hero-trust-pill {
  background: rgba(255,255,255,.88);
}

body.landing-page .metric-card {
  position: relative;
  overflow: hidden;
  background: linear-gradient(180deg, rgba(255,255,255,.94), rgba(240,248,255,.86));
}

body.landing-page .metric-card::before {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  width: 4px;
  background: linear-gradient(180deg, #0f70ff, #7cc7ff);
}

body.landing-page .hero-visual {
  perspective: 1200px;
}

body.landing-page .mockup-card-real {
  transform: rotateX(0deg) rotateY(-3deg);
  border-color: rgba(31,116,255,.30);
  box-shadow: 0 34px 96px rgba(13, 61, 143, 0.18);
}

body.landing-page .mockup-card-real::after {
  content: "";
  position: absolute;
  inset: -1px;
  border-radius: inherit;
  pointer-events: none;
  background: linear-gradient(135deg, rgba(31,116,255,.35), transparent 18%, transparent 78%, rgba(124,199,255,.28));
  mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  padding: 1px;
  -webkit-mask-composite: xor;
  mask-composite: exclude;
}

body.landing-page .operation-stack {
  position: absolute;
  inset: 0;
  z-index: 5;
  pointer-events: none;
}

body.landing-page .operation-chip {
  position: absolute;
  display: grid;
  gap: 3px;
  min-width: 184px;
  padding: 13px 15px;
  border-radius: 18px;
  background: rgba(255,255,255,.94);
  border: 1px solid rgba(31,116,255,.22);
  box-shadow: 0 18px 40px rgba(13,61,143,.14);
  backdrop-filter: blur(14px);
  animation: acrilsoftFloat 5.8s ease-in-out infinite;
}

body.landing-page .operation-chip strong {
  color: var(--ink-deep);
  font-size: .92rem;
  letter-spacing: -.02em;
}

body.landing-page .operation-chip small {
  color: #4e6d95;
  font-weight: 650;
}

body.landing-page .chip-order {
  left: -36px;
  top: 90px;
}

body.landing-page .chip-sheet {
  right: -34px;
  top: 210px;
  animation-delay: -1.6s;
}

body.landing-page .chip-delivery {
  left: 22px;
  bottom: -18px;
  animation-delay: -3.1s;
}

@keyframes acrilsoftFloat {
  0%, 100% { transform: translate3d(0, 0, 0); }
  50% { transform: translate3d(0, -10px, 0); }
}

body.landing-page .pain-card,
body.landing-page .how-card,
body.landing-page .info-card,
body.landing-page .benefit-card,
body.landing-page .trust-card,
body.landing-page .seo-link-card,
body.landing-page .pricing-home-card,
body.landing-page .final-mini,
body.landing-page .faq-item {
  position: relative;
  overflow: hidden;
}

body.landing-page .pain-card::after,
body.landing-page .how-card::after,
body.landing-page .info-card::after,
body.landing-page .benefit-card::after,
body.landing-page .trust-card::after,
body.landing-page .seo-link-card::after,
body.landing-page .pricing-home-card::after,
body.landing-page .final-mini::after {
  content: "";
  position: absolute;
  right: 18px;
  top: 18px;
  width: 34px;
  height: 34px;
  border-top: 1px solid rgba(31,116,255,.16);
  border-right: 1px solid rgba(31,116,255,.16);
  border-radius: 0 13px 0 0;
  pointer-events: none;
}

body.landing-page .pain-card span {
  background: linear-gradient(135deg, rgba(255, 244, 224, .95), rgba(255, 229, 205, .86));
  color: #b45309;
  box-shadow: inset 0 0 0 1px rgba(180,83,9,.11);
}

body.landing-page .modules-grid {
  align-items: stretch;
}

body.landing-page .info-card:not(.featured-info-card) {
  background: linear-gradient(180deg, rgba(255,255,255,.96), rgba(243,249,255,.88));
}

body.landing-page .featured-info-card {
  background:
    radial-gradient(circle at 12% 12%, rgba(124,199,255,.28), transparent 28%),
    linear-gradient(160deg, #08245b 0%, #1557d4 58%, #1f74ff 100%);
}

body.landing-page .how-grid {
  position: relative;
}

body.landing-page .how-grid::before {
  content: "";
  position: absolute;
  left: 9%;
  right: 9%;
  top: 42px;
  height: 2px;
  background: linear-gradient(90deg, transparent, rgba(31,116,255,.25), transparent);
}

body.landing-page .how-card {
  z-index: 1;
}

body.landing-page .process-box,
body.landing-page .client-access-strip {
  background:
    radial-gradient(circle at 10% 12%, rgba(124,199,255,.25), transparent 28%),
    linear-gradient(135deg, #061a3b 0%, #0d3d8f 58%, #1f74ff 100%);
}

body.landing-page .shot-card img,
body.landing-page .screenshot-frame-real > img,
body.landing-page .floating-shot img {
  image-rendering: auto;
}

body.landing-page .faq-item summary:focus-visible,
body.landing-page .btn:focus-visible,
body.landing-page .menu-toggle:focus-visible,
body.landing-page .nav-links a:focus-visible {
  outline: 3px solid rgba(31,116,255,.30);
  outline-offset: 3px;
}

@media (prefers-reduced-motion: no-preference) {
  html.reveal-ready .landing-reveal {
    opacity: 0;
    transform: translateY(26px);
    transition:
      opacity .72s cubic-bezier(.2,.8,.2,1),
      transform .72s cubic-bezier(.2,.8,.2,1),
      box-shadow .18s ease,
      border-color .18s ease;
    transition-delay: var(--reveal-delay, 0ms);
    will-change: opacity, transform;
  }

  html.reveal-ready .landing-reveal--left {
    transform: translateX(-28px);
  }

  html.reveal-ready .landing-reveal--right {
    transform: translateX(28px);
  }

  html.reveal-ready .landing-reveal.is-visible {
    opacity: 1;
    transform: translate3d(0,0,0);
  }
}

@media (prefers-reduced-motion: reduce) {
  body.landing-page .operation-chip {
    animation: none;
  }
}

@media (max-width: 1180px) {
  body.landing-page .chip-order,
  body.landing-page .chip-sheet {
    left: auto;
    right: 14px;
  }

  body.landing-page .chip-order { top: 78px; }
  body.landing-page .chip-sheet { top: 166px; }
  body.landing-page .chip-delivery { left: 16px; bottom: 16px; }
}

@media (max-width: 1080px) {
  body.landing-page .mockup-card-real {
    transform: none;
  }

  body.landing-page .operation-stack {
    display: none;
  }

  body.landing-page .how-grid::before {
    display: none;
  }
}

@media (max-width: 720px) {
  body.landing-page .hero {
    padding-top: 42px;
  }

  body.landing-page .hero::before {
    inset: 18px 12px auto;
    height: 640px;
    border-radius: 30px;
  }

  body.landing-page .notice-pill {
    text-align: left;
    justify-content: flex-start;
  }

  body.landing-page .hero h1 {
    font-size: clamp(2.25rem, 12vw, 3.2rem);
    letter-spacing: -.06em;
  }

  body.landing-page .mockup-top {
    align-items: flex-start;
    flex-direction: column;
  }

  body.landing-page .pricing-home-actions .btn,
  body.landing-page .final-actions .btn,
  body.landing-page .pricing-home-card .btn {
    width: 100%;
  }
}

/* Landing Visual V2 - ajustes finos a partir dos prints reais
   Mantém a V1 e corrige proporção, contraste e encaixe do hero/fluxo. */
body.landing-page .hero {
  padding-top: 52px;
  padding-bottom: 72px;
}

body.landing-page .hero::before {
  inset: 22px 3.4vw auto;
  height: 505px;
  border-radius: 44px;
}

body.landing-page .notice-strip {
  display: flex;
  justify-content: center;
  margin-bottom: 24px;
}

body.landing-page .notice-pill {
  width: auto;
  max-width: 900px;
  padding: 12px 22px;
  border-radius: 17px;
  line-height: 1.55;
}

body.landing-page .hero-grid {
  grid-template-columns: minmax(0, 1.12fr) minmax(420px, .88fr);
  gap: 42px;
  align-items: start;
}

body.landing-page .hero-copy {
  padding-top: 18px;
}

body.landing-page .hero h1 {
  font-size: clamp(2.95rem, 4.45vw, 4.35rem);
  line-height: 1.035;
  letter-spacing: -.06em;
  max-width: 10.8em;
}

body.landing-page .hero-text {
  font-size: 1.04rem;
  line-height: 1.78;
  margin-top: 20px;
}

body.landing-page .hero-actions {
  margin-top: 24px;
}

body.landing-page .hero-trust-note {
  margin-top: 14px;
}

body.landing-page .hero-metrics {
  margin-top: 22px;
}

body.landing-page .metric-card {
  padding: 16px 16px 14px;
}

body.landing-page .hero-visual {
  padding-top: 72px;
}

body.landing-page .mockup-card-real {
  padding: 23px;
  transform: rotateY(-2deg);
}

body.landing-page .operation-chip {
  min-width: 164px;
  padding: 11px 13px;
  border-radius: 16px;
}

body.landing-page .operation-chip strong {
  font-size: .86rem;
}

body.landing-page .operation-chip small {
  font-size: .78rem;
}

body.landing-page .chip-order {
  left: -66px;
  top: 126px;
}

body.landing-page .chip-sheet {
  right: -38px;
  top: 224px;
}

body.landing-page .chip-delivery {
  left: 10px;
  bottom: -20px;
}

body.landing-page .process-box {
  padding: 42px 36px;
  gap: 32px;
  border-radius: 34px;
}

body.landing-page .process-box .section-tag-light {
  color: #dbeafe;
  background: rgba(255,255,255,.11);
  border-color: rgba(255,255,255,.20);
  box-shadow: none;
}

body.landing-page .process-intro h2 {
  font-size: clamp(2.45rem, 4.2vw, 4.25rem);
  line-height: 1.04;
  letter-spacing: -.055em;
  max-width: 11ch;
}

body.landing-page .process-intro p {
  max-width: 44ch;
  font-size: 1.04rem;
  line-height: 1.75;
}

body.landing-page .step-card {
  padding: 22px 24px;
  border-radius: 24px;
}

body.landing-page .step-card span {
  margin-bottom: 12px;
}

body.landing-page .step-card h3 {
  margin-bottom: 8px;
  font-size: 1.2rem;
}

body.landing-page .step-card p {
  line-height: 1.68;
}

@media (max-width: 1180px) {
  body.landing-page .hero-grid {
    grid-template-columns: 1fr 1fr;
    gap: 32px;
  }

  body.landing-page .hero-visual {
    padding-top: 58px;
  }

  body.landing-page .chip-order {
    left: -22px;
    right: auto;
    top: 104px;
  }

  body.landing-page .chip-sheet {
    right: -12px;
    top: 198px;
  }
}

@media (max-width: 1080px) {
  body.landing-page .hero-grid {
    grid-template-columns: 1fr;
  }

  body.landing-page .hero-visual {
    padding-top: 8px;
  }
}

@media (max-width: 980px) {
  body.landing-page .hero {
    padding-top: 42px;
  }

  body.landing-page .hero-copy {
    padding-top: 0;
  }

  body.landing-page .notice-strip {
    margin-bottom: 18px;
  }

  body.landing-page .notice-pill {
    max-width: 100%;
  }

  body.landing-page .process-box {
    padding: 30px;
  }
}

@media (max-width: 720px) {
  body.landing-page .hero {
    padding-top: 32px;
    padding-bottom: 48px;
  }

  body.landing-page .hero::before {
    height: 600px;
  }

  body.landing-page .notice-strip {
    justify-content: stretch;
  }

  body.landing-page .notice-pill {
    width: 100%;
    padding: 12px 16px;
  }

  body.landing-page .hero h1 {
    font-size: clamp(2.28rem, 11vw, 3.12rem);
  }

  body.landing-page .process-box {
    padding: 24px;
    border-radius: 28px;
  }

  body.landing-page .process-intro h2 {
    font-size: clamp(2.15rem, 10vw, 3rem);
  }
}

/* Landing Visual V3 - correção do header/logo sobre o background
   O patch V1 colocou topbar e main no mesmo z-index. Como o main vem depois no DOM,
   a onda do hero podia passar visualmente por cima do header. */
body.landing-page .site-shell {
  isolation: isolate;
}

body.landing-page .topbar {
  position: sticky;
  top: 0;
  z-index: 120;
}

body.landing-page main {
  position: relative;
  z-index: 1;
}

body.landing-page .nav {
  position: relative;
  z-index: 2;
  background: rgba(255, 255, 255, 0.96);
  border-color: rgba(167, 202, 247, 0.48);
  box-shadow: 0 18px 44px rgba(23, 80, 165, 0.13);
}

body.landing-page .brand,
body.landing-page .brand img,
body.landing-page .nav-links,
body.landing-page .menu-toggle {
  position: relative;
  z-index: 3;
}

body.landing-page .hero {
  z-index: 0;
}

body.landing-page .hero-wave,
body.landing-page .hero-glow {
  z-index: 0;
}

body.landing-page .notice-strip,
body.landing-page .hero-grid {
  position: relative;
  z-index: 2;
}

@media (max-width: 720px) {
  body.landing-page .topbar {
    z-index: 140;
  }

  body.landing-page .nav {
    background: rgba(255, 255, 255, 0.98);
  }
}

/* Landing Visual V4 - blocos intermediários com identidade operacional
   Melhora a leitura de problemas, módulos e fluxo sem tocar em rotas. */
body.landing-page .pain-section {
  padding-top: 64px;
}

body.landing-page .pain-grid {
  display: grid;
  grid-template-columns: repeat(12, minmax(0, 1fr));
  gap: 16px;
}

body.landing-page .pain-card {
  grid-column: span 4;
  min-height: 188px;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  border-color: rgba(245, 158, 11, 0.20);
  background:
    radial-gradient(circle at 82% 18%, rgba(255, 187, 95, 0.16), transparent 34%),
    linear-gradient(180deg, rgba(255,255,255,.95), rgba(255,249,239,.86));
}

body.landing-page .pain-card:nth-child(1),
body.landing-page .pain-card:nth-child(2) {
  grid-column: span 6;
}

body.landing-page .pain-card span {
  width: 38px;
  height: 38px;
  border-radius: 15px;
}

body.landing-page .pain-card h3 {
  font-size: 1.12rem;
}

body.landing-page .pain-conversion-note {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  margin-top: 18px;
  padding: 18px 22px;
  border-radius: 24px;
  color: #fff;
  background:
    linear-gradient(135deg, rgba(8,29,63,.96), rgba(13,61,143,.94)),
    radial-gradient(circle at 12% 50%, rgba(124,199,255,.22), transparent 30%);
  border: 1px solid rgba(124,199,255,.24);
  box-shadow: 0 22px 46px rgba(13,61,143,.18);
}

body.landing-page .pain-conversion-note strong {
  flex: 0 0 auto;
  font-size: 1.02rem;
  letter-spacing: -.02em;
}

body.landing-page .pain-conversion-note span {
  color: rgba(255,255,255,.82);
  line-height: 1.65;
}

body.landing-page .audience-box {
  position: relative;
  overflow: hidden;
}

body.landing-page .audience-box::before {
  content: "nichos atendidos";
  position: absolute;
  right: 26px;
  top: 22px;
  color: rgba(31,116,255,.13);
  font-weight: 900;
  letter-spacing: .18em;
  text-transform: uppercase;
  pointer-events: none;
}

body.landing-page .audience-tag {
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}

body.landing-page .audience-tag:hover {
  transform: translateY(-2px);
  border-color: rgba(31,116,255,.36);
  box-shadow: 0 16px 28px rgba(50,112,200,.10);
}

body.landing-page .modules-section {
  position: relative;
}

body.landing-page .modules-section::before {
  content: "";
  position: absolute;
  inset: 24px 0 auto;
  height: 64%;
  pointer-events: none;
  background:
    radial-gradient(circle at 16% 20%, rgba(31,116,255,.10), transparent 30%),
    radial-gradient(circle at 86% 62%, rgba(124,199,255,.14), transparent 30%);
  opacity: .9;
}

body.landing-page .modules-section .container {
  position: relative;
}

body.landing-page .modules-grid {
  grid-template-columns: repeat(12, minmax(0, 1fr));
  gap: 16px;
}

body.landing-page .modules-grid .info-card {
  grid-column: span 4;
  min-height: 250px;
  padding: 24px;
}

body.landing-page .modules-grid .info-card:nth-child(1) {
  grid-column: span 5;
}

body.landing-page .modules-grid .info-card:nth-child(2) {
  grid-column: span 3;
}

body.landing-page .modules-grid .info-card:nth-child(3) {
  grid-column: span 4;
}

body.landing-page .modules-grid .info-card h3 {
  font-size: 1.24rem;
}

body.landing-page .modules-grid .info-card p {
  line-height: 1.68;
}

body.landing-page .featured-info-card::before {
  content: "entrada da operação";
  position: absolute;
  right: 22px;
  top: 22px;
  padding: 7px 10px;
  border-radius: 999px;
  background: rgba(255,255,255,.14);
  color: rgba(255,255,255,.84);
  font-size: .68rem;
  font-weight: 900;
  letter-spacing: .12em;
  text-transform: uppercase;
}

body.landing-page .module-flow-ribbon {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 18px;
  padding: 16px;
  border-radius: 26px;
  background: rgba(255,255,255,.78);
  border: 1px solid rgba(153,194,251,.30);
  box-shadow: 0 18px 36px rgba(34,94,180,.09);
  backdrop-filter: blur(12px);
}

body.landing-page .module-flow-ribbon span {
  display: inline-flex;
  align-items: center;
  min-height: 38px;
  padding: 0 14px;
  border-radius: 999px;
  background: linear-gradient(180deg, rgba(255,255,255,.96), rgba(238,247,255,.88));
  border: 1px solid rgba(153,194,251,.28);
  color: var(--ink-deep);
  font-size: .88rem;
  font-weight: 850;
  letter-spacing: -.01em;
}

body.landing-page .module-flow-ribbon i {
  width: 34px;
  height: 1px;
  position: relative;
  background: linear-gradient(90deg, rgba(31,116,255,.18), rgba(31,116,255,.54));
}

body.landing-page .module-flow-ribbon i::after {
  content: "";
  position: absolute;
  right: -1px;
  top: 50%;
  width: 7px;
  height: 7px;
  border-right: 2px solid rgba(31,116,255,.58);
  border-top: 2px solid rgba(31,116,255,.58);
  transform: translateY(-50%) rotate(45deg);
}

body.landing-page .panel-section {
  position: relative;
}

body.landing-page .panel-grid {
  align-items: start;
}

body.landing-page .panel-copy {
  position: sticky;
  top: 116px;
}

body.landing-page .shot-stack {
  position: relative;
}

body.landing-page .shot-stack::before {
  content: "prints reais";
  position: absolute;
  left: -10px;
  top: -14px;
  z-index: 2;
  padding: 8px 11px;
  border-radius: 999px;
  background: linear-gradient(135deg,#0f70ff,#62c7ff);
  color: #fff;
  font-size: .72rem;
  font-weight: 900;
  letter-spacing: .10em;
  text-transform: uppercase;
  box-shadow: 0 14px 28px rgba(31,116,255,.20);
}

body.landing-page .shot-card {
  transform-origin: center;
}

body.landing-page .shot-card:nth-child(2) {
  margin-left: 44px;
  margin-top: -4px;
}

body.landing-page .how-card {
  min-height: 218px;
}

body.landing-page .how-card .num {
  box-shadow: 0 14px 28px rgba(31,116,255,.18);
}

body.landing-page .process-box {
  position: relative;
  overflow: hidden;
}

body.landing-page .process-box::after {
  content: "";
  position: absolute;
  right: -80px;
  bottom: -90px;
  width: 260px;
  height: 260px;
  border-radius: 999px;
  border: 42px solid rgba(255,255,255,.06);
  pointer-events: none;
}

body.landing-page .step-card {
  position: relative;
  overflow: hidden;
}

body.landing-page .step-card::before {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  width: 4px;
  background: linear-gradient(180deg, rgba(124,199,255,.95), rgba(255,255,255,.20));
}

@media (max-width: 1080px) {
  body.landing-page .pain-grid,
  body.landing-page .modules-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  body.landing-page .pain-card,
  body.landing-page .pain-card:nth-child(1),
  body.landing-page .pain-card:nth-child(2),
  body.landing-page .modules-grid .info-card,
  body.landing-page .modules-grid .info-card:nth-child(1),
  body.landing-page .modules-grid .info-card:nth-child(2),
  body.landing-page .modules-grid .info-card:nth-child(3) {
    grid-column: auto;
  }

  body.landing-page .panel-copy {
    position: relative;
    top: auto;
  }
}

@media (max-width: 720px) {
  body.landing-page .pain-grid,
  body.landing-page .modules-grid {
    grid-template-columns: 1fr;
  }

  body.landing-page .pain-card,
  body.landing-page .modules-grid .info-card,
  body.landing-page .how-card {
    min-height: auto;
  }

  body.landing-page .pain-conversion-note {
    align-items: flex-start;
    flex-direction: column;
    padding: 18px;
  }

  body.landing-page .audience-box::before,
  body.landing-page .featured-info-card::before {
    display: none;
  }

  body.landing-page .module-flow-ribbon {
    justify-content: flex-start;
  }

  body.landing-page .module-flow-ribbon i {
    display: none;
  }

  body.landing-page .module-flow-ribbon span {
    min-height: 34px;
    padding: 0 12px;
    font-size: .82rem;
  }

  body.landing-page .shot-card:nth-child(2) {
    margin-left: 0;
  }
}

/* Landing Visual V5 - polimento do bloco "O problema"
   Ajusta proporção, respiro e faixa "A virada" após validação visual. */
body.landing-page .pain-section {
  padding-top: 54px;
  padding-bottom: 34px;
}

body.landing-page .pain-section .section-heading {
  max-width: 860px;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 34px;
}

body.landing-page .pain-section .section-heading .section-tag {
  margin-bottom: 18px;
  box-shadow: 0 12px 26px rgba(13, 61, 143, 0.08);
}

body.landing-page .pain-section .section-heading h2 {
  max-width: 790px;
  margin-left: auto;
  margin-right: auto;
  font-size: clamp(2.45rem, 3.55vw, 3.9rem);
  line-height: 1.055;
  letter-spacing: -0.058em;
  text-wrap: balance;
}

body.landing-page .pain-section .section-heading p {
  max-width: 760px;
  margin-left: auto;
  margin-right: auto;
  margin-top: 20px;
  line-height: 1.74;
}

body.landing-page .pain-grid {
  gap: 14px;
}

body.landing-page .pain-card {
  min-height: 170px;
  padding: 22px 22px 24px;
  border-radius: 22px;
  box-shadow: 0 16px 38px rgba(34, 94, 180, 0.07);
}

body.landing-page .pain-card:nth-child(1),
body.landing-page .pain-card:nth-child(2) {
  min-height: 158px;
}

body.landing-page .pain-card span {
  width: 36px;
  height: 36px;
  margin-bottom: 12px;
  font-size: .88rem;
}

body.landing-page .pain-card h3 {
  margin-bottom: 8px;
  line-height: 1.2;
}

body.landing-page .pain-card p {
  line-height: 1.6;
  max-width: 54ch;
}

body.landing-page .pain-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 24px 48px rgba(34, 94, 180, 0.11);
}

body.landing-page .pain-conversion-note {
  align-items: flex-start;
  justify-content: flex-start;
  gap: 14px;
  margin-top: 18px;
  padding: 22px 24px;
  border-radius: 24px;
  background:
    radial-gradient(circle at 8% 20%, rgba(124,199,255,.22), transparent 30%),
    linear-gradient(135deg, rgba(8,29,63,.98), rgba(13,61,143,.96));
}

body.landing-page .pain-conversion-note strong {
  display: inline-flex;
  align-items: center;
  flex: 0 0 auto;
  min-height: 34px;
  padding: 0 12px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.12);
  border: 1px solid rgba(255, 255, 255, 0.16);
  color: #fff;
  font-size: .86rem;
  letter-spacing: -.01em;
  white-space: nowrap;
}

body.landing-page .pain-conversion-note span {
  flex: 1 1 auto;
  padding-top: 3px;
  max-width: 82ch;
  color: rgba(255, 255, 255, 0.88);
  font-size: 1rem;
  font-weight: 650;
  line-height: 1.65;
}

@media (max-width: 1080px) {
  body.landing-page .pain-section .section-heading h2 {
    font-size: clamp(2.28rem, 6vw, 3.4rem);
  }

  body.landing-page .pain-card,
  body.landing-page .pain-card:nth-child(1),
  body.landing-page .pain-card:nth-child(2) {
    min-height: 164px;
  }
}

@media (max-width: 720px) {
  body.landing-page .pain-section {
    padding-top: 42px;
  }

  body.landing-page .pain-section .section-heading {
    margin-bottom: 24px;
  }

  body.landing-page .pain-section .section-heading h2 {
    font-size: clamp(2rem, 10vw, 2.85rem);
    letter-spacing: -0.052em;
  }

  body.landing-page .pain-card,
  body.landing-page .pain-card:nth-child(1),
  body.landing-page .pain-card:nth-child(2) {
    min-height: auto;
    padding: 20px;
  }

  body.landing-page .pain-conversion-note {
    gap: 10px;
    padding: 18px;
  }

  body.landing-page .pain-conversion-note strong {
    white-space: normal;
  }

  body.landing-page .pain-conversion-note span {
    padding-top: 0;
    font-size: .96rem;
  }
}

/* Landing Visual V6 - polimento do bloco "Para quem é"
   Deixa o bloco mais equilibrado, menos genérico e com leitura melhor no desktop/mobile. */
body.landing-page .audience-section {
  padding-top: 34px;
  padding-bottom: 34px;
}

body.landing-page .audience-box {
  grid-template-columns: minmax(360px, .9fr) minmax(0, 1.1fr);
  align-items: center;
  gap: 48px;
  padding: 46px 58px;
  min-height: 430px;
  border-radius: 34px;
  background:
    radial-gradient(circle at 100% 0%, rgba(31,116,255,.10), transparent 24%),
    radial-gradient(circle at 12% 86%, rgba(124,199,255,.12), transparent 30%),
    linear-gradient(135deg, rgba(255,255,255,.96), rgba(240,248,255,.88));
  border-color: rgba(153,194,251,.36);
  box-shadow: 0 26px 70px rgba(34,94,180,.10);
}

body.landing-page .audience-box::before {
  right: 34px;
  top: 28px;
  z-index: 1;
  color: rgba(31,116,255,.10);
  font-size: .9rem;
  letter-spacing: .20em;
}

body.landing-page .audience-box::after {
  right: -78px;
  top: -92px;
  width: 230px;
  height: 230px;
  background:
    radial-gradient(circle, rgba(31,116,255,.10), rgba(31,116,255,.03) 62%, transparent 63%);
  border: 1px solid rgba(31,116,255,.08);
}

body.landing-page .audience-box .section-heading {
  position: relative;
  z-index: 2;
  text-align: left;
  max-width: 500px;
}

body.landing-page .audience-box .section-tag {
  margin-bottom: 18px;
}

body.landing-page .audience-box h2 {
  max-width: 480px;
  margin: 0;
  font-size: clamp(2.45rem, 3.15vw, 3.45rem);
  line-height: 1.07;
  letter-spacing: -.058em;
  text-align: left;
  text-wrap: balance;
}

body.landing-page .audience-box p {
  max-width: 490px;
  margin: 24px 0 0;
  color: #315986;
  font-size: 1.04rem;
  line-height: 1.75;
  text-align: left;
}

body.landing-page .audience-tags {
  position: relative;
  z-index: 2;
  display: flex;
  justify-content: flex-start;
  align-content: center;
  gap: 12px;
  max-width: 640px;
  padding-top: 20px;
}

body.landing-page .audience-tags::before {
  content: "operações sob demanda";
  flex: 0 0 100%;
  width: 100%;
  margin-bottom: 2px;
  color: rgba(8,29,63,.42);
  font-size: .72rem;
  font-weight: 900;
  letter-spacing: .14em;
  text-transform: uppercase;
}

body.landing-page .audience-tag {
  min-height: 42px;
  padding: 0 16px;
  border-radius: 999px;
  background: rgba(255,255,255,.88);
  border-color: rgba(153,194,251,.34);
  color: var(--ink-deep);
  font-size: .96rem;
  font-weight: 850;
  letter-spacing: -.01em;
  box-shadow: 0 14px 30px rgba(34,94,180,.075);
  backdrop-filter: blur(10px);
}

body.landing-page .audience-tag::before {
  width: 7px;
  height: 7px;
  box-shadow: 0 0 0 4px rgba(31,116,255,.10);
}

body.landing-page .audience-tag:hover {
  transform: translateY(-3px);
  border-color: rgba(31,116,255,.42);
  box-shadow: 0 20px 38px rgba(34,94,180,.12);
}

@media (max-width: 1080px) {
  body.landing-page .audience-box {
    grid-template-columns: 1fr;
    gap: 30px;
    padding: 38px;
    min-height: auto;
  }

  body.landing-page .audience-box .section-heading,
  body.landing-page .audience-box h2,
  body.landing-page .audience-box p,
  body.landing-page .audience-tags {
    max-width: none;
  }

  body.landing-page .audience-tags {
    padding-top: 0;
  }
}

@media (max-width: 720px) {
  body.landing-page .audience-section {
    padding-top: 24px;
  }

  body.landing-page .audience-box {
    padding: 26px 22px;
    border-radius: 28px;
  }

  body.landing-page .audience-box h2 {
    font-size: clamp(2rem, 9vw, 2.85rem);
    letter-spacing: -.052em;
  }

  body.landing-page .audience-box p {
    margin-top: 16px;
    font-size: .98rem;
  }

  body.landing-page .audience-tags::before {
    display: block;
  }

  body.landing-page .audience-tag {
    width: 100%;
    justify-content: flex-start;
    min-height: 40px;
  }
}

/* Landing Visual V7 - polimento do bloco "Solução Acrilsoft"
   Transforma os módulos em um painel operacional mais premium e menos genérico. */
body.landing-page .modules-section {
  padding-top: 46px;
  padding-bottom: 58px;
}

body.landing-page .modules-section .container {
  position: relative;
  isolation: isolate;
}

body.landing-page .modules-section .container::before {
  content: "";
  position: absolute;
  left: -28px;
  right: -28px;
  top: 86px;
  bottom: -18px;
  z-index: 0;
  pointer-events: none;
  border-radius: 42px;
  background:
    radial-gradient(circle at 14% 16%, rgba(31,116,255,.10), transparent 28%),
    radial-gradient(circle at 84% 84%, rgba(124,199,255,.14), transparent 30%),
    linear-gradient(135deg, rgba(255,255,255,.70), rgba(235,246,255,.55));
  border: 1px solid rgba(153,194,251,.24);
  box-shadow: 0 30px 90px rgba(34,94,180,.08);
}

body.landing-page .modules-section .section-heading,
body.landing-page .modules-section .modules-grid,
body.landing-page .modules-section .module-flow-ribbon {
  position: relative;
  z-index: 1;
}

body.landing-page .modules-section .section-heading {
  max-width: 860px;
  margin-bottom: 28px;
}

body.landing-page .modules-section .section-heading .section-tag {
  margin-bottom: 18px;
  box-shadow: 0 12px 26px rgba(13,61,143,.08);
}

body.landing-page .modules-section .section-heading h2 {
  max-width: 820px;
  margin-left: auto;
  margin-right: auto;
  font-size: clamp(2.35rem, 3.3vw, 3.55rem);
  line-height: 1.06;
  letter-spacing: -.058em;
  text-wrap: balance;
}

body.landing-page .modules-section .section-heading p {
  max-width: 720px;
  margin-top: 20px;
  line-height: 1.74;
}

body.landing-page .modules-grid {
  gap: 18px;
  margin-top: 30px;
}

body.landing-page .modules-grid .info-card {
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  min-height: 244px;
  padding: 26px;
  border-radius: 28px;
  border-color: rgba(153,194,251,.32);
  background:
    radial-gradient(circle at 84% 14%, rgba(124,199,255,.13), transparent 32%),
    linear-gradient(180deg, rgba(255,255,255,.96), rgba(241,248,255,.88));
  box-shadow: 0 18px 44px rgba(34,94,180,.075);
}

body.landing-page .modules-grid .info-card:nth-child(1) {
  grid-column: span 5;
}

body.landing-page .modules-grid .info-card:nth-child(2) {
  grid-column: span 3;
}

body.landing-page .modules-grid .info-card:nth-child(3) {
  grid-column: span 4;
}

body.landing-page .modules-grid .info-card:nth-child(n+4) {
  min-height: 220px;
}

body.landing-page .modules-grid .info-card:hover {
  transform: translateY(-5px);
  border-color: rgba(31,116,255,.34);
  box-shadow: 0 28px 62px rgba(34,94,180,.13);
}

body.landing-page .modules-grid .info-card .icon-wrap {
  width: 64px;
  height: 64px;
  border-radius: 22px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.88), rgba(225,242,255,.86));
  border-color: rgba(153,194,251,.36);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.9), 0 16px 30px rgba(34,94,180,.08);
}

body.landing-page .modules-grid .info-card .icon-wrap img {
  width: 30px;
  height: 30px;
}

body.landing-page .modules-grid .info-card h3 {
  margin-top: 24px;
  font-size: 1.28rem;
  line-height: 1.16;
}

body.landing-page .modules-grid .info-card p {
  margin-top: 12px;
  max-width: 48ch;
  line-height: 1.68;
}

body.landing-page .modules-grid .featured-info-card {
  min-height: 244px;
  background:
    radial-gradient(circle at 16% 14%, rgba(124,199,255,.26), transparent 30%),
    linear-gradient(150deg, #071d45 0%, #114bb7 56%, #1f74ff 100%);
  border-color: rgba(124,199,255,.28);
  box-shadow: 0 28px 62px rgba(13,61,143,.22);
}

body.landing-page .modules-grid .featured-info-card::before {
  top: 24px;
  right: 24px;
  background: rgba(255,255,255,.13);
  border: 1px solid rgba(255,255,255,.18);
  color: rgba(255,255,255,.88);
}

body.landing-page .modules-grid .featured-info-card::after {
  border-color: rgba(255,255,255,.18);
}

body.landing-page .modules-grid .featured-info-card .icon-wrap {
  background: rgba(255,255,255,.14);
  border-color: rgba(255,255,255,.22);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.22), 0 18px 32px rgba(0,0,0,.08);
}

body.landing-page .modules-grid .featured-info-card h3 {
  color: #fff;
  text-shadow: 0 1px 0 rgba(0,0,0,.12);
}

body.landing-page .modules-grid .featured-info-card p {
  color: rgba(255,255,255,.88);
}

body.landing-page .module-flow-ribbon {
  max-width: 1110px;
  margin: 22px auto 0;
  padding: 14px 18px;
  border-radius: 28px;
  background: rgba(255,255,255,.86);
  border-color: rgba(153,194,251,.34);
  box-shadow: 0 22px 48px rgba(34,94,180,.10);
}

body.landing-page .module-flow-ribbon::before {
  content: "fluxo resumido";
  display: inline-flex;
  align-items: center;
  min-height: 36px;
  padding: 0 12px;
  border-radius: 999px;
  background: linear-gradient(135deg, rgba(8,29,63,.96), rgba(13,61,143,.94));
  color: #fff;
  font-size: .68rem;
  font-weight: 900;
  letter-spacing: .13em;
  text-transform: uppercase;
  box-shadow: 0 14px 28px rgba(13,61,143,.16);
}

body.landing-page .module-flow-ribbon span {
  min-height: 36px;
  padding: 0 13px;
  font-size: .86rem;
  background: linear-gradient(180deg, #fff, #eef7ff);
}

body.landing-page .module-flow-ribbon i {
  width: 26px;
}

@media (max-width: 1080px) {
  body.landing-page .modules-section .container::before {
    left: -10px;
    right: -10px;
    top: 70px;
    border-radius: 34px;
  }

  body.landing-page .modules-grid .info-card,
  body.landing-page .modules-grid .info-card:nth-child(1),
  body.landing-page .modules-grid .info-card:nth-child(2),
  body.landing-page .modules-grid .info-card:nth-child(3) {
    grid-column: auto;
    min-height: 226px;
  }

  body.landing-page .module-flow-ribbon {
    justify-content: flex-start;
  }
}

@media (max-width: 720px) {
  body.landing-page .modules-section {
    padding-top: 36px;
    padding-bottom: 42px;
  }

  body.landing-page .modules-section .container::before {
    inset: 58px 0 -8px;
    border-radius: 28px;
  }

  body.landing-page .modules-section .section-heading h2 {
    font-size: clamp(2rem, 9.4vw, 2.85rem);
    letter-spacing: -.052em;
  }

  body.landing-page .modules-grid {
    gap: 14px;
  }

  body.landing-page .modules-grid .info-card,
  body.landing-page .modules-grid .featured-info-card,
  body.landing-page .modules-grid .info-card:nth-child(n+4) {
    min-height: auto;
    padding: 22px;
    border-radius: 24px;
  }

  body.landing-page .modules-grid .info-card .icon-wrap {
    width: 58px;
    height: 58px;
    border-radius: 19px;
  }

  body.landing-page .modules-grid .featured-info-card::before {
    position: static;
    display: inline-flex;
    width: fit-content;
    margin-bottom: 16px;
  }

  body.landing-page .module-flow-ribbon {
    padding: 14px;
    border-radius: 24px;
  }

  body.landing-page .module-flow-ribbon::before {
    flex: 0 0 100%;
    justify-content: center;
    width: 100%;
  }
}

/* Landing Visual V8 - polimento do bloco "Módulo de brindes"
   Corrige proporção do título, encaixe dos prints e evita estouro horizontal em telas menores. */
body.landing-page .panel-section {
  position: relative;
  overflow-x: clip;
  padding-top: 56px;
  padding-bottom: 58px;
  scroll-margin-top: 110px;
}

body.landing-page .panel-section .section-wave {
  top: -12px;
  opacity: .78;
}

body.landing-page .panel-grid {
  position: relative;
  isolation: isolate;
  grid-template-columns: minmax(360px, .86fr) minmax(0, 1.14fr);
  gap: 42px;
  align-items: center;
}

body.landing-page .panel-grid::before {
  content: "";
  position: absolute;
  inset: -28px -26px -30px;
  z-index: 0;
  pointer-events: none;
  border-radius: 42px;
  background:
    radial-gradient(circle at 6% 14%, rgba(31,116,255,.10), transparent 27%),
    radial-gradient(circle at 86% 88%, rgba(124,199,255,.14), transparent 30%),
    linear-gradient(135deg, rgba(255,255,255,.70), rgba(235,246,255,.55));
  border: 1px solid rgba(153,194,251,.24);
  box-shadow: 0 30px 90px rgba(34,94,180,.08);
}

body.landing-page .panel-copy,
body.landing-page .panel-visual {
  position: relative;
  z-index: 1;
}

body.landing-page .panel-copy {
  position: relative;
  top: auto;
  max-width: 520px;
  padding: 10px 0;
}

body.landing-page .panel-copy .section-tag {
  margin-bottom: 18px;
  box-shadow: 0 12px 26px rgba(13,61,143,.08);
}

body.landing-page .panel-copy h2 {
  max-width: 10.8ch;
  margin-top: 18px;
  font-size: clamp(2.45rem, 3.55vw, 4.15rem);
  line-height: 1.04;
  letter-spacing: -.058em;
  text-wrap: balance;
}

body.landing-page .panel-copy p {
  max-width: 520px;
  margin-top: 24px;
  color: #315986;
  font-size: 1.04rem;
  line-height: 1.78;
}

body.landing-page .feature-list {
  gap: 12px;
  margin-top: 28px;
  max-width: 520px;
}

body.landing-page .feature-item {
  align-items: flex-start;
  padding: 16px 18px;
  border-radius: 22px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.96), rgba(243,249,255,.88));
  border-color: rgba(153,194,251,.32);
  box-shadow: 0 16px 36px rgba(34,94,180,.075);
}

body.landing-page .feature-item:hover {
  transform: translateY(-3px);
  border-color: rgba(31,116,255,.32);
  box-shadow: 0 24px 48px rgba(34,94,180,.12);
}

body.landing-page .feature-item img {
  width: 20px;
  height: 20px;
  flex: 0 0 20px;
  margin-top: 3px;
  filter: drop-shadow(0 8px 12px rgba(31,116,255,.16));
}

body.landing-page .feature-item span {
  color: #163d73;
  font-size: .97rem;
  font-weight: 620;
  line-height: 1.62;
}

body.landing-page .panel-visual {
  min-width: 0;
}

body.landing-page .shot-stack {
  max-width: 650px;
  margin-left: auto;
  gap: 16px;
}

body.landing-page .shot-stack::before {
  left: -8px;
  top: -16px;
  padding: 8px 12px;
  border-radius: 999px;
  letter-spacing: .09em;
  box-shadow: 0 16px 30px rgba(31,116,255,.18);
}

body.landing-page .shot-card {
  max-width: 100%;
  padding: 14px;
  border-radius: 28px;
  background:
    radial-gradient(circle at 88% 12%, rgba(124,199,255,.13), transparent 28%),
    linear-gradient(180deg, rgba(255,255,255,.97), rgba(242,248,255,.90));
  border-color: rgba(153,194,251,.34);
  box-shadow: 0 24px 62px rgba(34,94,180,.12);
  overflow: hidden;
}

body.landing-page .shot-card:hover {
  transform: translateY(-4px);
  border-color: rgba(31,116,255,.34);
  box-shadow: 0 32px 76px rgba(34,94,180,.16);
}

body.landing-page .shot-card:nth-child(2) {
  margin-left: 34px;
  margin-top: 0;
}

body.landing-page .shot-card-head {
  padding: 2px 8px 10px;
  margin-bottom: 0;
}

body.landing-page .shot-card-head strong {
  color: var(--ink-deep);
  font-size: 1.02rem;
  line-height: 1.2;
}

body.landing-page .shot-card-head span {
  color: #416693;
  font-size: .82rem;
  font-weight: 750;
  text-align: right;
}

body.landing-page .shot-card img {
  display: block;
  width: 100%;
  max-width: 100%;
  border-radius: 20px;
  border-color: rgba(153,194,251,.34);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.75);
}

@media (max-width: 1180px) {
  body.landing-page .panel-grid {
    grid-template-columns: minmax(320px, .9fr) minmax(0, 1.1fr);
    gap: 28px;
  }

  body.landing-page .panel-copy h2 {
    font-size: clamp(2.35rem, 4.2vw, 3.65rem);
  }

  body.landing-page .shot-stack {
    max-width: 610px;
  }

  body.landing-page .shot-card:nth-child(2) {
    margin-left: 22px;
  }
}

@media (max-width: 1080px) {
  body.landing-page .panel-section {
    padding-top: 44px;
  }

  body.landing-page .panel-grid {
    grid-template-columns: 1fr;
    gap: 28px;
  }

  body.landing-page .panel-grid::before {
    inset: -18px -10px -22px;
    border-radius: 34px;
  }

  body.landing-page .panel-copy {
    max-width: none;
  }

  body.landing-page .panel-copy h2,
  body.landing-page .panel-copy p,
  body.landing-page .feature-list {
    max-width: 760px;
  }

  body.landing-page .shot-stack {
    max-width: 860px;
    margin-left: 0;
  }
}

@media (max-width: 720px) {
  body.landing-page .panel-section {
    padding-top: 36px;
    padding-bottom: 42px;
  }

  body.landing-page .panel-grid::before {
    inset: -12px 0 -14px;
    border-radius: 28px;
  }

  body.landing-page .panel-copy {
    padding: 14px 14px 0;
  }

  body.landing-page .panel-copy h2 {
    max-width: none;
    font-size: clamp(2.05rem, 9.5vw, 2.9rem);
    letter-spacing: -.052em;
  }

  body.landing-page .panel-copy p {
    margin-top: 16px;
    font-size: .98rem;
  }

  body.landing-page .feature-list {
    margin-top: 20px;
  }

  body.landing-page .feature-item {
    padding: 15px;
    border-radius: 20px;
  }

  body.landing-page .shot-stack {
    gap: 14px;
  }

  body.landing-page .shot-stack::before {
    position: static;
    width: fit-content;
    margin: 0 0 -2px 14px;
  }

  body.landing-page .shot-card,
  body.landing-page .shot-card:nth-child(2) {
    margin-left: 0;
    padding: 12px;
    border-radius: 24px;
  }

  body.landing-page .shot-card-head {
    align-items: flex-start;
    flex-direction: column;
    gap: 3px;
    padding: 2px 4px 9px;
  }

  body.landing-page .shot-card-head span {
    text-align: left;
  }

  body.landing-page .shot-card img {
    border-radius: 17px;
  }
}

/* Landing Visual V9 - correção de encaixe do título no bloco "Solução Acrilsoft"
   Mantém o bloco dentro do painel branco e reduz o risco de o texto parecer fora do card. */
body.landing-page .modules-section {
  padding-top: 70px;
  padding-bottom: 62px;
}

body.landing-page .modules-section .container {
  padding-top: 42px;
  padding-bottom: 36px;
}

body.landing-page .modules-section .container::before {
  top: 0;
  bottom: 0;
  left: -34px;
  right: -34px;
  border-radius: 44px;
}

body.landing-page .modules-section .section-heading {
  margin-bottom: 26px;
}

body.landing-page .modules-section .section-heading h2 {
  max-width: 880px;
  font-size: clamp(2.18rem, 3vw, 3.22rem);
  line-height: 1.08;
  letter-spacing: -.054em;
}

body.landing-page .modules-section .section-heading p {
  max-width: 700px;
  margin-top: 18px;
}

body.landing-page .modules-grid {
  margin-top: 28px;
}

body.landing-page .module-flow-ribbon {
  margin-bottom: 2px;
}

@media (max-width: 1080px) {
  body.landing-page .modules-section {
    padding-top: 56px;
  }

  body.landing-page .modules-section .container {
    padding-top: 34px;
    padding-bottom: 30px;
  }

  body.landing-page .modules-section .container::before {
    inset: 0 -12px 0;
    border-radius: 34px;
  }

  body.landing-page .modules-section .section-heading h2 {
    font-size: clamp(2.05rem, 5vw, 2.9rem);
  }
}

@media (max-width: 720px) {
  body.landing-page .modules-section {
    padding-top: 42px;
    padding-bottom: 44px;
  }

  body.landing-page .modules-section .container {
    padding-top: 28px;
    padding-bottom: 24px;
  }

  body.landing-page .modules-section .container::before {
    inset: 0;
    border-radius: 28px;
  }

  body.landing-page .modules-section .section-heading h2 {
    font-size: clamp(1.88rem, 8vw, 2.42rem);
    letter-spacing: -.046em;
  }

  body.landing-page .modules-grid {
    margin-top: 22px;
  }
}


/* Landing Visual V10 - refinamento do bloco "Módulo de brindes"
   Dá mais equilíbrio ao texto, melhora a apresentação dos prints e corrige a ordem visual dos screenshots. */
body.landing-page .panel-section {
  padding-top: 62px;
  padding-bottom: 68px;
}

body.landing-page .panel-grid {
  grid-template-columns: minmax(340px, .82fr) minmax(0, 1.18fr);
  gap: 46px;
  align-items: start;
}

body.landing-page .panel-grid::before {
  inset: -26px -20px -22px;
  border-radius: 44px;
  background:
    radial-gradient(circle at 12% 18%, rgba(31,116,255,.10), transparent 26%),
    radial-gradient(circle at 88% 82%, rgba(124,199,255,.16), transparent 32%),
    linear-gradient(135deg, rgba(255,255,255,.74), rgba(236,246,255,.58));
}

body.landing-page .panel-copy {
  max-width: 500px;
  padding-top: 8px;
}

body.landing-page .panel-copy h2 {
  max-width: 9.5ch;
  font-size: clamp(2.2rem, 3.15vw, 3.62rem);
  line-height: 1.05;
  letter-spacing: -.054em;
}

body.landing-page .panel-copy p {
  max-width: 500px;
  margin-top: 20px;
  font-size: 1.01rem;
  line-height: 1.72;
}

body.landing-page .feature-list {
  margin-top: 24px;
  gap: 13px;
}

body.landing-page .feature-item {
  padding: 15px 18px;
  border-radius: 21px;
}

body.landing-page .feature-item span {
  font-size: .95rem;
  line-height: 1.58;
}

body.landing-page .panel-visual {
  padding-top: 4px;
}

body.landing-page .shot-stack {
  max-width: 690px;
  gap: 18px;
}

body.landing-page .shot-stack::before {
  left: -4px;
  top: -18px;
  padding: 9px 13px;
  box-shadow: 0 18px 34px rgba(31,116,255,.18);
}

body.landing-page .shot-card {
  padding: 14px;
  border-radius: 30px;
}

body.landing-page .shot-card:nth-child(1) {
  margin-right: 10px;
}

body.landing-page .shot-card:nth-child(2) {
  margin-left: 46px;
}

body.landing-page .shot-card-head {
  align-items: center;
  gap: 12px;
  padding: 4px 8px 12px;
}

body.landing-page .shot-card-head strong {
  font-size: 1.06rem;
}

body.landing-page .shot-card-head span {
  font-size: .81rem;
}

body.landing-page .shot-card img {
  border-radius: 18px;
  background: linear-gradient(180deg, #f9fcff, #eef5ff);
}

@media (max-width: 1180px) {
  body.landing-page .panel-grid {
    grid-template-columns: minmax(300px, .86fr) minmax(0, 1.14fr);
    gap: 32px;
  }

  body.landing-page .panel-copy h2 {
    font-size: clamp(2.08rem, 4vw, 3.18rem);
  }

  body.landing-page .shot-stack {
    max-width: 630px;
  }

  body.landing-page .shot-card:nth-child(2) {
    margin-left: 26px;
  }
}

@media (max-width: 1080px) {
  body.landing-page .panel-section {
    padding-top: 48px;
    padding-bottom: 52px;
  }

  body.landing-page .panel-grid {
    grid-template-columns: 1fr;
    gap: 26px;
  }

  body.landing-page .panel-copy {
    max-width: none;
    padding-top: 0;
  }

  body.landing-page .panel-copy h2,
  body.landing-page .panel-copy p,
  body.landing-page .feature-list {
    max-width: 760px;
  }

  body.landing-page .shot-stack {
    max-width: none;
  }

  body.landing-page .shot-card:nth-child(1),
  body.landing-page .shot-card:nth-child(2) {
    margin-right: 0;
  }
}

@media (max-width: 720px) {
  body.landing-page .panel-section {
    padding-top: 40px;
    padding-bottom: 42px;
  }

  body.landing-page .panel-copy {
    padding: 14px 14px 0;
  }

  body.landing-page .panel-copy h2 {
    max-width: none;
    font-size: clamp(1.9rem, 8.1vw, 2.6rem);
  }

  body.landing-page .panel-copy p {
    margin-top: 16px;
    font-size: .97rem;
  }

  body.landing-page .feature-item {
    padding: 14px 15px;
  }

  body.landing-page .feature-item span {
    font-size: .93rem;
  }

  body.landing-page .shot-stack {
    gap: 14px;
  }

  body.landing-page .shot-card,
  body.landing-page .shot-card:nth-child(1),
  body.landing-page .shot-card:nth-child(2) {
    margin-left: 0;
    padding: 12px;
    border-radius: 24px;
  }

  body.landing-page .shot-card-head {
    align-items: flex-start;
    gap: 4px;
    padding: 2px 4px 10px;
  }

  body.landing-page .shot-card-head strong {
    font-size: .98rem;
  }

  body.landing-page .shot-card-head span {
    font-size: .78rem;
  }
}


/* Landing Visual V11 - polimento de Como funciona, benefícios e planos
   Fecha a parte final da landing com mais leitura comercial e menos aparência genérica. */
body.landing-page .how-section {
  position: relative;
  padding-top: 70px;
  padding-bottom: 60px;
  overflow: clip;
}

body.landing-page .how-section::before {
  content: "";
  position: absolute;
  inset: 22px 4vw 24px;
  z-index: 0;
  border-radius: 44px;
  background:
    radial-gradient(circle at 14% 18%, rgba(31,116,255,.10), transparent 28%),
    radial-gradient(circle at 86% 80%, rgba(124,199,255,.14), transparent 30%),
    linear-gradient(135deg, rgba(255,255,255,.72), rgba(235,246,255,.58));
  border: 1px solid rgba(153,194,251,.24);
  box-shadow: 0 30px 88px rgba(34,94,180,.08);
  pointer-events: none;
}

body.landing-page .how-section .container {
  position: relative;
  z-index: 1;
}

body.landing-page .how-heading h2 {
  max-width: 760px;
  font-size: clamp(2.18rem, 3.05vw, 3.35rem);
  line-height: 1.08;
  letter-spacing: -.052em;
}

body.landing-page .how-heading p {
  max-width: 760px;
}

body.landing-page .how-grid {
  position: relative;
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 13px;
  margin-top: 32px;
}

body.landing-page .how-grid::before {
  left: 7%;
  right: 7%;
  top: 33px;
  height: 3px;
  border-radius: 999px;
  background: linear-gradient(90deg, transparent, rgba(31,116,255,.32), rgba(98,199,255,.42), transparent);
}

body.landing-page .how-card {
  display: grid;
  align-content: start;
  min-height: 245px;
  padding: 24px 20px 22px;
  border-radius: 28px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.97), rgba(242,248,255,.90));
  border: 1px solid rgba(153,194,251,.33);
  box-shadow: 0 22px 54px rgba(34,94,180,.10);
}

body.landing-page .how-card:hover {
  transform: translateY(-5px);
  border-color: rgba(31,116,255,.34);
  box-shadow: 0 30px 70px rgba(34,94,180,.14);
}

body.landing-page .how-card .num {
  display: inline-grid;
  place-items: center;
  width: 46px;
  height: 46px;
  margin-bottom: 18px;
  border-radius: 16px;
  background: linear-gradient(135deg, #0f70ff, #62c7ff);
  color: #fff;
  font-size: .84rem;
  font-weight: 950;
  letter-spacing: .08em;
  box-shadow: 0 15px 30px rgba(31,116,255,.20);
}

body.landing-page .how-card h3 {
  margin: 0 0 10px;
  color: var(--ink-deep);
  font-size: 1.08rem;
  line-height: 1.22;
  letter-spacing: -.025em;
}

body.landing-page .how-card p {
  margin: 0;
  color: #315986;
  font-size: .93rem;
  line-height: 1.62;
}

body.landing-page .benefits-section {
  position: relative;
  padding-top: 58px;
  padding-bottom: 62px;
}

body.landing-page .benefits-heading {
  margin-bottom: 28px;
}

body.landing-page .benefits-heading h2 {
  max-width: 760px;
  font-size: clamp(2.12rem, 2.8vw, 3.05rem);
  line-height: 1.09;
  letter-spacing: -.052em;
}

body.landing-page .benefits-heading p {
  max-width: 760px;
}

body.landing-page .benefits-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

body.landing-page .benefit-card {
  min-height: 250px;
  padding: 28px;
  border-radius: 30px;
  background:
    radial-gradient(circle at 86% 8%, rgba(124,199,255,.13), transparent 28%),
    linear-gradient(180deg, rgba(255,255,255,.97), rgba(241,248,255,.90));
  border: 1px solid rgba(153,194,251,.34);
  box-shadow: 0 24px 62px rgba(34,94,180,.11);
}

body.landing-page .benefit-card:nth-child(2) {
  transform: translateY(18px);
}

body.landing-page .benefit-card:hover {
  transform: translateY(-4px);
  border-color: rgba(31,116,255,.34);
  box-shadow: 0 34px 74px rgba(34,94,180,.15);
}

body.landing-page .benefit-card:nth-child(2):hover {
  transform: translateY(12px);
}

body.landing-page .benefit-card img {
  width: 52px;
  height: 52px;
  padding: 14px;
  border-radius: 18px;
  background: linear-gradient(180deg, rgba(237,247,255,.98), rgba(224,240,255,.90));
  border: 1px solid rgba(153,194,251,.42);
}

body.landing-page .benefit-card h3 {
  margin-top: 22px;
  margin-bottom: 10px;
  color: var(--ink-deep);
  font-size: 1.24rem;
  letter-spacing: -.03em;
}

body.landing-page .benefit-card p {
  color: #315986;
  line-height: 1.68;
}

body.landing-page .pricing-preview {
  position: relative;
  padding-top: 72px;
  padding-bottom: 76px;
  overflow: clip;
}

body.landing-page .pricing-preview::before {
  content: "";
  position: absolute;
  inset: 26px 3.4vw 28px;
  border-radius: 46px;
  background:
    radial-gradient(circle at 12% 12%, rgba(31,116,255,.10), transparent 30%),
    radial-gradient(circle at 88% 82%, rgba(124,199,255,.15), transparent 28%),
    linear-gradient(135deg, rgba(255,255,255,.76), rgba(236,246,255,.62));
  border: 1px solid rgba(153,194,251,.25);
  box-shadow: 0 32px 92px rgba(34,94,180,.09);
  pointer-events: none;
}

body.landing-page .pricing-preview .container {
  position: relative;
  z-index: 1;
}

body.landing-page .pricing-heading h2 {
  max-width: 820px;
  font-size: clamp(2.18rem, 3vw, 3.3rem);
  line-height: 1.08;
  letter-spacing: -.052em;
}

body.landing-page .pricing-heading p {
  max-width: 760px;
}

body.landing-page .pricing-proof-row {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  max-width: 900px;
  margin: 28px auto 4px;
}

body.landing-page .pricing-proof-row div {
  padding: 16px 18px;
  border-radius: 20px;
  background: rgba(255,255,255,.82);
  border: 1px solid rgba(153,194,251,.30);
  box-shadow: 0 16px 38px rgba(34,94,180,.08);
}

body.landing-page .pricing-proof-row strong {
  display: block;
  color: var(--ink-deep);
  font-size: 1rem;
  letter-spacing: -.015em;
}

body.landing-page .pricing-proof-row span {
  display: block;
  margin-top: 3px;
  color: #416693;
  font-size: .88rem;
  font-weight: 650;
}

body.landing-page .pricing-home-grid {
  gap: 20px;
  margin-top: 30px;
}

body.landing-page .pricing-home-card {
  padding: 28px;
  border-radius: 30px;
  background:
    radial-gradient(circle at 86% 10%, rgba(124,199,255,.12), transparent 28%),
    linear-gradient(180deg, rgba(255,255,255,.97), rgba(242,248,255,.90));
  border: 1px solid rgba(153,194,251,.34);
  box-shadow: 0 26px 68px rgba(34,94,180,.12);
}

body.landing-page .pricing-home-card.featured {
  transform: translateY(-8px);
  border-color: rgba(31,116,255,.40);
  box-shadow: 0 34px 82px rgba(31,116,255,.17);
}

body.landing-page .pricing-home-card h3 {
  font-size: 1.34rem;
}

body.landing-page .pricing-home-price {
  margin-top: 20px;
  color: var(--ink-deep);
}

body.landing-page .pricing-home-features div {
  background: rgba(255,255,255,.76);
  border-color: rgba(153,194,251,.28);
}

body.landing-page .client-access-strip {
  margin-top: 28px;
  padding: 24px 26px;
  border-radius: 28px;
  background:
    radial-gradient(circle at 12% 18%, rgba(124,199,255,.25), transparent 26%),
    linear-gradient(135deg, #061a3b 0%, #0d3d8f 58%, #1f74ff 100%);
  box-shadow: 0 28px 68px rgba(13,61,143,.18);
}

@media (max-width: 1080px) {
  body.landing-page .how-section::before,
  body.landing-page .pricing-preview::before {
    inset-left: 18px;
    inset-right: 18px;
    border-radius: 34px;
  }

  body.landing-page .how-grid,
  body.landing-page .benefits-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  body.landing-page .how-grid::before {
    display: none;
  }

  body.landing-page .benefit-card:nth-child(2) {
    transform: none;
  }

  body.landing-page .benefit-card:nth-child(2):hover {
    transform: translateY(-4px);
  }
}

@media (max-width: 720px) {
  body.landing-page .how-section,
  body.landing-page .benefits-section,
  body.landing-page .pricing-preview {
    padding-top: 44px;
    padding-bottom: 46px;
  }

  body.landing-page .how-section::before,
  body.landing-page .pricing-preview::before {
    inset: 8px 10px 10px;
    border-radius: 28px;
  }

  body.landing-page .how-heading h2,
  body.landing-page .benefits-heading h2,
  body.landing-page .pricing-heading h2 {
    font-size: clamp(1.88rem, 8vw, 2.42rem);
    letter-spacing: -.046em;
  }

  body.landing-page .how-grid,
  body.landing-page .benefits-grid,
  body.landing-page .pricing-proof-row {
    grid-template-columns: 1fr;
  }

  body.landing-page .how-card,
  body.landing-page .benefit-card,
  body.landing-page .pricing-home-card {
    min-height: auto;
    padding: 22px;
    border-radius: 24px;
  }

  body.landing-page .how-card .num {
    width: 42px;
    height: 42px;
    border-radius: 15px;
  }

  body.landing-page .pricing-home-card.featured {
    transform: none;
  }

  body.landing-page .client-access-strip {
    padding: 22px;
    border-radius: 24px;
  }
}


/* Landing Visual V12 - acabamento final: guias, confiança, FAQ, CTA e rodapé
   Fecha a landing com aparência mais comercial, organizada e menos genérica. */
body.landing-page .seo-links-section {
  position: relative;
  padding-top: 48px;
  padding-bottom: 38px;
}

body.landing-page .seo-links-section .section-heading {
  max-width: 860px;
}

body.landing-page .seo-links-section .section-heading h2 {
  max-width: 780px;
  font-size: clamp(2rem, 2.7vw, 3rem);
  line-height: 1.08;
  letter-spacing: -.05em;
}

body.landing-page .seo-links-grid {
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 12px;
}

body.landing-page .seo-link-card {
  min-height: 180px;
  padding: 20px;
  border-radius: 24px;
  background:
    radial-gradient(circle at 88% 12%, rgba(124,199,255,.12), transparent 28%),
    linear-gradient(180deg, rgba(255,255,255,.94), rgba(243,249,255,.88));
  border: 1px solid rgba(153,194,251,.30);
  box-shadow: 0 18px 46px rgba(34,94,180,.08);
}

body.landing-page .seo-link-card strong {
  color: var(--ink-deep);
  line-height: 1.2;
}

body.landing-page .seo-link-card span {
  font-size: .91rem;
  line-height: 1.58;
}

body.landing-page .trust-section {
  position: relative;
  padding-top: 52px;
  padding-bottom: 58px;
  overflow: clip;
}

body.landing-page .trust-section .container {
  position: relative;
  isolation: isolate;
  padding-top: 38px;
  padding-bottom: 40px;
}

body.landing-page .trust-section .container::before {
  content: "";
  position: absolute;
  inset: 0 -30px;
  z-index: -1;
  border-radius: 42px;
  background:
    radial-gradient(circle at 10% 20%, rgba(31,116,255,.12), transparent 30%),
    radial-gradient(circle at 92% 82%, rgba(124,199,255,.16), transparent 28%),
    linear-gradient(135deg, rgba(255,255,255,.74), rgba(236,246,255,.60));
  border: 1px solid rgba(153,194,251,.24);
  box-shadow: 0 32px 90px rgba(34,94,180,.08);
}

body.landing-page .trust-section .section-heading h2 {
  max-width: 760px;
  font-size: clamp(2.08rem, 3vw, 3.25rem);
  line-height: 1.08;
}

body.landing-page .trust-section .section-heading p {
  max-width: 760px;
}

body.landing-page .trust-grid {
  gap: 14px;
  margin-top: 28px;
}

body.landing-page .trust-card {
  min-height: 126px;
  padding: 20px;
  border-radius: 24px;
  background: linear-gradient(180deg, rgba(255,255,255,.96), rgba(244,249,255,.88));
  border-color: rgba(153,194,251,.30);
  box-shadow: 0 18px 44px rgba(34,94,180,.08);
}

body.landing-page .trust-card img {
  width: 22px;
  height: 22px;
  margin-top: 1px;
  padding: 3px;
  border-radius: 999px;
  background: rgba(31,116,255,.10);
}

body.landing-page .trust-card strong {
  font-size: 1.02rem;
  letter-spacing: -.02em;
}

body.landing-page .trust-card span {
  font-size: .92rem;
}

body.landing-page .faq-section {
  position: relative;
  padding-top: 72px;
  padding-bottom: 76px;
  overflow: clip;
}

body.landing-page .faq-grid {
  grid-template-columns: minmax(300px, .82fr) minmax(0, 1.18fr);
  gap: 34px;
  align-items: start;
}

body.landing-page .faq-copy {
  top: 118px;
  padding: 32px;
  border-radius: 34px;
  background:
    radial-gradient(circle at 12% 12%, rgba(124,199,255,.22), transparent 34%),
    linear-gradient(135deg, #061a3b 0%, #0d3d8f 62%, #1f74ff 100%);
  color: #fff;
  box-shadow: 0 34px 82px rgba(13,61,143,.20);
}

body.landing-page .faq-copy .section-tag {
  color: #fff;
  background: rgba(255,255,255,.14);
  border-color: rgba(255,255,255,.22);
  box-shadow: none;
}

body.landing-page .faq-copy h2 {
  color: #fff;
  font-size: clamp(2rem, 3.2vw, 3.1rem);
  line-height: 1.06;
}

body.landing-page .faq-copy p {
  color: rgba(255,255,255,.82);
  font-size: 1rem;
}

body.landing-page .faq-list {
  gap: 14px;
}

body.landing-page .faq-item {
  border-radius: 24px;
  background:
    radial-gradient(circle at 92% 8%, rgba(124,199,255,.12), transparent 28%),
    linear-gradient(180deg, rgba(255,255,255,.97), rgba(243,249,255,.90));
  border-color: rgba(153,194,251,.32);
  box-shadow: 0 18px 46px rgba(34,94,180,.08);
}

body.landing-page .faq-item summary {
  padding: 20px 58px 20px 22px;
  font-size: 1.02rem;
  letter-spacing: -.015em;
}

body.landing-page .faq-item summary::after {
  right: 20px;
  top: 50%;
  width: 30px;
  height: 30px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transform: translateY(-50%);
  border-radius: 12px;
  background: rgba(31,116,255,.10);
  font-size: 1.15rem;
  line-height: 1;
}

body.landing-page .faq-item p {
  padding: 0 58px 22px 22px;
  color: #315986;
}

body.landing-page .final-section {
  position: relative;
  padding-top: 56px;
  padding-bottom: 58px;
  overflow: clip;
}

body.landing-page .final-box {
  position: relative;
  overflow: hidden;
  grid-template-columns: 1fr .92fr;
  gap: 38px;
  padding: 46px;
  border-radius: 40px;
  background:
    radial-gradient(circle at 10% 18%, rgba(124,199,255,.22), transparent 30%),
    radial-gradient(circle at 94% 86%, rgba(31,116,255,.32), transparent 32%),
    linear-gradient(135deg, #061a3b 0%, #0d3d8f 56%, #1f74ff 100%);
  border-color: rgba(255,255,255,.18);
  box-shadow: 0 36px 90px rgba(13,61,143,.24);
  color: #fff;
}

body.landing-page .final-box::before {
  content: "";
  position: absolute;
  inset: 20px 20px auto auto;
  width: 170px;
  height: 170px;
  border-radius: 999px;
  background: rgba(255,255,255,.10);
  pointer-events: none;
}

body.landing-page .final-copy,
body.landing-page .final-card-grid {
  position: relative;
  z-index: 1;
}

body.landing-page .final-copy .section-tag {
  color: #fff;
  background: rgba(255,255,255,.14);
  border-color: rgba(255,255,255,.22);
  box-shadow: none;
}

body.landing-page .final-copy h2 {
  max-width: 760px;
  margin-top: 18px;
  color: #fff;
  font-size: clamp(2.25rem, 4vw, 4rem);
  line-height: 1.02;
  letter-spacing: -.06em;
}

body.landing-page .final-copy p {
  max-width: 650px;
  color: rgba(255,255,255,.84);
  font-size: 1.05rem;
  line-height: 1.76;
}

body.landing-page .final-actions .btn-primary {
  background: #fff;
  border-color: #fff;
  color: #0d3d8f;
  box-shadow: 0 22px 44px rgba(0,0,0,.14);
}

body.landing-page .final-actions .btn-secondary {
  background: rgba(255,255,255,.10);
  border-color: rgba(255,255,255,.24);
  color: #fff;
}

body.landing-page .final-actions .btn-secondary:hover {
  background: rgba(255,255,255,.16);
}

body.landing-page .mini-note {
  color: rgba(255,255,255,.74);
}

body.landing-page .final-card-grid {
  gap: 14px;
}

body.landing-page .final-mini {
  padding: 22px;
  border-radius: 24px;
  background: rgba(255,255,255,.11);
  border-color: rgba(255,255,255,.18);
  box-shadow: none;
  backdrop-filter: blur(10px);
}

body.landing-page .final-mini::after {
  border-color: rgba(255,255,255,.18);
}

body.landing-page .final-mini strong {
  color: #fff;
  font-size: 1.08rem;
}

body.landing-page .final-mini span {
  color: rgba(255,255,255,.78);
}

body.landing-page .public-footer {
  padding: 46px 0 28px;
  background:
    linear-gradient(180deg, rgba(239,247,255,.72), rgba(220,237,255,.88));
  border-top: 1px solid rgba(153,194,251,.28);
}

body.landing-page .public-footer-grid {
  display: grid;
  grid-template-columns: minmax(260px, 1.35fr) repeat(3, minmax(150px, .55fr));
  gap: 28px;
  align-items: start;
}

body.landing-page .public-footer-brand img {
  width: 184px;
  height: auto;
  display: block;
  margin-bottom: 16px;
}

body.landing-page .public-footer-brand p {
  max-width: 470px;
  margin: 0;
  color: #416693;
  line-height: 1.72;
}

body.landing-page .public-footer-col {
  display: grid;
  gap: 10px;
}

body.landing-page .public-footer-col strong {
  margin-bottom: 4px;
  color: var(--ink-deep);
  font-size: .92rem;
  text-transform: uppercase;
  letter-spacing: .12em;
}

body.landing-page .public-footer-col a {
  color: #315986;
  text-decoration: none;
  font-weight: 700;
  font-size: .95rem;
}

body.landing-page .public-footer-col a:hover {
  color: #1f74ff;
}

body.landing-page .public-footer-bottom {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
  margin-top: 34px;
  padding-top: 22px;
  border-top: 1px solid rgba(153,194,251,.30);
  color: #5a789d;
  font-size: .92rem;
  font-weight: 650;
}

@media (max-width: 1120px) {
  body.landing-page .seo-links-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  body.landing-page .final-box {
    grid-template-columns: 1fr;
  }

  body.landing-page .public-footer-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 900px) {
  body.landing-page .faq-grid {
    grid-template-columns: 1fr;
  }

  body.landing-page .faq-copy {
    position: relative;
    top: auto;
  }
}

@media (max-width: 720px) {
  body.landing-page .seo-links-section,
  body.landing-page .trust-section,
  body.landing-page .faq-section,
  body.landing-page .final-section {
    padding-top: 42px;
    padding-bottom: 44px;
  }

  body.landing-page .trust-section .container {
    padding-top: 28px;
    padding-bottom: 30px;
  }

  body.landing-page .trust-section .container::before {
    inset: 0;
    border-radius: 28px;
  }

  body.landing-page .seo-links-grid,
  body.landing-page .trust-grid,
  body.landing-page .final-card-grid,
  body.landing-page .public-footer-grid {
    grid-template-columns: 1fr;
  }

  body.landing-page .seo-link-card,
  body.landing-page .trust-card {
    min-height: auto;
    border-radius: 22px;
  }

  body.landing-page .faq-copy,
  body.landing-page .final-box {
    padding: 26px;
    border-radius: 28px;
  }

  body.landing-page .faq-copy h2,
  body.landing-page .final-copy h2 {
    font-size: clamp(1.9rem, 8.4vw, 2.7rem);
  }

  body.landing-page .faq-item summary {
    padding: 18px 52px 18px 18px;
  }

  body.landing-page .faq-item p {
    padding: 0 18px 20px;
  }

  body.landing-page .final-actions .btn {
    width: 100%;
  }

  body.landing-page .public-footer {
    padding-top: 36px;
  }

  body.landing-page .public-footer-bottom {
    margin-top: 24px;
  }
}


/* Landing Visual V13 - microacabamento do final da landing
   Ajusta leitura dos cards finais, FAQ e rodapé sem alterar rotas ou integrações. */
body.landing-page .seo-links-section {
  padding-bottom: 46px;
}

body.landing-page .seo-links-grid {
  align-items: stretch;
}

body.landing-page .seo-link-card {
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  gap: 12px;
}

body.landing-page .seo-link-card:hover {
  transform: translateY(-4px);
  border-color: rgba(31,116,255,.34);
  box-shadow: 0 26px 58px rgba(34,94,180,.12);
}

body.landing-page .trust-card {
  align-items: flex-start;
}

body.landing-page .trust-card span {
  max-width: 35ch;
  line-height: 1.55;
}

body.landing-page .faq-copy {
  min-height: 360px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

body.landing-page .faq-item[open] {
  border-color: rgba(31,116,255,.24);
  box-shadow: 0 24px 58px rgba(34,94,180,.11);
}

body.landing-page .final-section {
  padding-bottom: 50px;
}

body.landing-page .final-box {
  align-items: center;
}

body.landing-page .final-card-grid {
  align-content: center;
}

body.landing-page .final-mini {
  min-height: 142px;
}

body.landing-page .public-footer-brand p {
  max-width: 520px;
}

body.landing-page .public-footer-bottom span:last-child {
  color: #315986;
}

@media (max-width: 1120px) {
  body.landing-page .seo-links-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 900px) {
  body.landing-page .seo-links-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  body.landing-page .faq-copy {
    min-height: auto;
  }
}

@media (max-width: 720px) {
  body.landing-page .seo-links-grid {
    grid-template-columns: 1fr;
  }

  body.landing-page .seo-link-card,
  body.landing-page .trust-card,
  body.landing-page .final-mini {
    min-height: auto;
  }

  body.landing-page .final-copy p {
    font-size: .98rem;
  }
}

/* Landing Visual V14 - validação responsiva notebook/tablet/celular
   Mantém o visual aprovado no desktop e corrige encaixes em telas menores. */
body.landing-page {
  overflow-x: hidden;
}

body.landing-page .site-shell {
  overflow-x: clip;
}

body.landing-page img,
body.landing-page svg,
body.landing-page video {
  max-width: 100%;
}

@media (max-width: 1360px) {
  body.landing-page {
    --container: min(1120px, calc(100% - 44px));
  }

  body.landing-page .nav {
    padding: 14px 20px;
  }

  body.landing-page .nav-links {
    gap: 6px;
  }

  body.landing-page .nav-links a:not(.btn) {
    padding: 9px 11px;
  }

  body.landing-page .hero h1 {
    font-size: clamp(3.35rem, 5.2vw, 5.4rem);
  }

  body.landing-page .hero-grid {
    gap: 42px;
  }

  body.landing-page .operation-chip {
    min-width: 166px;
  }

  body.landing-page .chip-order {
    left: -18px;
  }

  body.landing-page .chip-sheet {
    right: -18px;
  }

  body.landing-page .panel-grid,
  body.landing-page .final-box {
    gap: 34px;
  }
}

@media (max-width: 1180px) {
  body.landing-page {
    --container: min(1040px, calc(100% - 36px));
  }

  body.landing-page .hero {
    padding-top: 58px;
  }

  body.landing-page .notice-pill {
    padding: 12px 16px;
    font-size: .92rem;
  }

  body.landing-page .hero h1 {
    font-size: clamp(3rem, 5.4vw, 4.55rem);
  }

  body.landing-page .hero-text {
    font-size: 1rem;
  }

  body.landing-page .hero-actions {
    gap: 10px;
  }

  body.landing-page .hero-actions .btn {
    min-height: 50px;
    padding-inline: 18px;
  }

  body.landing-page .operation-chip {
    transform: scale(.92);
  }

  body.landing-page .modules-section .section-heading h2,
  body.landing-page .panel-copy h2,
  body.landing-page .how-heading h2,
  body.landing-page .benefits-heading h2,
  body.landing-page .pricing-heading h2,
  body.landing-page .trust-section .section-heading h2,
  body.landing-page .faq-copy h2,
  body.landing-page .final-copy h2 {
    letter-spacing: -.046em;
  }
}

@media (max-width: 980px) {
  body.landing-page {
    --container: min(900px, calc(100% - 32px));
  }

  body.landing-page .topbar {
    padding-top: 12px;
  }

  body.landing-page .nav {
    border-radius: 24px;
  }

  body.landing-page .nav-links {
    right: 16px;
    left: 16px;
    z-index: 80;
  }

  body.landing-page .nav-links .btn,
  body.landing-page .nav-links a:not(.btn) {
    width: 100%;
    justify-content: center;
    text-align: center;
  }

  body.landing-page .hero::before {
    inset: 22px 16px auto;
    height: 600px;
    border-radius: 36px;
  }

  body.landing-page .hero-grid {
    grid-template-columns: 1fr;
    gap: 28px;
  }

  body.landing-page .hero-copy {
    text-align: center;
    max-width: 780px;
    margin: 0 auto;
  }

  body.landing-page .hero h1,
  body.landing-page .hero-text {
    margin-left: auto;
    margin-right: auto;
  }

  body.landing-page .hero-actions,
  body.landing-page .hero-trust-pills,
  body.landing-page .hero-metrics {
    justify-content: center;
  }

  body.landing-page .hero-visual {
    max-width: 760px;
    margin: 0 auto;
  }

  body.landing-page .mockup-card-real {
    transform: none;
  }

  body.landing-page .operation-chip {
    animation: none;
  }

  body.landing-page .chip-order {
    left: 10px;
    top: 72px;
  }

  body.landing-page .chip-sheet {
    right: 10px;
    top: 174px;
  }

  body.landing-page .chip-delivery {
    left: 30px;
    bottom: -8px;
  }

  body.landing-page .pain-section .section-heading,
  body.landing-page .modules-section .section-heading,
  body.landing-page .how-heading,
  body.landing-page .benefits-heading,
  body.landing-page .pricing-heading,
  body.landing-page .seo-links-section .section-heading,
  body.landing-page .trust-section .section-heading {
    max-width: 760px;
  }

  body.landing-page .process-box {
    grid-template-columns: 1fr;
    gap: 26px;
  }

  body.landing-page .process-steps {
    grid-template-columns: 1fr;
  }

  body.landing-page .step-card {
    min-height: auto;
  }

  body.landing-page .pricing-home-grid {
    grid-template-columns: 1fr;
  }

  body.landing-page .pricing-home-card.featured {
    transform: none;
  }
}

@media (max-width: 760px) {
  body.landing-page {
    --container: min(100% - 28px, 680px);
  }

  body.landing-page .site-shell::before {
    opacity: .48;
    background-size: 56px 56px, 56px 56px, 14px 14px, 14px 14px;
  }

  body.landing-page .brand img,
  body.landing-page .public-footer-brand img {
    max-width: 172px;
    height: auto;
  }

  body.landing-page .nav {
    padding: 12px 14px;
    border-radius: 22px;
  }

  body.landing-page .menu-toggle {
    width: 44px;
    height: 44px;
    flex: 0 0 44px;
  }

  body.landing-page .nav-links {
    top: calc(100% + 8px);
    right: 14px;
    left: 14px;
    padding: 14px;
    border-radius: 22px;
  }

  body.landing-page .hero {
    padding-top: 34px;
  }

  body.landing-page .hero::before {
    inset: 18px 10px auto;
    height: 650px;
    border-radius: 30px;
  }

  body.landing-page .notice-strip {
    margin-bottom: 18px;
  }

  body.landing-page .notice-pill {
    padding: 12px 14px;
    font-size: .88rem;
    line-height: 1.55;
    border-radius: 16px;
  }

  body.landing-page .eyebrow,
  body.landing-page .section-tag {
    max-width: 100%;
    text-align: center;
    white-space: normal;
    line-height: 1.35;
    letter-spacing: .13em;
  }

  body.landing-page .hero h1 {
    max-width: 10.8em;
    font-size: clamp(2.32rem, 12vw, 3.42rem);
    line-height: 1.02;
    letter-spacing: -.055em;
  }

  body.landing-page .hero-text,
  body.landing-page .hero-trust-note {
    font-size: .98rem;
    line-height: 1.72;
  }

  body.landing-page .hero-actions {
    display: grid;
    grid-template-columns: 1fr;
    gap: 10px;
  }

  body.landing-page .hero-actions .btn,
  body.landing-page .final-actions .btn,
  body.landing-page .pricing-home-actions .btn,
  body.landing-page .client-access-strip .btn {
    width: 100%;
  }

  body.landing-page .hero-trust-pills,
  body.landing-page .hero-metrics,
  body.landing-page .pricing-proof-row {
    grid-template-columns: 1fr;
  }

  body.landing-page .hero-trust-pill,
  body.landing-page .metric-card,
  body.landing-page .pricing-proof-row div {
    width: 100%;
  }

  body.landing-page .operation-stack {
    display: none;
  }

  body.landing-page .mockup-card,
  body.landing-page .mockup-card-real,
  body.landing-page .process-box,
  body.landing-page .faq-copy,
  body.landing-page .final-box {
    padding: 20px;
    border-radius: 26px;
  }

  body.landing-page .mockup-top,
  body.landing-page .shot-card-head,
  body.landing-page .public-footer-bottom {
    align-items: flex-start;
    flex-direction: column;
  }

  body.landing-page .stats-row {
    grid-template-columns: 1fr;
    gap: 10px;
  }

  body.landing-page .floating-shot {
    display: none;
  }

  body.landing-page .pain-section,
  body.landing-page .audience-section,
  body.landing-page .modules-section,
  body.landing-page .panel-section,
  body.landing-page .how-section,
  body.landing-page .process-section,
  body.landing-page .benefits-section,
  body.landing-page .pricing-preview,
  body.landing-page .seo-links-section,
  body.landing-page .trust-section,
  body.landing-page .faq-section,
  body.landing-page .final-section {
    padding-top: 40px;
    padding-bottom: 42px;
  }

  body.landing-page .pain-section .section-heading h2,
  body.landing-page .audience-box h2,
  body.landing-page .modules-section .section-heading h2,
  body.landing-page .panel-copy h2,
  body.landing-page .how-heading h2,
  body.landing-page .process-intro h2,
  body.landing-page .benefits-heading h2,
  body.landing-page .pricing-heading h2,
  body.landing-page .seo-links-section .section-heading h2,
  body.landing-page .trust-section .section-heading h2,
  body.landing-page .faq-copy h2,
  body.landing-page .final-copy h2 {
    font-size: clamp(1.86rem, 8.7vw, 2.55rem);
    line-height: 1.08;
    letter-spacing: -.045em;
  }

  body.landing-page .section-heading p,
  body.landing-page .audience-box p,
  body.landing-page .panel-copy p,
  body.landing-page .process-intro p,
  body.landing-page .final-copy p {
    font-size: .98rem;
    line-height: 1.72;
  }

  body.landing-page .pain-grid,
  body.landing-page .modules-grid,
  body.landing-page .benefits-grid,
  body.landing-page .trust-grid,
  body.landing-page .seo-links-grid,
  body.landing-page .final-card-grid,
  body.landing-page .public-footer-grid {
    grid-template-columns: 1fr;
    gap: 14px;
  }

  body.landing-page .pain-card,
  body.landing-page .modules-grid .info-card,
  body.landing-page .feature-item,
  body.landing-page .how-card,
  body.landing-page .step-card,
  body.landing-page .benefit-card,
  body.landing-page .pricing-home-card,
  body.landing-page .seo-link-card,
  body.landing-page .trust-card,
  body.landing-page .final-mini {
    padding: 20px;
    border-radius: 22px;
    min-height: auto;
  }

  body.landing-page .audience-box,
  body.landing-page .modules-section .container,
  body.landing-page .trust-section .container {
    padding-top: 26px;
    padding-bottom: 28px;
  }

  body.landing-page .audience-tags {
    justify-content: flex-start;
    gap: 10px;
  }

  body.landing-page .audience-tag,
  body.landing-page .module-flow-ribbon span {
    font-size: .84rem;
  }

  body.landing-page .module-flow-ribbon {
    padding: 12px;
    border-radius: 22px;
  }

  body.landing-page .module-flow-ribbon i {
    display: none;
  }

  body.landing-page .panel-grid::before,
  body.landing-page .modules-section .container::before,
  body.landing-page .trust-section .container::before,
  body.landing-page .how-section::before,
  body.landing-page .pricing-preview::before {
    border-radius: 26px;
  }

  body.landing-page .shot-card,
  body.landing-page .shot-card:nth-child(1),
  body.landing-page .shot-card:nth-child(2) {
    margin: 0;
    border-radius: 22px;
  }

  body.landing-page .shot-stack::before {
    margin-left: 0;
  }

  body.landing-page .how-grid {
    gap: 14px;
  }

  body.landing-page .how-card .num {
    margin-bottom: 14px;
  }

  body.landing-page .client-access-strip {
    flex-direction: column;
    align-items: stretch;
    text-align: left;
  }

  body.landing-page .faq-grid,
  body.landing-page .final-box {
    gap: 20px;
  }

  body.landing-page .faq-item summary {
    min-height: 64px;
    padding: 17px 50px 17px 18px;
  }

  body.landing-page .faq-item summary::after {
    right: 16px;
  }

  body.landing-page .public-footer {
    padding-bottom: 24px;
  }
}

@media (max-width: 520px) {
  body.landing-page {
    --container: min(100% - 22px, 480px);
  }

  body.landing-page .brand img,
  body.landing-page .public-footer-brand img {
    max-width: 154px;
  }

  body.landing-page .hero h1 {
    font-size: clamp(2.05rem, 11.4vw, 2.72rem);
  }

  body.landing-page .eyebrow,
  body.landing-page .section-tag {
    padding-inline: 14px;
    font-size: .68rem;
  }

  body.landing-page .mockup-card,
  body.landing-page .mockup-card-real,
  body.landing-page .process-box,
  body.landing-page .faq-copy,
  body.landing-page .final-box {
    padding: 16px;
  }

  body.landing-page .badge,
  body.landing-page .badge-soft {
    width: fit-content;
  }

  body.landing-page .screenshot-frame-real,
  body.landing-page .shot-card img {
    border-radius: 14px;
  }

  body.landing-page .pain-card,
  body.landing-page .modules-grid .info-card,
  body.landing-page .feature-item,
  body.landing-page .how-card,
  body.landing-page .step-card,
  body.landing-page .benefit-card,
  body.landing-page .pricing-home-card,
  body.landing-page .seo-link-card,
  body.landing-page .trust-card,
  body.landing-page .final-mini {
    padding: 18px;
  }

  body.landing-page .pricing-home-price {
    font-size: clamp(2rem, 12vw, 2.75rem);
  }

  body.landing-page .faq-copy p,
  body.landing-page .faq-item p,
  body.landing-page .public-footer-brand p {
    font-size: .95rem;
  }

  body.landing-page .public-footer-bottom {
    font-size: .86rem;
  }
}

/* Landing Visual V15 - SEO, performance, acessibilidade e conversão final */
body.landing-page .skip-link {
  position: fixed;
  left: 16px;
  top: 12px;
  z-index: 9999;
  transform: translateY(-140%);
  padding: 10px 14px;
  border-radius: 999px;
  background: #ffffff;
  color: #0b2b5f;
  font-weight: 850;
  text-decoration: none;
  box-shadow: 0 16px 34px rgba(8, 34, 82, .18);
  transition: transform .18s ease;
}

body.landing-page .skip-link:focus {
  transform: translateY(0);
}

body.landing-page a:focus-visible,
body.landing-page button:focus-visible,
body.landing-page summary:focus-visible {
  outline: 3px solid rgba(31, 116, 255, .42);
  outline-offset: 4px;
  border-radius: 14px;
}

body.landing-page picture {
  display: block;
}

body.landing-page .screenshot-frame picture,
body.landing-page .floating-shot picture,
body.landing-page .shot-card picture {
  width: 100%;
}

body.landing-page .screenshot-frame picture > img,
body.landing-page .floating-shot picture > img,
body.landing-page .shot-card picture > img {
  display: block;
  height: auto;
}

body.landing-page .hero-actions .btn-primary,
body.landing-page .final-actions .btn-primary,
body.landing-page .pricing-home-actions .btn-primary {
  box-shadow: 0 18px 38px rgba(31, 116, 255, .22);
}

body.landing-page .hero-trust-note,
body.landing-page .mini-note {
  text-wrap: balance;
}

@media (max-width: 720px) {
  body.landing-page .skip-link {
    left: 12px;
    right: 12px;
    text-align: center;
  }

  body.landing-page .topbar .btn-primary[href="/cadastro"] {
    box-shadow: 0 18px 34px rgba(31, 116, 255, .18);
  }
}


/* Landing Visual V19 - ajuste fino do painel de fundo do hero
   Desce um pouco mais o fundo branco/azulado e faz ele abraçar melhor a área dos cards inferiores. */
body.landing-page .hero::before {
  inset: 108px 3.4vw 2px;
  height: auto;
}

@media (max-width: 1180px) {
  body.landing-page .hero::before {
    inset: 92px 2.4vw 4px;
    height: auto;
  }
}

@media (max-width: 980px) {
  body.landing-page .hero::before {
    inset: 74px 2vw 4px;
    height: auto;
  }
}

@media (max-width: 720px) {
  body.landing-page .hero::before {
    inset: 22px 3.4vw auto;
    height: 600px;
  }
}


/* Landing Marketplace V2 - bloco animado para Mercado Livre, Shopee e produção sob demanda */
body.landing-page .marketplace-section-v2 {
  position: relative;
  padding: 76px 0 68px;
  overflow: clip;
  scroll-margin-top: 110px;
}

body.landing-page .marketplace-section-v2::before {
  content: "";
  position: absolute;
  inset: 24px 4vw 20px;
  border-radius: 48px;
  pointer-events: none;
  background:
    radial-gradient(circle at 12% 18%, rgba(255, 216, 122, .20), transparent 27%),
    radial-gradient(circle at 88% 22%, rgba(238, 77, 45, .13), transparent 26%),
    radial-gradient(circle at 64% 92%, rgba(31, 116, 255, .12), transparent 28%),
    linear-gradient(135deg, rgba(255,255,255,.78), rgba(235,246,255,.58));
  border: 1px solid rgba(153,194,251,.26);
  box-shadow: 0 30px 90px rgba(34,94,180,.09);
}

body.landing-page .marketplace-shell-v2 {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: minmax(0, .92fr) minmax(460px, 1.08fr);
  gap: 44px;
  align-items: center;
}

body.landing-page .marketplace-copy-v2 h2 {
  max-width: 12ch;
  margin: 16px 0 18px;
  color: var(--ink-deep);
  font-size: clamp(2.35rem, 3.75vw, 4.15rem);
  line-height: 1.03;
  letter-spacing: -.058em;
  text-wrap: balance;
}

body.landing-page .marketplace-copy-v2 p {
  max-width: 58ch;
  color: #315986;
  font-size: 1.04rem;
  line-height: 1.78;
}

body.landing-page .marketplace-proof-v2 {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  margin-top: 26px;
}

body.landing-page .marketplace-proof-v2 div,
body.landing-page .marketplace-usecases-v2 article {
  position: relative;
  overflow: hidden;
  padding: 16px;
  border-radius: 22px;
  background: linear-gradient(180deg, rgba(255,255,255,.96), rgba(244,249,255,.88));
  border: 1px solid rgba(153,194,251,.30);
  box-shadow: 0 18px 38px rgba(34,94,180,.08);
}

body.landing-page .marketplace-proof-v2 div::after,
body.landing-page .marketplace-usecases-v2 article::after {
  content: "";
  position: absolute;
  right: 16px;
  top: 16px;
  width: 30px;
  height: 30px;
  border-top: 1px solid rgba(31,116,255,.16);
  border-right: 1px solid rgba(31,116,255,.16);
  border-radius: 0 12px 0 0;
}

body.landing-page .marketplace-proof-v2 strong,
body.landing-page .marketplace-usecases-v2 strong {
  display: block;
  color: var(--ink-deep);
  font-size: .98rem;
  letter-spacing: -.025em;
}

body.landing-page .marketplace-proof-v2 span,
body.landing-page .marketplace-usecases-v2 span {
  display: block;
  margin-top: 6px;
  color: #4a6e99;
  font-size: .9rem;
  font-weight: 650;
  line-height: 1.55;
}

body.landing-page .marketplace-usecases-v2 {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin-top: 14px;
}

body.landing-page .marketplace-usecases-v2 small {
  display: inline-flex;
  margin-bottom: 10px;
  padding: 6px 9px;
  border-radius: 999px;
  color: #0d3d8f;
  background: rgba(31,116,255,.08);
  border: 1px solid rgba(31,116,255,.14);
  font-size: .68rem;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .09em;
}

body.landing-page .marketplace-actions-v2 {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 24px;
}

body.landing-page .marketplace-visual-v2 {
  min-width: 0;
}

body.landing-page .marketplace-stage-v2 {
  position: relative;
  min-height: 520px;
  border-radius: 42px;
  overflow: hidden;
  background:
    radial-gradient(circle at 16% 16%, rgba(255, 225, 134, .24), transparent 24%),
    radial-gradient(circle at 86% 18%, rgba(238, 77, 45, .13), transparent 25%),
    radial-gradient(circle at 50% 90%, rgba(31, 116, 255, .18), transparent 28%),
    linear-gradient(160deg, rgba(255,255,255,.98), rgba(238,247,255,.92));
  border: 1px solid rgba(153,194,251,.34);
  box-shadow: 0 34px 92px rgba(13, 61, 143, .15);
}

body.landing-page .marketplace-bg-grid {
  position: absolute;
  inset: 0;
  opacity: .85;
  background-image:
    linear-gradient(rgba(31,116,255,.07) 1px, transparent 1px),
    linear-gradient(90deg, rgba(31,116,255,.07) 1px, transparent 1px);
  background-size: 30px 30px;
  mask-image: radial-gradient(circle at center, #000 0%, rgba(0,0,0,.76) 56%, transparent 100%);
}

body.landing-page .market-card-v2,
body.landing-page .market-hub-v2,
body.landing-page .flow-node-v2,
body.landing-page .market-order-v2,
body.landing-page .market-product-tags-v2 span {
  position: absolute;
  z-index: 2;
  border: 1px solid rgba(153,194,251,.30);
  background: rgba(255,255,255,.90);
  box-shadow: 0 18px 40px rgba(13,61,143,.12);
  backdrop-filter: blur(12px);
}

body.landing-page .market-card-v2 {
  display: grid;
  grid-template-columns: auto 1fr;
  column-gap: 12px;
  row-gap: 2px;
  align-items: center;
  width: 188px;
  padding: 14px;
  border-radius: 22px;
}

body.landing-page .market-card-v2 strong,
body.landing-page .market-hub-v2 strong,
body.landing-page .flow-node-v2 strong,
body.landing-page .market-order-v2 strong {
  color: var(--ink-deep);
  font-size: .96rem;
  letter-spacing: -.02em;
}

body.landing-page .market-card-v2 small,
body.landing-page .market-hub-v2 small,
body.landing-page .market-order-v2 span {
  color: #54749d;
  font-size: .78rem;
  font-weight: 750;
}

body.landing-page .market-card-v2 small {
  grid-column: 2;
}

body.landing-page .market-icon-v2 {
  grid-row: 1 / span 2;
  display: inline-flex;
  width: 42px;
  height: 42px;
  align-items: center;
  justify-content: center;
  border-radius: 15px;
  color: #fff;
  font-size: .82rem;
  font-weight: 950;
  letter-spacing: -.02em;
}

body.landing-page .market-card-ml {
  left: 34px;
  top: 52px;
}

body.landing-page .market-card-ml .market-icon-v2 {
  color: #102a5c;
  background: linear-gradient(135deg, #ffe066, #f7c948);
}

body.landing-page .market-card-shopee {
  right: 34px;
  top: 52px;
}

body.landing-page .market-card-shopee .market-icon-v2 {
  background: linear-gradient(135deg, #ee4d2d, #ff8a5c);
}

body.landing-page .market-line-v2 {
  position: absolute;
  z-index: 1;
  height: 2px;
  top: 152px;
  background: linear-gradient(90deg, transparent, rgba(31,116,255,.32), transparent);
  transform-origin: center;
}

body.landing-page .market-line-v2 span {
  position: absolute;
  left: 0;
  top: -4px;
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: #1f74ff;
  box-shadow: 0 0 0 7px rgba(31,116,255,.11);
  animation: marketplaceDotV2 2.8s ease-in-out infinite;
}

body.landing-page .line-ml {
  left: 202px;
  right: 52%;
  transform: rotate(18deg);
}

body.landing-page .line-shopee {
  right: 202px;
  left: 52%;
  transform: rotate(-18deg);
}

body.landing-page .line-shopee span {
  animation-delay: -1.35s;
}

body.landing-page .market-hub-v2 {
  left: 50%;
  top: 178px;
  display: grid;
  width: 168px;
  height: 168px;
  place-items: center;
  padding: 20px;
  text-align: center;
  border-radius: 42px;
  transform: translateX(-50%);
  background:
    radial-gradient(circle at 22% 20%, rgba(124,199,255,.28), transparent 42%),
    linear-gradient(145deg, #08245b, #1557d4 60%, #1f74ff);
  border-color: rgba(255,255,255,.42);
  box-shadow: 0 28px 74px rgba(31,116,255,.28);
}

body.landing-page .market-hub-v2 strong {
  display: block;
  color: #fff;
  font-size: 1.18rem;
}

body.landing-page .market-hub-v2 small {
  display: block;
  max-width: 16ch;
  margin-top: -18px;
  color: rgba(255,255,255,.82);
}

body.landing-page .hub-pulse-v2 {
  position: absolute;
  inset: -12px;
  border-radius: inherit;
  border: 1px solid rgba(31,116,255,.18);
  animation: marketplacePulseV2 2.8s ease-in-out infinite;
}

body.landing-page .market-order-v2 {
  display: grid;
  gap: 2px;
  min-width: 150px;
  padding: 11px 13px;
  border-radius: 18px;
  animation: marketplaceFloatV2 5.6s ease-in-out infinite;
}

body.landing-page .order-ml {
  left: 94px;
  top: 196px;
}

body.landing-page .order-shopee {
  right: 80px;
  top: 220px;
  animation-delay: -2s;
}

body.landing-page .market-flow-v2 {
  position: absolute;
  left: 26px;
  right: 26px;
  bottom: 48px;
  z-index: 2;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
}

body.landing-page .flow-node-v2 {
  position: relative;
  display: grid;
  gap: 8px;
  min-height: 106px;
  padding: 16px 14px;
  border-radius: 22px;
  text-align: center;
}

body.landing-page .flow-node-v2 span {
  display: inline-flex;
  width: 34px;
  height: 34px;
  margin: 0 auto;
  align-items: center;
  justify-content: center;
  border-radius: 13px;
  background: linear-gradient(135deg, #0f70ff, #62c7ff);
  color: #fff;
  font-weight: 950;
  font-size: .78rem;
}

body.landing-page .flow-node-v2::before {
  content: "";
  position: absolute;
  left: -12px;
  top: 50%;
  width: 12px;
  height: 2px;
  background: rgba(31,116,255,.28);
}

body.landing-page .flow-node-v2:first-child::before {
  display: none;
}

body.landing-page .node-op { animation: marketplaceStepV2 5.4s ease-in-out infinite; }
body.landing-page .node-stock { animation: marketplaceStepV2 5.4s ease-in-out infinite .8s; }
body.landing-page .node-prod { animation: marketplaceStepV2 5.4s ease-in-out infinite 1.6s; }
body.landing-page .node-ship { animation: marketplaceStepV2 5.4s ease-in-out infinite 2.4s; }

body.landing-page .market-product-tags-v2 {
  position: absolute;
  left: 50%;
  bottom: 180px;
  z-index: 3;
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  justify-content: center;
  transform: translateX(-50%);
}

body.landing-page .market-product-tags-v2 span {
  position: relative;
  padding: 7px 10px;
  border-radius: 999px;
  color: #0d3d8f;
  font-size: .72rem;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .06em;
}

@keyframes marketplaceDotV2 {
  0% { transform: translateX(0); opacity: 0; }
  18% { opacity: 1; }
  82% { opacity: 1; }
  100% { transform: translateX(160px); opacity: 0; }
}

@keyframes marketplacePulseV2 {
  0%, 100% { transform: scale(.96); opacity: .26; }
  50% { transform: scale(1.06); opacity: .74; }
}

@keyframes marketplaceFloatV2 {
  0%, 100% { transform: translate3d(0,0,0); }
  50% { transform: translate3d(0,-9px,0); }
}

@keyframes marketplaceStepV2 {
  0%, 100% { transform: translateY(0); box-shadow: 0 18px 40px rgba(13,61,143,.12); }
  46% { transform: translateY(-5px); box-shadow: 0 24px 52px rgba(31,116,255,.16); }
}

@media (max-width: 1180px) {
  body.landing-page .marketplace-shell-v2 {
    grid-template-columns: 1fr;
    gap: 30px;
  }

  body.landing-page .marketplace-copy-v2 h2,
  body.landing-page .marketplace-copy-v2 p {
    max-width: 760px;
  }

  body.landing-page .marketplace-stage-v2 {
    max-width: 820px;
    margin: 0 auto;
  }
}

@media (max-width: 780px) {
  body.landing-page .marketplace-section-v2 {
    padding: 48px 0 44px;
  }

  body.landing-page .marketplace-section-v2::before {
    inset: 10px 0 8px;
    border-radius: 30px;
  }

  body.landing-page .marketplace-copy-v2 h2 {
    max-width: none;
    font-size: clamp(2rem, 8.6vw, 2.7rem);
  }

  body.landing-page .marketplace-proof-v2,
  body.landing-page .marketplace-usecases-v2 {
    grid-template-columns: 1fr;
  }

  body.landing-page .marketplace-actions-v2 .btn {
    width: 100%;
  }

  body.landing-page .marketplace-stage-v2 {
    min-height: 620px;
    border-radius: 28px;
  }

  body.landing-page .market-card-v2 {
    width: calc(50% - 22px);
    min-width: 0;
    grid-template-columns: 1fr;
    text-align: center;
    justify-items: center;
    padding: 12px;
  }

  body.landing-page .market-card-v2 small {
    grid-column: auto;
  }

  body.landing-page .market-card-ml {
    left: 14px;
    top: 22px;
  }

  body.landing-page .market-card-shopee {
    right: 14px;
    top: 22px;
  }

  body.landing-page .market-line-v2,
  body.landing-page .market-order-v2 {
    display: none;
  }

  body.landing-page .market-hub-v2 {
    top: 186px;
    width: 146px;
    height: 146px;
    border-radius: 34px;
  }

  body.landing-page .market-product-tags-v2 {
    bottom: 270px;
    width: min(280px, 82%);
  }

  body.landing-page .market-flow-v2 {
    grid-template-columns: 1fr;
    left: 18px;
    right: 18px;
    bottom: 18px;
  }

  body.landing-page .flow-node-v2 {
    min-height: auto;
    grid-template-columns: auto 1fr;
    align-items: center;
    text-align: left;
    padding: 13px 15px;
  }

  body.landing-page .flow-node-v2 span {
    margin: 0;
  }

  body.landing-page .flow-node-v2::before {
    display: none;
  }
}

@media (prefers-reduced-motion: reduce) {
  body.landing-page .market-line-v2 span,
  body.landing-page .hub-pulse-v2,
  body.landing-page .market-order-v2,
  body.landing-page .flow-node-v2 {
    animation: none !important;
  }
}


/* Landing Brindes V2 - módulo de brindes como diferencial principal
   Reforça catálogo, personalizações, técnicas, setup, marketplaces e fluxo operacional. */
body.landing-page .gifts-section-v2 {
  position: relative;
  overflow: clip;
  padding-top: 74px;
  padding-bottom: 78px;
}

body.landing-page .gifts-grid-v2 {
  grid-template-columns: minmax(360px, .86fr) minmax(0, 1.14fr);
  gap: 44px;
  align-items: start;
}

body.landing-page .gifts-grid-v2::before {
  inset: -34px -28px -34px;
  border-radius: 46px;
  background:
    radial-gradient(circle at 7% 12%, rgba(255, 214, 102, .16), transparent 27%),
    radial-gradient(circle at 88% 14%, rgba(31, 116, 255, .12), transparent 30%),
    radial-gradient(circle at 78% 88%, rgba(124, 199, 255, .18), transparent 31%),
    linear-gradient(135deg, rgba(255,255,255,.82), rgba(236,246,255,.60));
  border-color: rgba(153,194,251,.30);
}

body.landing-page .gifts-copy-v2 {
  max-width: 540px;
}

body.landing-page .gifts-copy-v2 .section-tag {
  color: #0b56c4;
}

body.landing-page .gifts-copy-v2 h2 {
  max-width: 11.2ch;
  font-size: clamp(2.35rem, 3.25vw, 3.75rem);
  line-height: 1.04;
  letter-spacing: -.058em;
}

body.landing-page .gifts-copy-v2 p {
  max-width: 540px;
  color: #284f80;
}

body.landing-page .gifts-tech-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 9px;
  margin-top: 24px;
}

body.landing-page .gifts-tech-tags span {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 9px 12px;
  border-radius: 999px;
  background: rgba(255,255,255,.88);
  border: 1px solid rgba(153,194,251,.32);
  color: #0b2b5f;
  font-size: .82rem;
  font-weight: 850;
  box-shadow: 0 12px 24px rgba(34,94,180,.06);
}

body.landing-page .gifts-tech-tags span::before {
  content: "";
  width: 7px;
  height: 7px;
  border-radius: 999px;
  background: linear-gradient(135deg, #ffd34d, #1f74ff);
  box-shadow: 0 0 0 4px rgba(31,116,255,.08);
}

body.landing-page .gifts-feature-grid {
  display: grid;
  gap: 12px;
  margin-top: 24px;
}

body.landing-page .gifts-feature-card {
  position: relative;
  overflow: hidden;
  padding: 17px 18px 17px 20px;
  border-radius: 22px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.96), rgba(242,248,255,.88));
  border: 1px solid rgba(153,194,251,.32);
  box-shadow: 0 18px 40px rgba(34,94,180,.075);
}

body.landing-page .gifts-feature-card::before {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  width: 4px;
  background: linear-gradient(180deg, #ffd34d, #1f74ff);
}

body.landing-page .gifts-feature-card::after {
  content: "";
  position: absolute;
  right: 16px;
  top: 16px;
  width: 34px;
  height: 34px;
  border-top: 1px solid rgba(31,116,255,.16);
  border-right: 1px solid rgba(31,116,255,.16);
  border-radius: 0 13px 0 0;
}

body.landing-page .gifts-feature-card strong {
  display: block;
  color: var(--ink-deep);
  font-size: 1rem;
  letter-spacing: -.02em;
  margin-bottom: 6px;
}

body.landing-page .gifts-feature-card span {
  display: block;
  color: #335d8c;
  line-height: 1.58;
  font-size: .94rem;
}

body.landing-page .gifts-cta-row {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 26px;
}

body.landing-page .gifts-visual-v2 {
  display: grid;
  gap: 18px;
  padding-top: 0;
}

body.landing-page .gifts-flow-panel {
  position: relative;
  overflow: hidden;
  border-radius: 30px;
  padding: 22px;
  background:
    radial-gradient(circle at 12% 12%, rgba(255, 211, 77, .20), transparent 28%),
    radial-gradient(circle at 86% 22%, rgba(31, 116, 255, .16), transparent 30%),
    linear-gradient(135deg, rgba(255,255,255,.95), rgba(238,247,255,.90));
  border: 1px solid rgba(153,194,251,.34);
  box-shadow: 0 26px 70px rgba(34,94,180,.12);
}

body.landing-page .gifts-flow-panel::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(31, 116, 255, .055) 1px, transparent 1px),
    linear-gradient(90deg, rgba(31, 116, 255, .055) 1px, transparent 1px);
  background-size: 22px 22px;
  opacity: .75;
  pointer-events: none;
}

body.landing-page .gifts-flow-head,
body.landing-page .gifts-flow-steps,
body.landing-page .gifts-examples-v2 {
  position: relative;
  z-index: 1;
}

body.landing-page .gifts-flow-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 18px;
  margin-bottom: 18px;
}

body.landing-page .gifts-flow-head strong {
  display: block;
  color: var(--ink-deep);
  font-size: 1.15rem;
  letter-spacing: -.03em;
}

body.landing-page .gifts-flow-head span {
  color: #416693;
  font-size: .84rem;
  font-weight: 750;
  text-align: right;
}

body.landing-page .gifts-flow-steps {
  display: flex;
  align-items: stretch;
  gap: 8px;
  margin: 4px 0 18px;
}

body.landing-page .gifts-flow-steps span {
  display: grid;
  place-items: center;
  min-height: 72px;
  flex: 1 1 0;
  padding: 12px 10px;
  border-radius: 18px;
  background: rgba(255,255,255,.86);
  border: 1px solid rgba(153,194,251,.34);
  color: #0b2b5f;
  font-weight: 850;
  text-align: center;
  box-shadow: 0 16px 32px rgba(34,94,180,.07);
}

body.landing-page .gifts-flow-steps span b {
  display: inline-grid;
  place-items: center;
  width: 28px;
  height: 28px;
  margin-bottom: 6px;
  border-radius: 11px;
  background: linear-gradient(135deg, #0f70ff, #62c7ff);
  color: #fff;
  font-size: .75rem;
  box-shadow: 0 10px 18px rgba(31,116,255,.18);
}

body.landing-page .gifts-flow-steps i {
  position: relative;
  align-self: center;
  width: 18px;
  height: 2px;
  flex: 0 0 18px;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(31,116,255,.20), rgba(31,116,255,.70));
}

body.landing-page .gifts-flow-steps i::after {
  content: "";
  position: absolute;
  right: -1px;
  top: 50%;
  width: 7px;
  height: 7px;
  border-top: 2px solid rgba(31,116,255,.72);
  border-right: 2px solid rgba(31,116,255,.72);
  transform: translateY(-50%) rotate(45deg);
}

body.landing-page .gifts-examples-v2 {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

body.landing-page .gifts-examples-v2 article {
  padding: 16px;
  border-radius: 20px;
  background: rgba(255,255,255,.88);
  border: 1px solid rgba(153,194,251,.30);
  box-shadow: 0 16px 32px rgba(34,94,180,.07);
}

body.landing-page .gifts-examples-v2 small {
  display: inline-flex;
  margin-bottom: 10px;
  padding: 6px 9px;
  border-radius: 999px;
  background: rgba(31,116,255,.08);
  color: #0b56c4;
  font-size: .68rem;
  font-weight: 900;
  letter-spacing: .12em;
  text-transform: uppercase;
}

body.landing-page .gifts-examples-v2 strong {
  display: block;
  color: var(--ink-deep);
  font-size: 1rem;
  letter-spacing: -.02em;
  margin-bottom: 6px;
}

body.landing-page .gifts-examples-v2 span {
  display: block;
  color: #335d8c;
  font-size: .92rem;
  line-height: 1.55;
}

body.landing-page .gifts-shots-v2 {
  max-width: none;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  align-items: start;
  gap: 14px;
}

body.landing-page .gifts-shots-v2::before {
  content: "prints reais do módulo";
  left: 8px;
  top: -16px;
}

body.landing-page .gifts-shots-v2 .shot-card,
body.landing-page .gifts-shots-v2 .shot-card:nth-child(1),
body.landing-page .gifts-shots-v2 .shot-card:nth-child(2) {
  margin: 0;
  padding: 12px;
  border-radius: 24px;
}

body.landing-page .gifts-shots-v2 .shot-card-head {
  align-items: flex-start;
  flex-direction: column;
  gap: 3px;
  padding: 2px 4px 9px;
}

body.landing-page .gifts-shots-v2 .shot-card-head strong {
  font-size: .95rem;
}

body.landing-page .gifts-shots-v2 .shot-card-head span {
  font-size: .76rem;
  text-align: left;
}

body.landing-page .gifts-shots-v2 .shot-card img {
  border-radius: 16px;
}

@media (max-width: 1180px) {
  body.landing-page .gifts-grid-v2 {
    grid-template-columns: 1fr;
    gap: 30px;
  }

  body.landing-page .gifts-copy-v2,
  body.landing-page .gifts-copy-v2 p,
  body.landing-page .gifts-feature-grid {
    max-width: 860px;
  }

  body.landing-page .gifts-copy-v2 h2 {
    max-width: 13ch;
  }
}

@media (max-width: 820px) {
  body.landing-page .gifts-flow-head {
    flex-direction: column;
    gap: 6px;
  }

  body.landing-page .gifts-flow-head span {
    text-align: left;
  }

  body.landing-page .gifts-flow-steps {
    flex-wrap: wrap;
  }

  body.landing-page .gifts-flow-steps span {
    flex: 1 1 42%;
  }

  body.landing-page .gifts-flow-steps i {
    display: none;
  }

  body.landing-page .gifts-examples-v2,
  body.landing-page .gifts-shots-v2 {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 720px) {
  body.landing-page .gifts-section-v2 {
    padding-top: 46px;
    padding-bottom: 46px;
  }

  body.landing-page .gifts-grid-v2::before {
    inset: -12px 0 -14px;
    border-radius: 28px;
  }

  body.landing-page .gifts-copy-v2 h2 {
    max-width: none;
    font-size: clamp(1.95rem, 8.6vw, 2.75rem);
  }

  body.landing-page .gifts-tech-tags span {
    padding: 8px 10px;
    font-size: .78rem;
  }

  body.landing-page .gifts-flow-panel {
    padding: 16px;
    border-radius: 24px;
  }

  body.landing-page .gifts-flow-steps span {
    min-height: 64px;
    flex-basis: 100%;
  }

  body.landing-page .gifts-cta-row .btn {
    width: 100%;
  }

  body.landing-page .gifts-shots-v2::before {
    position: static;
    width: fit-content;
    margin: 0 0 -2px;
  }
}


/* Landing Brindes V3 - animação e destaque do fluxo de brindes */
body.landing-page .gifts-flow-panel {
  isolation: isolate;
}

body.landing-page .gifts-flow-panel::before {
  animation: giftsGridFloat 14s linear infinite;
}

body.landing-page .gifts-flow-panel::after {
  content: "";
  position: absolute;
  left: 9%;
  right: 9%;
  top: 118px;
  height: 2px;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(31,116,255,.08), rgba(31,116,255,.55), rgba(255,211,77,.82), rgba(31,116,255,.55), rgba(31,116,255,.08));
  opacity: .72;
  z-index: 0;
  transform-origin: left center;
  animation: giftsProgressPulse 5.4s ease-in-out infinite;
}

body.landing-page .gifts-flow-head {
  margin-bottom: 22px;
}

body.landing-page .gifts-flow-head strong {
  position: relative;
}

body.landing-page .gifts-flow-head strong::after {
  content: "";
  display: block;
  width: 88px;
  height: 4px;
  margin-top: 10px;
  border-radius: 999px;
  background: linear-gradient(90deg, #ffd34d, #1f74ff);
  box-shadow: 0 8px 18px rgba(31,116,255,.14);
}

body.landing-page .gifts-flow-steps {
  position: relative;
  z-index: 1;
  gap: 10px;
  margin: 6px 0 20px;
}

body.landing-page .gifts-flow-steps .gift-step {
  position: relative;
  overflow: hidden;
  transform: translateY(0);
  animation: giftsStepPulse 5.4s ease-in-out infinite;
}

body.landing-page .gifts-flow-steps .gift-step::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(110deg, transparent 10%, rgba(255,255,255,.58) 48%, transparent 86%);
  transform: translateX(-140%);
  animation: giftsCardSweep 5.4s ease-in-out infinite;
  pointer-events: none;
}

body.landing-page .gifts-flow-steps .gift-step b {
  transition: transform .28s ease, box-shadow .28s ease;
}

body.landing-page .gifts-flow-steps .step-1,
body.landing-page .gifts-flow-steps .step-1::after { animation-delay: .00s; }
body.landing-page .gifts-flow-steps .step-2,
body.landing-page .gifts-flow-steps .step-2::after { animation-delay: .45s; }
body.landing-page .gifts-flow-steps .step-3,
body.landing-page .gifts-flow-steps .step-3::after { animation-delay: .90s; }
body.landing-page .gifts-flow-steps .step-4,
body.landing-page .gifts-flow-steps .step-4::after { animation-delay: 1.35s; }
body.landing-page .gifts-flow-steps .step-5,
body.landing-page .gifts-flow-steps .step-5::after { animation-delay: 1.80s; }

body.landing-page .gifts-flow-steps .gift-arrow {
  animation: giftsArrowPulse 5.4s ease-in-out infinite;
}

body.landing-page .gifts-flow-steps .gift-arrow:nth-of-type(1) { animation-delay: .20s; }
body.landing-page .gifts-flow-steps .gift-arrow:nth-of-type(2) { animation-delay: .65s; }
body.landing-page .gifts-flow-steps .gift-arrow:nth-of-type(3) { animation-delay: 1.10s; }
body.landing-page .gifts-flow-steps .gift-arrow:nth-of-type(4) { animation-delay: 1.55s; }

body.landing-page .gifts-examples-v2 article {
  transition: transform .28s ease, box-shadow .28s ease, border-color .28s ease;
}

body.landing-page .gifts-examples-v2 article:nth-child(1) {
  animation: giftsExampleFloat 4.8s ease-in-out infinite;
}

body.landing-page .gifts-examples-v2 article:nth-child(2) {
  animation: giftsExampleFloat 4.8s ease-in-out infinite .5s;
}

body.landing-page .gifts-examples-v2 article:hover {
  transform: translateY(-4px);
  box-shadow: 0 22px 36px rgba(34,94,180,.12);
  border-color: rgba(31,116,255,.34);
}

body.landing-page .gifts-shots-v2 .shot-card {
  transition: transform .3s ease, box-shadow .3s ease;
}

body.landing-page .gifts-shots-v2 .shot-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 26px 44px rgba(34,94,180,.14);
}

@keyframes giftsGridFloat {
  0% { transform: translate3d(0,0,0); }
  50% { transform: translate3d(-8px,-6px,0); }
  100% { transform: translate3d(0,0,0); }
}

@keyframes giftsProgressPulse {
  0%, 18% { opacity: .28; transform: scaleX(.18); }
  28%, 78% { opacity: .82; transform: scaleX(1); }
  100% { opacity: .34; transform: scaleX(.28); }
}

@keyframes giftsStepPulse {
  0%, 100% { transform: translateY(0); box-shadow: 0 16px 32px rgba(34,94,180,.07); border-color: rgba(153,194,251,.34); }
  14%, 24% { transform: translateY(-8px); box-shadow: 0 24px 42px rgba(31,116,255,.16); border-color: rgba(31,116,255,.40); }
}

@keyframes giftsCardSweep {
  0%, 18% { transform: translateX(-145%); }
  30%, 56% { transform: translateX(135%); }
  100% { transform: translateX(135%); }
}

@keyframes giftsArrowPulse {
  0%, 100% { opacity: .30; transform: translateX(0); }
  18%, 42% { opacity: 1; transform: translateX(6px); }
}

@keyframes giftsExampleFloat {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-6px); }
}

@media (prefers-reduced-motion: reduce) {
  body.landing-page .gifts-flow-panel::before,
  body.landing-page .gifts-flow-panel::after,
  body.landing-page .gifts-flow-steps .gift-step,
  body.landing-page .gifts-flow-steps .gift-step::after,
  body.landing-page .gifts-flow-steps .gift-arrow,
  body.landing-page .gifts-examples-v2 article {
    animation: none !important;
  }
}

@media (max-width: 820px) {
  body.landing-page .gifts-flow-panel::after {
    display: none;
  }

  body.landing-page .gifts-flow-head strong::after {
    width: 74px;
  }
}


/* Landing Brindes V4 - corrige legibilidade do fluxo e refina o selo dos prints */
body.landing-page .gifts-flow-head {
  margin-bottom: 20px;
}

body.landing-page .gifts-flow-head strong {
  font-size: 1.12rem;
}

body.landing-page .gifts-flow-head span {
  font-size: .82rem;
}

body.landing-page .gifts-flow-panel::after {
  left: 8%;
  right: 8%;
  top: 126px;
  opacity: .56;
}

body.landing-page .gifts-flow-steps {
  gap: 6px;
  margin: 6px 0 18px;
}

body.landing-page .gifts-flow-steps .gift-step {
  min-width: 0;
  min-height: 82px;
  padding: 12px 6px;
  font-size: .86rem;
  line-height: 1.14;
  letter-spacing: -.02em;
  word-break: break-word;
  white-space: normal;
  box-shadow: 0 14px 24px rgba(34,94,180,.06);
}

body.landing-page .gifts-flow-steps .gift-step::after {
  display: none;
}

body.landing-page .gifts-flow-steps .gift-step b {
  margin-bottom: 7px;
}

body.landing-page .gifts-flow-steps .gift-arrow {
  width: 12px;
  flex: 0 0 12px;
}

body.landing-page .gifts-flow-steps .gift-arrow::after {
  width: 6px;
  height: 6px;
}

body.landing-page .gifts-flow-steps .step-1,
body.landing-page .gifts-flow-steps .step-2,
body.landing-page .gifts-flow-steps .step-3,
body.landing-page .gifts-flow-steps .step-4,
body.landing-page .gifts-flow-steps .step-5 {
  animation: giftsStepGlow 5.6s ease-in-out infinite;
}

body.landing-page .gifts-flow-steps .step-1 { animation-delay: 0s; }
body.landing-page .gifts-flow-steps .step-2 { animation-delay: .45s; }
body.landing-page .gifts-flow-steps .step-3 { animation-delay: .9s; }
body.landing-page .gifts-flow-steps .step-4 { animation-delay: 1.35s; }
body.landing-page .gifts-flow-steps .step-5 { animation-delay: 1.8s; }

body.landing-page .gifts-flow-steps .gift-step b {
  animation: giftsBadgePulse 5.6s ease-in-out infinite;
}

body.landing-page .gifts-flow-steps .step-1 b { animation-delay: 0s; }
body.landing-page .gifts-flow-steps .step-2 b { animation-delay: .45s; }
body.landing-page .gifts-flow-steps .step-3 b { animation-delay: .9s; }
body.landing-page .gifts-flow-steps .step-4 b { animation-delay: 1.35s; }
body.landing-page .gifts-flow-steps .step-5 b { animation-delay: 1.8s; }

body.landing-page .gifts-flow-steps .gift-arrow {
  animation: giftsArrowFlowSoft 5.6s ease-in-out infinite;
}

body.landing-page .gifts-shots-v2::before {
  content: "telas reais de brindes";
}

body.landing-page .gifts-shots-v2 .shot-card-head strong {
  font-size: .98rem;
  line-height: 1.25;
}

@keyframes giftsStepGlow {
  0%, 100% {
    transform: translateY(0);
    background: rgba(255,255,255,.86);
    border-color: rgba(153,194,251,.34);
    box-shadow: 0 14px 24px rgba(34,94,180,.06);
  }
  16%, 26% {
    transform: translateY(-4px);
    background: linear-gradient(180deg, rgba(255,255,255,.98), rgba(236,246,255,.96));
    border-color: rgba(31,116,255,.38);
    box-shadow: 0 20px 34px rgba(31,116,255,.12);
  }
}

@keyframes giftsBadgePulse {
  0%, 100% {
    transform: scale(1);
    box-shadow: 0 10px 18px rgba(31,116,255,.18);
  }
  18%, 26% {
    transform: scale(1.08);
    box-shadow: 0 14px 24px rgba(31,116,255,.26);
  }
}

@keyframes giftsArrowFlowSoft {
  0%, 100% { opacity: .35; transform: translateX(0); }
  18%, 28% { opacity: .95; transform: translateX(4px); }
}

@media (max-width: 1180px) {
  body.landing-page .gifts-flow-steps .gift-step {
    font-size: .84rem;
    padding-inline: 4px;
  }
}

@media (max-width: 920px) {
  body.landing-page .gifts-flow-panel::after {
    display: none;
  }
}

@media (max-width: 820px) {
  body.landing-page .gifts-flow-steps {
    gap: 10px;
  }

  body.landing-page .gifts-flow-steps .gift-step {
    min-height: 74px;
    font-size: .92rem;
    padding: 12px 10px;
  }
}


/* Landing Brindes V5 - limpeza do hub marketplace e preparação para o próximo ajuste */
body.landing-page .market-product-tags-v2 {
  display: none !important;
}

body.landing-page .market-hub-v2 {
  min-height: 118px;
  padding: 20px 22px;
  border-radius: 28px;
  box-shadow: 0 28px 70px rgba(13,61,143,.20);
}

body.landing-page .market-hub-v2 strong {
  font-size: 1.18rem;
  letter-spacing: -.03em;
}

body.landing-page .market-hub-v2 small {
  margin-top: 6px;
  color: rgba(255,255,255,.86);
  font-weight: 760;
}

body.landing-page .market-order-v2 {
  z-index: 4;
}

body.landing-page .market-line-v2 {
  opacity: .72;
}

@media (max-width: 820px) {
  body.landing-page .market-hub-v2 {
    min-height: 104px;
    padding: 18px;
    border-radius: 24px;
  }
}


/* Landing Brindes V6 - régua premium com ícones e cards horizontais sofisticados */
body.landing-page .gifts-flow-panel {
  padding: 24px;
  border-radius: 32px;
  background:
    radial-gradient(circle at 10% 12%, rgba(255, 211, 77, .15), transparent 30%),
    radial-gradient(circle at 86% 18%, rgba(31, 116, 255, .14), transparent 30%),
    linear-gradient(135deg, rgba(255,255,255,.96), rgba(239,247,255,.92));
}

body.landing-page .gifts-flow-panel::after,
body.landing-page .gifts-flow-steps {
  display: none !important;
}

body.landing-page .gifts-flow-head {
  align-items: flex-start;
  margin-bottom: 18px;
}

body.landing-page .gifts-flow-head strong {
  font-size: 1.16rem;
  line-height: 1.22;
}

body.landing-page .gifts-flow-head span {
  max-width: 250px;
  color: #2c5a92;
}

body.landing-page .gifts-premium-ruler,
body.landing-page .gifts-premium-cases {
  position: relative;
  z-index: 1;
}

body.landing-page .gifts-premium-ruler {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 10px;
  margin-top: 12px;
  padding-top: 18px;
}

body.landing-page .gifts-premium-ruler::before {
  content: "";
  position: absolute;
  left: 9%;
  right: 9%;
  top: 44px;
  height: 2px;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(31,116,255,.14), rgba(31,116,255,.46), rgba(255,211,77,.72), rgba(31,116,255,.46), rgba(31,116,255,.14));
  z-index: 0;
}

body.landing-page .gifts-premium-ruler::after {
  content: "";
  position: absolute;
  left: 9%;
  top: 39px;
  width: 12px;
  height: 12px;
  border-radius: 999px;
  background: linear-gradient(135deg, #ffd34d, #1f74ff);
  box-shadow: 0 0 0 7px rgba(31,116,255,.10), 0 10px 18px rgba(31,116,255,.20);
  z-index: 2;
  animation: giftsRulerDot 7s ease-in-out infinite;
}

body.landing-page .gift-premium-step {
  position: relative;
  z-index: 1;
  display: grid;
  align-content: start;
  min-height: 168px;
  padding: 17px 14px 16px;
  border-radius: 22px;
  background: linear-gradient(180deg, rgba(255,255,255,.96), rgba(245,250,255,.90));
  border: 1px solid rgba(153,194,251,.34);
  box-shadow: 0 16px 34px rgba(34,94,180,.08);
  transition: transform .28s ease, border-color .28s ease, box-shadow .28s ease;
  overflow: hidden;
}

body.landing-page .gift-premium-step::after {
  content: "";
  position: absolute;
  right: 12px;
  top: 12px;
  width: 30px;
  height: 30px;
  border-top: 1px solid rgba(31,116,255,.16);
  border-right: 1px solid rgba(31,116,255,.16);
  border-radius: 0 12px 0 0;
  pointer-events: none;
}

body.landing-page .gift-premium-step:hover {
  transform: translateY(-5px);
  border-color: rgba(31,116,255,.38);
  box-shadow: 0 24px 44px rgba(34,94,180,.13);
}

body.landing-page .gift-step-icon {
  display: inline-grid;
  place-items: center;
  width: 44px;
  height: 44px;
  margin-bottom: 12px;
  border-radius: 16px;
  background: linear-gradient(180deg, rgba(239,248,255,.98), rgba(220,240,255,.82));
  border: 1px solid rgba(153,194,251,.36);
  box-shadow: 0 12px 24px rgba(31,116,255,.10);
}

body.landing-page .gift-step-icon img {
  width: 20px;
  height: 20px;
}

body.landing-page .gift-premium-step small {
  position: absolute;
  right: 14px;
  top: 17px;
  color: #0b56c4;
  font-size: .68rem;
  font-weight: 900;
  letter-spacing: .12em;
}

body.landing-page .gift-premium-step strong {
  display: block;
  color: var(--ink-deep);
  font-size: .98rem;
  line-height: 1.22;
  letter-spacing: -.025em;
  margin-bottom: 7px;
}

body.landing-page .gift-premium-step p {
  margin: 0;
  color: #365f90;
  font-size: .82rem;
  line-height: 1.48;
}

body.landing-page .gifts-premium-cases {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin-top: 14px;
}

body.landing-page .gifts-premium-cases article {
  position: relative;
  overflow: hidden;
  padding: 17px 18px;
  border-radius: 22px;
  background:
    radial-gradient(circle at 90% 0%, rgba(31,116,255,.10), transparent 32%),
    rgba(255,255,255,.90);
  border: 1px solid rgba(153,194,251,.32);
  box-shadow: 0 16px 34px rgba(34,94,180,.08);
}

body.landing-page .gifts-premium-cases article::before {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  width: 4px;
  background: linear-gradient(180deg, #ffd34d, #1f74ff);
}

body.landing-page .gifts-premium-cases small {
  display: inline-flex;
  margin-bottom: 9px;
  padding: 6px 9px;
  border-radius: 999px;
  background: rgba(31,116,255,.08);
  color: #0b56c4;
  font-size: .68rem;
  font-weight: 900;
  letter-spacing: .11em;
  text-transform: uppercase;
}

body.landing-page .gifts-premium-cases strong {
  display: block;
  color: var(--ink-deep);
  font-size: 1.02rem;
  letter-spacing: -.025em;
  margin-bottom: 6px;
}

body.landing-page .gifts-premium-cases span {
  display: block;
  color: #335d8c;
  font-size: .92rem;
  line-height: 1.55;
}

body.landing-page .gifts-shots-v2::before {
  content: "telas reais de brindes";
  padding-inline: 14px;
}

@keyframes giftsRulerDot {
  0%, 12% { left: 9%; opacity: .55; transform: scale(.92); }
  24% { left: 28%; opacity: 1; transform: scale(1.06); }
  42% { left: 47%; opacity: 1; transform: scale(1.06); }
  60% { left: 66%; opacity: 1; transform: scale(1.06); }
  78% { left: 85%; opacity: 1; transform: scale(1.06); }
  100% { left: 85%; opacity: .55; transform: scale(.92); }
}

@media (max-width: 1180px) {
  body.landing-page .gifts-premium-ruler {
    grid-template-columns: repeat(5, minmax(112px, 1fr));
    overflow-x: auto;
    padding-bottom: 6px;
    scrollbar-width: thin;
  }

  body.landing-page .gifts-premium-ruler::before,
  body.landing-page .gifts-premium-ruler::after {
    display: none;
  }

  body.landing-page .gift-premium-step {
    min-width: 138px;
  }
}

@media (max-width: 820px) {
  body.landing-page .gifts-flow-head {
    flex-direction: column;
  }

  body.landing-page .gifts-flow-head span {
    max-width: none;
    text-align: left;
  }

  body.landing-page .gifts-premium-ruler {
    grid-template-columns: 1fr;
    overflow: visible;
  }

  body.landing-page .gift-premium-step {
    min-height: auto;
    min-width: 0;
    grid-template-columns: 54px 1fr;
    column-gap: 14px;
    align-items: start;
  }

  body.landing-page .gift-step-icon {
    grid-row: span 3;
    margin-bottom: 0;
  }

  body.landing-page .gift-premium-step small {
    position: static;
    align-self: center;
    margin-bottom: 4px;
  }

  body.landing-page .gifts-premium-cases {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 520px) {
  body.landing-page .gifts-flow-panel {
    padding: 16px;
  }

  body.landing-page .gift-premium-step {
    padding: 15px;
    border-radius: 20px;
  }
}

@media (prefers-reduced-motion: reduce) {
  body.landing-page .gifts-premium-ruler::after {
    animation: none !important;
  }
}


/* Landing Brindes V7 - ajuste fino do texto "Personalização" na régua premium */
body.landing-page .gift-premium-step .gift-step-personalizacao {
  max-width: 100%;
  font-size: .94rem;
  line-height: 1.12;
  letter-spacing: -.035em;
  overflow-wrap: anywhere;
  word-break: normal;
}

@media (max-width: 1280px) {
  body.landing-page .gift-premium-step .gift-step-personalizacao {
    font-size: .88rem;
    line-height: 1.08;
  }
}

@media (max-width: 1180px) {
  body.landing-page .gift-premium-step .gift-step-personalizacao {
    font-size: .94rem;
  }
}


/* Landing Video Flow V1 - substitui o bloco de benefícios por uma animação premium */
body.landing-page .operation-video-section {
  position: relative;
  padding: 54px 0 56px;
}

body.landing-page .operation-video-box {
  display: grid;
  grid-template-columns: minmax(340px, .86fr) minmax(0, 1.14fr);
  gap: 34px;
  align-items: center;
  position: relative;
  isolation: isolate;
  padding: 38px;
  border-radius: 42px;
  background:
    radial-gradient(circle at 8% 12%, rgba(31,116,255,.10), transparent 28%),
    radial-gradient(circle at 88% 16%, rgba(124,199,255,.14), transparent 30%),
    linear-gradient(135deg, rgba(255,255,255,.86), rgba(236,246,255,.68));
  border: 1px solid rgba(153,194,251,.32);
  box-shadow: 0 30px 90px rgba(34,94,180,.10);
  overflow: hidden;
}

body.landing-page .operation-video-box::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  background-image:
    linear-gradient(rgba(31,116,255,.050) 1px, transparent 1px),
    linear-gradient(90deg, rgba(31,116,255,.050) 1px, transparent 1px);
  background-size: 24px 24px;
  opacity: .75;
}

body.landing-page .operation-video-copy h2 {
  max-width: 11ch;
  margin: 18px 0 18px;
  color: var(--ink-deep);
  font-size: clamp(2.25rem, 3.15vw, 3.7rem);
  line-height: 1.04;
  letter-spacing: -.056em;
  text-wrap: balance;
}

body.landing-page .operation-video-copy p {
  max-width: 54ch;
  color: #2e5686;
  font-size: 1rem;
  line-height: 1.72;
}

body.landing-page .operation-video-points {
  display: grid;
  gap: 10px;
  margin-top: 22px;
  max-width: 520px;
}

body.landing-page .operation-video-points div {
  display: grid;
  gap: 3px;
  padding: 13px 15px 13px 17px;
  border-radius: 18px;
  background: rgba(255,255,255,.84);
  border: 1px solid rgba(153,194,251,.30);
  box-shadow: 0 14px 28px rgba(34,94,180,.06);
}

body.landing-page .operation-video-points strong {
  color: var(--ink-deep);
  font-size: .94rem;
}

body.landing-page .operation-video-points span {
  color: #416693;
  font-size: .88rem;
  font-weight: 650;
}

body.landing-page .operation-video-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 24px;
}

body.landing-page .operation-video-visual {
  position: relative;
  overflow: hidden;
  min-height: 430px;
  border-radius: 34px;
  background:
    radial-gradient(circle at 18% 18%, rgba(255,211,77,.16), transparent 28%),
    radial-gradient(circle at 82% 28%, rgba(31,116,255,.18), transparent 30%),
    linear-gradient(145deg, rgba(255,255,255,.96), rgba(234,246,255,.88));
  border: 1px solid rgba(153,194,251,.36);
  box-shadow: 0 26px 70px rgba(34,94,180,.12);
}

body.landing-page .video-window-top {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 14px 18px;
  border-bottom: 1px solid rgba(153,194,251,.26);
  background: rgba(255,255,255,.58);
}

body.landing-page .video-window-top span {
  width: 9px;
  height: 9px;
  border-radius: 999px;
  background: rgba(31,116,255,.26);
}

body.landing-page .video-window-top strong {
  margin-left: 8px;
  color: #0b2b5f;
  font-size: .78rem;
  font-weight: 900;
  letter-spacing: .12em;
  text-transform: uppercase;
}

body.landing-page .video-stage {
  position: relative;
  min-height: 374px;
  overflow: hidden;
  background-image:
    linear-gradient(rgba(31,116,255,.045) 1px, transparent 1px),
    linear-gradient(90deg, rgba(31,116,255,.045) 1px, transparent 1px);
  background-size: 22px 22px;
}

body.landing-page .video-order {
  position: absolute;
  z-index: 3;
  display: grid;
  gap: 3px;
  width: 175px;
  padding: 13px 14px;
  border-radius: 18px;
  background: rgba(255,255,255,.94);
  border: 1px solid rgba(153,194,251,.34);
  box-shadow: 0 18px 38px rgba(34,94,180,.12);
  animation: operationOrderFloat 5.8s ease-in-out infinite;
}

body.landing-page .video-order small {
  color: #0b56c4;
  font-size: .68rem;
  font-weight: 900;
  letter-spacing: .11em;
  text-transform: uppercase;
}

body.landing-page .video-order strong {
  color: var(--ink-deep);
  font-size: 1rem;
}

body.landing-page .video-order span {
  color: #416693;
  font-size: .82rem;
  font-weight: 700;
}

body.landing-page .video-order-ml {
  left: 7%;
  top: 36px;
}

body.landing-page .video-order-shopee {
  right: 7%;
  top: 54px;
  animation-delay: -.9s;
}

body.landing-page .video-hub {
  position: absolute;
  left: 50%;
  top: 132px;
  z-index: 4;
  display: grid;
  place-items: center;
  gap: 5px;
  width: 156px;
  height: 110px;
  transform: translateX(-50%);
  border-radius: 30px;
  background: linear-gradient(150deg, #08245b 0%, #1557d4 58%, #1f74ff 100%);
  color: #fff;
  box-shadow: 0 24px 52px rgba(13,61,143,.24);
  animation: operationHubPulse 3.8s ease-in-out infinite;
}

body.landing-page .video-hub strong {
  font-size: 1.12rem;
  letter-spacing: -.03em;
}

body.landing-page .video-hub span {
  font-size: .78rem;
  font-weight: 850;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: rgba(255,255,255,.78);
}

body.landing-page .video-flow-line {
  position: absolute;
  z-index: 2;
  height: 2px;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(31,116,255,.06), rgba(31,116,255,.62));
  transform-origin: left center;
  animation: operationLineDraw 4.8s ease-in-out infinite;
}

body.landing-page .video-flow-line.line-left {
  left: 22%;
  top: 124px;
  width: 28%;
  transform: rotate(18deg) scaleX(.2);
}

body.landing-page .video-flow-line.line-right {
  left: 50%;
  top: 126px;
  width: 29%;
  transform: rotate(-18deg) scaleX(.2);
  animation-delay: .45s;
}

body.landing-page .video-flow-steps {
  position: absolute;
  left: 6%;
  right: 6%;
  bottom: 54px;
  z-index: 3;
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 10px;
}

body.landing-page .video-step {
  display: grid;
  place-items: center;
  min-height: 86px;
  padding: 12px 8px;
  border-radius: 20px;
  background: rgba(255,255,255,.90);
  border: 1px solid rgba(153,194,251,.34);
  color: var(--ink-deep);
  font-weight: 850;
  text-align: center;
  box-shadow: 0 16px 32px rgba(34,94,180,.08);
  animation: operationStepActive 5.8s ease-in-out infinite;
}

body.landing-page .video-step b {
  display: inline-grid;
  place-items: center;
  width: 30px;
  height: 30px;
  margin-bottom: 7px;
  border-radius: 11px;
  background: linear-gradient(135deg, #0f70ff, #62c7ff);
  color: #fff;
  font-size: .74rem;
}

body.landing-page .vstep-2 { animation-delay: .42s; }
body.landing-page .vstep-3 { animation-delay: .84s; }
body.landing-page .vstep-4 { animation-delay: 1.26s; }
body.landing-page .vstep-5 { animation-delay: 1.68s; }

body.landing-page .video-progress {
  position: absolute;
  left: 8%;
  right: 8%;
  bottom: 28px;
  height: 4px;
  border-radius: 999px;
  background: rgba(153,194,251,.34);
  overflow: hidden;
}

body.landing-page .video-progress i {
  display: block;
  width: 28%;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, #ffd34d, #1f74ff, #62c7ff);
  animation: operationProgress 5.8s ease-in-out infinite;
}

@keyframes operationOrderFloat {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-8px); }
}

@keyframes operationHubPulse {
  0%, 100% { transform: translateX(-50%) scale(1); }
  50% { transform: translateX(-50%) scale(1.035); }
}

@keyframes operationLineDraw {
  0%, 18% { opacity: .25; transform: rotate(18deg) scaleX(.18); }
  42%, 72% { opacity: .90; transform: rotate(18deg) scaleX(1); }
  100% { opacity: .35; transform: rotate(18deg) scaleX(.30); }
}

body.landing-page .video-flow-line.line-right {
  animation-name: operationLineDrawRight;
}

@keyframes operationLineDrawRight {
  0%, 18% { opacity: .25; transform: rotate(-18deg) scaleX(.18); }
  42%, 72% { opacity: .90; transform: rotate(-18deg) scaleX(1); }
  100% { opacity: .35; transform: rotate(-18deg) scaleX(.30); }
}

@keyframes operationStepActive {
  0%, 100% { transform: translateY(0); border-color: rgba(153,194,251,.34); box-shadow: 0 16px 32px rgba(34,94,180,.08); }
  16%, 26% { transform: translateY(-6px); border-color: rgba(31,116,255,.42); box-shadow: 0 22px 42px rgba(31,116,255,.15); }
}

@keyframes operationProgress {
  0% { transform: translateX(-110%); }
  18% { transform: translateX(-50%); }
  44% { transform: translateX(55%); }
  70% { transform: translateX(190%); }
  100% { transform: translateX(285%); }
}

@media (prefers-reduced-motion: reduce) {
  body.landing-page .video-order,
  body.landing-page .video-hub,
  body.landing-page .video-flow-line,
  body.landing-page .video-step,
  body.landing-page .video-progress i {
    animation: none !important;
  }
}

@media (max-width: 1180px) {
  body.landing-page .operation-video-box {
    grid-template-columns: 1fr;
    padding: 30px;
  }

  body.landing-page .operation-video-copy h2,
  body.landing-page .operation-video-copy p,
  body.landing-page .operation-video-points {
    max-width: 820px;
  }
}

@media (max-width: 720px) {
  body.landing-page .operation-video-section {
    padding: 42px 0 44px;
  }

  body.landing-page .operation-video-box {
    padding: 18px;
    border-radius: 28px;
  }

  body.landing-page .operation-video-copy h2 {
    max-width: none;
    font-size: clamp(1.95rem, 8.4vw, 2.7rem);
  }

  body.landing-page .operation-video-actions .btn {
    width: 100%;
  }

  body.landing-page .operation-video-visual {
    min-height: 560px;
    border-radius: 24px;
  }

  body.landing-page .video-stage {
    min-height: 506px;
  }

  body.landing-page .video-order {
    width: 148px;
    padding: 11px;
  }

  body.landing-page .video-order-ml {
    left: 5%;
    top: 28px;
  }

  body.landing-page .video-order-shopee {
    right: 5%;
    top: 96px;
  }

  body.landing-page .video-hub {
    top: 192px;
  }

  body.landing-page .video-flow-line {
    display: none;
  }

  body.landing-page .video-flow-steps {
    grid-template-columns: 1fr;
    left: 7%;
    right: 7%;
    bottom: 36px;
  }

  body.landing-page .video-step {
    min-height: 54px;
    grid-template-columns: 34px 1fr;
    justify-items: start;
    text-align: left;
    padding: 10px 14px;
  }

  body.landing-page .video-step b {
    margin-bottom: 0;
  }

  body.landing-page .video-progress {
    display: none;
  }
}


/* Landing Video Flow V2 - polimento premium do bloco animado */
body.landing-page .operation-video-section {
  padding-top: 48px;
  padding-bottom: 62px;
}

body.landing-page .operation-video-box {
  grid-template-columns: minmax(330px, .78fr) minmax(0, 1.22fr);
  gap: 38px;
  padding: 42px;
  border-radius: 44px;
  background:
    radial-gradient(circle at 9% 12%, rgba(31,116,255,.12), transparent 28%),
    radial-gradient(circle at 92% 20%, rgba(255,211,77,.13), transparent 28%),
    radial-gradient(circle at 78% 92%, rgba(124,199,255,.18), transparent 30%),
    linear-gradient(135deg, rgba(255,255,255,.90), rgba(235,246,255,.70));
}

body.landing-page .operation-video-copy h2 {
  max-width: 10.4ch;
  font-size: clamp(2.18rem, 2.85vw, 3.35rem);
  line-height: 1.05;
  letter-spacing: -.052em;
}

body.landing-page .operation-video-copy p {
  max-width: 50ch;
  font-size: .98rem;
}

body.landing-page .operation-video-points {
  gap: 11px;
  margin-top: 24px;
}

body.landing-page .operation-video-points .video-point {
  position: relative;
  grid-template-columns: 40px 1fr;
  column-gap: 12px;
  align-items: center;
  padding: 14px 16px;
  min-height: 62px;
  overflow: hidden;
}

body.landing-page .operation-video-points .video-point::before {
  content: "";
  grid-row: 1 / span 2;
  width: 38px;
  height: 38px;
  border-radius: 14px;
  background:
    linear-gradient(135deg, rgba(31,116,255,.14), rgba(124,199,255,.18));
  border: 1px solid rgba(153,194,251,.34);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.70), 0 12px 22px rgba(34,94,180,.06);
}

body.landing-page .operation-video-points .video-point::after {
  content: "";
  position: absolute;
  left: 31px;
  top: 28px;
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: linear-gradient(135deg, #0f70ff, #62c7ff);
  box-shadow: 0 0 0 5px rgba(31,116,255,.08);
}

body.landing-page .operation-video-points .point-market::after {
  background: linear-gradient(135deg, #ffd34d, #1f74ff);
}

body.landing-page .operation-video-points strong,
body.landing-page .operation-video-points span {
  grid-column: 2;
}

body.landing-page .operation-video-visual {
  min-height: 412px;
  border-radius: 36px;
  border-color: rgba(153,194,251,.40);
  box-shadow: 0 30px 86px rgba(34,94,180,.14);
}

body.landing-page .operation-video-visual::after {
  content: "";
  position: absolute;
  inset: 12px;
  border-radius: 28px;
  pointer-events: none;
  border: 1px solid rgba(255,255,255,.72);
  box-shadow: inset 0 0 0 1px rgba(31,116,255,.05);
  z-index: 5;
}

body.landing-page .operation-video-play-badge {
  position: absolute;
  right: 18px;
  top: 16px;
  z-index: 8;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 9px 12px;
  border-radius: 999px;
  background: rgba(255,255,255,.88);
  border: 1px solid rgba(153,194,251,.36);
  color: #0b2b5f;
  font-size: .76rem;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
  box-shadow: 0 16px 32px rgba(34,94,180,.10);
  backdrop-filter: blur(12px);
}

body.landing-page .operation-video-play-badge span {
  width: 26px;
  height: 26px;
  border-radius: 999px;
  background: linear-gradient(135deg, #0f70ff, #62c7ff);
  box-shadow: 0 10px 20px rgba(31,116,255,.18);
  position: relative;
}

body.landing-page .operation-video-play-badge span::after {
  content: "";
  position: absolute;
  left: 10px;
  top: 7px;
  width: 0;
  height: 0;
  border-top: 6px solid transparent;
  border-bottom: 6px solid transparent;
  border-left: 8px solid #fff;
}

body.landing-page .video-window-top {
  min-height: 48px;
  padding-right: 170px;
  background: rgba(255,255,255,.72);
  backdrop-filter: blur(10px);
}

body.landing-page .video-stage {
  min-height: 364px;
}

body.landing-page .video-order {
  width: 172px;
  border-radius: 20px;
  box-shadow: 0 20px 44px rgba(34,94,180,.13);
}

body.landing-page .video-order-ml {
  left: 7.5%;
  top: 42px;
}

body.landing-page .video-order-shopee {
  right: 7.5%;
  top: 62px;
}

body.landing-page .video-hub {
  top: 128px;
  width: 168px;
  height: 116px;
  border-radius: 32px;
  background:
    radial-gradient(circle at 18% 18%, rgba(124,199,255,.32), transparent 28%),
    linear-gradient(150deg, #061a3b 0%, #1353cc 54%, #1f74ff 100%);
  box-shadow: 0 28px 60px rgba(13,61,143,.28);
}

body.landing-page .video-hub::before {
  content: "";
  position: absolute;
  inset: -8px;
  border-radius: 38px;
  background: linear-gradient(135deg, rgba(31,116,255,.18), rgba(255,211,77,.14));
  z-index: -1;
  filter: blur(2px);
}

body.landing-page .video-hub strong {
  font-size: 1.22rem;
}

body.landing-page .video-flow-steps {
  bottom: 58px;
  gap: 12px;
}

body.landing-page .video-step {
  min-height: 78px;
  border-radius: 18px;
  background: rgba(255,255,255,.92);
}

body.landing-page .video-step b {
  width: 28px;
  height: 28px;
}

body.landing-page .video-progress {
  bottom: 32px;
  height: 5px;
  background: rgba(153,194,251,.30);
}

@media (max-width: 1180px) {
  body.landing-page .operation-video-box {
    grid-template-columns: 1fr;
    padding: 32px;
  }

  body.landing-page .operation-video-copy h2 {
    max-width: 16ch;
  }

  body.landing-page .operation-video-copy p,
  body.landing-page .operation-video-points {
    max-width: 820px;
  }
}

@media (max-width: 720px) {
  body.landing-page .operation-video-box {
    padding: 18px;
  }

  body.landing-page .operation-video-copy h2 {
    max-width: none;
    font-size: clamp(1.92rem, 8.1vw, 2.58rem);
  }

  body.landing-page .operation-video-points .video-point {
    grid-template-columns: 36px 1fr;
    padding: 13px 14px;
  }

  body.landing-page .operation-video-points .video-point::before {
    width: 34px;
    height: 34px;
  }

  body.landing-page .operation-video-points .video-point::after {
    left: 27px;
    top: 27px;
  }

  body.landing-page .operation-video-visual {
    min-height: 570px;
  }

  body.landing-page .operation-video-play-badge {
    right: 12px;
    top: 12px;
    padding: 7px 9px;
    font-size: .66rem;
  }

  body.landing-page .operation-video-play-badge span {
    width: 22px;
    height: 22px;
  }

  body.landing-page .operation-video-play-badge span::after {
    left: 8px;
    top: 6px;
    border-top-width: 5px;
    border-bottom-width: 5px;
    border-left-width: 7px;
  }

  body.landing-page .video-window-top {
    padding-right: 130px;
  }
}


/* Landing Brindes V8 - reforço estratégico do módulo de brindes
   Deixa o bloco mais protagonista, especializado e comercial. */
body.landing-page .gifts-section-v2 {
  padding-top: 86px;
  padding-bottom: 86px;
}

body.landing-page .gifts-grid-v2::before {
  background:
    radial-gradient(circle at 8% 12%, rgba(255, 211, 77, .20), transparent 27%),
    radial-gradient(circle at 86% 10%, rgba(31, 116, 255, .16), transparent 30%),
    radial-gradient(circle at 78% 88%, rgba(124, 199, 255, .18), transparent 31%),
    linear-gradient(135deg, rgba(255,255,255,.86), rgba(232,244,255,.66));
  box-shadow: 0 34px 92px rgba(34,94,180,.13);
}

body.landing-page .gifts-copy-strong .section-tag {
  color: #0b56c4;
  border-color: rgba(31,116,255,.28);
}

body.landing-page .gifts-copy-strong h2 {
  max-width: 12.4ch;
  font-size: clamp(2.28rem, 3.05vw, 3.48rem);
  line-height: 1.04;
}

body.landing-page .gifts-copy-strong p {
  max-width: 560px;
  color: #254d7e;
  font-size: 1.02rem;
}

body.landing-page .gifts-spotlight-card {
  position: relative;
  overflow: hidden;
  margin-top: 24px;
  padding: 22px;
  border-radius: 26px;
  color: #ffffff;
  background:
    radial-gradient(circle at 12% 14%, rgba(124,199,255,.28), transparent 30%),
    linear-gradient(135deg, #071b3f 0%, #0d3d8f 58%, #1f74ff 100%);
  box-shadow: 0 28px 64px rgba(13,61,143,.20);
}

body.landing-page .gifts-spotlight-card::before {
  content: "";
  position: absolute;
  right: -42px;
  top: -42px;
  width: 130px;
  height: 130px;
  border-radius: 999px;
  background: rgba(255,255,255,.12);
}

body.landing-page .gifts-spotlight-card strong,
body.landing-page .gifts-spotlight-card span,
body.landing-page .gifts-spotlight-card div {
  position: relative;
  z-index: 1;
}

body.landing-page .gifts-spotlight-card strong {
  display: block;
  font-size: 1.12rem;
  letter-spacing: -.025em;
  margin-bottom: 7px;
}

body.landing-page .gifts-spotlight-card span {
  display: block;
  color: rgba(255,255,255,.84);
  line-height: 1.58;
}

body.landing-page .gifts-spotlight-card div {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 16px;
}

body.landing-page .gifts-spotlight-card b {
  display: inline-flex;
  padding: 7px 10px;
  border-radius: 999px;
  background: rgba(255,255,255,.12);
  border: 1px solid rgba(255,255,255,.18);
  color: #ffffff;
  font-size: .74rem;
  letter-spacing: .08em;
  text-transform: uppercase;
}

body.landing-page .gifts-tech-tags-strong {
  margin-top: 18px;
}

body.landing-page .gifts-tech-tags-strong span {
  border-color: rgba(31,116,255,.28);
}

body.landing-page .gifts-feature-grid-strong {
  gap: 10px;
  margin-top: 20px;
}

body.landing-page .gifts-feature-grid-strong .gifts-feature-card {
  padding: 16px 18px 16px 20px;
}

body.landing-page .gifts-visual-strong {
  gap: 16px;
}

body.landing-page .gifts-suite-preview {
  position: relative;
  overflow: hidden;
  padding: 18px;
  border-radius: 30px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.98), rgba(239,248,255,.92));
  border: 1px solid rgba(153,194,251,.38);
  box-shadow: 0 24px 58px rgba(34,94,180,.12);
}

body.landing-page .gifts-suite-preview::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(31,116,255,.052) 1px, transparent 1px),
    linear-gradient(90deg, rgba(31,116,255,.052) 1px, transparent 1px);
  background-size: 22px 22px;
  pointer-events: none;
}

body.landing-page .gifts-suite-top,
body.landing-page .gifts-suite-body {
  position: relative;
  z-index: 1;
}

body.landing-page .gifts-suite-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  margin-bottom: 14px;
}

body.landing-page .gifts-suite-top span {
  display: inline-flex;
  padding: 7px 10px;
  border-radius: 999px;
  background: linear-gradient(135deg, #0f70ff, #62c7ff);
  color: #fff;
  font-size: .72rem;
  font-weight: 900;
  letter-spacing: .1em;
  text-transform: uppercase;
}

body.landing-page .gifts-suite-top strong {
  color: var(--ink-deep);
  font-size: .95rem;
  letter-spacing: -.02em;
}

body.landing-page .gifts-suite-body {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

body.landing-page .gifts-suite-body article {
  padding: 15px;
  border-radius: 20px;
  background: rgba(255,255,255,.88);
  border: 1px solid rgba(153,194,251,.32);
  box-shadow: 0 14px 30px rgba(34,94,180,.07);
}

body.landing-page .gifts-suite-body small {
  display: block;
  margin-bottom: 6px;
  color: #0b56c4;
  font-size: .68rem;
  font-weight: 900;
  letter-spacing: .12em;
  text-transform: uppercase;
}

body.landing-page .gifts-suite-body strong {
  display: block;
  margin-bottom: 5px;
  color: var(--ink-deep);
  font-size: .98rem;
  letter-spacing: -.02em;
}

body.landing-page .gifts-suite-body span {
  display: block;
  color: #416693;
  font-size: .84rem;
  line-height: 1.42;
}

body.landing-page .gifts-flow-panel-strong {
  border-color: rgba(31,116,255,.30);
}

body.landing-page .gifts-shots-v2 .shot-card {
  background: linear-gradient(180deg, rgba(255,255,255,.98), rgba(241,248,255,.92));
}

@media (max-width: 1180px) {
  body.landing-page .gifts-copy-strong h2 {
    max-width: 14ch;
  }
}

@media (max-width: 820px) {
  body.landing-page .gifts-suite-body {
    grid-template-columns: 1fr;
  }

  body.landing-page .gifts-suite-top {
    align-items: flex-start;
    flex-direction: column;
  }
}

@media (max-width: 720px) {
  body.landing-page .gifts-section-v2 {
    padding-top: 48px;
    padding-bottom: 48px;
  }

  body.landing-page .gifts-copy-strong h2 {
    max-width: none;
  }

  body.landing-page .gifts-spotlight-card,
  body.landing-page .gifts-suite-preview {
    border-radius: 24px;
  }
}


/* Landing Brindes V9 - animação maior, menos leitura, sem telas reais */
body.landing-page .gifts-grid-v2 {
  grid-template-columns: minmax(0, .88fr) minmax(0, 1.12fr);
  gap: 28px;
  align-items: start;
}

body.landing-page .gifts-copy-lean h2 {
  max-width: 10.5ch;
  font-size: clamp(2.12rem, 2.8vw, 3.2rem);
}

body.landing-page .gifts-copy-lean p {
  max-width: 500px;
  font-size: 1rem;
  line-height: 1.65;
}

body.landing-page .gifts-copy-lean .gifts-tech-tags-lean {
  margin-top: 18px;
  gap: 8px;
}

body.landing-page .gifts-copy-lean .gifts-tech-tags-lean span {
  padding: 9px 12px;
  font-size: .76rem;
}

body.landing-page .gifts-feature-grid-lean {
  margin-top: 18px;
  gap: 10px;
}

body.landing-page .gifts-feature-grid-lean .gifts-feature-card {
  padding: 14px 16px;
}

body.landing-page .gifts-feature-grid-lean .gifts-feature-card span {
  font-size: .9rem;
  line-height: 1.45;
}

body.landing-page .gifts-visual-focus {
  gap: 0;
}

body.landing-page .gifts-flow-panel-focus {
  padding: 26px;
  border-radius: 30px;
  background:
    radial-gradient(circle at 86% 12%, rgba(31,116,255,.10), transparent 28%),
    radial-gradient(circle at 8% 10%, rgba(255,211,77,.14), transparent 24%),
    linear-gradient(180deg, rgba(255,255,255,.97), rgba(240,248,255,.92));
  box-shadow: 0 28px 66px rgba(34,94,180,.12);
}

body.landing-page .gifts-flow-panel-focus .gifts-flow-head {
  margin-bottom: 12px;
}

body.landing-page .gifts-flow-panel-focus .gifts-flow-head strong {
  font-size: 1.24rem;
}

body.landing-page .gifts-flow-panel-focus .gifts-flow-head span {
  max-width: none;
  font-size: .84rem;
  text-transform: uppercase;
  letter-spacing: .12em;
}

body.landing-page .gifts-flow-panel-focus .gifts-premium-ruler {
  gap: 12px;
  margin-top: 16px;
  padding-top: 20px;
}

body.landing-page .gifts-flow-panel-focus .gifts-premium-ruler::before {
  left: 8%;
  right: 8%;
  top: 50px;
}

body.landing-page .gifts-flow-panel-focus .gifts-premium-ruler::after {
  left: 8%;
  top: 44px;
  width: 14px;
  height: 14px;
}

body.landing-page .gifts-flow-panel-focus .gift-premium-step {
  min-height: 196px;
  padding: 18px 14px 18px;
  border-radius: 24px;
}

body.landing-page .gifts-flow-panel-focus .gift-step-icon {
  width: 48px;
  height: 48px;
}

body.landing-page .gifts-flow-panel-focus .gift-step-icon img {
  width: 21px;
  height: 21px;
}

body.landing-page .gifts-flow-panel-focus .gift-premium-step strong {
  font-size: 1.08rem;
  margin-bottom: 6px;
}

body.landing-page .gifts-flow-panel-focus .gift-premium-step p {
  font-size: .9rem;
  line-height: 1.5;
  color: #295888;
}

body.landing-page .gifts-premium-cases-lean {
  margin-top: 16px;
  gap: 10px;
}

body.landing-page .gifts-premium-cases-lean article {
  padding: 14px 16px;
}

body.landing-page .gifts-premium-cases-lean strong {
  font-size: .96rem;
}

body.landing-page .gifts-premium-cases-lean span {
  font-size: .88rem;
  line-height: 1.42;
}

@media (max-width: 1180px) {
  body.landing-page .gifts-grid-v2 {
    grid-template-columns: 1fr;
  }

  body.landing-page .gifts-copy-lean h2 {
    max-width: 12ch;
  }
}

@media (max-width: 820px) {
  body.landing-page .gifts-flow-panel-focus {
    padding: 20px;
  }

  body.landing-page .gifts-flow-panel-focus .gift-premium-step {
    min-height: auto;
  }
}


/* Landing Conversion V1 - revisão geral: menos texto, mais conversão e nova animação de brindes */
body.landing-page .notice-pill {
  max-width: 760px;
}

body.landing-page .hero h1 {
  max-width: 9.4em;
}

body.landing-page .hero-text {
  max-width: 46ch;
}

body.landing-page .hero-trust-note {
  font-size: .92rem;
}

body.landing-page .metric-card span,
body.landing-page .marketplace-proof-v2 span,
body.landing-page .marketplace-usecases-v2 span {
  line-height: 1.42;
}

body.landing-page .marketplace-copy-v2 p {
  max-width: 42ch;
}

body.landing-page .marketplace-usecases-v2 article {
  padding: 16px;
}

body.landing-page .gifts-grid-v2 {
  grid-template-columns: minmax(0, .78fr) minmax(0, 1.22fr);
  gap: 34px;
  align-items: center;
}

body.landing-page .gifts-copy-conversion h2 {
  max-width: 9.2ch;
  font-size: clamp(2.25rem, 3.05vw, 3.55rem);
}

body.landing-page .gifts-copy-conversion p {
  max-width: 430px;
  font-size: 1.02rem;
  line-height: 1.62;
}

body.landing-page .gifts-tags-conversion {
  max-width: 430px;
}

body.landing-page .gifts-feature-conversion {
  max-width: 430px;
}

body.landing-page .gifts-feature-conversion .gifts-feature-card {
  padding: 14px 16px;
}

body.landing-page .gifts-feature-conversion .gifts-feature-card span {
  font-size: .9rem;
}

body.landing-page .gifts-visual-conversion {
  min-width: 0;
}

body.landing-page .gifts-motion-card {
  position: relative;
  overflow: hidden;
  min-height: 438px;
  padding: 24px;
  border-radius: 34px;
  background:
    radial-gradient(circle at 16% 18%, rgba(255,211,77,.18), transparent 28%),
    radial-gradient(circle at 86% 18%, rgba(31,116,255,.16), transparent 32%),
    linear-gradient(180deg, rgba(255,255,255,.98), rgba(238,247,255,.92));
  border: 1px solid rgba(153,194,251,.36);
  box-shadow: 0 32px 76px rgba(34,94,180,.14);
  isolation: isolate;
}

body.landing-page .gifts-motion-card::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  background-image:
    linear-gradient(rgba(31,116,255,.052) 1px, transparent 1px),
    linear-gradient(90deg, rgba(31,116,255,.052) 1px, transparent 1px);
  background-size: 24px 24px;
  animation: giftGridDrift 16s linear infinite;
}

body.landing-page .gifts-motion-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  position: relative;
  z-index: 2;
}

body.landing-page .gifts-motion-head span {
  display: inline-flex;
  padding: 8px 11px;
  border-radius: 999px;
  background: rgba(31,116,255,.08);
  color: #0b56c4;
  font-size: .72rem;
  font-weight: 900;
  letter-spacing: .12em;
  text-transform: uppercase;
}

body.landing-page .gifts-motion-head strong {
  color: var(--ink-deep);
  font-size: 1.06rem;
  letter-spacing: -.025em;
  text-align: right;
}

body.landing-page .gifts-motion-stage {
  position: relative;
  height: 300px;
  margin-top: 20px;
}

body.landing-page .gift-origin,
body.landing-page .gift-order-card,
body.landing-page .gift-motion-hub,
body.landing-page .gift-orbit {
  position: absolute;
  z-index: 2;
  background: rgba(255,255,255,.92);
  border: 1px solid rgba(153,194,251,.34);
  box-shadow: 0 16px 34px rgba(34,94,180,.10);
  backdrop-filter: blur(10px);
}

body.landing-page .gift-origin,
body.landing-page .gift-order-card {
  border-radius: 20px;
  padding: 13px 15px;
}

body.landing-page .gift-origin small,
body.landing-page .gift-order-card small,
body.landing-page .gift-motion-hub small {
  display: block;
  color: #0b56c4;
  font-size: .68rem;
  font-weight: 900;
  letter-spacing: .12em;
  text-transform: uppercase;
}

body.landing-page .gift-origin strong,
body.landing-page .gift-order-card strong {
  display: block;
  margin-top: 4px;
  color: var(--ink-deep);
  font-size: .96rem;
  letter-spacing: -.02em;
}

body.landing-page .gift-origin-marketplace {
  left: 4%;
  top: 22px;
}

body.landing-page .gift-order-card {
  right: 4%;
  top: 46px;
  animation: giftFloatSoft 4.8s ease-in-out infinite;
}

body.landing-page .gift-motion-hub {
  left: 50%;
  top: 50%;
  width: 178px;
  height: 178px;
  display: grid;
  place-items: center;
  text-align: center;
  padding: 18px;
  border-radius: 42px;
  color: #fff;
  background:
    radial-gradient(circle at 28% 18%, rgba(124,199,255,.42), transparent 30%),
    linear-gradient(135deg, #061a3b 0%, #0d3d8f 55%, #1f74ff 100%);
  border-color: rgba(255,255,255,.26);
  box-shadow: 0 26px 58px rgba(13,61,143,.25);
  transform: translate(-50%, -50%);
}

body.landing-page .gift-motion-hub::before,
body.landing-page .gift-motion-hub::after {
  content: "";
  position: absolute;
  inset: -12px;
  border-radius: 50px;
  border: 1px solid rgba(31,116,255,.22);
  animation: giftHubPulse 3.8s ease-in-out infinite;
}

body.landing-page .gift-motion-hub::after {
  inset: -24px;
  animation-delay: .6s;
}

body.landing-page .gift-motion-hub strong {
  display: block;
  color: #fff;
  font-size: 1.14rem;
  letter-spacing: -.03em;
}

body.landing-page .gift-motion-hub small {
  color: rgba(255,255,255,.82);
}

body.landing-page .gift-package-icon {
  position: relative;
  width: 48px;
  height: 42px;
  margin-bottom: 8px;
  border-radius: 12px;
  background: linear-gradient(135deg, #ffffff, #dceeff);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.45), 0 12px 24px rgba(0,0,0,.14);
}

body.landing-page .gift-package-icon::before,
body.landing-page .gift-package-icon::after {
  content: "";
  position: absolute;
  background: linear-gradient(180deg, #ffd34d, #1f74ff);
}

body.landing-page .gift-package-icon::before {
  left: 50%;
  top: 0;
  width: 6px;
  height: 100%;
  transform: translateX(-50%);
}

body.landing-page .gift-package-icon::after {
  left: 0;
  right: 0;
  top: 14px;
  height: 6px;
}

body.landing-page .gift-package-icon i {
  position: absolute;
  left: 50%;
  top: -11px;
  width: 26px;
  height: 16px;
  border: 4px solid #ffd34d;
  border-bottom: 0;
  border-radius: 18px 18px 0 0;
  transform: translateX(-50%);
}

body.landing-page .gift-orbit {
  display: inline-grid;
  place-items: center;
  min-width: 82px;
  height: 42px;
  padding: 0 12px;
  border-radius: 999px;
  color: #0b2b5f;
  font-weight: 900;
  font-size: .82rem;
  animation: giftOrbitPulse 5.6s ease-in-out infinite;
}

body.landing-page .gift-orbit-1 { left: 22%; top: 92px; animation-delay: .1s; }
body.landing-page .gift-orbit-2 { right: 20%; top: 138px; animation-delay: .8s; }
body.landing-page .gift-orbit-3 { left: 18%; bottom: 42px; animation-delay: 1.5s; }
body.landing-page .gift-orbit-4 { right: 18%; bottom: 30px; animation-delay: 2.2s; }

body.landing-page .gift-motion-line {
  position: absolute;
  z-index: 1;
  height: 2px;
  border-radius: 999px;
  background: rgba(31,116,255,.14);
  overflow: hidden;
}

body.landing-page .gift-motion-line span {
  display: block;
  width: 38%;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, transparent, #1f74ff, #ffd34d);
  animation: giftLineRun 2.9s ease-in-out infinite;
}

body.landing-page .line-a {
  left: 18%;
  right: 18%;
  top: 110px;
  transform: rotate(12deg);
}

body.landing-page .line-b {
  left: 18%;
  right: 18%;
  bottom: 82px;
  transform: rotate(-10deg);
}

body.landing-page .line-b span { animation-delay: .75s; }

body.landing-page .gift-motion-bottom {
  position: relative;
  z-index: 2;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  margin-top: 6px;
  padding: 14px 16px;
  border-radius: 22px;
  background: rgba(255,255,255,.80);
  border: 1px solid rgba(153,194,251,.28);
}

body.landing-page .gift-motion-bottom span {
  color: #0b2b5f;
  font-size: .86rem;
  font-weight: 900;
}

body.landing-page .gift-motion-bottom i {
  width: 24px;
  height: 2px;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(31,116,255,.20), rgba(31,116,255,.70));
}

@keyframes giftGridDrift {
  0% { transform: translate3d(0,0,0); }
  100% { transform: translate3d(-24px,-24px,0); }
}

@keyframes giftFloatSoft {
  0%,100% { transform: translateY(0); }
  50% { transform: translateY(-8px); }
}

@keyframes giftHubPulse {
  0%,100% { opacity: .24; transform: scale(.95); }
  50% { opacity: .62; transform: scale(1); }
}

@keyframes giftOrbitPulse {
  0%,100% { transform: translateY(0); border-color: rgba(153,194,251,.34); box-shadow: 0 16px 34px rgba(34,94,180,.10); }
  50% { transform: translateY(-6px); border-color: rgba(31,116,255,.40); box-shadow: 0 22px 40px rgba(31,116,255,.14); }
}

@keyframes giftLineRun {
  0% { transform: translateX(-120%); opacity: .25; }
  45%,65% { opacity: 1; }
  100% { transform: translateX(320%); opacity: .25; }
}

@media (max-width: 1180px) {
  body.landing-page .gifts-grid-v2 {
    grid-template-columns: 1fr;
  }

  body.landing-page .gifts-copy-conversion h2,
  body.landing-page .gifts-copy-conversion p,
  body.landing-page .gifts-tags-conversion,
  body.landing-page .gifts-feature-conversion {
    max-width: 760px;
  }
}

@media (max-width: 720px) {
  body.landing-page .gifts-motion-card {
    min-height: auto;
    padding: 18px;
    border-radius: 26px;
  }

  body.landing-page .gifts-motion-head {
    align-items: flex-start;
    flex-direction: column;
  }

  body.landing-page .gifts-motion-head strong {
    text-align: left;
  }

  body.landing-page .gifts-motion-stage {
    height: 300px;
  }

  body.landing-page .gift-motion-hub {
    width: 150px;
    height: 150px;
    border-radius: 34px;
  }

  body.landing-page .gift-origin-marketplace {
    left: 0;
    top: 18px;
  }

  body.landing-page .gift-order-card {
    right: 0;
    top: 52px;
  }

  body.landing-page .gift-orbit {
    min-width: 74px;
    height: 38px;
    font-size: .76rem;
  }

  body.landing-page .gift-orbit-1 { left: 7%; top: 112px; }
  body.landing-page .gift-orbit-2 { right: 5%; top: 142px; }
  body.landing-page .gift-orbit-3 { left: 8%; bottom: 42px; }
  body.landing-page .gift-orbit-4 { right: 8%; bottom: 34px; }

  body.landing-page .gift-motion-bottom {
    flex-wrap: wrap;
    justify-content: flex-start;
  }
}

@media (prefers-reduced-motion: reduce) {
  body.landing-page .gifts-motion-card::before,
  body.landing-page .gift-order-card,
  body.landing-page .gift-motion-hub::before,
  body.landing-page .gift-motion-hub::after,
  body.landing-page .gift-orbit,
  body.landing-page .gift-motion-line span {
    animation: none !important;
  }
}


/* Landing Conversion V3 - bloco Bling no lugar da área SEO */
body.landing-page .bling-section {
  padding: 38px 0 42px;
  position: relative;
  scroll-margin-top: 110px;
}

body.landing-page .bling-box {
  position: relative;
  isolation: isolate;
  display: grid;
  grid-template-columns: minmax(0, .92fr) minmax(0, 1.08fr);
  gap: 34px;
  align-items: center;
  padding: 38px;
  border-radius: 38px;
  background:
    radial-gradient(circle at 8% 18%, rgba(39, 180, 119, .14), transparent 26%),
    radial-gradient(circle at 88% 16%, rgba(31,116,255,.15), transparent 30%),
    linear-gradient(135deg, rgba(255,255,255,.88), rgba(235,247,255,.70));
  border: 1px solid rgba(153,194,251,.30);
  box-shadow: 0 30px 86px rgba(34,94,180,.12);
  overflow: hidden;
}

body.landing-page .bling-box::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background-image:
    linear-gradient(rgba(31,116,255,.048) 1px, transparent 1px),
    linear-gradient(90deg, rgba(31,116,255,.048) 1px, transparent 1px);
  background-size: 24px 24px;
  opacity: .65;
}

body.landing-page .bling-copy,
body.landing-page .bling-visual {
  position: relative;
  z-index: 1;
}

body.landing-page .bling-copy h2 {
  max-width: 11.5ch;
  margin: 18px 0 16px;
  color: var(--ink-deep);
  font-size: clamp(2.25rem, 3.35vw, 3.85rem);
  line-height: 1.03;
  letter-spacing: -.058em;
  text-wrap: balance;
}

body.landing-page .bling-copy p {
  max-width: 560px;
  margin: 0;
  color: #2f5788;
  font-size: 1.03rem;
  line-height: 1.68;
}

body.landing-page .bling-points {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  margin-top: 22px;
}

body.landing-page .bling-points article {
  position: relative;
  overflow: hidden;
  padding: 16px;
  border-radius: 20px;
  background: rgba(255,255,255,.86);
  border: 1px solid rgba(153,194,251,.30);
  box-shadow: 0 16px 34px rgba(34,94,180,.07);
}

body.landing-page .bling-points article::before {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  width: 4px;
  background: linear-gradient(180deg, #2fd386, #1f74ff);
}

body.landing-page .bling-points strong {
  display: block;
  margin-bottom: 5px;
  color: var(--ink-deep);
  font-size: .98rem;
  letter-spacing: -.02em;
}

body.landing-page .bling-points span {
  display: block;
  color: #416693;
  font-size: .88rem;
  line-height: 1.45;
}

body.landing-page .bling-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 24px;
}

body.landing-page .bling-stage {
  position: relative;
  min-height: 380px;
  border-radius: 32px;
  background:
    radial-gradient(circle at 18% 16%, rgba(47,211,134,.14), transparent 28%),
    radial-gradient(circle at 84% 18%, rgba(31,116,255,.14), transparent 30%),
    linear-gradient(180deg, rgba(255,255,255,.94), rgba(240,248,255,.88));
  border: 1px solid rgba(153,194,251,.34);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.70), 0 26px 70px rgba(34,94,180,.11);
  overflow: hidden;
}

body.landing-page .bling-stage::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(31,116,255,.052) 1px, transparent 1px),
    linear-gradient(90deg, rgba(31,116,255,.052) 1px, transparent 1px);
  background-size: 22px 22px;
  opacity: .72;
}

body.landing-page .bling-source-card,
body.landing-page .bling-hub-card,
body.landing-page .bling-flow-row,
body.landing-page .bling-line,
body.landing-page .bling-dot {
  position: absolute;
  z-index: 1;
}

body.landing-page .bling-source-card {
  left: 38px;
  top: 48px;
  width: 210px;
  padding: 18px;
  border-radius: 22px;
  background: rgba(255,255,255,.94);
  border: 1px solid rgba(153,194,251,.34);
  box-shadow: 0 20px 44px rgba(34,94,180,.11);
}

body.landing-page .bling-source-card span {
  display: inline-flex;
  margin-bottom: 9px;
  padding: 7px 10px;
  border-radius: 999px;
  background: linear-gradient(135deg, #1fbf76, #2fd386);
  color: #fff;
  font-size: .72rem;
  font-weight: 900;
  letter-spacing: .12em;
  text-transform: uppercase;
}

body.landing-page .bling-source-card strong,
body.landing-page .bling-hub-card strong {
  display: block;
  color: var(--ink-deep);
  font-size: 1.06rem;
  letter-spacing: -.025em;
}

body.landing-page .bling-source-card small,
body.landing-page .bling-hub-card span {
  display: block;
  margin-top: 5px;
  color: #416693;
  font-weight: 650;
}

body.landing-page .bling-hub-card {
  left: 50%;
  top: 112px;
  width: 190px;
  height: 150px;
  display: grid;
  place-items: center;
  align-content: center;
  text-align: center;
  transform: translateX(-50%);
  border-radius: 34px;
  color: #fff;
  background:
    radial-gradient(circle at 18% 16%, rgba(124,199,255,.28), transparent 30%),
    linear-gradient(135deg, #071b3f, #0d3d8f 58%, #1f74ff);
  box-shadow: 0 26px 62px rgba(13,61,143,.22);
}

body.landing-page .bling-hub-card strong {
  color: #fff;
  font-size: 1.28rem;
}

body.landing-page .bling-hub-card span {
  color: rgba(255,255,255,.84);
  font-size: .86rem;
  text-transform: uppercase;
  letter-spacing: .12em;
}

body.landing-page .bling-flow-row {
  left: 34px;
  right: 34px;
  bottom: 34px;
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 10px;
}

body.landing-page .bling-flow-row article {
  display: grid;
  gap: 8px;
  place-items: center;
  min-height: 82px;
  padding: 12px 8px;
  border-radius: 20px;
  background: rgba(255,255,255,.90);
  border: 1px solid rgba(153,194,251,.34);
  box-shadow: 0 16px 34px rgba(34,94,180,.08);
}

body.landing-page .bling-flow-row b {
  display: inline-grid;
  place-items: center;
  width: 30px;
  height: 30px;
  border-radius: 12px;
  background: linear-gradient(135deg, #0f70ff, #62c7ff);
  color: #fff;
  font-size: .75rem;
}

body.landing-page .bling-flow-row span {
  color: var(--ink-deep);
  font-weight: 850;
  font-size: .88rem;
}

body.landing-page .bling-line-one {
  left: 248px;
  top: 126px;
  width: 170px;
  height: 2px;
  background: linear-gradient(90deg, rgba(47,211,134,.10), rgba(31,116,255,.54));
  transform: rotate(10deg);
}

body.landing-page .bling-line-two {
  left: 50%;
  top: 260px;
  width: 2px;
  height: 50px;
  transform: translateX(-50%);
  background: linear-gradient(180deg, rgba(31,116,255,.54), rgba(47,211,134,.18));
}

body.landing-page .bling-dot {
  left: 258px;
  top: 120px;
  width: 12px;
  height: 12px;
  border-radius: 999px;
  background: linear-gradient(135deg, #2fd386, #1f74ff);
  box-shadow: 0 0 0 8px rgba(31,116,255,.10), 0 12px 24px rgba(31,116,255,.20);
  animation: blingDotMove 5.8s ease-in-out infinite;
}

@keyframes blingDotMove {
  0%, 12% { transform: translate(0,0) scale(.9); opacity: .45; }
  32% { transform: translate(155px, 28px) scale(1.06); opacity: 1; }
  62% { transform: translate(230px, 170px) scale(1.06); opacity: 1; }
  100% { transform: translate(230px, 170px) scale(.92); opacity: .45; }
}

@media (max-width: 1180px) {
  body.landing-page .bling-box {
    grid-template-columns: 1fr;
  }

  body.landing-page .bling-copy h2,
  body.landing-page .bling-copy p {
    max-width: 760px;
  }
}

@media (max-width: 720px) {
  body.landing-page .bling-section {
    padding: 28px 0 34px;
  }

  body.landing-page .bling-box {
    padding: 22px;
    border-radius: 30px;
  }

  body.landing-page .bling-copy h2 {
    max-width: none;
    font-size: clamp(1.95rem, 8.8vw, 2.6rem);
  }

  body.landing-page .bling-points {
    grid-template-columns: 1fr;
  }

  body.landing-page .bling-actions .btn {
    width: 100%;
  }

  body.landing-page .bling-stage {
    min-height: 500px;
    border-radius: 26px;
  }

  body.landing-page .bling-source-card {
    left: 18px;
    right: 18px;
    top: 24px;
    width: auto;
  }

  body.landing-page .bling-hub-card {
    top: 145px;
    width: 160px;
    height: 132px;
  }

  body.landing-page .bling-flow-row {
    left: 18px;
    right: 18px;
    bottom: 18px;
    grid-template-columns: 1fr;
  }

  body.landing-page .bling-flow-row article {
    min-height: 58px;
    grid-template-columns: 36px 1fr;
    justify-items: start;
    text-align: left;
  }

  body.landing-page .bling-line,
  body.landing-page .bling-dot {
    display: none;
  }
}

@media (prefers-reduced-motion: reduce) {
  body.landing-page .bling-dot {
    animation: none !important;
  }
}
