:root{
  --azul: #0D47A1;
  --azul-claro: #1565C0;
  --azul-escuro: #0A3880;
  --amarelo: #FFC107;
  --amarelo-escuro: #E0A800;
  --verde: #2E7D32;
  --verde-claro: #43A047;
  --vermelho: #E53935;
  --texto: #1a2942;
  --texto-suave: #4a5a78;
  --cinza-claro: #F4F7FC;
  --branco: #FFFFFF;
}

*{margin:0;padding:0;box-sizing:border-box;}

html{scroll-behavior:smooth;}

body{
  font-family:'Inter','Assistant',sans-serif;
  background:var(--branco);
  color:var(--texto);
  line-height:1.5;
  padding-bottom:78px;
}

h1,h2,h3,.headline{
  font-family:'Montserrat','Poppins',sans-serif;
  font-weight:900;
  line-height:1.15;
}

img{max-width:100%;display:block;}

.container{
  max-width:680px;
  margin:0 auto;
  padding:0 20px;
}

/* ===== BARRA DE OFERTA ===== */
.offer-bar{
  background:linear-gradient(90deg, var(--verde-claro), var(--verde));
  color:#fff;
  text-align:center;
  font-weight:700;
  font-size:14px;
  padding:10px 12px;
  position:sticky;
  top:0;
  z-index:1000;
  letter-spacing:.3px;
  animation:pulse-bar 2s infinite;
}
@keyframes pulse-bar{
  0%,100%{box-shadow:0 0 0 rgba(46,125,50,.4);}
  50%{box-shadow:0 0 18px rgba(46,125,50,.7);}
}
.offer-bar span#countdown-bar{
  color:var(--amarelo);
  font-weight:900;
}

/* ===== HERO ===== */
.hero{
  position:relative;
  background:linear-gradient(180deg, var(--azul-claro) 0%, var(--azul) 100%);
  padding:36px 0 40px;
  text-align:center;
  overflow:hidden;
}
.hero .badge{
  display:inline-block;
  background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.35);
  color:var(--amarelo);
  font-weight:800;
  font-size:13px;
  padding:6px 16px;
  border-radius:999px;
  margin-bottom:18px;
  letter-spacing:1px;
}
.hero h1{
  font-size:28px;
  color:#fff;
  text-transform:uppercase;
  margin-bottom:14px;
}
.hero h1 .gold{color:var(--amarelo);}
.hero p.lead{
  color:rgba(255,255,255,.9);
  font-size:16px;
  max-width:520px;
  margin:0 auto 22px;
}
.hero-img{
  margin:0 auto 24px;
  max-width:380px;
  border-radius:18px;
  overflow:hidden;
  box-shadow:0 12px 40px rgba(0,0,0,.25);
  border:4px solid rgba(255,255,255,.25);
}
.feature-pills{
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  gap:10px;
  margin-bottom:26px;
}
.feature-pills span{
  background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.25);
  color:#fff;
  font-size:13px;
  font-weight:600;
  padding:8px 14px;
  border-radius:999px;
}

