:root{
  --bg-start:#0e0a1f;
  --bg-end:#15123a;
  --card:#14112e;
  --text:#e9e7ff;
  --muted:#a49fd1;
  --brand:#6c3ebb;
  --accent:#8f62ff;
  --success:#2bdc84;
}

*{box-sizing:border-box}

html,body{height:100%}

body{
  margin:0;
  font-family:Inter, system-ui, -apple-system, Segoe UI, Roboto, Ubuntu, Cantarell, 'Helvetica Neue', Arial, 'Noto Sans', 'Apple Color Emoji','Segoe UI Emoji', 'Segoe UI Symbol', 'Noto Color Emoji', sans-serif;
  color:var(--text);
  background: radial-gradient(1000px 500px at 15% 10%, #241d52 0%, rgba(36,29,82,0) 60%) no-repeat,
              radial-gradient(800px 400px at 85% 20%, #1f184a 0%, rgba(31,24,74,0) 60%) no-repeat,
              linear-gradient(180deg, var(--bg-start), var(--bg-end));
  display:grid;
  place-items:center;
}

.container{
  width:min(1100px, 96vw);
  padding:20px 16px;
  text-align:center;
}

.card{
  border:1px solid rgba(255,255,255,.06);
  background: linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.01));
  backdrop-filter: blur(8px);
  border-radius:24px;
  padding:40px 28px 36px;
  position:relative;
  overflow:hidden;
  box-shadow:0 20px 70px rgba(0,0,0,.35);
}

.glow{
  position:absolute;
  inset:auto -120px -120px auto;
  width:300px;
  height:300px;
  background: radial-gradient(circle at 30% 30%, var(--accent), transparent 60%);
  filter: blur(50px);
  opacity:.35;
  pointer-events:none;
  animation: drift 12s ease-in-out infinite;
}

@keyframes drift{
  0%,100%{transform:translate3d(0,0,0) scale(1)}
  50%{transform:translate3d(-20px,-10px,0) scale(1.05)}
}

/* HERO LAYOUT */

.hero-layout{
  display:grid;
  grid-template-columns:minmax(0,1.7fr) minmax(0,1.4fr);
  gap:30px;
  align-items:center;
  margin-bottom:12px;
}

.hero-copy{text-align:left;}
.hero-copy-center{text-align:center;}

.hero-media{
  border-radius:20px;
  border:1px solid rgba(255,255,255,.12);
  background:radial-gradient(140% 220% at 0% 0%, rgba(255,255,255,.06), rgba(20,17,46,.96));
  padding:16px 16px 14px;
  position:relative;
  box-shadow:0 18px 45px rgba(0,0,0,.5);
}

.hero-media img{
  width:100%;
  display:block;
  border-radius:14px;
}

.hero-media-tag{
  position:absolute;
  left:16px;
  bottom:14px;
  padding:6px 10px;
  border-radius:999px;
  background:rgba(0,0,0,.74);
  border:1px solid rgba(255,255,255,.24);
  font-size:.75rem;
  color:var(--muted);
  display:flex;
  align-items:center;
  gap:6px;
}

