/* ============================================================
   POKÉMON DELUXE — estilos
   Paleta e fonte fiéis ao original (Nunito + cores Pokémon).
   ============================================================ */
:root{
  --red:    hsl(7 87% 47%);
  --red-d:  hsl(7 87% 40%);
  --yellow: hsl(45 100% 51%);
  --yellow-d:hsl(45 100% 45%);
  --sky:    hsl(199 98% 65%);
  --teal:   hsl(168 100% 50%);
  --blue:   hsl(213 56% 47%);
  --dark:   hsl(0 0% 10%);
  --bg:     hsl(200 20% 96%);
  --card:   #fff;
  --muted:  hsl(215 16% 47%);
  --border: hsl(214 32% 91%);
  --gradient-sky: linear-gradient(135deg, hsl(199 98% 65%), hsl(168 100% 50%));
  --shadow-card: 0 10px 30px -10px rgba(0,0,0,.15);
  --radius: .9rem;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:Nunito,system-ui,-apple-system,"Segoe UI",sans-serif;
  background:var(--bg);color:var(--dark);
  overflow-x:hidden;line-height:1.5;
}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
button{font-family:inherit;cursor:pointer;border:none;background:none}
section{position:relative}
.container{width:100%;max-width:1100px;margin:0 auto;padding:0 1rem}

/* ---------- tipografia utilitária ---------- */
.eyebrow{display:inline-block;font-weight:900;letter-spacing:.05em;text-transform:uppercase;
  font-size:.75rem;color:var(--red);background:rgba(220,38,38,.1);
  padding:.35rem .9rem;border-radius:999px;margin-bottom:.8rem}
h2.title{font-size:clamp(1.6rem,5vw,2.6rem);font-weight:900;line-height:1.1;letter-spacing:-.02em}
.subtitle{color:var(--muted);font-size:clamp(1rem,2.5vw,1.15rem);font-weight:600;margin-top:.6rem}

/* ============ ANIMAÇÕES ============ */
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-15px)}}
@keyframes pulse-glow{0%,100%{box-shadow:0 0 8px rgba(255,255,255,.8)}50%{box-shadow:0 0 22px rgba(255,255,255,1)}}
@keyframes scroll-left{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
@keyframes pulse{50%{opacity:.45}}
@keyframes bounce-y{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}
@keyframes spin-slow{to{transform:rotate(360deg)}}
@keyframes shine{0%{background-position:-150% 0}100%{background-position:250% 0}}
@keyframes pop-in{0%{transform:scale(.8);opacity:0}100%{transform:scale(1);opacity:1}}

.float{animation:float 3s ease-in-out infinite}
.pulse-glow{animation:pulse-glow 2s ease-in-out infinite}
.pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}

/* reveal ao rolar (controlado pelo JS) */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s ease,transform .7s cubic-bezier(.16,1,.3,1)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}
.reveal.d3{transition-delay:.24s}.reveal.d4{transition-delay:.32s}


/* ============ BOTÃO CTA ============ */
.cta{
  position:relative;display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  width:100%;max-width:480px;padding:1.15rem 1.5rem;border-radius:999px;
  font-weight:900;font-size:clamp(1.05rem,3.5vw,1.35rem);letter-spacing:.01em;
  color:var(--dark);background:var(--yellow);
  box-shadow:0 8px 0 var(--yellow-d),0 14px 24px -8px rgba(245,158,11,.6);
  transition:transform .12s ease,box-shadow .12s ease;text-align:center;
  text-transform:uppercase;overflow:hidden;
}
.cta::after{content:"";position:absolute;inset:0;background:linear-gradient(120deg,transparent 30%,rgba(255,255,255,.55) 50%,transparent 70%);
  background-size:250% 100%;animation:shine 3.5s linear infinite}
