/* =========================
   TOKENS / BASE
   ========================= */
:root{
  --bg:#0b0f14; --panel:#0f1720; --txt:#eaf6ff; --text-2:#bfefff;
  --hud:#2fd1ff; --hud-2:#56e0ff; --accent:#2ee59d; --secondary:#7dd3fc;
  --radius:16px; --section:36px;
  --stroke-weak:rgba(255,255,255,.08); --stroke-faint:rgba(255,255,255,.04);
  --shadow-strong:0 10px 30px rgba(0,0,0,.35); --shadow-soft:0 8px 22px rgba(0,0,0,.32);
}
*{box-sizing:border-box}
body{background:var(--bg);color:var(--txt);overflow-x:hidden}
.container{max-width:1120px;margin:0 auto;padding:0 16px}

/* BGs */
.grid-bg{position:fixed; inset:0; pointer-events:none; opacity:.45; z-index:0;
  background:linear-gradient(transparent 31px, rgba(255,255,255,.06) 32px),
             linear-gradient(90deg, transparent 31px, rgba(255,255,255,.06) 32px);
  background-size:32px 32px; mask: radial-gradient(ellipse at center, #000 55%, transparent 100%);
  animation:drift 18s linear infinite}
@keyframes drift{to{transform:translate3d(-32px,-32px,0)}}
.particles{position:fixed; inset:0; pointer-events:none; z-index:0; opacity:.28;
  background:
    radial-gradient(circle 2px at 10% 20%, rgba(125,211,252,.65), transparent 45%),
    radial-gradient(circle 2px at 35% 70%, rgba(46,229,157,.7),  transparent 45%),
    radial-gradient(circle 2px at 70% 30%, rgba(125,211,252,.55), transparent 45%),
    radial-gradient(circle 2px at 85% 60%, rgba(46,229,157,.65),  transparent 45%);
  animation:particlesFloat 26s linear infinite}
@keyframes particlesFloat{50%{background-position:20px -30px,-25px 18px,12px 24px,-18px -16px}}

/* HERO */
.hero{position:relative; z-index:1; isolation:isolate; margin:10vh auto 0; padding:32px 0 28px;
  background:linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.02));
  border:1px solid var(--stroke-weak); border-radius:var(--radius);
  box-shadow:var(--shadow-strong), inset 0 0 0 1px var(--stroke-faint); backdrop-filter:blur(6px)}
.hero .inner{padding:0 24px;max-width:1050px;margin:0 auto}
.hero::after{content:""; position:absolute; inset:0; pointer-events:none; opacity:.18;
  background:repeating-linear-gradient(to bottom, rgba(125,211,252,.07) 0 1px, transparent 1px 4px);
  mix-blend-mode:screen; animation:scan 8s linear infinite}