.hero-media-dot{
  width:8px;
  height:8px;
  border-radius:50%;
  background:radial-gradient(circle at 30% 30%, var(--success), #149a59);
  box-shadow:0 0 10px rgba(43,220,132,.8);
}

.logo-wrap{
  display:inline-flex;
  align-items:center;
  gap:18px;
  transform: translateZ(0);
  will-change: transform, opacity;
  animation: fadeUp .9s ease-out .2s both;
}

@keyframes fadeUp{
  from{opacity:0; transform: translateY(10px)}
  to{opacity:1; transform: translateY(0)}
}

.badge{
  font-size:.78rem;
  color:var(--muted);
  letter-spacing:.12em;
  text-transform:uppercase;
  margin-bottom:14px;
  display:inline-flex;
  gap:8px;
  align-items:center;
  opacity:.9;
}

.badge .dot{
  width:8px;
  height:8px;
  border-radius:50%;
  background: radial-gradient(circle at 30% 30%, var(--success), #149a59);
  box-shadow:0 0 14px rgba(43,220,132,.8);
  animation: pulse 2s ease-in-out infinite;
}

@keyframes pulse{
  0%,100%{transform:scale(1)}
  50%{transform:scale(1.25)}
}

.title{
  margin:18px 0 10px;
  font-size: clamp(36px, 5.6vw, 62px);
  line-height:1.02;
  letter-spacing:-.02em;
  font-weight:800;
}

/* BLOCO TEXTO URLs ÚNICAS */

.subtitle{
  margin:0 0 24px;
  max-width:820px;
  margin-inline:auto;
  display:flex;
  flex-direction:column;
  gap:4px;
}

.subtitle-tagline{
  font-size:clamp(13px,2vw,15px);
  text-transform:uppercase;
  letter-spacing:.18em;
  color:var(--muted);
  font-weight:600;
}

.subtitle-main{
  font-size:clamp(20px,3vw,26px);
  font-weight:600;
  letter-spacing:-.01em;
  line-height:1.25;
}

.subtitle-tail{
  font-size:clamp(15px,2.3vw,18px);
  color:var(--muted);
  line-height:1.4;
}

.subtitle-highlight{
  background:linear-gradient(90deg, var(--accent), var(--brand));
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
  font-weight:800;
}

.highlight-text{
  font-size:.9rem;
  color:var(--muted);
  margin-bottom:24px;
}

.highlight-text strong{color:var(--text);}

.actions{
  display:flex;
  align-items:center;
  justify-content:flex-start;
  gap:12px;
  flex-wrap:wrap;
  margin-top:4px;
  margin-bottom:16px;
}

.btn{
  border-radius:14px;
  padding:14px 18px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.02);
  color:var(--text);
  font-weight:600;
  text-decoration:none;
  transition:.25s ease;
  font-size:.92rem;
  cursor:pointer;
}

.btn.primary{
  border-color:transparent;
  background:linear-gradient(90deg, var(--brand), var(--accent));
  box-shadow: 0 10px 30px rgba(108,62,187,.35);
}

.btn:hover{
  transform: translateY(-2px);
  box-shadow: 0 14px 40px rgba(0,0,0,.25);
}

.btn-ghost{
  background:transparent;
  border-color:rgba(255,255,255,.24);
  box-shadow:none;
}

.legal{
  color:#b8b4e7;
  opacity:.8;
  font-size:.78rem;
  margin-top:26px;
}

.bubble{
  filter: drop-shadow(0 6px 20px rgba(108,62,187,.45));
  animation: float 4s ease-in-out infinite;
  transform-origin: center;
}

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

.shine{
  stroke-dasharray: 160;
  stroke-dashoffset: 160;
  animation: draw 1.4s ease-out .35s both;
}

@keyframes draw{
  to{stroke-dashoffset: 0}
}

.type span{
  opacity:1;
  transform: translateY(0);
  display:inline-block;
  animation: pop .55s ease forwards;
}

@keyframes pop{
  from{opacity:0; transform: translateY(6px);}
  to{opacity:1; transform: translateY(0);}
}

.accent-underline{
  position:relative;
}

.accent-underline::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  bottom:-6px;
  height:8px;
  background: radial-gradient(60% 100% at 50% 100%, rgba(143,98,255,.65), rgba(143,98,255,0));
  filter: blur(6px);
  animation: breathe 3.2s ease-in-out infinite;
}

@keyframes breathe{
  0%,100%{opacity:.55; transform: scaleX(1)}
  50%{opacity:.9; transform: scaleX(1.08)}
}

footer{
  text-align:center;
  margin-top:18px;
  color:var(--muted);
  font-size:.8rem;
}

/* PLANOS */

.plans{
  margin-top:24px;
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap:18px;
  text-align:left;
}

.plan-card{
  border-radius:18px;
  border:1px solid rgba(255,255,255,.09);
  background: radial-gradient(140% 220% at 0% 0%, rgba(255,255,255,.06), rgba(20,17,46,.9));
  padding:18px 18px 20px;
  position:relative;
  overflow:hidden;
}

.plan-card.featured{
  border-color:rgba(143,98,255,.9);
  box-shadow:0 16px 45px rgba(143,98,255,.35);
  transform:translateY(-2px);
}

.plan-badge{
  display:inline-flex;
  align-items:center;
  gap:6px;
  font-size:.68rem;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--muted);
  opacity:.9;
  margin-bottom:8px;
}