/* ===== CTA BUTTONS ===== */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:6px;
  font-family:'Montserrat',sans-serif;
  font-weight:800;
  font-size:14px;
  text-transform:uppercase;
  text-decoration:none;
  border:none;
  cursor:pointer;
  border-radius:999px;
  padding:14px 20px;
  width:100%;
  max-width:420px;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  transition:transform .15s ease, box-shadow .15s ease;
}
@media(max-width:380px){
  .btn{font-size:12.5px;padding:13px 14px;}
}
.btn:active{transform:scale(.98);}
.btn-gold{
  background:linear-gradient(180deg, #ffd54a, var(--amarelo));
  color:var(--texto);
  box-shadow:0 8px 24px rgba(255,193,7,.4), inset 0 1px 0 rgba(255,255,255,.5);
}
.btn-green{
  background:linear-gradient(180deg, var(--verde-claro), var(--verde));
  color:#fff;
  box-shadow:0 8px 24px rgba(46,125,50,.35), inset 0 1px 0 rgba(255,255,255,.25);
}
.btn-wrap{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:10px;
  margin-top:8px;
}
.btn-sub{
  font-size:13px;
  color:var(--texto-suave);
  text-align:center;
}
.hero .btn-sub,
.urgency-section .btn-sub{
  color:rgba(255,255,255,.8);
}

/* ===== SECTION GENERIC ===== */
section{
  padding:48px 0;
  position:relative;
}
.section-eyebrow{
  text-align:center;
  color:var(--azul);
  font-weight:800;
  letter-spacing:2px;
  font-size:13px;
  text-transform:uppercase;
  margin-bottom:8px;
}
.section-title{
  text-align:center;
  font-size:24px;
  color:var(--texto);
  margin-bottom:10px;
}
.section-sub{
  text-align:center;
  color:var(--texto-suave);
  font-size:15px;
  max-width:520px;
  margin:0 auto 28px;
}
.ball::before{content:"⚽ ";}

/* ===== TESTIMONIOS FACEBOOK ===== */
.testimonios-section{
  background:var(--cinza-claro);
}
.fb-card{
  background:var(--branco);
  border:1px solid #e3e9f5;
  border-radius:14px;
  padding:16px;
  margin-bottom:14px;
  box-shadow:0 2px 10px rgba(13,71,161,.05);
}
.fb-header{
  display:flex;
  align-items:center;
  gap:10px;
  margin-bottom:10px;
}
.fb-avatar{
  width:42px;
  height:42px;
  border-radius:50%;
  object-fit:cover;
  flex-shrink:0;
}
.fb-name{font-weight:700;color:var(--texto);font-size:14px;}
.fb-meta{font-size:12px;color:var(--texto-suave);}
.fb-text{font-size:14px;color:var(--texto);margin-bottom:10px;}
.fb-actions{
  font-size:12px;
  color:var(--texto-suave);
  display:flex;
  gap:14px;
  border-top:1px solid #e3e9f5;
  padding-top:8px;
}
.fb-actions b{color:var(--azul);}

/* ===== ES PARA VOS ===== */
.checklist{
  display:flex;
  flex-direction:column;
  gap:14px;
}
.check-item{
  background:var(--cinza-claro);
  border:1px solid #e3e9f5;
  border-radius:14px;
  padding:16px 18px;
}
.check-item h3{
  font-size:15px;
  color:var(--azul);
  margin-bottom:6px;
  font-family:'Montserrat',sans-serif;
  font-weight:800;
}
.check-item p{
  font-size:14px;
  color:var(--texto-suave);
}

/* ===== CARROSSEL DE REGALOS ===== */
.regalos-section{
  background:linear-gradient(180deg, var(--azul) 0%, var(--azul-escuro) 100%);
}
.regalos-header{
  text-align:center;
  margin-bottom:24px;
}
.regalos-header .small-tag{
  color:rgba(255,255,255,.75);
  font-size:13px;
  font-weight:700;
  letter-spacing:1px;
  text-transform:uppercase;
}
.regalos-header h2{
  font-size:24px;
  color:var(--amarelo);
  margin:6px 0;
}
.regalos-header .pack-tag{
  color:rgba(255,255,255,.9);
  font-size:14px;
  margin-bottom:6px;
}
.regalos-header .value-tag{
  font-size:14px;
  color:rgba(255,255,255,.75);
}
.regalos-header .value-tag b{color:var(--amarelo);}
.swipe-hint{
  text-align:center;
  color:rgba(255,255,255,.75);
  font-size:13px;
  margin-top:14px;
  font-weight:600;
}

.carousel-wrap{
  position:relative;
}
.carousel{
  display:flex;
  gap:14px;
  overflow-x:auto;
  scroll-snap-type:x mandatory;
  padding:6px 6px 14px;
  -webkit-overflow-scrolling:touch;
  scrollbar-width:none;
}
.carousel::-webkit-scrollbar{display:none;}
.gift-card{
  flex:0 0 80%;
  scroll-snap-align:center;
  background:var(--branco);
  border:1px solid #e3e9f5;
  border-radius:18px;
  padding:18px;
  display:flex;
  flex-direction:column;
  align-items:center;
  text-align:center;
}
.gift-card img{
  border-radius:12px;
  margin-bottom:14px;
  box-shadow:0 8px 24px rgba(0,0,0,.15);
  aspect-ratio:1/1;
  object-fit:cover;
}
.gift-card h3{
  font-size:15px;
  color:var(--azul);
  margin-bottom:8px;
  font-family:'Montserrat',sans-serif;
  font-weight:800;
}
.gift-card p{
  font-size:13px;
  color:var(--texto-suave);
  margin-bottom:14px;
}
.gift-price{
  display:flex;
  align-items:center;
  gap:10px;
  font-weight:800;
  font-family:'Montserrat',sans-serif;
}
.gift-price .old{
  color:var(--vermelho);
  text-decoration:line-through;
  font-size:14px;
}
.gift-price .new{
  color:var(--verde);
  font-size:16px;
  text-transform:uppercase;
}
.carousel-arrows{
  display:flex;
  justify-content:center;
  gap:18px;
  margin-top:10px;
}
.carousel-arrows button{
  background:rgba(255,255,255,.15);
  border:1px solid rgba(255,255,255,.3);
  color:#fff;
  width:40px;
  height:40px;
  border-radius:50%;
  font-size:18px;
  cursor:pointer;
}

/* ===== PRODUTO ===== */
.product-section{
  background:var(--branco);
}
.product-title{
  font-size:20px;
  color:var(--texto);
  margin-bottom:18px;
  text-align:center;
}

/* ===== OFFER CARD (producto) ===== */
.offer-card{
  background:var(--cinza-claro);
  border:2px solid var(--amarelo);
  border-radius:22px;
  padding:24px 18px;
  box-shadow:0 8px 30px rgba(255,193,7,.18);
}

/* ===== PLANS GRID ===== */
.plans-grid{
  display:flex;
  flex-direction:column;
  gap:24px;
  margin-top:24px;
}
.plan-card{
  border-color:#d6e0f5;
  box-shadow:none;
  opacity:.92;
}
.plan-premium{
  position:relative;
  border:3px solid var(--amarelo);
  box-shadow:0 12px 40px rgba(255,193,7,.35);
  opacity:1;
  transform:scale(1.02);
}
.plan-badge{
  position:absolute;
  top:-14px;
  left:50%;
  transform:translateX(-50%);
  background:var(--amarelo);
  color:var(--azul-escuro);
  font-family:'Montserrat',sans-serif;
  font-weight:900;
  font-size:13px;
  text-transform:uppercase;
  letter-spacing:1px;
  padding:6px 18px;
  border-radius:999px;
  box-shadow:0 4px 12px rgba(0,0,0,.15);
  white-space:nowrap;
}

@media (min-width:760px){
  .plans-grid{
    flex-direction:row;
    align-items:stretch;
  }
  .plans-grid .offer-card{
    flex:1;
  }
}

/* ===== INCLUYE BOX (producto) ===== */
.includes-box{
  background:#fff8e1;
  border:1px dashed var(--amarelo-escuro);
  border-radius:16px;
  padding:18px 20px;
  margin-bottom:20px;
}
.includes-title{
  color:var(--azul);
  font-size:16px;
  text-align:center;
  margin-bottom:12px;
  font-family:'Montserrat',sans-serif;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:1px;
}
.includes-list{
  list-style:none;
  display:flex;
  flex-direction:column;
  gap:10px;
}
.includes-list li{
  display:flex;
  align-items:flex-start;
  gap:10px;
  font-size:14px;
  color:var(--texto);
}
.includes-list .check{
  flex-shrink:0;
  color:var(--verde);
}

/* ===== OFFER TAGS ===== */
.offer-tags{
  display:flex;
  justify-content:center;
  gap:10px;
  flex-wrap:wrap;
  margin-bottom:10px;
}
.offer-tags-single{
  margin-bottom:20px;
}
.offer-tags span{
  background:var(--branco);
  border:1px solid #d6e0f5;
  color:var(--texto);
  font-size:13px;
  font-weight:700;
  padding:8px 16px;
  border-radius:999px;
}

/* ===== PRICE BOX ===== */
.price-box{
  text-align:center;
  margin-bottom:20px;
}
.price-old-label{
  font-size:14px;
  color:var(--texto-suave);
  margin-bottom:6px;
}
.price-old{
  color:var(--vermelho);
  text-decoration:line-through;
  font-weight:700;
}
.price-row{
  display:flex;
  align-items:flex-start;
  justify-content:center;
  gap:6px;
  line-height:1;
  animation:price-pop 1.8s ease-in-out infinite;
}
.price-row .price-currency{
  font-size:30px;
  font-weight:900;
  color:var(--azul);
  font-family:'Montserrat',sans-serif;
  margin-top:10px;
}
.price-row .price{
  font-size:64px;
  font-weight:900;
  color:var(--azul);
  font-family:'Montserrat',sans-serif;
}
@keyframes price-pop{
  0%,100%{transform:scale(1);}
  50%{transform:scale(1.05);}
}
.price-note{
  text-align:center;
  color:var(--amarelo-escuro);
  font-size:13px;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:1px;
  margin-top:8px;
}

/* ===== FAQ ===== */
.faq-section{
  background:var(--cinza-claro);
}
.faq-item{
  background:var(--branco);
  border:1px solid #e3e9f5;
  border-radius:14px;
  margin-bottom:12px;
  overflow:hidden;
}
.faq-q{
  width:100%;
  background:none;
  border:none;
  color:var(--texto);
  text-align:left;
  font-family:'Montserrat',sans-serif;
  font-weight:800;
  font-size:14px;
  padding:16px 18px;
  cursor:pointer;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:10px;
}
.faq-q .arrow{
  transition:transform .25s ease;
  flex-shrink:0;
  font-size:18px;
  color:var(--azul);
}
.faq-item.open .arrow{transform:rotate(45deg);}
.faq-a{
  max-height:0;
  overflow:hidden;
  transition:max-height .3s ease;
  padding:0 18px;
}
.faq-item.open .faq-a{
  max-height:400px;
  padding:0 18px 18px;
}
.faq-a p{
  font-size:13.5px;
  color:var(--texto-suave);
}

/* ===== URGENCIA / TIMER ===== */
.urgency-section{
  background:linear-gradient(180deg, var(--azul) 0%, var(--azul-escuro) 100%);
  text-align:center;
}
.urgency-section h2{
  font-size:22px;
  color:#fff;
  margin-bottom:10px;
}
.urgency-section p{
  color:rgba(255,255,255,.9);
  font-size:14px;
  margin-bottom:22px;
  max-width:480px;
  margin-left:auto;
  margin-right:auto;
}
.timer-box{
  display:flex;
  justify-content:center;
  gap:14px;
  margin-bottom:14px;
}
.timer-unit{
  background:rgba(255,255,255,.1);
  border:1px solid rgba(255,193,7,.5);
  border-radius:14px;
  padding:14px 20px;
  min-width:80px;
}
.timer-unit .num{
  font-size:32px;
  font-weight:900;
  color:var(--amarelo);
  font-family:'Montserrat',sans-serif;
}
.timer-unit .lbl{
  font-size:11px;
  color:rgba(255,255,255,.75);
  text-transform:uppercase;
  letter-spacing:1px;
}
.savings{
  color:var(--amarelo);
  font-weight:800;
  font-size:15px;
}

/* ===== VISTA PREVIA ===== */
.preview-section{
  background:var(--cinza-claro);
  text-align:center;
}
.preview-section h2{
  font-size:24px;
  color:var(--texto);
  margin-bottom:8px;
}
.preview-section .sub{
  color:var(--texto-suave);
  font-size:14px;
  margin-bottom:24px;
}
.preview-gallery{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:10px;
  margin-bottom:26px;
}
.preview-gallery img{
  border-radius:10px;
  aspect-ratio:3/4;
  object-fit:cover;
  box-shadow:0 6px 18px rgba(0,0,0,.12);
}

/* ===== QUE INCLUYE ===== */
.incluye-section{
  background:var(--branco);
}
.incluye-grid{
  display:flex;
  flex-direction:column;
  gap:14px;
}
.incluye-card{
  background:var(--cinza-claro);
  border:1px solid #e3e9f5;
  border-radius:14px;
  padding:16px 18px;
  display:flex;
  gap:14px;
  align-items:flex-start;
}
.incluye-card .emoji{font-size:26px;flex-shrink:0;}
.incluye-card h3{
  font-size:15px;
  color:var(--azul);
  margin-bottom:4px;
  font-family:'Montserrat',sans-serif;
  font-weight:800;
}
.incluye-card p{
  font-size:13.5px;
  color:var(--texto-suave);
}

/* ===== GARANTIA + LOJA ===== */
.guarantee-section{
  background:var(--cinza-claro);
  text-align:center;
}
.guarantee-badge{
  width:120px;
  margin:0 auto 18px;
}
.guarantee-section h2{
  font-size:20px;
  color:var(--texto);
  margin-bottom:6px;
}
.guarantee-section p{
  color:var(--texto-suave);
  font-size:14px;
  margin-bottom:30px;
}
.store-card{
  background:var(--branco);
  border:1px solid #e3e9f5;
  border-radius:14px;
  padding:18px;
  text-align:center;
}
.store-card h3{
  color:var(--azul);
  font-size:15px;
  margin-bottom:6px;
  font-family:'Montserrat',sans-serif;
  font-weight:800;
}
.store-card p{
  color:var(--texto-suave);
  font-size:13px;
}

/* ===== REVIEWS ===== */
.reviews-section{
  background:var(--branco);
}
.reviews-section .stars{
  text-align:center;
  color:var(--amarelo-escuro);
  font-size:18px;
  margin-bottom:6px;
}
.review-card{
  background:var(--cinza-claro);
  border:1px solid #e3e9f5;
  border-radius:14px;
  padding:16px;
  margin-bottom:12px;
}
.review-head{
  display:flex;
  justify-content:space-between;
  align-items:center;
  margin-bottom:8px;
  flex-wrap:wrap;
  gap:6px;
}
.review-head .name{
  font-weight:700;
  color:var(--texto);
  font-size:14px;
}
.review-head .meta{
  font-size:11px;
  color:var(--texto-suave);
}
.review-stars{color:var(--amarelo-escuro);font-size:13px;margin-bottom:6px;}
.review-card p.text{font-size:13.5px;color:var(--texto-suave);}
.verified-badge{
  display:inline-block;
  background:rgba(46,125,50,.12);
  color:var(--verde);
  font-size:10px;
  font-weight:800;
  padding:2px 8px;
  border-radius:999px;
  margin-left:6px;
}
.reviews-hidden{display:none;}
.reviews-hidden.show{display:block;}
#show-more-reviews{
  display:block;
  margin:18px auto 0;
  background:var(--azul);
  border:none;
  color:#fff;
  font-weight:700;
  font-size:14px;
  padding:12px 28px;
  border-radius:999px;
  cursor:pointer;
}

@media(min-width:700px){
  .preview-gallery{grid-template-columns:repeat(3,1fr);}
  .gift-card{flex:0 0 320px;}
  .hero h1{font-size:36px;}
}