@keyframes scan{to{background-position-y:-120px}}
.kicker{color:var(--text-2);letter-spacing:.18em;font-weight:800;font-size:.72rem;opacity:.9;text-align:center}
.hero h1{margin:4px 0 10px; text-align:center;
  font:900 clamp(1.7rem,3.6vw,2.25rem)/1.15 ui-sans-serif,system-ui;
  background:linear-gradient(90deg, var(--hud), #fff, var(--hud-2));
  -webkit-background-clip:text; background-clip:text; color:transparent; -webkit-text-fill-color:transparent;
  background-size:200% auto; animation:textShine 6s linear infinite}
@keyframes textShine{to{background-position:200% center}}
.hero p{margin:0 auto; max-width:760px; color:var(--text-2); font-size:clamp(.98rem,1.6vw,1.05rem); text-align:center}

/* Expectativa */
.expect{margin:12px auto 10px; max-width:360px; text-align:left; font-size:.85rem; color:var(--text-2)}
.expect-label{font-weight:800; letter-spacing:.02em; margin-bottom:6px; display:block}
.expect-bar{height:14px; border-radius:999px; background:rgba(255,255,255,.08); overflow:hidden; box-shadow:inset 0 0 4px rgba(0,0,0,.45)}
.expect-fill{height:100%; width:0%; background:linear-gradient(90deg,#ef4444,#f59e0b,#facc15,#22c55e);
  border-radius:inherit; box-shadow:0 0 12px rgba(46,229,157,.35); animation:expectAnim 4.2s ease-in-out infinite alternate}
@keyframes expectAnim{0%{width:10%}50%{width:55%}100%{width:96%}}

/* CTAs do hero */
.cta-buttons{display:flex;gap:16px;flex-wrap:wrap;justify-content:center;margin-top:14px}
.btn-login,.btn-assinar{all:unset;display:inline-flex;align-items:center;justify-content:center;gap:10px;min-height:50px;
  padding:0 26px;border-radius:14px;font-weight:800;font-size:1rem;cursor:pointer;text-decoration:none;
  transition:transform .18s ease, filter .18s ease, box-shadow .18s ease}
.btn-assinar--mod{background:linear-gradient(90deg,#22c55e,#2ee59d,#3bcdfc);background-size:200% 200%;color:#041016;
  box-shadow:0 14px 34px rgba(59,205,252,.30), 0 0 0 1px rgba(46,229,157,.22) inset;padding:14px 28px;border-radius:14px;
  transform:translateY(0) scale(1.02);position:relative;animation:ctaShift 6s ease infinite}
.btn-assinar--mod::after{content:"➜";font-weight:900;margin-left:10px;opacity:.9}
.btn-assinar--mod:hover{transform:translateY(-2px) scale(1.05);filter:brightness(1.06)}
@keyframes ctaShift{0%{background-position:0 50%}50%{background-position:100% 50%}100%{background-position:0 50%}}
.btn-login{border:2px solid rgba(125,211,252,.7);color:#bfefff;background:rgba(18,26,34,.35)}
.btn-login:hover{background:rgba(125,211,252,.12);border-color:#7dd3fc;transform:translateY(-1px)}

/* ================= PRICING ================= */
.section-spacer{height:var(--section)}
.pricing .wrap{margin:8px auto 0;border-radius:16px;padding:26px 18px 18px;
  background:linear-gradient(180deg,#0f1724,#0d1520);border:1px solid rgba(125,211,252,.20);
  box-shadow:0 12px 30px rgba(0,0,0,.42), inset 0 0 0 1px rgba(255,255,255,.04)}
.pricing-head{display:flex;justify-content:center;margin-bottom:16px}
.price-pill{display:inline-flex;align-items:center;gap:8px;padding:6px 12px;border-radius:999px;
  background:rgba(47,209,255,.10);border:1px solid rgba(125,211,252,.22);color:#cfe3f7;font-weight:800;font-size:.95rem;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.03)}

/* Toggle faturamento */
.billing-toggle{display:flex;gap:6px;justify-content:center;margin:6px 0 16px}
.billing-toggle button{all:unset;cursor:pointer;padding:8px 14px;border-radius:999px;font-weight:900;color:#cfe7ff;
  border:1px solid rgba(125,211,252,.22);background:rgba(12,18,26,.6)}
.billing-toggle .is-active{background:linear-gradient(90deg,#22c55e,#2ee59d);color:#041016;border-color:transparent}

/* Cards */
.pricing-grid{display:grid;grid-template-columns:1fr 1.12fr 1fr;gap:18px}
.plan{background:linear-gradient(180deg,#0f1b2a,#0b1421);border:1px solid rgba(125,211,252,.16);
  border-radius:14px;padding:18px;display:grid;grid-template-rows:auto auto auto 1fr auto;row-gap:12px;
  text-align:center;min-height:260px;position:relative}
.plan::before{content:"";position:absolute;left:18px;right:18px;top:64px;height:1px;
  background:linear-gradient(90deg,rgba(125,211,252,.12),rgba(46,229,157,.18),rgba(125,211,252,.12))}
.plan-header{display:flex;flex-direction:column;align-items:center;gap:6px}
.plan-title{margin:0;color:#cfe7ff;font-weight:900;letter-spacing:.2px}
.plan-ribbon{padding:4px 10px;border-radius:999px;font-size:.75rem;font-weight:900;color:#052016;
  background:linear-gradient(90deg,#22c55e,#2ee59d);box-shadow:0 0 0 1px rgba(46,229,157,.45),0 8px 18px rgba(46,229,157,.22)}
.plan-price{display:flex;align-items:baseline;justify-content:center;gap:6px;margin:6px 0 12px}
.plan-price strong{font-size:2rem;line-height:1;color:#eaf6ff}
.plan-price span{color:#9ec6db;font-weight:700}
.plan-desc{color:#cfe7ff;font-weight:800;line-height:1.35;min-height:3em}
.pill-badge{justify-self:center;margin-top:-4px;font-size:.8rem;font-weight:900;color:#052016;
  background:linear-gradient(90deg,#22c55e,#2ee59d);padding:4px 10px;border-radius:999px;box-shadow:0 0 0 1px rgba(46,229,157,.35)}
.plan-feats{list-style:none;margin:0;padding:0;display:grid;gap:6px}
.plan-feats li{color:#9bb0c9;font-size:.95rem;display:flex;gap:8px;justify-content:center}
.plan-feats li::before{content:"✓";font-weight:900;color:#2ee59d}
.plan-cta{width:100%;display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px;border-radius:12px;
  font-weight:900;text-decoration:none;color:#041016;background:linear-gradient(90deg,#22c55e,#2ee59d,#3bcdfc);
  box-shadow:0 8px 20px rgba(59,205,252,.22);transition:transform .15s ease, filter .15s ease}
.plan-cta::after{content:"➜";margin-left:6px}
.plan-cta:hover{transform:translateY(-2px);filter:brightness(1.06)}
.plan .micro-trust{margin-top:6px;color:#9ec6db}
.plan.is-featured{background:linear-gradient(180deg,#0f1e2f,#0c1624);border:1px solid rgba(46,229,157,.45);
  box-shadow:0 12px 28px rgba(46,229,157,.18),0 0 0 1px rgba(46,229,157,.20) inset;transform:translateY(-2px);z-index:1}
.plan.is-featured::after{content:"";position:absolute;inset:-1px;border-radius:inherit;padding:1px;
  background:linear-gradient(90deg,#22c55e,#2ee59d,#3bcdfc);
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;opacity:.22}

/* Trust row */
.trust-row{display:flex;gap:12px;justify-content:space-between;align-items:center;margin-top:12px;
  padding:10px 12px;border:1px solid rgba(125,211,252,.16);border-radius:12px;background:rgba(12,18,26,.5)}
.trust-row .guarantee{font-weight:800;color:#cfe7ff}
.pay-logos{display:flex;gap:10px;list-style:none;margin:0;padding:0;opacity:.9}
.pay-logos li{padding:6px 10px;border-radius:8px;border:1px solid rgba(125,211,252,.14)}

/* FAQ compacto */
.faq{margin-top:14px;display:grid;gap:8px}
.faq .q{width:100%;text-align:left;padding:12px 14px;border:1px solid rgba(125,211,252,.18);
  border-radius:10px;background:rgba(15,23,32,.6);font-weight:800;color:#cfe7ff;cursor:pointer}
.faq .a{display:none;padding:10px 14px;color:#9ec6db}

/* FEATURES / WHY (inalterados) */
.features{ margin:26px auto 0; padding:0 16px; display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:14px; max-width:1100px }
.card{ background:linear-gradient(180deg,#101a26,#0c141d); border:1px solid var(--stroke-weak); border-radius:14px; padding:16px; box-shadow:var(--shadow-soft), inset 0 0 0 1px var(--stroke-faint)}
.card h3{margin:0 0 8px; font-size:1rem; color:#cfe7ff; letter-spacing:.4px}
.muted{color:#9bb0c9; font-size:.95rem}
.viz{ display:grid; place-items:center; height:200px; margin-top:10px; background:radial-gradient(60% 80% at 50% 50%, rgba(125,211,252,.08), transparent 70%); border:1px dashed rgba(125,211,252,.18); border-radius:12px }
.viz .bars rect{ transform-origin:bottom center; animation:pulseBar 2.8s ease-in-out infinite; filter:drop-shadow(0 0 6px rgba(125,211,252,.25)) }
.viz .bars rect:nth-child(1){animation-delay:.1s}.viz .bars rect:nth-child(2){animation-delay:.3s}
.viz .bars rect:nth-child(3){animation-delay:.5s}.viz .bars rect:nth-child(4){animation-delay:.7s}
@keyframes pulseBar{0%,100%{transform:scaleY(.92)}50%{transform:scaleY(1.12)}} .viz .scan-line{stroke-dasharray:6 8;animation:dashMove 3s linear infinite;filter:drop-shadow(0 0 8px rgba(46,229,157,.35))}
@keyframes dashMove{to{stroke-dashoffset:-100}}

.why-strip{ position:relative; margin:28px 0 0;
  background: radial-gradient(900px 380px at 50% 0%, rgba(125,211,252,.10), transparent 70%), linear-gradient(180deg, rgba(10,17,24,.85), rgba(6,12,18,.92));
  border-top:1px solid rgba(125,211,252,.15); border-bottom:1px solid rgba(46,229,157,.10) }
.why-strip::before{ content:""; position:absolute; inset:0; opacity:.25; pointer-events:none;
  background: radial-gradient(60% 100% at 50% 0%, rgba(46,229,157,.10), transparent 60%), repeating-linear-gradient(90deg, rgba(255,255,255,.04) 0 1px, transparent 1px 64px) }
.why-inner{max-width:1100px;margin:0 auto;padding:28px 16px 30px;text-align:center}
.why-inner h3{margin:0 0 10px;font-weight:800;letter-spacing:.3px;color:#d9f3ff;text-shadow:0 0 12px rgba(125,211,252,.18)}
.manifesto{display:flex;flex-wrap:wrap;gap:10px 12px;justify-content:center;list-style:none;margin:6px 0 0;padding:0}
.manifesto li{ padding:10px 14px; border-radius:999px; font-weight:700; color:#d7ebff; background:rgba(21,34,49,.72); border:1px solid rgba(32,48,68,.9); box-shadow:0 8px 22px rgba(0,0,0,.22), inset 0 0 0 1px rgba(255,255,255,.03) }
.manifesto .dot{width:8px;height:8px;border-radius:50%;display:inline-block;margin-right:8px;background:linear-gradient(90deg,#7dd3fc,#2ee59d);box-shadow:0 0 10px rgba(125,211,252,.6)}
.why-foot{margin:10px 0 0;font-size:.9rem;color:#9ec6db;opacity:.9}

/* STICKY CTA */
.sticky-cta{
  position:fixed; left:50%; bottom:calc(12px + env(safe-area-inset-bottom,0));
  transform:translateX(-50%) translateY(120%); z-index:30;
  display:flex; align-items:center; gap:12px; padding:10px 12px; border-radius:999px;
  background:rgba(11,17,24,.72); backdrop-filter:blur(10px);
  border:1px solid rgba(125,211,252,.18);
  box-shadow:0 18px 44px rgba(0,0,0,.55), inset 0 0 0 1px rgba(255,255,255,.04);
  transition:transform .25s ease, opacity .2s ease;
}
.sticky-cta::before{content:""; position:absolute; inset:-2px; border-radius:inherit; z-index:-1;
  background:conic-gradient(from 180deg, #22c55e, #2ee59d, #3bcdfc, #22c55e); filter:blur(18px); opacity:.22}
.sticky-cta.show{ transform:translateX(-50%) translateY(0) }
.sticky-primary{all:unset; cursor:pointer; padding:10px 16px; border-radius:999px; font-weight:900;
  background:linear-gradient(90deg,#22c55e,#2ee59d,#3bcdfc); color:#041016; box-shadow:0 10px 26px rgba(59,205,252,.28)}
.sticky-primary:hover{ filter:brightness(1.06); transform:translateY(-1px) }
.sticky-note{ color:#cfe7ff; font-weight:800 }
.sticky-close{width:28px; height:28px; border-radius:999px; cursor:pointer; background:transparent; color:#cfe3ff;
  border:1px solid rgba(125,211,252,.25); display:grid; place-items:center; line-height:1; font-size:18px}
.sticky-close:hover{ background:rgba(125,211,252,.10) }

/* Responsivo */
@media (max-width:1000px){.pricing-grid{grid-template-columns:1fr}}
@media (max-width:960px){.features{grid-template-columns:1fr 1fr}}
@media (max-width:640px){
  .features{grid-template-columns:1fr}
  .hero{margin:6vh auto 0}
  .sticky-note{display:none}
}

/* Acessibilidade / motion */
@media (prefers-reduced-motion:reduce){
  .grid-bg,.particles,.hero::after,.expect-fill{animation:none!important}
}


/* 1) O card não deve esticar os filhos verticalmente */
.plan{
  align-items: start;                          /* evita stretch */
  grid-template-rows: auto auto auto auto 1fr auto; /* badge vira linha 'auto' */
}

/* 2) Badge sempre do tamanho do conteúdo, centralizado */
.pill-badge{
  display: inline-flex;
  align-self: center;
  justify-self: center;
  padding: 6px 12px;
  border-radius: 999px;
  width: auto;                                 /* garante que não estique */
}


/* esconder os dois balões no mobile */
@media (max-width:640px){
  .pricing-head,      /* "Planos a partir de R$ 19,90 / mês" */
  .trust-row {        /* "7 dias de garantia..." + formas de pagamento */
    display: none !important;
  }
}



/* --- Suavizar barra + CTAs --- */
.hero .expect{ margin:16px auto 8px }

/* barra menos “neon” */
.expect-bar{ height:12px; background:rgba(255,255,255,.06) }
.expect-fill{
  background:linear-gradient(90deg,#ff7b7b,#f6d267,#5bd28b);
  box-shadow:none;
  animation:expectAnim 6s ease-in-out infinite alternate;
}

/* botões mais discretos e alinhados */
.cta-buttons{ gap:12px; margin-top:18px }
.btn-assinar--mod{
  background:linear-gradient(90deg,#34d399,#38bdf8);
  box-shadow:0 8px 18px rgba(56,189,248,.22), 0 0 0 1px rgba(52,211,153,.18) inset;
  min-height:46px; padding:0 22px; border-radius:12px;
  transform:none; animation:none;
  font-weight:700; letter-spacing:.2px; /* menos “gritado” */
}
.btn-assinar--mod:hover{ transform:translateY(-1px); filter:brightness(1.03) }

.btn-login{
  min-height:46px; padding:0 20px; border-radius:12px;
  border:1.5px solid rgba(125,211,252,.55);
}

/* espaçamento entre barra e botões */
.expect + .cta-buttons{ margin-top:10px }

/* mobile: largura total */
@media (max-width:640px){
  .btn-assinar--mod,
  .btn-login{ width:100% }
}


/* ajuste botão login no mobile */
.btn-login svg{
  width:20px;
  height:20px;
  flex-shrink:0;
}

.btn-login{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  font-size:.95rem;
  font-weight:700;
  padding:10px 18px;
  border-radius:10px;
}

/* no mobile: largura cheia e altura uniforme */
@media (max-width:640px){
  .cta-buttons{ flex-direction:column }
  .btn-assinar--mod,
  .btn-login{
    width:100%;
    max-width:100%;
  }
}


/* CTAs no mobile: ocupar 100% sem estourar */
@media (max-width:640px){
  .cta-buttons{
    flex-direction: column;
    align-items: stretch;
    gap: 10px;
    margin-inline: 0;
    width: 100%;
  }
  .cta-buttons a{
    display: block;
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
    padding: 12px 16px;
    border-radius: 12px;
  }
  .btn-login svg{ width:18px; height:18px; }

  /* garante que nada “vaze” do cartão */
  .hero .inner{ overflow-x: hidden; }
}


/* garantir contexto e z-index do CTA */
.plan.is-featured { position: relative; }
.plan .plan-cta { position: relative; z-index: 2; }

/* evitar que overlays bloqueiem clique */
.plan.is-featured::before,
.plan.is-featured::after,
.plan .plan-ribbon,
.plan .plan-ribbon::before,
.plan .plan-ribbon::after {
  pointer-events: none !important;
}

/* se houver brilho/borda animada no destaque */
.plan.is-featured .plan-header::before,
.plan.is-featured .plan-header::after {
  pointer-events: none !important;
}