.plan-badge span.dot-mini{
  width:7px;
  height:7px;
  border-radius:999px;
  background: radial-gradient(circle at 30% 30%, var(--success), #149a59);
  box-shadow:0 0 10px rgba(43,220,132,.8);
}

.plan-name{
  font-size:1.05rem;
  font-weight:700;
  margin:0 0 6px;
}

.plan-desc{
  font-size:.82rem;
  color:var(--muted);
  margin:0 0 12px;
}

.plan-price{
  display:flex;
  align-items:baseline;
  gap:4px;
  margin-bottom:4px;
}

.plan-price strong{
  font-size:1.24rem;
  font-weight:800;
}

.plan-price span{
  font-size:.8rem;
  color:var(--muted);
}

.plan-note{
  font-size:.75rem;
  color:var(--muted);
  margin-bottom:10px;
}

.plan-features{
  list-style:none;
  padding:0;
  margin:0 0 12px;
  font-size:.8rem;
  color:var(--muted);
}

.plan-features li{
  display:flex;
  gap:6px;
  align-items:flex-start;
  margin-bottom:4px;
}

.plan-features li::before{
  content:"✓";
  font-size:.78rem;
  margin-top:1px;
  color:var(--success);
}

.plan-cta{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:6px;
  padding:8px 10px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.16);
  background:rgba(0,0,0,.18);
  color:var(--text);
  font-size:.78rem;
  font-weight:600;
  text-decoration:none;
  cursor:pointer;
  transition:.2s ease;
}

.plan-card.featured .plan-cta{
  background:linear-gradient(90deg, var(--brand), var(--accent));
  border-color:transparent;
}

.plan-cta:hover{
  transform:translateY(-1px);
  box-shadow:0 8px 22px rgba(0,0,0,.35);
}

.per-url{
  font-size:.7rem;
  opacity:.8;
}

/* BLOCOS DE CONTEÚDO EXTRA */

.section-block{
  margin-top:34px;
  text-align:left;
}

.section-eyebrow{
  font-size:.78rem;
  text-transform:uppercase;
  letter-spacing:.16em;
  color:var(--muted);
  margin-bottom:6px;
}

.section-heading{
  font-size:clamp(20px,2.3vw,24px);
  font-weight:700;
  margin:0 0 10px;
}

.section-lead{
  font-size:.9rem;
  color:var(--muted);
  max-width:640px;
}

/* IMAGEM DE SEÇÃO */

.section-figure{
  margin:16px 0 0;
  text-align:center;
}

.section-figure img{
  max-width:360px;
  width:100%;
  border-radius:18px;
  border:1px solid rgba(255,255,255,.12);
  box-shadow:0 16px 40px rgba(0,0,0,.55);
  display:inline-block;
}

/* COMO FUNCIONA */

.steps-grid{
  margin-top:16px;
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:16px;
}

.step-card{
  border-radius:16px;
  border:1px solid rgba(255,255,255,.08);
  background:radial-gradient(120% 180% at 0% 0%, rgba(255,255,255,.05), rgba(20,17,46,.96));
  padding:14px 16px 16px;
  font-size:.86rem;
  color:var(--muted);
}

.step-number{
  width:26px;
  height:26px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.28);
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:.78rem;
  margin-bottom:8px;
  background:rgba(0,0,0,.35);
}

.step-title{
  font-weight:600;
  color:var(--text);
  margin-bottom:4px;
  font-size:.9rem;
}

/* BENEFÍCIOS */

.benefits-grid{
  margin-top:16px;
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(230px,1fr));
  gap:14px;
  font-size:.86rem;
}

.benefit-item{
  display:flex;
  gap:10px;
  align-items:flex-start;
  color:var(--muted);
}

.benefit-bullet{
  width:18px;
  height:18px;
  border-radius:999px;
  background:radial-gradient(circle at 30% 30%, var(--success), #149a59);
  box-shadow:0 0 10px rgba(43,220,132,.7);
  margin-top:3px;
  flex-shrink:0;
}

.benefit-title{
  font-weight:600;
  color:var(--text);
  margin-bottom:2px;
  font-size:.9rem;
}

/* PARA QUEM É */

.tag-list{
  margin-top:14px;
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  font-size:.78rem;
}

.tag-pill{
  padding:6px 10px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.16);
  background:rgba(0,0,0,.28);
  color:var(--muted);
  white-space:nowrap;
}

/* DEPOIMENTOS */

.testimonials-grid{
  margin-top:16px;
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
  gap:16px;
  font-size:.86rem;
}

.testimonial-card{
  border-radius:16px;
  border:1px solid rgba(255,255,255,.08);
  background:radial-gradient(140% 200% at 0% 0%, rgba(255,255,255,.06), rgba(20,17,46,.96));
  padding:16px 16px 14px;
  position:relative;
}