.cta:hover{transform:translateY(-2px);box-shadow:0 10px 0 var(--yellow-d),0 18px 28px -8px rgba(245,158,11,.7)}
.cta:active{transform:translateY(4px);box-shadow:0 4px 0 var(--yellow-d)}
.cta--red{color:#fff;background:var(--red);box-shadow:0 8px 0 var(--red-d),0 14px 24px -8px rgba(220,38,38,.5)}
.cta--red:hover{box-shadow:0 10px 0 var(--red-d),0 18px 28px -8px rgba(220,38,38,.6)}
.cta--red:active{box-shadow:0 4px 0 var(--red-d)}

/* ============ HERO ============ */
.hero{
  background:var(--gradient-sky);padding:0 1rem 1.4rem;text-align:center;overflow:hidden;
}
.hero::before{content:"";position:absolute;inset:0;
  background-image:repeating-linear-gradient(45deg,transparent,transparent 15px,rgba(255,255,255,.12) 15px,rgba(255,255,255,.12) 30px);
  pointer-events:none}
.hero .floaters img{position:absolute;width:64px;opacity:.4;pointer-events:none}
.hero .f1{top:14%;right:3%}
.hero .f2{bottom:8%;right:5%}
.hero .f3{bottom:30%;left:3%;opacity:.3}
.hero-inner{position:relative;z-index:2;max-width:760px;margin:0 auto;display:flex;flex-direction:column;align-items:center}
/* logo: margens negativas cortam a área transparente do PNG (elimina os espaços) */
.hero-logo{width:min(58%,240px);height:auto;margin:-2.6rem 0 -2rem;
  filter:drop-shadow(0 6px 12px rgba(0,0,0,.25));animation:pop-in .6s ease both}
.hero h1{color:#fff;font-weight:900;line-height:1;margin-top:0;
  text-shadow:0 3px 0 rgba(0,0,0,.18);letter-spacing:-.02em}
.hero h1 .big{display:block;font-size:clamp(2rem,8.5vw,3.4rem);color:var(--yellow);
  text-shadow:0 3px 0 var(--red),0 5px 10px rgba(0,0,0,.25);-webkit-text-stroke:1px rgba(0,0,0,.15)}
.hero h1 .small{display:block;font-size:clamp(.9rem,3.6vw,1.4rem);margin-top:.1rem}
.hero .lead{color:#fff;font-weight:800;margin-top:.35rem;font-size:clamp(.85rem,3vw,1.05rem);
  text-shadow:0 2px 4px rgba(0,0,0,.2);max-width:560px}

/* player de vídeo VSL — vertical 9:16, maior, mas limitado pela altura da tela
   para não empurrar o CTA pra fora da dobra. Largura derivada da altura. */
.video-wrap{position:relative;z-index:2;height:56vh;max-height:580px;width:calc(56vh * 9 / 16);
  max-width:88vw;margin:.6rem auto 0;aspect-ratio:9/16;
  border-radius:1rem;overflow:hidden;background:#0b1220;
  box-shadow:0 18px 50px -12px rgba(0,0,0,.5);border:3px solid rgba(255,255,255,.6)}
.video-wrap>*{display:block;width:100%;height:100%;object-fit:cover}

.hero-cta-zone{position:relative;z-index:2;width:100%;display:flex;flex-direction:column;align-items:center;margin-top:.9rem}
.trust{margin-top:.6rem;color:#fff;font-weight:800;font-size:.85rem;display:flex;gap:.4rem;
  align-items:center;justify-content:center;flex-wrap:wrap;text-shadow:0 1px 2px rgba(0,0,0,.25)}
.trust span{white-space:nowrap}

/* ============ FEATURE BADGES ============ */
.badges{padding:1.6rem 1rem}
.badges-grid{max-width:640px;margin:0 auto;display:grid;gap:.7rem}
.badge{display:flex;align-items:center;gap:.85rem;background:var(--card);
  border:1px solid var(--border);border-radius:var(--radius);padding:.85rem 1rem;
  box-shadow:var(--shadow-card);font-weight:800}
.badge img{width:40px;height:40px;flex-shrink:0;animation:bounce-y 2.4s ease-in-out infinite}
.badge:nth-child(2) img{animation-delay:.3s}
.badge:nth-child(3) img{animation-delay:.6s}

/* ============ SEÇÃO GENÉRICA ============ */
.section{padding:3rem 1rem}
.section.alt{background:var(--card)}
.section-head{max-width:680px;margin:0 auto 2rem;text-align:center}

/* ============ HOW IT WORKS ============ */
.steps{max-width:920px;margin:0 auto;display:grid;gap:1.1rem;grid-template-columns:1fr}
.step{background:var(--card);border:1px solid var(--border);border-radius:1.1rem;
  padding:1.5rem 1.2rem;text-align:center;box-shadow:var(--shadow-card);position:relative;
  transition:transform .2s ease,box-shadow .2s ease}
.step:hover{transform:translateY(-5px);box-shadow:0 18px 36px -14px rgba(0,0,0,.25)}
.step .num{position:absolute;top:-14px;left:50%;transform:translateX(-50%);
  width:34px;height:34px;border-radius:50%;background:var(--red);color:#fff;font-weight:900;
  display:grid;place-items:center;box-shadow:0 4px 10px rgba(220,38,38,.4)}
.step .gif{width:88px;height:88px;margin:.4rem auto .8rem;image-rendering:pixelated;object-fit:contain}
.step h3{font-size:1.15rem;font-weight:900;margin-bottom:.3rem}
.step p{color:var(--muted);font-weight:600;font-size:.95rem}

/* ============ GAME CAROUSEL ============ */
.carousel-cat{margin-bottom:1.8rem}
.carousel-cat h3{text-align:center;font-weight:900;letter-spacing:.06em;font-size:.85rem;
  color:var(--blue);text-transform:uppercase;margin-bottom:.9rem}
.marquee{overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
/* CSS puro, igual ao site original: track em flex com itens duplicados,
   desliza de 0 a -50% em loop infinito */
.marquee-track{display:flex;gap:.8rem;width:max-content;
  animation:scroll-left 30s linear infinite}
.marquee:hover .marquee-track{animation-play-state:paused}
.marquee.rev .marquee-track{animation-duration:40s;animation-direction:reverse}
.game{flex:0 0 auto;width:150px;background:var(--card);border:1px solid var(--border);
  border-radius:1rem;padding:.9rem .6rem;text-align:center;box-shadow:var(--shadow-card);
  transition:transform .2s ease}
.game:hover{transform:translateY(-6px) scale(1.03)}
.game img{width:96px;height:96px;margin:0 auto .5rem;object-fit:contain;
  filter:drop-shadow(0 6px 8px rgba(0,0,0,.18));transition:transform .2s ease}
.game:hover img{transform:scale(1.1)}
.game .name{font-weight:900;font-size:.92rem;line-height:1.15}
.game .tag{display:inline-block;margin-top:.35rem;font-size:.62rem;font-weight:900;
  text-transform:uppercase;letter-spacing:.04em;padding:.15rem .5rem;border-radius:999px;
  background:rgba(220,38,38,.12);color:var(--red)}
.game .tag.top{background:rgba(245,158,11,.18);color:var(--yellow-d)}

/* ============ PACKAGE CONTENTS ============ */
.pack-grid{max-width:760px;margin:0 auto;display:grid;gap:.7rem;grid-template-columns:1fr}
.pack-item{display:flex;align-items:flex-start;gap:.75rem;background:var(--card);
  border:1px solid var(--border);border-radius:.8rem;padding:.85rem 1rem;
  box-shadow:0 4px 14px -8px rgba(0,0,0,.15);font-weight:700}
.pack-item .check{flex-shrink:0;width:24px;height:24px;border-radius:50%;background:var(--teal);
  color:#063;display:grid;place-items:center;margin-top:1px}
.pack-item .check svg{width:14px;height:14px;stroke:#053;stroke-width:3.5;fill:none}

/* ============ TESTIMONIALS ============ */
/* desliza automático igual ao carrossel (usa .marquee + .marquee-track) */
.testi-track{gap:1rem;padding:.5rem .2rem 1.2rem;animation-duration:45s}
.testi{flex:0 0 auto;width:min(78vw,300px);
  border-radius:1.1rem;overflow:hidden;box-shadow:var(--shadow-card);border:1px solid var(--border);
  background:var(--card)}
.testi img{width:100%;height:auto}
.testi .badge-real{display:flex;align-items:center;gap:.4rem;padding:.55rem .8rem;
  font-weight:800;font-size:.8rem;color:var(--muted)}
.stars{color:var(--yellow);letter-spacing:1px}

/* ============ PRICING ============ */
.pricing{padding:3rem 1rem;background:linear-gradient(180deg,var(--bg),#e8eef3)}
.timer{display:flex;align-items:center;justify-content:center;gap:.5rem;font-weight:900;
  margin:0 auto 1.6rem;background:#fff;border:1px solid var(--border);border-radius:999px;
  padding:.55rem 1.1rem;width:max-content;max-width:100%;box-shadow:var(--shadow-card)}
.timer .dot{width:11px;height:11px;border-radius:50%;background:var(--red);
  box-shadow:0 0 10px rgba(239,68,68,.6);animation:pulse 1.4s infinite}
.timer b{color:var(--red);font-variant-numeric:tabular-nums}
.plans{display:grid;gap:1.4rem;max-width:920px;margin:0 auto;align-items:stretch}
.plan{position:relative;background:var(--card);border-radius:1.6rem;border:2px solid var(--border);
  padding:1.8rem 1.4rem;box-shadow:var(--shadow-card);display:flex;flex-direction:column;
  text-align:center;align-items:center}
.plan h3{font-size:.8rem;font-weight:900;letter-spacing:.06em;text-transform:uppercase;color:var(--muted)}
.plan .plan-name{font-size:1.5rem;font-weight:900;margin:.1rem 0 .3rem}
.plan .price-box{margin:0 0 1.1rem;padding:1.1rem 1rem;text-align:center;
  background:hsl(200 20% 96%);border:1px solid var(--border);border-radius:1.3rem}
.plan .price-row{display:flex;align-items:center;justify-content:center;gap:.6rem;flex-wrap:wrap;margin:0}
.plan .old{color:#94a3b8;text-decoration:line-through;font-weight:800;font-size:1.05rem}
.plan .off{background:var(--red);color:#fff;font-size:.7rem;font-weight:900;padding:.2rem .6rem;
  border-radius:999px;text-transform:uppercase}
.plan .price{font-size:2.8rem;font-weight:900;line-height:1;letter-spacing:-.03em;margin-top:.4rem}
.plan .price small{font-size:1.1rem;vertical-align:top}
.plan ul{list-style:none;display:grid;gap:.6rem;margin:.8rem auto 1.2rem;flex:1 0 auto;
  width:max-content;max-width:100%;text-align:left}
.plan li{display:flex;gap:.55rem;align-items:flex-start;font-weight:700;font-size:.95rem}
.plan li svg{flex-shrink:0;width:20px;height:20px;margin-top:1px}
.plan .price-box{margin-top:auto;align-self:stretch}

/* ----- CARD BÁSICO: azul Pokémon ----- */
.plan:not(.featured){border-color:rgba(59,130,246,.35)}
.plan:not(.featured) .plan-name{color:#1e3a8a}
.plan:not(.featured) li svg{stroke:#3B82F6}
.plan:not(.featured) .price-box{background:rgba(59,130,246,.08);border-color:rgba(59,130,246,.25)}
.plan:not(.featured) .price{color:#2563EB}
.plan:not(.featured) .cta{color:#fff;background:#3B82F6;
  box-shadow:0 8px 0 #2563EB,0 14px 24px -8px rgba(59,130,246,.5)}
.plan:not(.featured) .cta:hover{box-shadow:0 10px 0 #2563EB,0 18px 28px -8px rgba(59,130,246,.6)}
.plan:not(.featured) .cta:active{box-shadow:0 4px 0 #2563EB}

/* ----- FAIXA "MAIS VENDIDO": no fluxo, sempre centralizada ----- */
.plan .ribbon{order:-1;display:inline-block;margin:-.4rem auto 1rem;
  background:var(--yellow);color:var(--dark);white-space:nowrap;
  font-weight:900;font-size:.74rem;text-transform:uppercase;padding:.4rem 1.3rem;
  letter-spacing:.06em;border-radius:999px;box-shadow:0 6px 16px -4px rgba(245,158,11,.7);
  animation:bounce-y 2.5s ease-in-out infinite}

/* ----- CARD DESTAQUE: azul-escuro + vermelho (igual ao original) ----- */
.plan.featured{border:3px solid var(--red);background:linear-gradient(180deg,#0f172a,#1e293b);color:#fff;
  box-shadow:0 0 60px -15px rgba(239,68,68,.55);overflow:hidden}
.plan.featured .lugia{position:absolute;bottom:-18px;right:-22px;width:170px;height:auto;
  opacity:.14;pointer-events:none;z-index:0;
  filter:drop-shadow(0 0 18px rgba(120,200,255,.5));animation:float 5s ease-in-out infinite}
.plan.featured>:not(.lugia){position:relative;z-index:1}
.plan.featured h3{color:var(--yellow)}
.plan.featured li svg{color:var(--yellow)}
.plan.featured .price{color:var(--yellow);text-shadow:0 2px 8px rgba(245,158,11,.4)}
.plan.featured .price-box{background:rgba(15,23,42,.55);border-color:rgba(255,255,255,.12)}

.guarantee{max-width:560px;margin:2rem auto 0;text-align:center;background:#fff;border:2px dashed var(--teal);
  border-radius:1.2rem;padding:1.4rem 1.2rem;box-shadow:var(--shadow-card)}
.guarantee .seal{font-size:2.2rem}
.guarantee h4{font-weight:900;font-size:1.15rem;margin:.3rem 0}
.guarantee p{color:var(--muted);font-weight:600;font-size:.92rem}

/* ============ MODAL UPSELL ============ */
.modal-overlay{position:fixed;inset:0;background:rgba(2,6,23,.7);backdrop-filter:blur(4px);
  display:none;align-items:center;justify-content:center;z-index:200;padding:1rem}
.modal-overlay.open{display:flex}
.modal{background:linear-gradient(180deg,#0f172a,#1e293b);color:#fff;border:3px solid var(--yellow);
  border-radius:1.6rem;max-width:440px;width:100%;padding:1.8rem 1.3rem;text-align:center;
  position:relative;animation:pop-in .35s ease both;box-shadow:0 0 70px -10px rgba(245,158,11,.5);
  max-height:92vh;overflow-y:auto}
.modal .surprise{font-size:.8rem;font-weight:900;letter-spacing:.1em;color:var(--yellow);text-transform:uppercase}
.modal h3{font-size:1.4rem;font-weight:900;margin:.4rem 0 .2rem;line-height:1.15}
.modal .pack-name{font-weight:900;color:var(--sky)}
.modal .m-sub{color:#cbd5e1;font-weight:600;font-size:.9rem;margin-bottom:1.1rem}
/* cards de oferta dentro do modal */
.modal .m-offer{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);
  border-radius:1.2rem;padding:1.1rem 1rem;margin-bottom:1rem;text-align:left}
.modal .m-offer--premium{border-color:var(--yellow);background:rgba(245,158,11,.08);
  box-shadow:0 0 26px -10px rgba(245,158,11,.6)}
.modal .m-offer-head{display:flex;flex-direction:column;gap:.35rem;margin-bottom:.6rem}
.modal .m-tag{align-self:flex-start;font-size:.66rem;font-weight:900;text-transform:uppercase;
  letter-spacing:.04em;padding:.22rem .6rem;border-radius:999px}
.modal .tag-pop{background:var(--sky);color:#06283d}
.modal .tag-premium{background:var(--yellow);color:#3a2a00}
.modal .m-offer-title{font-weight:900;font-size:1.05rem}
.modal .m-list{list-style:none;display:grid;gap:.3rem;margin:.2rem 0 .8rem;font-size:.85rem;
  font-weight:700;color:#e2e8f0}
.modal .m-price-row{display:flex;align-items:baseline;gap:.5rem;margin:.2rem 0 .9rem;font-weight:900}
.modal .m-price-row b{font-size:1.9rem;color:var(--yellow);line-height:1}
.modal .m-old{color:#94a3b8;text-decoration:line-through;font-size:.95rem;font-weight:800}
.modal .m-offer .cta{padding:.9rem 1rem;font-size:1rem}
.modal .decline{display:block;margin-top:.4rem;color:#94a3b8;font-weight:700;font-size:.82rem;
  text-decoration:underline;width:100%;line-height:1.4}
.modal .close{position:absolute;top:.7rem;right:.9rem;color:#fff;opacity:.6;font-size:1.4rem;font-weight:900;z-index:2}

/* ============ FAQ ============ */
.faq{max-width:680px;margin:0 auto}
.faq-item{border-bottom:1px solid var(--border)}
.faq-q{display:flex;justify-content:space-between;align-items:center;gap:1rem;width:100%;
  text-align:left;padding:1.1rem .2rem;font-weight:800;font-size:1.02rem}
.faq-q svg{flex-shrink:0;width:20px;height:20px;transition:transform .25s ease;color:var(--red)}
.faq-item.open .faq-q svg{transform:rotate(180deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .3s ease;color:var(--muted);font-weight:600}
.faq-a div{padding:0 .2rem 1.1rem}

/* ============ FOOTER ============ */
.footer{background:var(--dark);color:#cbd5e1;text-align:center;padding:2.2rem 1rem;font-size:.85rem;font-weight:600}
.footer img{width:140px;margin:0 auto 1rem;opacity:.95}
.footer .links{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;margin:.8rem 0}
.footer a{text-decoration:underline;opacity:.85}
.footer .legal{opacity:.55;font-size:.75rem;margin-top:1rem;max-width:620px;margin-inline:auto;line-height:1.5}

/* ============ TOAST PROVA SOCIAL ============ */
.toast{position:fixed;bottom:1rem;left:1rem;z-index:90;max-width:320px;
  background:var(--card);border:1px solid var(--border);border-radius:1rem;
  box-shadow:0 18px 40px -12px rgba(0,0,0,.35);padding:.75rem .9rem;
  display:flex;align-items:center;gap:.75rem;
  transform:translateX(-120%);transition:transform .5s cubic-bezier(.16,1,.3,1)}
.toast.show{transform:translateX(0)}
.toast .av{width:40px;height:40px;border-radius:50%;background:hsl(210 40% 96%);
  display:grid;place-items:center;flex-shrink:0}
.toast .av img{width:26px;height:26px}
.toast .t-name{font-weight:900;font-size:.85rem}
.toast .t-text{font-size:.75rem;color:var(--muted);font-weight:600}
.toast .t-text b{color:var(--teal)}

/* ============ STICKY CTA (mobile) ============ */
.sticky-cta{position:fixed;left:0;right:0;bottom:0;z-index:80;padding:.6rem .8rem;
  background:rgba(255,255,255,.92);backdrop-filter:blur(8px);border-top:1px solid var(--border);
  transform:translateY(120%);transition:transform .35s ease;box-shadow:0 -6px 20px -10px rgba(0,0,0,.3)}
.sticky-cta.show{transform:translateY(0)}
.sticky-cta .cta{padding:.85rem 1rem;font-size:1rem;max-width:100%}

/* ============ RESPONSIVO ============ */
@media (min-width:640px){
  .hero .floaters img{width:120px}
  .hero{padding:3rem 1rem}
  .steps{grid-template-columns:repeat(3,1fr)}
  .pack-grid{grid-template-columns:1fr 1fr}
  .plans{grid-template-columns:1fr 1fr}
  .badge img{width:46px;height:46px}
  .sticky-cta{display:none}
  body{padding-bottom:0!important}
}
@media (min-width:900px){
  .plan.featured{transform:scale(1.04)}
}
