/* ============================================================
   TOKI BABY — Landing page styles
   Brand: rosa #fd82a0 · azul-bebê #b0e0e6 · turquesa #5ecbd4
   Type: Glossy Sheen (display) · VAG Rounded (subtítulo) · Gotham (corpo)
   ============================================================ */

:root {
  /* brand */
  --rosa:        #fd82a0;
  --rosa-claro:  #ffb6c1;
  --rosa-deep:   #ec5e81;
  --azul:        #b0e0e6;
  --turquesa:    #5ecbd4;
  --turquesa-deep:#39b2bf;
  --lilas:       #e6d6e2;
  --cinza-1:     #7f7a80;
  --cinza-2:     #9e9aa0;

  /* ink + surfaces */
  --ink:         #4b4453;   /* body text — soft, warm */
  --ink-strong:  #3a3442;   /* headings */
  --white:       #ffffff;
  --bg:          #ffffff;
  --bg-rosa:     #fff4f7;   /* very light pink band */
  --bg-azul:     #f0fafc;   /* very light blue band */
  --bg-cream:    #fffaf6;

  /* themeable accents (driven by [data-palette] / [data-cta]) */
  --accent:        var(--rosa);
  --accent-deep:   var(--rosa-deep);
  --accent-2:      var(--turquesa);
  --hero-grad:     linear-gradient(125deg, #ffc2d0 0%, #fd82a0 42%, #7ad3dd 100%);
  --cta-bg:        var(--rosa);
  --cta-bg-hover:  var(--rosa-deep);
  --cta-fg:        #ffffff;

  /* type */
  --f-display: "Glossy Sheen", "VAG Rounded", system-ui, sans-serif;
  --f-head:    "VAG Rounded", "Glossy Sheen", system-ui, sans-serif;
  --f-body:    "Gotham", "Helvetica Neue", Arial, sans-serif;

  /* radii + shadow */
  --r-sm: 14px;
  --r-md: 22px;
  --r-lg: 32px;
  --r-xl: 44px;
  --r-pill: 999px;
  --sh-soft:  0 10px 30px rgba(252,130,160,.12);
  --sh-blue:  0 14px 40px rgba(94,203,212,.16);
  --sh-pink:  0 16px 44px rgba(252,130,160,.28);
  --sh-card:  0 12px 34px rgba(75,68,83,.08);
  --sh-lift:  0 22px 56px rgba(75,68,83,.14);

  --maxw: 1180px;
  --gut: clamp(20px, 5vw, 56px);
}

/* themeable: palette emphasis (driven by [data-palette]) */
[data-palette="rosa"] { --accent: var(--rosa); --accent-deep: var(--rosa-deep); --hero-grad: linear-gradient(125deg,#ffc2d0 0%,#fd82a0 52%,#ec5e81 100%); }
[data-palette="azul"] { --accent: var(--turquesa); --accent-deep: var(--turquesa-deep); --hero-grad: linear-gradient(125deg,#cdeef2 0%,#5ecbd4 52%,#39b2bf 100%); }
[data-palette="equilibrio"] { --accent: var(--rosa); --accent-deep: var(--rosa-deep); --hero-grad: linear-gradient(125deg,#ffc2d0 0%,#fd82a0 42%,#7ad3dd 100%); }

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: var(--f-body);
  color: var(--ink);
  background: var(--bg);
  font-size: 18px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}
img { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button { font-family: inherit; cursor: pointer; border: none; background: none; }

/* ---------- type helpers ---------- */
.display {
  font-family: var(--f-display);
  text-transform: uppercase;
  line-height: 1.02;
  letter-spacing: .005em;
  color: var(--ink-strong);
  font-weight: 400;
}
.subhead { font-family: var(--f-head); font-weight: 700; line-height: 1.15; color: var(--ink-strong); }
.eyebrow {
  font-family: var(--f-head); font-weight: 700;
  text-transform: uppercase; letter-spacing: .14em;
  font-size: 13px; color: var(--accent);
  display: inline-flex; align-items: center; gap: 8px;
}
.lead { font-size: clamp(18px, 2.1vw, 22px); line-height: 1.55; }
.muted { color: var(--cinza-1); }
.tx-rosa { color: var(--rosa); }
.tx-azul { color: var(--turquesa); }

/* ---------- layout ---------- */
.wrap { max-width: var(--maxw); margin: 0 auto; padding-inline: var(--gut); }
.section { padding-block: clamp(56px, 8vw, 104px); position: relative; overflow: hidden; }
.section--rosa { background: var(--bg-rosa); }
.section--azul { background: var(--bg-azul); }
.section--cream { background: var(--bg-cream); }
.abertura-prod { position: absolute; bottom: 0; width: clamp(150px, 16vw, 240px); z-index: 1; opacity: .9; pointer-events: none; filter: drop-shadow(0 16px 28px rgba(75,68,83,.12)); }
.abertura-prod--l { left: clamp(-30px, 1vw, 30px); transform: rotate(-6deg); }
.abertura-prod--r { right: clamp(-30px, 1vw, 30px); transform: rotate(6deg); }
.abertura-prod--tl { top: clamp(20px, 4vw, 56px); bottom: auto; left: clamp(-20px, 2vw, 50px); width: clamp(120px, 12vw, 180px); transform: rotate(8deg); opacity: 1; border-radius: 22px; border: 6px solid #fff; box-shadow: 0 16px 34px rgba(75,68,83,.16); }
.abertura-prod--tr { top: clamp(20px, 4vw, 56px); bottom: auto; right: clamp(-20px, 2vw, 50px); width: clamp(120px, 12vw, 180px); transform: rotate(-8deg); opacity: 1; border-radius: 22px; border: 6px solid #fff; box-shadow: 0 16px 34px rgba(75,68,83,.16); }
.section--cream .wrap { position: relative; z-index: 2; }
@media (max-width: 1100px){ .abertura-prod { display: none; } }
.center { text-align: center; }
.sec-head { max-width: 720px; margin: 0 auto clamp(32px, 5vw, 56px); }
.center .eyebrow { justify-content: center; }
.sec-title { font-size: clamp(30px, 4.4vw, 52px); margin: 14px 0 0; }
.sec-sub { margin: 16px auto 0; max-width: 620px; color: var(--cinza-1); }

/* ---------- buttons ---------- */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 10px;
  font-family: var(--f-head); font-weight: 700; font-size: 18px;
  padding: 17px 32px; border-radius: var(--r-pill);
  transition: transform .15s ease, box-shadow .2s ease, background .2s ease;
  white-space: nowrap;
}
.btn:active { transform: scale(.97); }
.btn--primary {
  background: var(--cta-bg); color: var(--cta-fg); box-shadow: var(--sh-pink);
}
.btn--primary:hover { background: var(--cta-bg-hover); transform: translateY(-2px); box-shadow: 0 20px 50px rgba(252,130,160,.36); }
[data-cta="gradiente"] .btn--primary { background: linear-gradient(120deg, var(--rosa), var(--turquesa)); }
[data-cta="turquesa"] .btn--primary { background: var(--turquesa); box-shadow: var(--sh-blue); }
[data-cta="turquesa"] .btn--primary:hover { background: var(--turquesa-deep); }
.btn--ghost {
  background: var(--white); color: var(--ink-strong); box-shadow: var(--sh-card);
}
.btn--ghost:hover { transform: translateY(-2px); box-shadow: var(--sh-lift); }
.btn--lg { font-size: 20px; padding: 20px 40px; }
.btn .ic { width: 22px; height: 22px; }

.microcopy { margin-top: 16px; font-size: 14.5px; color: var(--cinza-1); display: flex; flex-wrap: wrap; gap: 6px 18px; align-items: center; }
.microcopy .dot { display: inline-flex; align-items: center; gap: 7px; }
.microcopy svg { width: 16px; height: 16px; color: var(--turquesa); }
.center .microcopy { justify-content: center; }

/* ---------- header ---------- */
.site-head {
  position: sticky; top: 0; z-index: 60;
  background: rgba(255,255,255,.82); backdrop-filter: blur(14px);
  border-bottom: 1px solid rgba(75,68,83,.06);
}
.site-head .wrap { display: flex; align-items: center; justify-content: space-between; height: 70px; }
.logo { font-family: var(--f-display); text-transform: uppercase; font-size: 26px; line-height: 1; letter-spacing: .01em; display: inline-flex; align-items: center; gap: .18em; }
.logo img { height: 40px; width: auto; display: block; }
.logo .t { color: var(--rosa); }
.logo .b { color: var(--turquesa); }
.head-cta { display: flex; align-items: center; gap: 14px; }
.head-link { font-family: var(--f-head); font-weight: 700; font-size: 15px; color: var(--ink-strong); }
.head-link:hover { color: var(--rosa); }
@media (max-width: 640px){ .head-link { display: none; } .site-head .wrap { height: 60px; } }

/* ---------- hero ---------- */
.hero { position: relative; background: var(--hero-grad); overflow: hidden; }
.hero-video { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; z-index: 0; pointer-events: none; }
.hero-veil { position: absolute; inset: 0; z-index: 1; pointer-events: none;
  background: linear-gradient(125deg, rgba(252,130,160,.58) 0%, rgba(252,130,160,.46) 45%, rgba(94,203,212,.48) 100%); }
[data-hero-bg="gradiente"] .hero-video, [data-hero-bg="gradiente"] .hero-veil { display: none; }
.hero-beams { position: absolute; inset: 0; width: 100%; height: 100%; z-index: 1; mix-blend-mode: screen; pointer-events: none; }
[data-bubbles="off"] .hero-beams { display: none; }
.hero .wrap { position: relative; z-index: 2; display: grid; grid-template-columns: 1.05fr .95fr; gap: clamp(28px, 5vw, 64px); align-items: center; padding-block: clamp(48px, 7vw, 92px); }
.hero-copy { color: #fff; }
.hero .eyebrow { color: #fff; background: rgba(255,255,255,.22); padding: 7px 14px; border-radius: var(--r-pill); }
.hero h1 { font-family: var(--f-display); text-transform: uppercase; color: #fff; font-weight: 400; line-height: 1.0; letter-spacing: .004em; font-size: clamp(38px, 6vw, 76px); margin: 20px 0 0; text-shadow: 0 4px 24px rgba(180,60,95,.18); }
.hero h1 .hl { color: #fff4c4; }
.hero-sub { color: rgba(255,255,255,.96); font-size: clamp(17px, 2vw, 21px); margin: 20px 0 0; max-width: 30ch; font-weight: 500; }
.hero-actions { margin-top: 30px; display: flex; flex-wrap: wrap; gap: 14px; align-items: center; }
.hero .btn--primary { background: #fff; color: var(--rosa-deep); box-shadow: 0 16px 40px rgba(150,50,80,.22); }
.hero .btn--primary:hover { background: #fff; color: var(--rosa-deep); transform: translateY(-2px); box-shadow: 0 22px 52px rgba(150,50,80,.3); }
.hero .microcopy { color: rgba(255,255,255,.92); }
.hero .microcopy svg { color: #fff4c4; }

/* hero media — soft blob frame */
.hero-media { position: relative; }
.hero-photo {
  border-radius: 50% 50% 48% 52% / 54% 52% 48% 46%;
  overflow: hidden; background: #fff;
  box-shadow: 0 30px 70px rgba(120,40,70,.28);
  border: 10px solid rgba(255,255,255,.55);
  aspect-ratio: 1/1;
}
.hero-photo img { width: 100%; height: 100%; object-fit: cover; }
.hero-badge {
  position: absolute; background: #fff; border-radius: var(--r-md);
  box-shadow: var(--sh-card); padding: 12px 16px; display: flex; align-items: center; gap: 11px;
}
.hero-badge .ico { width: 38px; height: 38px; border-radius: 12px; display: grid; place-items: center; flex: none; }
.hero-badge svg { width: 21px; height: 21px; }
.hero-badge b { font-family: var(--f-head); font-size: 15px; color: var(--ink-strong); display: block; line-height: 1.1; }
.hero-badge span { font-size: 12.5px; color: var(--cinza-1); }
.hero-badge--1 { top: 8%; left: -6%; }
.hero-badge--2 { bottom: 9%; right: -5%; }

/* orbiting product circles */
.hero-orbit {
  position: absolute; border-radius: 50%; overflow: hidden; background: #fff;
  border: 5px solid #fff; box-shadow: 0 14px 34px rgba(120,40,70,.26);
  display: grid; place-items: center; z-index: 3;
  animation: orbit-float 5s ease-in-out infinite;
}
.hero-orbit img { width: 100%; height: 100%; object-fit: contain; padding: 12px; }
.hero-orbit--1 { width: 184px; height: 184px; top: -3%; right: -10%; animation-delay: 0s; }
.hero-orbit--1 img { padding: 5px; }
.hero-orbit--2 { width: 168px; height: 168px; bottom: 10%; left: -12%; animation-delay: .8s; }
.hero-orbit--3 { width: 138px; height: 138px; bottom: -6%; right: 12%; animation-delay: 1.6s; }
.hero-orbit--4 { width: 132px; height: 132px; top: 6%; left: -10%; animation-delay: 1.2s; }
.hero-orbit--4 img { padding: 12px; }
@keyframes orbit-float { 0%,100% { transform: translateY(0); } 50% { transform: translateY(-10px); } }
@media (prefers-reduced-motion: reduce){ .hero-orbit { animation: none; } }
@media (max-width: 880px){
  .hero .wrap { grid-template-columns: 1fr; text-align: center; }
  .hero-sub { margin-inline: auto; }
  .hero-actions { justify-content: center; }
  .hero .eyebrow { margin-inline: auto; }
  .hero-media { max-width: 420px; margin: 8px auto 0; order: -1; }
  .hero-badge--1 { left: -2%; }
  .hero-badge--2 { right: -2%; }
  .hero-orbit--1 { width: 132px; height: 132px; right: -5%; }
  .hero-orbit--2 { width: 122px; height: 122px; left: -6%; }
  .hero-orbit--3 { width: 100px; height: 100px; right: 8%; }
  .hero-orbit--4 { width: 96px; height: 96px; left: -5%; }
}

/* trust strip */
.trust { background: var(--white); border-bottom: 1px solid rgba(75,68,83,.06); }
.trust .wrap { display: flex; flex-wrap: wrap; gap: 16px 40px; justify-content: center; align-items: center; padding-block: 20px; }
.trust .item { display: inline-flex; align-items: center; gap: 10px; font-family: var(--f-head); font-weight: 700; font-size: 15px; color: var(--ink-strong); }
.trust svg { width: 20px; height: 20px; color: var(--turquesa); }
.trust .stars { color: var(--rosa); }

/* ---------- pain points ---------- */
.pain-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(250px,1fr)); gap: 18px; }
.pain {
  background: var(--white); border-radius: var(--r-md); padding: 26px 24px;
  box-shadow: var(--sh-card); display: flex; gap: 16px; align-items: flex-start;
}
.pain .ico { width: 46px; height: 46px; border-radius: 14px; background: var(--bg-rosa); color: var(--rosa); display: grid; place-items: center; flex: none; }
.pain .ico svg { width: 24px; height: 24px; }
.pain .ico--emoji { background: var(--bg-rosa); padding: 6px; }
.pain .ico--emoji svg { width: 100%; height: 100%; }
.pain .ico-img { width: 100%; height: 100%; object-fit: contain; }
.pain p { margin: 0; font-size: 16.5px; line-height: 1.5; }
.pain strong { font-family: var(--f-head); color: var(--ink-strong); }
.pain-foot { margin-top: 36px; text-align: center; font-family: var(--f-head); font-weight: 700; font-size: clamp(20px,2.6vw,28px); color: var(--ink-strong); }
.pain-foot .tx-rosa { color: var(--rosa); }

/* ---------- products / solution ---------- */
.prod-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 22px; }
@media (max-width: 1080px){ .prod-grid { grid-template-columns: repeat(2, 1fr); max-width: 720px; margin-inline: auto; } }
@media (max-width: 560px){ .prod-grid { grid-template-columns: 1fr; max-width: 380px; } }
.prod {
  background: var(--white); border-radius: var(--r-lg); overflow: hidden;
  box-shadow: var(--sh-card); transition: transform .25s ease, box-shadow .25s ease;
  display: flex; flex-direction: column;
}
.prod:hover { transform: translateY(-6px); box-shadow: var(--sh-lift); }
.prod-media { aspect-ratio: 1/1; background: radial-gradient(120% 120% at 50% 18%, #ffeaf0 0%, #ffd5e0 100%); position: relative; display: grid; place-items: center; }
.prod--azul .prod-media { background: radial-gradient(120% 120% at 50% 18%, #e4f6f9 0%, #c4ebef 100%); }
.prod-media img { width: 86%; height: 86%; object-fit: contain; }

/* click-to-advance photo gallery (all product cards) */
.prod-gallery { position: absolute; inset: 0; cursor: pointer; outline: none; -webkit-tap-highlight-color: transparent; }
.prod-gallery img {
  position: absolute; inset: 0; margin: auto; width: 86%; height: 86%; object-fit: contain;
  opacity: 0; transition: opacity .4s ease; will-change: opacity;
}
.prod-gallery img.show { opacity: 1; }
.prod-gallery img.show { transition: opacity .4s ease, transform .35s ease; }
.prod:hover .prod-gallery img.show { transform: scale(1.07); }
.gal-placeholder { position: absolute; inset: 12%; display: grid; place-content: center; justify-items: center; gap: 8px; color: var(--cinza-2); border: 2px dashed rgba(252,130,160,.35); border-radius: var(--r-md); background: rgba(255,255,255,.4); }
.gal-placeholder svg { width: 38px; height: 38px; color: var(--rosa); opacity: .7; }
.gal-placeholder span { font-family: var(--f-head); font-weight: 700; font-size: 14px; }
.gal-1 { cursor: default; }

.gal-dots { position: absolute; bottom: 14px; left: 0; right: 0; display: flex; gap: 7px; justify-content: center; z-index: 2; pointer-events: none; --dot-off: rgba(252,130,160,.32); --dot-on: var(--rosa); }
.prod--azul .gal-dots { --dot-off: rgba(94,203,212,.32); --dot-on: var(--turquesa); }
.gal-dots b { width: 7px; height: 7px; border-radius: 50%; background: var(--dot-off); transition: background .25s ease, transform .25s ease; }
.gal-dots b.on { background: var(--dot-on); transform: scale(1.25); }

/* expand affordance */
.gal-expand { position: absolute; top: 14px; right: 14px; z-index: 3; width: 36px; height: 36px; border-radius: 50%;
  background: rgba(255,255,255,.9); color: var(--ink-strong); display: grid; place-items: center;
  box-shadow: var(--sh-card); transition: transform .15s ease, background .15s ease; cursor: zoom-in; }
.prod-media:hover .gal-expand { transform: scale(1.08); background: #fff; }
.gal-expand:hover { transform: scale(1.12); background: #fff; }
.gal-expand svg { width: 18px; height: 18px; }

/* gallery prev/next arrows */
.gal-arrow { position: absolute; top: 50%; transform: translateY(-50%); z-index: 4; width: 42px; height: 42px;
  border-radius: 50%; background: rgba(255,255,255,.92); color: var(--ink-strong); display: grid; place-items: center;
  box-shadow: var(--sh-card); cursor: pointer; opacity: 0; transition: opacity .2s ease, transform .15s ease, background .15s ease; }
.gal-arrow--prev { left: 14px; }
.gal-arrow--next { right: 14px; }
.prod-media:hover .gal-arrow { opacity: 1; }
.gal-arrow:hover { background: var(--rosa); color: #fff; transform: translateY(-50%) scale(1.08); }
.prod--azul .gal-arrow:hover { background: var(--turquesa); }
.gal-arrow:active { transform: translateY(-50%) scale(.95); }
.gal-arrow svg { width: 22px; height: 22px; }
@media (hover: none) { .gal-arrow { opacity: 1; background: rgba(255,255,255,.82); } }

/* lightbox */
.lb { position: fixed; inset: 0; z-index: 120; display: none; align-items: center; justify-content: center; padding: 24px; }
.lb.open { display: flex; }
.lb-bg { position: absolute; inset: 0; background: rgba(58,52,66,.72); backdrop-filter: blur(6px); }
.lb-stage { position: relative; z-index: 2; max-width: 720px; width: 100%; }
.lb-frame { background: #fff; border-radius: var(--r-lg); padding: 18px; box-shadow: var(--sh-lift); aspect-ratio: 1/1; display: grid; place-items: center; overflow: hidden; }
.lb-frame img { max-width: 100%; max-height: 100%; object-fit: contain; }
.lb-title { text-align: center; color: #fff; font-family: var(--f-head); font-weight: 700; font-size: 18px; margin-top: 16px; }
.lb-nav { position: absolute; top: 50%; transform: translateY(-50%); width: 52px; height: 52px; border-radius: 50%; background: #fff; color: var(--ink-strong); display: grid; place-items: center; box-shadow: var(--sh-card); transition: transform .15s ease; }
.lb-nav:hover { transform: translateY(-50%) scale(1.08); }
.lb-nav svg { width: 24px; height: 24px; }
.lb-prev { left: -20px; } .lb-next { right: -20px; }
.lb-close { position: absolute; top: -16px; right: -16px; width: 42px; height: 42px; border-radius: 50%; background: var(--rosa); color: #fff; display: grid; place-items: center; box-shadow: var(--sh-pink); z-index: 3; }
.lb-close svg { width: 22px; height: 22px; }
.lb-dots { display: flex; gap: 8px; justify-content: center; margin-top: 14px; }
.lb-dots i { width: 9px; height: 9px; border-radius: 50%; background: rgba(255,255,255,.4); cursor: pointer; transition: background .15s ease, transform .15s ease; }
.lb-dots i.on { background: #fff; transform: scale(1.2); }
@media (max-width: 600px){ .lb-prev { left: 6px; } .lb-next { right: 6px; } .lb-nav { width: 44px; height: 44px; } }
.prod-tag { position: absolute; top: 16px; left: 16px; z-index: 4; font-family: var(--f-head); font-weight: 700; font-size: 12px; letter-spacing: .04em; text-transform: uppercase; color: #fff; background: var(--rosa); padding: 6px 13px; border-radius: var(--r-pill); box-shadow: 0 4px 12px rgba(75,68,83,.16); }
.prod--azul .prod-tag { background: var(--turquesa); }
.prod-body { padding: 24px 24px 28px; display: flex; flex-direction: column; flex: 1; }
.prod-body h3 { font-family: var(--f-head); font-weight: 700; font-size: 23px; color: var(--ink-strong); margin: 0; }
.prod-body p { margin: 10px 0 0; font-size: 16px; color: var(--cinza-1); }
.prod-feats { list-style: none; margin: 16px 0 0; padding: 0; display: flex; flex-direction: column; gap: 9px; }
.prod-feats li { display: flex; gap: 9px; align-items: flex-start; font-size: 15px; }
.prod-feats svg { width: 18px; height: 18px; color: var(--turquesa); flex: none; margin-top: 3px; }
.prod--rosa .prod-feats svg { color: var(--rosa); }
.prod-cta { margin-top: auto; padding-top: 22px; }
.prod .btn { width: 100%; }
.prod--rosa .btn--soft { background: var(--bg-rosa); color: var(--rosa-deep); }
.prod--azul .btn--soft { background: var(--bg-azul); color: var(--turquesa-deep); }
.btn--soft:hover { transform: translateY(-2px); }

.mech { margin-top: 40px; text-align: center; background: var(--white); border-radius: var(--r-lg); padding: clamp(26px,4vw,40px); box-shadow: var(--sh-card); }
.mech .eyebrow { justify-content: center; }
.mech p { max-width: 760px; margin: 12px auto 0; font-size: clamp(17px,2vw,20px); }
.mech .tx-rosa { color: var(--rosa); }

@media (max-width: 860px){ .mech p { font-size: 18px; } }

/* ---------- benefits ---------- */
.benef-side { position: absolute; top: 50%; transform: translateY(-50%); width: clamp(150px, 14vw, 210px); z-index: 1; display: flex; flex-direction: column; gap: 16px; }
.benef-side img { width: 100%; aspect-ratio: 1/1; object-fit: cover; border-radius: 26px; box-shadow: 0 18px 44px rgba(75,68,83,.16); border: 6px solid #fff; }
.benef-side--l { left: clamp(-40px, -1vw, 20px); }
.benef-side--l img:nth-child(1) { transform: rotate(-5deg); }
.benef-side--l img:nth-child(2) { transform: rotate(4deg); }
.benef-side--r { right: clamp(-40px, -1vw, 20px); }
.benef-side--r img:nth-child(1) { transform: rotate(5deg); }
.benef-side--r img:nth-child(2) { transform: rotate(-4deg); }
.section--azul .wrap { position: relative; z-index: 2; }
@media (max-width: 1300px){ .benef-side { display: none; } }
.benef-photos { display: none; gap: 14px; justify-content: center; flex-wrap: wrap; margin: 0 auto clamp(28px,4vw,40px); }
.benef-photos img { width: clamp(130px, 22vw, 200px); aspect-ratio: 1/1; object-fit: cover; border-radius: 24px; border: 5px solid #fff; box-shadow: 0 14px 36px rgba(75,68,83,.16); }
.benef-photos img:nth-child(odd) { transform: rotate(-4deg); }
.benef-photos img:nth-child(even) { transform: rotate(4deg); }
@media (max-width: 1300px){ .benef-photos { display: flex; } }
@media (max-width: 420px){ .benef-photos img { width: 40vw; } }
.ben-grid { display: grid; grid-template-columns: repeat(auto-fit,minmax(280px,1fr)); gap: 16px; }
.ben { display: flex; gap: 16px; align-items: flex-start; background: var(--white); border-radius: var(--r-md); padding: 22px 22px; box-shadow: var(--sh-soft); }
.ben .ico { width: 48px; height: 48px; border-radius: 14px; display: grid; place-items: center; flex: none; background: var(--bg-azul); color: var(--turquesa-deep); }
.ben:nth-child(odd) .ico { background: var(--bg-rosa); color: var(--rosa); }
.ben .ico svg { width: 25px; height: 25px; }
.ben h4 { font-family: var(--f-head); font-weight: 700; font-size: 18px; color: var(--ink-strong); margin: 0 0 4px; }
.ben p { margin: 0; font-size: 15px; color: var(--cinza-1); line-height: 1.5; }

/* ---------- social proof ---------- */
.stat-row { display: grid; grid-template-columns: repeat(3,1fr); gap: 18px; margin-bottom: 28px; }
.revs-intro { text-align: center; max-width: 640px; margin: 32px auto 0; color: var(--cinza-1); font-size: 16px; }
.stat { background: var(--white); border-radius: var(--r-lg); padding: 30px 24px; text-align: center; box-shadow: var(--sh-card); }
.stat .big { font-family: var(--f-display); text-transform: uppercase; font-size: clamp(30px,4vw,46px); color: var(--rosa); line-height: 1; }
.stat:nth-child(2) .big { color: var(--turquesa); }
.stat .lbl { margin-top: 10px; font-size: 15px; color: var(--cinza-1); }
.stat-logos { display: flex; flex-wrap: wrap; align-items: center; justify-content: center; gap: 10px 18px; min-height: 46px; }
.stat-logos img { height: 30px; width: auto; object-fit: contain; }
.stat .stars { color: var(--rosa); font-size: 22px; letter-spacing: 2px; }

.revs { display: grid; grid-template-columns: repeat(3,1fr); gap: 20px; }
.rev { background: var(--white); border-radius: var(--r-lg); padding: 26px 24px; box-shadow: var(--sh-card); display: flex; flex-direction: column; min-height: 280px; }
.rev .stars { color: var(--rosa); letter-spacing: 2px; font-size: 16px; }
.rev p { margin: 12px 0 0; font-size: 16px; line-height: 1.55; color: var(--ink); }
.rev .who { margin-top: auto; padding-top: 16px; border-top: 1px solid rgba(75,68,83,.07); display: flex; align-items: center; gap: 12px; }
.rev .av { width: 40px; height: 40px; border-radius: 50%; display: grid; place-items: center; font-family: var(--f-head); font-weight: 700; color: #fff; background: var(--turquesa); flex: none; }
.rev:nth-child(odd) .av { background: var(--rosa); }
.rev .av--img { background: none; overflow: hidden; position: relative; }
.rev:nth-child(odd) .av--img { background: none; }
.rev .av--img img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.rev .av--logo { background: #fff !important; border: 1px solid var(--border-2, #ededed); box-shadow: 0 2px 8px rgba(75,68,83,.1); }
.rev .av--logo img { object-fit: contain; padding: 6px; }
.rev .who b { font-family: var(--f-head); font-size: 15px; color: var(--ink-strong); display: block; }
.rev .who span { font-size: 13px; color: var(--cinza-2); }
@media (max-width: 860px){ .stat-row, .revs { grid-template-columns: 1fr; } }

/* ---------- marketplaces / offer ---------- */
.offer { background: var(--hero-grad); }
.offer .sec-title, .offer .eyebrow { color: #fff; }
.offer .eyebrow { color: #fff; }
.offer .sec-sub { color: rgba(255,255,255,.95); }
.mk-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 16px; max-width: 940px; margin: 0 auto; }
.mk {
  background: #fff; border-radius: var(--r-lg); padding: 26px 18px; text-align: center;
  box-shadow: 0 14px 38px rgba(120,40,70,.18); transition: transform .2s ease, box-shadow .2s ease;
  display: flex; flex-direction: column; align-items: center; justify-content: space-between; gap: 16px; min-height: 168px;
}
.mk:hover { transform: translateY(-5px); box-shadow: 0 24px 54px rgba(120,40,70,.26); }
.mk .mk-logo img { transition: transform .25s ease; }
.mk:hover .mk-logo img { transform: scale(1.1); }
.mk:hover .mk-go { color: var(--rosa); font-weight: 700; }
.mk:hover .mk-go svg { transform: translateX(3px); }
.mk .mk-go svg { transition: transform .2s ease; }
.mk .mk-logo { flex: 1; display: grid; place-items: center; width: 100%; }
.mk .mk-logo img { max-height: 72px; max-width: 78%; width: auto; object-fit: contain; }
.mk .mk-go { font-size: 13px; color: var(--cinza-1); display: inline-flex; align-items: center; gap: 5px; }
.mk .mk-go svg { width: 15px; height: 15px; }
.ml-dot{color:#2d3277}.ml-bg{background:#ffe600}
.mk--soon { opacity: .55; filter: grayscale(1); cursor: not-allowed; }
.mk--soon:hover { transform: none; box-shadow: 0 14px 38px rgba(120,40,70,.18); }
.mk--soon .mk-go { color: var(--cinza-1); font-weight: 700; }
.btn--soon { background: var(--cinza-2); color: #fff; opacity: .6; cursor: not-allowed; pointer-events: none; }
.btn--mk { gap: 12px; }
.btn--mk img { height: 26px; width: auto; object-fit: contain; }
.btn--soon img { filter: grayscale(1); }
.offer-foot { display: flex; flex-wrap: wrap; gap: 14px 30px; justify-content: center; margin-top: 36px; }
.offer-foot .item { display: inline-flex; align-items: center; gap: 9px; color: #fff; font-family: var(--f-head); font-weight: 700; font-size: 15px; }
.offer-foot svg { width: 20px; height: 20px; color: #fff4c4; }
@media (max-width: 760px){ .mk-grid { grid-template-columns: repeat(2,1fr); } }

/* ---------- objections ---------- */
.obj-grid { display: grid; grid-template-columns: repeat(2,1fr); gap: 18px; }
.obj { background: var(--white); border-radius: var(--r-md); padding: 26px 26px; box-shadow: var(--sh-card); }
.obj .q { font-family: var(--f-head); font-weight: 700; font-size: 18px; color: var(--ink-strong); display: flex; gap: 11px; align-items: flex-start; }
.obj .q svg { width: 22px; height: 22px; color: var(--rosa); flex: none; margin-top: 1px; }
.obj p { margin: 12px 0 0; font-size: 16px; color: var(--cinza-1); line-height: 1.55; }
.obj p em { color: var(--turquesa-deep); font-style: normal; font-weight: 600; }
@media (max-width: 760px){ .obj-grid { grid-template-columns: 1fr; } }

/* ---------- guarantee ---------- */
.guar { display: grid; grid-template-columns: auto 1fr; gap: clamp(24px,4vw,48px); align-items: center; background: var(--white); border-radius: var(--r-xl); padding: clamp(28px,4vw,52px); box-shadow: var(--sh-card); border: 2px solid var(--bg-rosa); }
.guar-seal { width: 130px; height: 130px; border-radius: 50%; background: linear-gradient(135deg,var(--rosa),var(--turquesa)); display: grid; place-items: center; color: #fff; text-align: center; flex: none; box-shadow: var(--sh-pink); }
.guar-seal svg { width: 54px; height: 54px; }
.guar h3 { font-family: var(--f-head); font-weight: 700; font-size: clamp(22px,3vw,30px); color: var(--ink-strong); margin: 0; }
.guar p { margin: 12px 0 0; }
@media (max-width: 620px){ .guar { grid-template-columns: 1fr; text-align: center; justify-items: center; } }

/* ---------- urgency ---------- */
.urg { background: var(--ink-strong); color: #fff; border-radius: var(--r-lg); padding: clamp(28px,4vw,44px); display: flex; gap: 22px; align-items: center; }
.urg .ico { width: 60px; height: 60px; border-radius: 18px; background: rgba(255,255,255,.12); display: grid; place-items: center; flex: none; color: #ffd27a; }
.urg .ico svg { width: 30px; height: 30px; }
.urg h3 { font-family: var(--f-head); font-weight: 700; font-size: clamp(20px,2.6vw,26px); margin: 0; color: #fff; }
.urg p { margin: 8px 0 0; color: rgba(255,255,255,.8); font-size: 16px; }
@media (max-width: 560px){ .urg { flex-direction: column; text-align: center; } }

/* ---------- FAQ ---------- */
.faq { max-width: 800px; margin: 0 auto; display: flex; flex-direction: column; gap: 12px; }
.fq { background: var(--white); border-radius: var(--r-md); box-shadow: var(--sh-soft); overflow: hidden; }
.fq summary { list-style: none; cursor: pointer; padding: 22px 24px; display: flex; justify-content: space-between; align-items: center; gap: 16px; font-family: var(--f-head); font-weight: 700; font-size: 17.5px; color: var(--ink-strong); }
.fq summary::-webkit-details-marker { display: none; }
.fq summary .chev { width: 30px; height: 30px; border-radius: 50%; background: var(--bg-rosa); color: var(--rosa); display: grid; place-items: center; flex: none; transition: transform .25s ease; }
.fq summary .chev svg { width: 18px; height: 18px; }
.fq[open] summary .chev { transform: rotate(180deg); background: var(--rosa); color: #fff; }
.fq .ans { padding: 0 24px 22px; color: var(--cinza-1); font-size: 16px; line-height: 1.6; }

/* ---------- final cta ---------- */
.final { background: var(--hero-grad); text-align: center; color: #fff; }
.final h2 { font-family: var(--f-display); text-transform: uppercase; font-weight: 400; color: #fff; font-size: clamp(30px,5vw,60px); line-height: 1.04; margin: 0 auto; max-width: 16ch; }
.final p { margin: 20px auto 0; max-width: 52ch; color: rgba(255,255,255,.95); font-size: clamp(17px,2vw,20px); }
.final .btn--primary { background: #fff; color: var(--rosa-deep); margin-top: 30px; box-shadow: 0 18px 44px rgba(150,50,80,.26); }
.final .btn--primary:hover { color: var(--rosa-deep); }
.final .microcopy { color: rgba(255,255,255,.92); justify-content: center; }
.final .microcopy svg { color: #fff4c4; }

/* ---------- PS / footer ---------- */
.ps { background: var(--bg-rosa); }
.ps-card { background: var(--white); border-radius: var(--r-lg); padding: clamp(26px,4vw,40px); box-shadow: var(--sh-card); max-width: 860px; margin: 0 auto; }
.ps-card .eyebrow { color: var(--turquesa); }
.ps-card p { margin: 12px 0 0; }
.foot { background: var(--ink-strong); color: rgba(255,255,255,.7); }
.foot .wrap { padding-block: 40px; display: flex; flex-wrap: wrap; gap: 18px; justify-content: space-between; align-items: center; }
.foot .logo { font-size: 22px; }
.foot .logo img { height: 44px; }
.foot small { font-size: 13px; line-height: 1.6; display: block; }
.foot .links { display: flex; align-items: center; gap: 20px; font-family: var(--f-head); font-weight: 700; font-size: 14px; }
.foot .links a:hover { color: #fff; }
.foot-social { display: inline-flex; align-items: center; gap: 10px; }
.foot-social a { display: grid; place-items: center; width: 38px; height: 38px; border-radius: 50%; background: rgba(255,255,255,.1); color: rgba(255,255,255,.85); transition: background .18s ease, color .18s ease, transform .15s ease; }
.foot-social a:hover { background: var(--rosa); color: #fff; transform: translateY(-2px); }
.foot-social svg { width: 20px; height: 20px; }
.foot-social a.soc-img { background: none; padding: 0; overflow: hidden; }
.foot-social a.soc-img:hover { background: none; }
.foot-social a.soc-img img { width: 100%; height: 100%; object-fit: cover; }

/* ---------- sticky mobile bar ---------- */
.sticky-bar {
  position: fixed; left: 0; right: 0; bottom: 0; z-index: 70;
  background: rgba(255,255,255,.94); backdrop-filter: blur(12px);
  box-shadow: 0 -8px 28px rgba(75,68,83,.12); padding: 12px var(--gut);
  display: none; gap: 12px; align-items: center; justify-content: space-between;
  transform: translateY(120%); transition: transform .3s var(--ease, ease);
}
.sticky-bar.show { transform: translateY(0); }
.sticky-bar .s-txt { font-family: var(--f-head); font-weight: 700; font-size: 14px; color: var(--ink-strong); line-height: 1.2; }
.sticky-bar .s-txt span { display: block; font-family: var(--f-body); font-weight: 400; font-size: 12px; color: var(--cinza-1); }
.sticky-bar .btn { padding: 13px 22px; font-size: 15px; flex: none; }
@media (max-width: 760px){ .sticky-bar { display: flex; } body { padding-bottom: 76px; } }

/* ---------- decorative bubbles ---------- */
.deco { position: absolute; border-radius: 50%; pointer-events: none; z-index: 1; opacity: .5; }
[data-bubbles="off"] .deco { display: none; }
.deco--rosa { background: radial-gradient(circle at 35% 30%, #ffd0db, #ffb6c1); }
.deco--azul { background: radial-gradient(circle at 35% 30%, #cceef2, #b0e0e6); }

/* reveal on scroll */
.reveal { opacity: 0; transform: translateY(22px); transition: opacity .6s var(--ease,ease), transform .6s var(--ease,ease); }
.reveal.in { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce){ .reveal { opacity: 1; transform: none; transition: none; } html { scroll-behavior: auto; } }

/* modal */
.modal { position: fixed; inset: 0; z-index: 100; display: none; align-items: center; justify-content: center; padding: 24px; }
.modal.open { display: flex; }
.modal-bg { position: absolute; inset: 0; background: rgba(58,52,66,.5); backdrop-filter: blur(3px); }
.modal-card { position: relative; background: linear-gradient(150deg, #fff4f7 0%, #ffffff 50%, #eef9fb 100%); border-radius: var(--r-lg); padding: clamp(26px,4vw,40px); max-width: 460px; width: 100%; box-shadow: var(--sh-lift); text-align: center; border: 2px solid #fff; }
.modal-card h3 { font-family: var(--f-head); font-weight: 700; font-size: 24px; color: var(--ink-strong); margin: 0; }
.modal-card p { color: var(--cinza-1); margin: 10px 0 22px; font-size: 15.5px; }
.modal-list { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.modal-list .btn--mk { min-width: 0; padding: 14px 12px; font-size: 15px; white-space: nowrap; overflow: hidden; }
.modal-list .btn--mk img { height: 22px; max-width: 30px; }
.modal-close { position: absolute; top: 14px; right: 14px; width: 36px; height: 36px; border-radius: 50%; background: var(--bg-rosa); color: var(--rosa); display: grid; place-items: center; }
.modal-close svg { width: 20px; height: 20px; }