.testimonial-quote{
  color:var(--muted);
  margin:0 0 10px;
}

.testimonial-meta{
  display:flex;
  align-items:center;
  gap:8px;
}

.testimonial-avatar{
  width:32px;
  height:32px;
  border-radius:50%;
  object-fit:cover;
  border:1px solid rgba(255,255,255,.4);
  flex-shrink:0;
}

.testimonial-name{
  font-weight:600;
  font-size:.88rem;
}

.testimonial-role{
  font-size:.78rem;
  color:var(--muted);
}

.quote-mark{
  position:absolute;
  top:10px;
  right:14px;
  font-size:26px;
  color:rgba(255,255,255,.12);
}

/* FAQ */

.faq-list{
  margin-top:14px;
}

.faq-item{
  border-radius:12px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(0,0,0,.32);
  margin-bottom:8px;
  overflow:hidden;
}

.faq-item summary{
  list-style:none;
  cursor:pointer;
  padding:10px 12px;
  font-size:.86rem;
  font-weight:600;
  display:flex;
  justify-content:space-between;
  align-items:center;
  color:var(--text);
}

.faq-item summary::-webkit-details-marker{display:none;}

.faq-item p{
  padding:0 12px 10px;
  margin:0;
  font-size:.82rem;
  color:var(--muted);
}

/* CTA FINAL */

.final-cta{
  margin-top:26px;
  border-radius:18px;
  border:1px solid rgba(255,255,255,.16);
  background:linear-gradient(135deg, rgba(108,62,187,.45), rgba(20,17,46,.96));
  padding:18px 18px 20px;
  text-align:left;
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  align-items:center;
  justify-content:space-between;
}

.final-cta h3{
  margin:0 0 4px;
  font-size:1.02rem;
}

.final-cta p{
  margin:0;
  font-size:.86rem;
  color:#d2ceff;
  max-width:520px;
}

.final-cta .btn{
  white-space:nowrap;
}

/* MODAL DE CUPOM */

.coupon-modal-backdrop{
  position:fixed;
  inset:0;
  background:rgba(3,0,20,.88);
  display:none;
  align-items:center;
  justify-content:center;
  padding:16px;
  z-index:999;
}

.coupon-modal-backdrop.is-open{
  display:flex;
}

.coupon-modal{
  width:100%;
  max-width:420px;
  border-radius:18px;
  background:linear-gradient(160deg, #14112e, #231a63);
  border:1px solid rgba(255,255,255,.18);
  box-shadow:0 22px 60px rgba(0,0,0,.75);
  padding:20px 20px 18px;
  text-align:left;
  position:relative;
}

.coupon-close{
  position:absolute;
  right:10px;
  top:8px;
  border:none;
  background:transparent;
  color:var(--muted);
  font-size:18px;
  cursor:pointer;
}

.coupon-modal h3{
  margin:0 0 6px;
  font-size:1.02rem;
}

.coupon-text{
  margin:0 0 10px;
  font-size:.86rem;
  color:var(--muted);
}

.coupon-label{
  display:block;
  font-size:.8rem;
  margin-bottom:4px;
  color:var(--muted);
}

.coupon-input{
  width:100%;
  padding:10px 11px;
  border-radius:10px;
  border:1px solid rgba(255,255,255,.18);
  background:rgba(4,3,20,.95);
  color:var(--text);
  font-size:.9rem;
  outline:none;
}

.coupon-input:focus{
  border-color:var(--accent);
  box-shadow:0 0 0 1px rgba(143,98,255,.6);
}

.coupon-hint{
  margin:6px 0 0;
  font-size:.76rem;
  color:var(--muted);
}

.coupon-error{
  margin:4px 0 0;
  font-size:.78rem;
  color:#ff8b8b;
  min-height:1.1em;
}

.coupon-actions{
  margin-top:14px;
  display:flex;
  gap:8px;
  justify-content:flex-end;
}

/* MOBILE FIX */

@media (max-width:860px){
  .hero-layout{
    grid-template-columns:1fr;
  }
  .hero-copy{text-align:center;}
  .actions{justify-content:center;}
}

@media (max-width:640px){
  html,body{
    height:auto;
  }
  body{
    display:block;
    padding:12px 0 20px;
  }
  .container{
    width:100%;
    max-width:100%;
    padding:0 10px;
  }
  .card{
    padding:28px 18px 26px;
    border-radius:18px;
  }
  .plans{
    margin-top:20px;
  }
  .final-cta{
    text-align:left;
  }
}
