.elementor-949 .elementor-element.elementor-element-996d1c7 > .elementor-shape-bottom .elementor-shape-fill{fill:var( --e-global-color-29eb80b );}.elementor-949 .elementor-element.elementor-element-996d1c7 > .elementor-shape-bottom svg{width:calc(214% + 1.3px);height:57px;}.elementor-949 .elementor-element.elementor-element-996d1c7{margin-top:0px;margin-bottom:0px;}.elementor-949 .elementor-element.elementor-element-ad96cf7:not(.elementor-motion-effects-element-type-background), .elementor-949 .elementor-element.elementor-element-ad96cf7 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:#6B39B1;}.elementor-949 .elementor-element.elementor-element-ad96cf7{transition:background 0.3s, border 0.3s, border-radius 0.3s, box-shadow 0.3s;}.elementor-949 .elementor-element.elementor-element-ad96cf7 > .elementor-background-overlay{transition:background 0.3s, border-radius 0.3s, opacity 0.3s;}.elementor-949 .elementor-element.elementor-element-11add52:not(.elementor-motion-effects-element-type-background), .elementor-949 .elementor-element.elementor-element-11add52 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:#000000;}.elementor-949 .elementor-element.elementor-element-11add52{transition:background 0.3s, border 0.3s, border-radius 0.3s, box-shadow 0.3s;}.elementor-949 .elementor-element.elementor-element-11add52 > .elementor-background-overlay{transition:background 0.3s, border-radius 0.3s, opacity 0.3s;}.elementor-949 .elementor-element.elementor-element-4bd9be0{margin-top:0px;margin-bottom:0px;}.elementor-949 .elementor-element.elementor-element-dd5c50d:not(.elementor-motion-effects-element-type-background), .elementor-949 .elementor-element.elementor-element-dd5c50d > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:#6B39B1;}.elementor-949 .elementor-element.elementor-element-dd5c50d{transition:background 0.3s, border 0.3s, border-radius 0.3s, box-shadow 0.3s;margin-top:0px;margin-bottom:0px;}.elementor-949 .elementor-element.elementor-element-dd5c50d > .elementor-background-overlay{transition:background 0.3s, border-radius 0.3s, opacity 0.3s;}.elementor-949 .elementor-element.elementor-element-dd493cf:not(.elementor-motion-effects-element-type-background), .elementor-949 .elementor-element.elementor-element-dd493cf > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:var( --e-global-color-5476237 );}.elementor-949 .elementor-element.elementor-element-dd493cf{transition:background 0.3s, border 0.3s, border-radius 0.3s, box-shadow 0.3s;}.elementor-949 .elementor-element.elementor-element-dd493cf > .elementor-background-overlay{transition:background 0.3s, border-radius 0.3s, opacity 0.3s;}/* Start custom CSS for html, class: .elementor-element-c0bfce0 *//* =======================================================
   HERO SINGLE COLUMN + VSL PREMIUM (FUNDO TRANSPARENTE)
======================================================= */

/* Remove qualquer fundo */
.po-hero.po-hero-single {
  padding: 0.1rem 0 1rem;
}

/* Container sem fundo */
.po-hero.po-hero-single .po-container {
  max-width: 1040px;
  margin: 0 auto;
  background: transparent !important;
}

/* Conteúdo central */
.po-hero-content {
  max-width: 760px;
  margin: 0 auto 2.2rem auto;
  text-align: center;
  background: transparent !important;
}

/* Badge */
.po-badge {
  display: inline-block;
  background: rgba(241, 233, 255, 0.6); /* leve translucidez para ficar bonito no seu fundo */
  color: #5b2bbf;
  padding: 0.35rem 0.9rem;
  border-radius: 999px;
  font-size: 0.78rem;
  font-weight: 600;
  margin-bottom: 1rem;
  backdrop-filter: blur(4px);
}

/* Título */
.po-hero-title {
  font-size: 2.5rem;
  font-weight: 800;
  line-height: 1.22;
  color: #2e1065;
  margin-bottom: 1rem;
  background: transparent !important;
}

/* Subtítulo */
.po-hero-subtitle {
  font-size: 1.05rem;
  color: #4b5563;
  line-height: 1.7;
  margin-bottom: 1.3rem;
  background: transparent !important;
}

/* Lista */
.po-hero-benefits {
  list-style: none;
  padding: 0;
  margin: 0 0 1.6rem 0;
  background: transparent !important;
}

.po-hero-benefits li {
  font-size: 0.97rem;
  line-height: 1.6;
  margin-bottom: 0.45rem;
  color: #374151;
}

/* CTAs */
.po-hero-ctas {
  display: flex;
  gap: 1rem;
  justify-content: center;
  margin-bottom: 1.3rem;
  flex-wrap: wrap;
}

/* Botão primário */
.po-btn-primary {
  background: #16a34a;
  color: #ffffff !important;
  padding: 0.9rem 1.6rem;
  border-radius: 10px;
  font-size: 0.95rem;
  font-weight: 600;
  border: none;
  cursor: pointer;
  transition: 0.2s ease;
}

/* Botão ghost */
.po-btn-ghost {
  border: 1px solid #a78bfa;
  color: #6d28d9 !important;
  background: rgba(250, 245, 255, 0.7);
  backdrop-filter: blur(4px);
  padding: 0.9rem 1.6rem;
  border-radius: 10px;
  font-size: 0.95rem;
  font-weight: 600;
  cursor: pointer;
}

/* Nota */
.po-hero-note {
  color: #4b5563;
  font-size: 0.95rem;
  line-height: 1.6;
  background: transparent !important;
}

/* =======================================================
   PLAYER ESTILO VTURB (sem fundo ao redor)
======================================================= */

.po-hero-video-wrapper {
  max-width: 760px;
  margin: 0 auto;
  background: transparent !important;
}

.po-video-frame {
  position: relative;
  border-radius: 24px;
  overflow: hidden;
  aspect-ratio: 16 / 9;
  background: #000; /* vídeo precisa de fundo */
  box-shadow: 0 26px 60px rgba(0,0,0,0.45);
}

/* Vídeo */
.po-video {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* Overlay central */
.po-sound-overlay {
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at center, rgba(0,0,0,0.55), rgba(0,0,0,0.85));
  display: flex;
  justify-content: center;
  align-items: center;
  cursor: pointer;
  backdrop-filter: blur(4px);
  z-index: 10;
}

.po-sound-overlay-inner {
  text-align: center;
  color: #fff;
  animation: fadeIn 0.6s ease;
}

.po-sound-icon-big { font-size: 3.2rem; margin-bottom: 0.4rem; }
.po-sound-text { font-size: 1.2rem; font-weight: 600; opacity: 0.92; }

@keyframes fadeIn {
  from { opacity: 0; transform: scale(0.94); }
  to   { opacity: 1; transform: scale(1); }
}

/* Botão som */
.po-sound-toggle {
  position: absolute;
  bottom: 14px;
  left: 14px;
  background: rgba(0,0,0,0.55);
  border: 2px solid rgba(255,255,255,0.7);
  color: #fff;
  font-size: 1.2rem;
  border-radius: 999px;
  padding: 10px 14px;
  cursor: pointer;
  backdrop-filter: blur(4px);
  z-index: 20;
  transition: 0.2s ease;
}

/* Fullscreen */
.po-fullscreen-btn {
  position: absolute;
  bottom: 14px;
  right: 14px;
  background: rgba(0,0,0,0.55);
  border: 2px solid rgba(255,255,255,0.7);
  color: #fff;
  font-size: 1.15rem;
  border-radius: 10px;
  padding: 8px 12px;
  cursor: pointer;
  backdrop-filter: blur(4px);
  z-index: 20;
  transition: 0.2s ease;
}

:fullscreen .po-video,
:-webkit-full-screen .po-video {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* =======================================================
   MOBILE (transparent + layout mais limpo)
======================================================= */

@media (max-width: 768px) {

  .po-hero.po-hero-single {
    padding-top: 1.2rem;
    padding-bottom: 2rem;
    background: transparent !important;
  }

  .po-hero.po-hero-single .po-container {
    max-width: 100%;
    padding-left: 1rem;
    padding-right: 1rem;
  }

  /* mobile fica melhor alinhado à esquerda */
  .po-hero-content {
    margin-bottom: 1.4rem;
    text-align: left;
  }

  .po-badge {
    font-size: 0.68rem;
    padding: 0.25rem 0.7rem;
    margin-bottom: 0.55rem;
  }

  .po-hero-title {
    font-size: 1.65rem;
    line-height: 1.28;
    margin-bottom: 0.65rem;
  }

  .po-hero-subtitle {
    font-size: 0.92rem;
    line-height: 1.55;
    margin-bottom: 0.8rem;
  }

  .po-hero-benefits li {
    font-size: 0.88rem;
    margin-bottom: 0.3rem;
  }

  .po-hero-ctas {
    justify-content: flex-start;
    gap: 0.55rem;
    margin-bottom: 0.9rem;
  }

  .po-video-frame {
    border-radius: 16px;
    box-shadow: 0 14px 34px rgba(0,0,0,0.35);
  }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-ef75154 *//* ========================================
   SEÇÃO BENEFÍCIOS — PURPLE PREMIUM
======================================== */

.po-benefits.po-benefits-purple {
  background-color: #6B39B1 !important;
  padding: 3rem 0;
  color: #ffffff;
}

.po-benefits.po-benefits-purple .po-container {
  background: transparent !important;
}

/* Títulos totalmente brancos */
.po-benefits.po-benefits-purple .po-overline,
.po-benefits.po-benefits-purple .po-section-title,
.po-benefits.po-benefits-purple h1,
.po-benefits.po-benefits-purple h2,
.po-benefits.po-benefits-purple h3 {
  color: #ffffff !important;
}

/* Parágrafos — branco suave */
.po-benefits.po-benefits-purple p {
  color: rgba(255,255,255,0.90) !important;
}

/* GRID DOS BENEFÍCIOS */
.po-benefits.po-benefits-purple .po-benefits-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 1.8rem;
  margin-top: 1.6rem;
}

/* CARDS */
.po-benefits.po-benefits-purple .po-benefit-card {
  padding: 1.4rem 1.5rem;
  border-radius: 16px;
  background: rgba(17, 24, 39, 0.22); /* leve transparência */
  border: 1px solid rgba(255,255,255,0.16);
  box-shadow: 0 14px 32px rgba(0,0,0,0.20);
  opacity: 0; /* para animação */
  transform: translateY(16px);
  animation: poFadeUp 0.7s ease forwards;
}

/* ANIMAÇÃO — Fade Up */
@keyframes poFadeUp {
  from {
    opacity: 0;
    transform: translateY(16px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* DELAYS SUAVES (efeito “onda”) */
.po-benefits.po-benefits-purple .po-benefit-card:nth-child(1) { animation-delay: 0.05s; }
.po-benefits.po-benefits-purple .po-benefit-card:nth-child(2) { animation-delay: 0.12s; }
.po-benefits.po-benefits-purple .po-benefit-card:nth-child(3) { animation-delay: 0.19s; }
.po-benefits.po-benefits-purple .po-benefit-card:nth-child(4) { animation-delay: 0.26s; }
.po-benefits.po-benefits-purple .po-benefit-card:nth-child(5) { animation-delay: 0.33s; }
.po-benefits.po-benefits-purple .po-benefit-card:nth-child(6) { animation-delay: 0.40s; }

/* HEADER DO CARD (Ícone + Título) */
.po-benefits.po-benefits-purple .po-feature-header {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  margin-bottom: 0.45rem;
}

.po-benefits.po-benefits-purple .po-feature-header h3 {
  margin: 0;
  font-size: 1.05rem;
  font-weight: 600;
}

/* ÍCONE REDONDO ESTILIZADO */
.po-benefits.po-benefits-purple .po-icon-circle-light {
  width: 36px;
  height: 36px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 1.2rem;
  background: radial-gradient(circle at 30% 30%, #fef9c3, #fb923c);
  color: #111827;
  flex-shrink: 0;
}

/* TEXTO DOS CARDS */
.po-benefits.po-benefits-purple .po-benefit-card p {
  margin-top: 0.4rem;
  font-size: 0.95rem;
  line-height: 1.65;
}

/* RESPONSIVIDADE */
@media (max-width: 992px) {
  .po-benefits.po-benefits-purple .po-benefits-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 768px) {
  .po-benefits.po-benefits-purple .po-benefits-grid {
    grid-template-columns: 1fr;
  }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-f4b07bf *//* ============================================
   DOR x SOLUÇÃO — FUNDO PRETO + TEXTO BRANCO
============================================ */

.po-pain-solution.po-pain-dark {
  background: #000000 !important; /* preto total */
  padding: 1rem 0;
  color: #ffffff !important;
  position: relative;
  overflow: hidden;
}

/* brilho suave no fundo */
.po-pain-solution.po-pain-dark::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at top left, rgba(255,255,255,0.08), transparent 60%),
    radial-gradient(circle at bottom right, rgba(144,85,253,0.20), transparent 70%);
  z-index: 0;
  opacity: .7;
}

.po-pain-solution.po-pain-dark .po-container {
  position: relative;
  z-index: 2;
}

/* TUDO BRANCO — títulos, textos, listas, qualquer tag */
.po-pain-solution.po-pain-dark *,
.po-pain-solution.po-pain-dark h1,
.po-pain-solution.po-pain-dark h2,
.po-pain-solution.po-pain-dark h3,
.po-pain-solution.po-pain-dark h4,
.po-pain-solution.po-pain-dark h5,
.po-pain-solution.po-pain-dark h6,
.po-pain-solution.po-pain-dark p,
.po-pain-solution.po-pain-dark li,
.po-pain-solution.po-pain-dark a,
.po-pain-solution.po-pain-dark span {
  color: #ffffff !important;
}

/* listas */
.po-pain-list,
.po-solution-list {
  list-style: none;
  padding: 0;
  margin-top: 1rem;
}

.po-pain-list li,
.po-solution-list li {
  display: flex;
  align-items: flex-start;
  gap: 0.6rem;
  font-size: 1rem;
  line-height: 1.6;
  margin-bottom: 0.7rem;
}

/* ícones redondos */
.po-icon-circle-red,
.po-icon-circle-green {
  width: 34px;
  height: 34px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 1.1rem;
}

/* ❌ vermelho */
.po-icon-circle-red {
  background: rgba(255,255,255,0.15);
  border: 1px solid rgba(255,255,255,0.35);
  color: #ffffff !important;
}

/* ✅ verde */
.po-icon-circle-green {
  background: rgba(255,255,255,0.20);
  border: 1px solid rgba(255,255,255,0.35);
  color: #ffffff !important;
}

/* animação */
@keyframes poFadeUp {
  from { opacity: 0; transform: translateY(18px); }
  to   { opacity: 1; transform: translateY(0); }
}

.po-pain-solution.po-pain-dark .po-col {
  opacity: 0;
  animation: poFadeUp .9s ease forwards;
}

.po-pain-solution.po-pain-dark .po-col:nth-child(1) { animation-delay: .1s; }
.po-pain-solution.po-pain-dark .po-col:nth-child(2) { animation-delay: .3s; }

/* responsivo */
@media (max-width: 992px) {
  .po-grid-2 {
    display: flex;
    flex-direction: column;
    gap: 2rem;
  }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-7a99f33 *//* =========================================
   SEÇÃO PROVA SOCIAL — SOFT / PREMIUM
========================================= */

.po-social-proof.po-social-soft {
  background: #f9fafb;
  padding: 0.5rem 0;
}

.po-social-proof .po-section-title {
  text-align: center;
}

.po-social-proof .po-section-subtitle {
  text-align: center;
}

/* ===== STATS (números) ===== */
.po-social-stats {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 1.8rem;
  margin: 2rem 0 2.5rem 0;
}

.po-stat {
  min-width: 160px;
  text-align: center;
}

.po-stat-label {
  display: block;
  font-size: 0.8rem;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: #6b7280;
}

.po-stat-number {
  display: block;
  font-size: 1.6rem;
  font-weight: 800;
  color: #111827;
  line-height: 1.1;
}

.po-stat-text {
  display: block;
  font-size: 0.9rem;
  color: #4b5563;
}

/* ===== Testemunhos ===== */
.po-testimonials-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 1.5rem;
}

.po-testimonial-card {
  position: relative;
  background: #ffffff;
  border-radius: 18px;
  padding: 1.6rem 1.5rem 1.4rem;
  border: 1px solid #e5e7eb;
  box-shadow: 0 16px 40px rgba(15,23,42,0.08);
  overflow: hidden;
  opacity: 0;
  transform: translateY(18px);
  animation: poSocialFadeUp .7s ease forwards;
}

/* delay nos cards para entrar em “onda” */
.po-testimonial-card:nth-child(1) { animation-delay: 0.08s; }
.po-testimonial-card:nth-child(2) { animation-delay: 0.18s; }
.po-testimonial-card:nth-child(3) { animation-delay: 0.28s; }

/* Cabeçalho com avatar */
.po-testimonial-header {
  display: flex;
  align-items: center;
  gap: 0.7rem;
  margin-bottom: 0.9rem;
}

.po-avatar {
  width: 38px;
  height: 38px;
  border-radius: 999px;
  background: linear-gradient(135deg, #9055fd, #f97316);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 0.9rem;
  font-weight: 700;
  color: #ffffff;
}

.po-testimonial-author {
  margin: 0;
  font-size: 0.95rem;
  font-weight: 600;
  color: #111827;
}

.po-testimonial-role {
  margin: 0;
  font-size: 0.8rem;
  color: #6b7280;
}

/* Aspas decorativas */
.po-quote-icon {
  position: absolute;
  top: 10px;
  right: 14px;
  font-size: 3rem;
  line-height: 1;
  color: rgba(148,163,184,0.32);
  font-family: Georgia, "Times New Roman", serif;
  pointer-events: none;
}

/* Texto */
.po-testimonial-text {
  font-size: 0.95rem;
  line-height: 1.7;
  color: #374151;
  margin-bottom: 1rem;
}

/* Rating */
.po-rating {
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-size: 0.85rem;
  color: #f59e0b;
}

.po-rating span:first-child {
  letter-spacing: 0.1em;
}

.po-rating-label {
  color: #6b7280;
}

/* animação */
@keyframes poSocialFadeUp {
  from {
    opacity: 0;
    transform: translateY(18px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* responsivo */
@media (max-width: 992px) {
  .po-testimonials-grid {
    grid-template-columns: repeat(2, minmax(0,1fr));
  }
}

@media (max-width: 768px) {
  .po-social-proof.po-social-soft {
    padding: 3rem 0;
  }

  .po-testimonials-grid {
    grid-template-columns: 1fr;
  }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-2a29b83 *//* =========================================
   SEÇÃO DE PLANOS — FUNDO ROXO PREMIUM
========================================= */

.po-pricing.po-pricing-purple {
  background-color: #6B39B1;
  padding: 1rem 0;
  color: #ffffff;
  position: relative;
  overflow: hidden;
}

/* brilho suave por trás pra ficar mais “caro” */
.po-pricing.po-pricing-purple::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at top left, rgba(255,255,255,0.12), transparent 60%),
    radial-gradient(circle at bottom right, rgba(251,191,36,0.22), transparent 65%);
  opacity: 0.7;
  pointer-events: none;
  z-index: 0;
}

.po-pricing.po-pricing-purple .po-container {
  position: relative;
  z-index: 2;
}

/* Títulos e textos brancos */
.po-pricing.po-pricing-purple .po-overline,
.po-pricing.po-pricing-purple .po-section-title,
.po-pricing.po-pricing-purple .po-section-subtitle {
  color: #ffffff !important;
}

/* GRID */
.po-pricing.po-pricing-purple .po-pricing-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 1.8rem;
  align-items: stretch;
  margin-top: 1.8rem;
}

/* CARDS BASE */
.po-pricing.po-pricing-purple .po-pricing-card {
  border-radius: 18px;
  padding: 2rem 1.8rem;
  border: 1px solid rgba(255,255,255,0.22);
  background: rgba(15,23,42,0.26);
  box-shadow: 0 18px 40px rgba(15,23,42,0.35);
  text-align: left;
  position: relative;
  overflow: hidden;
  opacity: 0;
  transform: translateY(18px);
  animation: poPricingFadeUp 0.8s ease forwards;
}

/* animação em “onda” */
.po-pricing.po-pricing-purple .po-pricing-card:nth-child(1) {
  animation-delay: 0.12s;
}
.po-pricing.po-pricing-purple .po-pricing-card:nth-child(2) {
  animation-delay: 0.25s;
}

@keyframes poPricingFadeUp {
  from {
    opacity: 0;
    transform: translateY(18px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* textos dentro dos cards em branco suave */
.po-pricing.po-pricing-purple .po-pricing-name,
.po-pricing.po-pricing-purple .po-pricing-desc,
.po-pricing.po-pricing-purple .po-pricing-note,
.po-pricing.po-pricing-purple .po-pricing-saving,
.po-pricing.po-pricing-purple .po-pricing-perday,
.po-pricing.po-pricing-purple .po-pricing-features li {
  color: rgba(255,255,255,0.92);
}

.po-pricing.po-pricing-purple .po-pricing-name {
  font-size: 1.1rem;
  font-weight: 700;
  margin-bottom: 0.3rem;
}

.po-pricing.po-pricing-purple .po-pricing-desc {
  font-size: 0.9rem;
  margin-bottom: 1rem;
}

/* preçário */
.po-pricing.po-pricing-purple .po-pricing-price {
  display: flex;
  align-items: baseline;
  gap: 0.25rem;
  margin-bottom: 0.4rem;
}

.po-pricing.po-pricing-purple .po-pricing-currency {
  font-size: 1rem;
  font-weight: 600;
}

.po-pricing.po-pricing-purple .po-pricing-value {
  font-size: 2.3rem;
  font-weight: 800;
}

.po-pricing.po-pricing-purple .po-pricing-period {
  font-size: 0.9rem;
  opacity: 0.9;
}

/* lista de features */
.po-pricing.po-pricing-purple .po-pricing-features {
  list-style: none;
  padding: 0;
  margin: 1.1rem 0 1.5rem 0;
  font-size: 0.9rem;
}

.po-pricing.po-pricing-purple .po-pricing-features li {
  display: flex;
  gap: 0.45rem;
  margin-bottom: 0.45rem;
}

.po-pricing.po-pricing-purple .po-pricing-features li::before {
  content: "—";
  font-weight: 700;
  color: #facc15;
}

/* TEXTO SEGURO */
.po-pricing.po-pricing-purple .po-safe-text {
  margin-top: 2rem;
  font-size: 0.9rem;
  color: rgba(255,255,255,0.85);
  text-align: center;
}

/* ===============================
   DIFERENÇA VISUAL ENTRE OS PLANOS
================================ */

/* Plano Mensal — mais simples, mais “fraco” visualmente */
.po-pricing.po-pricing-purple .po-pricing-monthly {
  background: rgba(15,23,42,0.26);
}

/* Plano Anual — destaque forte */
.po-pricing.po-pricing-purple .po-pricing-featured {
  background: #f9fafb;
  border-color: #facc15;
  box-shadow: 0 24px 60px rgba(15,23,42,0.6);
  transform: translateY(-6px);
}

/* tudo dentro do plano anual volta a ser dark (pra ler bem) */
.po-pricing.po-pricing-purple .po-pricing-featured,
.po-pricing.po-pricing-purple .po-pricing-featured * {
  color: #0f172a !important;
}

/* mas o botão principal continua branco no texto */
.po-pricing.po-pricing-purple .po-pricing-featured .po-btn-primary {
  color: #ffffff !important;
}

/* fitas “Mais escolhido” */
.po-pricing.po-pricing-purple .po-pricing-ribbon {
  position: absolute;
  top: 30px;
  right: -50px;
  background: #facc15;
  color: #0f172a;
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  padding: 0.3rem 2.6rem;
  transform: rotate(36deg);
}

/* legenda do custo-benefício */
.po-pricing.po-pricing-purple .po-pricing-tagline {
  font-size: 0.85rem;
  font-weight: 600;
  color: #16a34a !important;
  margin-bottom: 0.4rem;
}

/* ===============================
   RESPONSIVO
================================ */

@media (max-width: 992px) {
  .po-pricing.po-pricing-purple .po-pricing-grid {
    grid-template-columns: 1fr;
  }

  .po-pricing.po-pricing-purple .po-pricing-featured {
    transform: none;
  }
}

@media (max-width: 768px) {
  .po-pricing.po-pricing-purple {
    padding: 3rem 0;
  }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-a2764b5 *//* =========================================
   FAQ – ACORDEON PREMIUM
========================================= */

.po-faq.po-faq-accordion {
  background: #f3f4f6; /* cinza soft, pode mudar se quiser */
  padding: 3.5rem 0;
}

.po-faq.po-faq-accordion .po-section-title,
.po-faq.po-faq-accordion .po-overline,
.po-faq.po-faq-accordion .po-section-subtitle {
  text-align: center;
}

.po-faq-list {
  max-width: 820px;
  margin: 2rem auto 0 auto;
}

/* item base */
.po-faq-item {
  border-radius: 14px;
  border: 1px solid #e5e7eb;
  background: #ffffff;
  margin-bottom: 0.8rem;
  overflow: hidden;
  box-shadow: 0 10px 28px rgba(15,23,42,0.06);
}

/* cabeçalho (summary) */
.po-faq-item > summary {
  list-style: none;
  cursor: pointer;
  padding: 1rem 1.2rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  font-size: 0.98rem;
  font-weight: 500;
  color: #111827;
}

/* tira seta padrão do <details> */
.po-faq-item > summary::-webkit-details-marker {
  display: none;
}

/* ícone de seta */
.po-faq-icon {
  width: 20px;
  height: 20px;
  border-radius: 999px;
  border: 1px solid #d1d5db;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  position: relative;
}

.po-faq-icon::before {
  content: "";
  width: 8px;
  height: 8px;
  border-right: 2px solid #6b7280;
  border-bottom: 2px solid #6b7280;
  transform: rotate(45deg);
  transition: transform 0.2s ease;
}

/* corpo */
.po-faq-body {
  padding: 0 1.2rem 1rem 1.2rem;
  border-top: 1px solid #e5e7eb;
}

.po-faq-body p {
  margin: 0.7rem 0 0 0;
  font-size: 0.92rem;
  color: #4b5563;
  line-height: 1.7;
}

/* estados de aberto/fechado */
.po-faq-item[open] {
  border-color: #9055fd;
  box-shadow: 0 18px 40px rgba(144,85,253,0.18);
}

.po-faq-item[open] > summary {
  color: #4c1d95;
}

.po-faq-item[open] .po-faq-icon {
  border-color: #c4b5fd;
  background: #ede9fe;
}

.po-faq-item[open] .po-faq-icon::before {
  transform: rotate(-135deg); /* seta pra cima */
}

/* animação suave na abertura */
.po-faq-item[open] .po-faq-body {
  animation: poFaqFade .18s ease-out;
}

@keyframes poFaqFade {
  from {
    opacity: 0;
    transform: translateY(-4px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* responsivo */
@media (max-width: 768px) {
  .po-faq.po-faq-accordion {
    padding: 3rem 0;
  }

  .po-faq-item > summary {
    font-size: 0.95rem;
  }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-1eca13e *//* ====================================
   CTA FINAL — FUNDO PRETO PREMIUM
==================================== */

.po-final-cta.po-final-dark {
  background: #000000;
  padding: 4rem 0 4.5rem;
  position: relative;
  color: #ffffff !important;
  overflow: hidden;
}

/* brilho elegante */
.po-final-cta.po-final-dark::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at top left, rgba(255,255,255,0.07), transparent 65%),
    radial-gradient(circle at bottom right, rgba(144,85,253,0.22), transparent 65%);
  opacity: 0.75;
  pointer-events: none;
  z-index: 0;
}

.po-final-cta.po-final-dark .po-container {
  position: relative;
  z-index: 2;
  text-align: center;
}

/* Títulos totalmente brancos */
.po-final-cta.po-final-dark h1,
.po-final-cta.po-final-dark h2,
.po-final-cta.po-final-dark h3,
.po-final-cta.po-final-dark .po-section-title {
  color: #ffffff !important;
  font-weight: 700;
}

/* Subtítulo claro */
.po-final-cta.po-final-dark .po-section-subtitle,
.po-final-cta.po-final-dark p {
  color: rgba(255,255,255,0.9) !important;
  font-size: 1.05rem;
  line-height: 1.65;
}

/* botões */
.po-final-actions {
  display: flex;
  justify-content: center;
  gap: 1.1rem;
  margin: 2rem 0 2.2rem;
  flex-wrap: wrap;
}

/* Ghost button */
.po-final-cta.po-final-dark .po-btn-ghost {
  border: 1px solid rgba(255,255,255,0.45);
  color: #ffffff !important;
}

.po-final-cta.po-final-dark .po-btn-ghost:hover {
  background: rgba(255,255,255,0.12);
}

/* nota final */
.po-final-cta.po-final-dark .po-hero-note {
  color: rgba(255,255,255,0.85) !important;
  font-size: 0.95rem;
  line-height: 1.6;
}

/* animação */
@keyframes poFinalFadeUp {
  from {
    opacity: 0;
    transform: translateY(22px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.po-final-cta.po-final-dark .po-section-title,
.po-final-cta.po-final-dark .po-section-subtitle,
.po-final-cta.po-final-dark .po-final-actions,
.po-final-cta.po-final-dark .po-hero-note {
  opacity: 0;
  animation: poFinalFadeUp .9s ease forwards;
}

.po-final-cta.po-final-dark .po-section-title { animation-delay: .1s; }
.po-final-cta.po-final-dark .po-section-subtitle { animation-delay: .25s; }
.po-final-cta.po-final-dark .po-final-actions { animation-delay: .4s; }
.po-final-cta.po-final-dark .po-hero-note { animation-delay: .6s; }

/* responsivo */
@media (max-width: 768px) {
  .po-final-actions {
    flex-direction: column;
    gap: 0.9rem;
  }

  .po-final-cta.po-final-dark {
    padding: 3rem 0 3.5rem;
  }
}/* End custom CSS */
/* Start custom CSS *//* ================================
   PALETA & BASE
=================================== */
:root {
  --po-primary: #9055fd;      /* roxo PapelariaON */
  --po-primary-dark: #7a46d4;
  --po-accent: #16a34a;       /* verde CTA */
  --po-accent-dark: #15803d;
  --po-ink: #111827;
  --po-muted: #6b7280;
  --po-border: #e5e7eb;
  --po-surface: #ffffff;
  --po-surface-soft: #f9fafb;
  --po-radius-lg: 22px;
  --po-radius-md: 14px;
  --po-radius-sm: 10px;
  --po-shadow-soft: 0 18px 45px rgba(15, 23, 42, 0.08);
  --po-shadow-card: 0 10px 30px rgba(15, 23, 42, 0.06);
}

/* Container padrão */
.po-container {
  max-width: 1120px;
  margin: 0 auto;
  padding: 3rem 1.5rem;
}

/* Tipografia base das seções .po- */
.po-hero,
.po-social-proof,
.po-benefits,
.po-product-tour,
.po-pain-solution,
.po-pricing,
.po-whats-included,
.po-faq,
.po-final-cta {
  font-family: "Poppins", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI",
    sans-serif;
  color: var(--po-ink);
}

/* Títulos e textos padrão */
.po-section-title {
  font-size: clamp(1.8rem, 3vw, 2.4rem);
  line-height: 1.15;
  font-weight: 700;
  margin-bottom: 1rem;
}

.po-section-subtitle {
  font-size: 1rem;
  line-height: 1.7;
  color: var(--po-muted);
  max-width: 640px;
  margin: 0 auto 2.5rem auto;
}

.po-overline {
  font-size: 0.75rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--po-primary);
  font-weight: 600;
  margin-bottom: 0.75rem;
}

/* Botões padrão */
.po-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.9rem 1.6rem;
  border-radius: 999px;
  font-size: 0.95rem;
  font-weight: 600;
  border: 1px solid transparent;
  cursor: pointer;
  text-decoration: none;
  transition: all 0.18s ease-out;
  white-space: nowrap;
  gap: 0.4rem;
}

.po-btn-primary {
  background: var(--po-accent);
  border-color: var(--po-accent);
  color: #ffffff;
  box-shadow: 0 12px 25px rgba(22, 163, 74, 0.35);
}

.po-btn-primary:hover {
  background: var(--po-accent-dark);
  border-color: var(--po-accent-dark);
  transform: translateY(-1px);
  box-shadow: 0 18px 40px rgba(22, 163, 74, 0.45);
}

.po-btn-ghost {
  background: transparent;
  color: var(--po-primary);
  border-color: rgba(144, 85, 253, 0.35);
}

.po-btn-ghost:hover {
  background: rgba(144, 85, 253, 0.06);
  border-color: var(--po-primary);
}

.po-btn-outline {
  background: transparent;
  color: var(--po-primary);
  border-color: var(--po-primary);
}

.po-btn-outline:hover {
  background: var(--po-primary);
  color: #ffffff;
}

/* Botão pulsando para o plano anual */
@keyframes poPulse {
  0% {
    transform: scale(1);
    box-shadow: 0 0 0 0 rgba(22, 163, 74, 0.5);
  }
  60% {
    transform: scale(1.03);
    box-shadow: 0 0 0 14px rgba(22, 163, 74, 0);
  }
  100% {
    transform: scale(1);
    box-shadow: 0 0 0 0 rgba(22, 163, 74, 0);
  }
}

.po-btn-pulse {
  animation: poPulse 1.8s infinite ease-out;
}

/* Centros */
.po-center {
  text-align: center;
}

/* Margem topo extra */
.po-mt {
  margin-top: 1.5rem;
}

/* =====================================
   HERO
===================================== */
.po-hero {
  background: linear-gradient(
      to bottom,
      rgba(144, 85, 253, 0.03),
      rgba(144, 85, 253, 0)
    ),
    #ffffff;
}

.po-hero-content {
  max-width: 720px;
  margin: 0 auto;
  text-align: center;
}

.po-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.25rem 0.9rem;
  border-radius: 999px;
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.11em;
  background: rgba(144, 85, 253, 0.07);
  color: var(--po-primary-dark);
  margin-bottom: 1rem;
}

.po-hero-title {
  font-size: clamp(2rem, 3.6vw, 2.9rem);
  line-height: 1.08;
  font-weight: 800;
  margin-bottom: 1rem;
}

.po-hero-subtitle {
  font-size: 1rem;
  line-height: 1.7;
  color: var(--po-muted);
  margin-bottom: 1.5rem;
}

.po-hero-benefits {
  list-style: none;
  padding: 0;
  margin: 0 0 1.8rem 0;
  font-size: 0.95rem;
  color: var(--po-ink);
}

.po-hero-benefits li {
  margin-bottom: 0.45rem;
}

.po-hero-ctas {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0.9rem;
  margin-bottom: 1rem;
}

.po-hero-note {
  font-size: 0.9rem;
  color: var(--po-muted);
}

/* =====================================
   PROVA SOCIAL
===================================== */
.po-social-proof {
  background: #ffffff;
}

.po-logos {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 1rem;
  margin: 2rem 0 2.5rem 0;
}

.po-logo-item {
  min-width: 110px;
  min-height: 52px;
  border-radius: var(--po-radius-md);
  border: 1px dashed var(--po-border);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.8rem;
  color: var(--po-muted);
  background: #f9fafb;
}

.po-testimonials-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1.5rem;
}

.po-testimonial-card {
  background: #ffffff;
  border-radius: var(--po-radius-md);
  padding: 1.4rem;
  border: 1px solid var(--po-border);
  box-shadow: var(--po-shadow-card);
}

.po-testimonial-text {
  font-size: 0.95rem;
  line-height: 1.7;
  color: var(--po-ink);
  margin-bottom: 0.8rem;
}

.po-testimonial-author {
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--po-primary-dark);
}

/* =====================================
   BENEFÍCIOS
===================================== */
.po-benefits {
  background: var(--po-surface-soft);
}

.po-benefits-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1.5rem;
}

.po-benefit-card {
  background: #ffffff;
  border-radius: var(--po-radius-md);
  padding: 1.4rem 1.5rem;
  border: 1px solid var(--po-border);
  box-shadow: var(--po-shadow-card);
}

.po-benefit-card h3 {
  font-size: 1.05rem;
  font-weight: 600;
  margin-bottom: 0.5rem;
}

.po-benefit-card p {
  font-size: 0.95rem;
  line-height: 1.6;
  color: var(--po-muted);
}

/* =====================================
   TOUR DO PRODUTO
===================================== */
.po-product-tour {
  background: #ffffff;
}

.po-tour-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1.5rem;
}

.po-tour-item {
  background: #ffffff;
  border-radius: var(--po-radius-md);
  border: 1px solid var(--po-border);
  padding: 1.2rem;
  box-shadow: var(--po-shadow-card);
}

.po-tour-item img {
  display: block;
  width: 100%;
  border-radius: var(--po-radius-sm);
  margin-bottom: 0.9rem;
}

.po-tour-item h3 {
  font-size: 1rem;
  font-weight: 600;
  margin-bottom: 0.4rem;
}

.po-tour-item p {
  font-size: 0.9rem;
  line-height: 1.6;
  color: var(--po-muted);
}

/* =====================================
   DOR x SOLUÇÃO
===================================== */
.po-pain-solution {
  background: var(--po-surface-soft);
}

.po-grid-2 {
  display: grid;
  grid-template-columns: 1.15fr 1fr;
  gap: 2.5rem;
  align-items: flex-start;
}

.po-pain-list,
.po-solution-list {
  list-style: none;
  padding: 0;
  margin: 1rem 0 0 0;
}

.po-pain-list li,
.po-solution-list li {
  font-size: 0.95rem;
  color: var(--po-ink);
  margin-bottom: 0.6rem;
}

/* =====================================
   PLANOS / PRICING
===================================== */
.po-pricing {
  background: #ffffff;
  text-align: center;
}

.po-pricing-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1.8rem;
  align-items: stretch;
  margin-top: 1.5rem;
}

.po-pricing-card {
  background: #ffffff;
  border-radius: var(--po-radius-lg);
  padding: 2rem 1.8rem;
  border: 1px solid var(--po-border);
  box-shadow: var(--po-shadow-soft);
  text-align: left;
  position: relative;
  overflow: hidden;
}

.po-pricing-featured {
  border-color: rgba(22, 163, 74, 0.4);
  box-shadow: 0 20px 60px rgba(22, 163, 74, 0.25);
  transform: translateY(-6px);
}

.po-pricing-name {
  font-size: 1.1rem;
  font-weight: 700;
  margin-bottom: 0.3rem;
}

.po-pricing-desc,
.po-pricing-note {
  font-size: 0.9rem;
  color: var(--po-muted);
  margin-bottom: 1rem;
}

.po-pricing-tagline {
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--po-accent-dark);
  margin-bottom: 0.4rem;
}

.po-pricing-price {
  display: flex;
  align-items: baseline;
  gap: 0.25rem;
  margin-bottom: 0.35rem;
}

.po-pricing-currency {
  font-size: 1rem;
  font-weight: 600;
}

.po-pricing-value {
  font-size: 2.2rem;
  font-weight: 800;
}

.po-pricing-period {
  font-size: 0.9rem;
  color: var(--po-muted);
}

.po-pricing-saving,
.po-pricing-perday {
  font-size: 0.9rem;
  color: var(--po-accent-dark);
  margin-bottom: 0.35rem;
}

.po-pricing-features {
  list-style: none;
  padding: 0;
  margin: 1.2rem 0 1.5rem 0;
  font-size: 0.9rem;
  color: var(--po-ink);
}

.po-pricing-features li {
  display: flex;
  gap: 0.4rem;
  margin-bottom: 0.5rem;
}

.po-pricing-features li::before {
  content: "•";
  color: var(--po-primary);
  font-weight: 700;
}

.po-pricing-ribbon {
  position: absolute;
  top: 14px;
  right: -50px;
  background: var(--po-primary);
  color: #ffffff;
  font-size: 0.7rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  padding: 0.35rem 2.5rem;
  transform: rotate(38deg);
}

.po-safe-text {
  margin-top: 1.5rem;
  font-size: 0.9rem;
  color: var(--po-muted);
}

/* =====================================
   TUDO O QUE RECEBE
===================================== */
.po-whats-included {
  background: var(--po-surface-soft);
}

.po-included-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 2rem;
  margin-top: 1rem;
}

.po-checklist {
  list-style: none;
  padding: 0;
  margin: 0;
}

.po-checklist li {
  font-size: 0.95rem;
  color: var(--po-ink);
  margin-bottom: 0.65rem;
}

/* =====================================
   FAQ
===================================== */
.po-faq {
  background: #ffffff;
}

.po-faq-list {
  max-width: 820px;
  margin: 0 auto;
}

.po-faq-item {
  border-radius: var(--po-radius-md);
  border: 1px solid var(--po-border);
  padding: 1.1rem 1.2rem;
  margin-bottom: 0.9rem;
  background: #ffffff;
}

.po-faq-item h3 {
  font-size: 0.98rem;
  font-weight: 600;
  margin-bottom: 0.3rem;
}

.po-faq-item p {
  font-size: 0.9rem;
  color: var(--po-muted);
  line-height: 1.6;
}

/* =====================================
   CTA FINAL
===================================== */
.po-final-cta {
  background: var(--po-surface-soft);
  text-align: center;
}

.po-final-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 1rem;
  margin: 1.8rem 0 1rem 0;
}

/* =====================================
   RESPONSIVIDADE
===================================== */

@media (max-width: 992px) {
  .po-testimonials-grid,
  .po-benefits-grid,
  .po-tour-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .po-grid-2 {
    grid-template-columns: 1fr;
  }

  .po-pricing-card,
  .po-pricing-featured {
    transform: none;
  }
}

@media (max-width: 768px) {
  .po-container {
    padding: 2.4rem 1.3rem;
  }

  .po-testimonials-grid,
  .po-benefits-grid,
  .po-tour-grid,
  .po-pricing-grid,
  .po-included-grid {
    grid-template-columns: 1fr;
  }

  .po-hero-content {
    text-align: left;
  }

  .po-hero-ctas {
    justify-content: flex-start;
  }

  .po-section-subtitle {
    margin-left: 0;
    margin-right: 0;
  }
}

@media (max-width: 480px) {
  .po-hero-title {
    font-size: 1.9rem;
  }

  .po-btn {
    width: 100%;
    justify-content: center;
  }

  .po-final-actions {
    flex-direction: column;
  }
}

/* ================================
   AJUSTES PARA UM DESIGN MAIS CLEAN
   (colar DEPOIS do CSS anterior)
=================================== */

/* Depoimentos mais flat, sem card pesado */
.po-testimonial-card {
  background: transparent;
  border-radius: 0;
  border: none;
  box-shadow: none;
  padding: 0 0 1.1rem 0;
  border-bottom: 1px solid var(--po-border);
}

/* Benefícios sem caixa, só linha separando */
.po-benefit-card {
  background: transparent;
  border-radius: 0;
  border: none;
  box-shadow: none;
  padding: 0 0 1.1rem 0;
  border-bottom: 1px solid var(--po-border);
}

/* Itens do tour também flat, estilo seção de recursos */
.po-tour-item {
  background: transparent;
  border-radius: 0;
  border: none;
  box-shadow: none;
  padding: 0 0 1.4rem 0;
  border-bottom: 1px solid var(--po-border);
}

.po-tour-item img {
  border-radius: 12px;
  margin-bottom: 0.6rem;
}

/* FAQ mais minimalista */
.po-faq-item {
  background: transparent;
  border-radius: 0;
  box-shadow: none;
  border-left: 3px solid rgba(144, 85, 253, 0.4);
  border-right: none;
  border-top: none;
  border-bottom: 1px solid var(--po-border);
  padding-left: 1rem;
}

/* Seção de dor x solução sem cara de card */
.po-pain-solution .po-col {
  background: transparent;
  padding: 0;
}

/* Ajuste geral de grid pra esse estilo mais leve */
.po-benefits-grid,
.po-tour-grid,
.po-testimonials-grid {
  gap: 1.2rem;
}

/* ================================
   PRICING MAIS CLEAN (só ele com "caixa")
=================================== */

.po-pricing-card {
  border-radius: 18px;
  box-shadow: none;
  border: 1px solid rgba(148, 163, 184, 0.5);
  background: #ffffff;
}

/* Deixa o mensal bem simples e o anual com leve destaque */
.po-pricing-monthly {
  background: #ffffff;
}

.po-pricing-featured {
  background: linear-gradient(
    135deg,
    rgba(144, 85, 253, 0.04),
    rgba(22, 163, 74, 0.07)
  );
  border-color: var(--po-accent);
  box-shadow: none;
}

/* Deixa o selo mais discreto */
.po-pricing-ribbon {
  font-size: 0.68rem;
  padding: 0.3rem 2.3rem;
  opacity: 0.9;
}

/* Deixa os bullets de features mais levinhos */
.po-pricing-features li::before {
  content: "—";
  color: var(--po-primary);
  font-weight: 700;
}

/* ================================
   MOBILE: mantém tudo organizado
=================================== */
@media (max-width: 768px) {
  .po-testimonial-card,
  .po-benefit-card,
  .po-tour-item {
    padding-bottom: 1rem;
  }

  .po-pricing-card {
    border-radius: 16px;
  }
}

/* ================================
   PALETA & BASE
=================================== */
:root {
  --po-primary: #9055fd;      /* roxo PapelariaON */
  --po-primary-dark: #7a46d4;
  --po-accent: #16a34a;       /* verde CTA */
  --po-accent-dark: #15803d;
  --po-ink: #111827;
  --po-muted: #6b7280;
  --po-border: #e5e7eb;
  --po-surface: #ffffff;
  --po-surface-soft: #f9fafb;
  --po-radius-lg: 22px;
  --po-radius-md: 14px;
  --po-radius-sm: 10px;
  --po-shadow-soft: 0 18px 45px rgba(15, 23, 42, 0.08);
  --po-shadow-card: 0 10px 30px rgba(15, 23, 42, 0.06);
}

/* Container padrão */
.po-container {
  max-width: 1120px;
  margin: 0 auto;
  padding: 3rem 1.5rem;
}

/* Tipografia base das seções .po- */
.po-hero,
.po-social-proof,
.po-benefits,
.po-product-tour,
.po-pain-solution,
.po-pricing,
.po-whats-included,
.po-faq,
.po-final-cta {
  font-family: "Poppins", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI",
    sans-serif;
  color: var(--po-ink);
}

/* Títulos e textos padrão */
.po-section-title {
  font-size: clamp(1.8rem, 3vw, 2.4rem);
  line-height: 1.15;
  font-weight: 700;
  margin-bottom: 1rem;
}

.po-section-subtitle {
  font-size: 1rem;
  line-height: 1.7;
  color: var(--po-muted);
  max-width: 640px;
  margin: 0 auto 2.5rem auto;
}

.po-overline {
  font-size: 0.75rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--po-primary);
  font-weight: 600;
  margin-bottom: 0.75rem;
}

/* Botões padrão */
.po-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.9rem 1.6rem;
  border-radius: 999px;
  font-size: 0.95rem;
  font-weight: 600;
  border: 1px solid transparent;
  cursor: pointer;
  text-decoration: none;
  transition: all 0.18s ease-out;
  white-space: nowrap;
  gap: 0.4rem;
}

.po-btn-primary {
  background: var(--po-accent);
  border-color: var(--po-accent);
  color: #ffffff;
  box-shadow: 0 12px 25px rgba(22, 163, 74, 0.35);
}

.po-btn-primary:hover {
  background: var(--po-accent-dark);
  border-color: var(--po-accent-dark);
  transform: translateY(-1px);
  box-shadow: 0 18px 40px rgba(22, 163, 74, 0.45);
}

.po-btn-ghost {
  background: transparent;
  color: var(--po-primary);
  border-color: rgba(144, 85, 253, 0.35);
}

.po-btn-ghost:hover {
  background: rgba(144, 85, 253, 0.06);
  border-color: var(--po-primary);
}

.po-btn-outline {
  background: transparent;
  color: var(--po-primary);
  border-color: var(--po-primary);
}

.po-btn-outline:hover {
  background: var(--po-primary);
  color: #ffffff;
}

/* Botão pulsando para o plano anual */
@keyframes poPulse {
  0% {
    transform: scale(1);
    box-shadow: 0 0 0 0 rgba(22, 163, 74, 0.5);
  }
  60% {
    transform: scale(1.03);
    box-shadow: 0 0 0 14px rgba(22, 163, 74, 0);
  }
  100% {
    transform: scale(1);
    box-shadow: 0 0 0 0 rgba(22, 163, 74, 0);
  }
}

.po-btn-pulse {
  animation: poPulse 1.8s infinite ease-out;
}

/* Centros */
.po-center {
  text-align: center;
}

/* Margem topo extra */
.po-mt {
  margin-top: 1.5rem;
}

/* =====================================
   HERO
===================================== */
.po-hero {
  background: linear-gradient(
      to bottom,
      rgba(144, 85, 253, 0.03),
      rgba(144, 85, 253, 0)
    ),
    #ffffff;
}

.po-hero-content {
  max-width: 720px;
  margin: 0 auto;
  text-align: center;
}

.po-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.25rem 0.9rem;
  border-radius: 999px;
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.11em;
  background: rgba(144, 85, 253, 0.07);
  color: var(--po-primary-dark);
  margin-bottom: 1rem;
}

.po-hero-title {
  font-size: clamp(2rem, 3.6vw, 2.9rem);
  line-height: 1.08;
  font-weight: 800;
  margin-bottom: 1rem;
}

.po-hero-subtitle {
  font-size: 1rem;
  line-height: 1.7;
  color: var(--po-muted);
  margin-bottom: 1.5rem;
}

.po-hero-benefits {
  list-style: none;
  padding: 0;
  margin: 0 0 1.8rem 0;
  font-size: 0.95rem;
  color: var(--po-ink);
}

.po-hero-benefits li {
  margin-bottom: 0.45rem;
}

.po-hero-ctas {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0.9rem;
  margin-bottom: 1rem;
}

.po-hero-note {
  font-size: 0.9rem;
  color: var(--po-muted);
}

/* =====================================
   PROVA SOCIAL
===================================== */
.po-social-proof {
  background: #ffffff;
}

.po-logos {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 1rem;
  margin: 2rem 0 2.5rem 0;
}

.po-logo-item {
  min-width: 110px;
  min-height: 52px;
  border-radius: var(--po-radius-md);
  border: 1px dashed var(--po-border);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.8rem;
  color: var(--po-muted);
  background: #f9fafb;
}

.po-testimonials-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1.5rem;
}

.po-testimonial-card {
  background: #ffffff;
  border-radius: var(--po-radius-md);
  padding: 1.4rem;
  border: 1px solid var(--po-border);
  box-shadow: var(--po-shadow-card);
}

.po-testimonial-text {
  font-size: 0.95rem;
  line-height: 1.7;
  color: var(--po-ink);
  margin-bottom: 0.8rem;
}

.po-testimonial-author {
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--po-primary-dark);
}

/* =====================================
   BENEFÍCIOS
===================================== */
.po-benefits {
  background: var(--po-surface-soft);
}

.po-benefits-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1.5rem;
}

.po-benefit-card {
  background: #ffffff;
  border-radius: var(--po-radius-md);
  padding: 1.4rem 1.5rem;
  border: 1px solid var(--po-border);
  box-shadow: var(--po-shadow-card);
}

.po-benefit-card h3 {
  font-size: 1.05rem;
  font-weight: 600;
  margin-bottom: 0.5rem;
}

.po-benefit-card p {
  font-size: 0.95rem;
  line-height: 1.6;
  color: var(--po-muted);
}

/* =====================================
   TOUR DO PRODUTO
===================================== */
.po-product-tour {
  background: #ffffff;
}

.po-tour-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1.5rem;
}

.po-tour-item {
  background: #ffffff;
  border-radius: var(--po-radius-md);
  border: 1px solid var(--po-border);
  padding: 1.2rem;
  box-shadow: var(--po-shadow-card);
}

.po-tour-item img {
  display: block;
  width: 100%;
  border-radius: var(--po-radius-sm);
  margin-bottom: 0.9rem;
}

.po-tour-item h3 {
  font-size: 1rem;
  font-weight: 600;
  margin-bottom: 0.4rem;
}

.po-tour-item p {
  font-size: 0.9rem;
  line-height: 1.6;
  color: var(--po-muted);
}

/* =====================================
   DOR x SOLUÇÃO
===================================== */
.po-pain-solution {
  background: var(--po-surface-soft);
}

.po-grid-2 {
  display: grid;
  grid-template-columns: 1.15fr 1fr;
  gap: 2.5rem;
  align-items: flex-start;
}

.po-pain-list,
.po-solution-list {
  list-style: none;
  padding: 0;
  margin: 1rem 0 0 0;
}

.po-pain-list li,
.po-solution-list li {
  font-size: 0.95rem;
  color: var(--po-ink);
  margin-bottom: 0.6rem;
}

/* =====================================
   PLANOS / PRICING (base)
===================================== */
.po-pricing {
  background: #ffffff;
  text-align: center;
}

.po-pricing-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1.8rem;
  align-items: stretch;
  margin-top: 1.5rem;
}

.po-pricing-card {
  background: #ffffff;
  border-radius: var(--po-radius-lg);
  padding: 2rem 1.8rem;
  border: 1px solid var(--po-border);
  box-shadow: var(--po-shadow-soft);
  text-align: left;
  position: relative;
  overflow: hidden;
}

.po-pricing-featured {
  border-color: rgba(22, 163, 74, 0.4);
  box-shadow: 0 20px 60px rgba(22, 163, 74, 0.25);
  transform: translateY(-6px);
}

.po-pricing-name {
  font-size: 1.1rem;
  font-weight: 700;
  margin-bottom: 0.3rem;
}

.po-pricing-desc,
.po-pricing-note {
  font-size: 0.9rem;
  color: var(--po-muted);
  margin-bottom: 1rem;
}

.po-pricing-tagline {
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--po-accent-dark);
  margin-bottom: 0.4rem;
}

.po-pricing-price {
  display: flex;
  align-items: baseline;
  gap: 0.25rem;
  margin-bottom: 0.35rem;
}

.po-pricing-currency {
  font-size: 1rem;
  font-weight: 600;
}

.po-pricing-value {
  font-size: 2.2rem;
  font-weight: 800;
}

.po-pricing-period {
  font-size: 0.9rem;
  color: var(--po-muted);
}

.po-pricing-saving,
.po-pricing-perday {
  font-size: 0.9rem;
  color: var(--po-accent-dark);
  margin-bottom: 0.35rem;
}

.po-pricing-features {
  list-style: none;
  padding: 0;
  margin: 1.2rem 0 1.5rem 0;
  font-size: 0.9rem;
  color: var(--po-ink);
}

.po-pricing-features li {
  display: flex;
  gap: 0.4rem;
  margin-bottom: 0.5rem;
}

.po-pricing-features li::before {
  content: "•";
  color: var(--po-primary);
  font-weight: 700;
}

.po-pricing-ribbon {
  position: absolute;
  top: 14px;
  right: -50px;
  background: var(--po-primary);
  color: #ffffff;
  font-size: 0.7rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  padding: 0.35rem 2.5rem;
  transform: rotate(38deg);
}

.po-safe-text {
  margin-top: 1.5rem;
  font-size: 0.9rem;
  color: var(--po-muted);
}

/* =====================================
   TUDO O QUE RECEBE
===================================== */
.po-whats-included {
  background: var(--po-surface-soft);
}

.po-included-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 2rem;
  margin-top: 1rem;
}

.po-checklist {
  list-style: none;
  padding: 0;
  margin: 0;
}

.po-checklist li {
  font-size: 0.95rem;
  color: var(--po-ink);
  margin-bottom: 0.65rem;
}

/* =====================================
   FAQ
===================================== */
.po-faq {
  background: #ffffff;
}

.po-faq-list {
  max-width: 820px;
  margin: 0 auto;
}

.po-faq-item {
  border-radius: var(--po-radius-md);
  border: 1px solid var(--po-border);
  padding: 1.1rem 1.2rem;
  margin-bottom: 0.9rem;
  background: #ffffff;
}

.po-faq-item h3 {
  font-size: 0.98rem;
  font-weight: 600;
  margin-bottom: 0.3rem;
}

.po-faq-item p {
  font-size: 0.9rem;
  color: var(--po-muted);
  line-height: 1.6;
}

/* =====================================
   CTA FINAL
===================================== */
.po-final-cta {
  background: var(--po-surface-soft);
  text-align: center;
}

.po-final-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 1rem;
  margin: 1.8rem 0 1rem 0;
}

/* =====================================
   AJUSTES PARA DESIGN MAIS CLEAN
   (override das caixinhas)
=================================== */

/* Depoimentos mais flat, sem card pesado */
.po-testimonial-card {
  background: transparent;
  border-radius: 0;
  border: none;
  box-shadow: none;
  padding: 0 0 1.1rem 0;
  border-bottom: 1px solid var(--po-border);
}

/* Benefícios sem caixa, só linha separando */
.po-benefit-card {
  background: transparent;
  border-radius: 0;
  border: none;
  box-shadow: none;
  padding: 0 0 1.1rem 0;
  border-bottom: 1px solid var(--po-border);
}

/* Itens do tour também flat, estilo seção de recursos */
.po-tour-item {
  background: transparent;
  border-radius: 0;
  border: none;
  box-shadow: none;
  padding: 0 0 1.4rem 0;
  border-bottom: 1px solid var(--po-border);
}

.po-tour-item img {
  border-radius: 12px;
  margin-bottom: 0.6rem;
}

/* FAQ mais minimalista */
.po-faq-item {
  background: transparent;
  border-radius: 0;
  box-shadow: none;
  border-left: 3px solid rgba(144, 85, 253, 0.4);
  border-right: none;
  border-top: none;
  border-bottom: 1px solid var(--po-border);
  padding-left: 1rem;
}

/* Seção de dor x solução sem cara de card */
.po-pain-solution .po-col {
  background: transparent;
  padding: 0;
}

/* Ajuste geral de grid pra esse estilo mais leve */
.po-benefits-grid,
.po-tour-grid,
.po-testimonials-grid {
  gap: 1.2rem;
}

/* PRICING mais clean (só ele com “caixa”) */
.po-pricing-card {
  border-radius: 18px;
  box-shadow: none;
  border: 1px solid rgba(148, 163, 184, 0.5);
  background: #ffffff;
}

/* Deixa o mensal bem simples e o anual com leve destaque */
.po-pricing-monthly {
  background: #ffffff;
}

.po-pricing-featured {
  background: linear-gradient(
    135deg,
    rgba(144, 85, 253, 0.04),
    rgba(22, 163, 74, 0.07)
  );
  border-color: var(--po-accent);
  box-shadow: none;
}

/* Deixa o selo mais discreto */
.po-pricing-ribbon {
  font-size: 0.68rem;
  padding: 0.3rem 2.3rem;
  opacity: 0.9;
}

/* Bullets de features mais levinhos */
.po-pricing-features li::before {
  content: "—";
  color: var(--po-primary);
  font-weight: 700;
}

/* =====================================
   RESPONSIVIDADE
===================================== */

@media (max-width: 992px) {
  .po-testimonials-grid,
  .po-benefits-grid,
  .po-tour-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .po-grid-2 {
    grid-template-columns: 1fr;
  }

  .po-pricing-card,
  .po-pricing-featured {
    transform: none;
  }
}

@media (max-width: 768px) {
  .po-container {
    padding: 2.4rem 1.3rem;
  }

  .po-testimonials-grid,
  .po-benefits-grid,
  .po-tour-grid,
  .po-pricing-grid,
  .po-included-grid {
    grid-template-columns: 1fr;
  }

  .po-hero-content {
    text-align: left;
  }

  .po-hero-ctas {
    justify-content: flex-start;
  }

  .po-section-subtitle {
    margin-left: 0;
    margin-right: 0;
  }

  .po-pricing-card {
    border-radius: 16px;
  }
}

@media (max-width: 480px) {
  .po-hero-title {
    font-size: 1.9rem;
  }

  .po-btn {
    width: 100%;
    justify-content: center;
  }

  .po-final-actions {
    flex-direction: column;
  }
}
/* =====================================
   ÍCONES ESTILO SAAS PREMIUM
===================================== */

/* Wrapper para títulos com ícone */
.po-with-icon {
  display: flex;
  align-items: center;
  gap: 0.6rem;
}

/* Bolinha com ícone (pode ser emoji ou <i>) */
.po-icon-circle {
  width: 32px;
  height: 32px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 1.1rem;
  background: radial-gradient(circle at 30% 30%, #fef9c3, #d9f99d);
  color: #16a34a;
  flex-shrink: 0;
}

/* Versão roxa (pra hero, headings, etc.) */
.po-icon-circle-purple {
  background: radial-gradient(circle at 30% 30%, #ede9fe, #c4b5fd);
  color: #6d28d9;
}

/* Ícone menor inline (para bullets) */
.po-inline-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  height: 22px;
  border-radius: 999px;
  font-size: 0.85rem;
  background: rgba(16,185,129,0.08);
  color: #16a34a;
  margin-right: 0.35rem;
}

/* Exemplo para grid de benefícios/tour com ícone em cima */
.po-feature-header {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  margin-bottom: 0.45rem;
}

.po-feature-header h3 {
  margin-bottom: 0;
}

/* Se quiser um pequeno gradiente de topo em cards importantes */
.po-highlight-top {
  border-top: 3px solid rgba(144,85,253,0.6);
}

/* =====================================
   ANIMAÇÕES SUAVES (FADE + SLIDE)
===================================== */

/* Estado inicial (escondido) */
.po-reveal {
  opacity: 0;
  transform: translateY(18px);
  transition: opacity 0.7s ease, transform 0.7s ease;
}

/* Quando o elemento estiver visível */
.po-in-view {
  opacity: 1;
  transform: translateY(0);
}

/* Variações de delay para "onda" */
.po-delay-1 { transition-delay: 0.08s; }
.po-delay-2 { transition-delay: 0.16s; }
.po-delay-3 { transition-delay: 0.24s; }
.po-delay-4 { transition-delay: 0.32s; }
.po-delay-5 { transition-delay: 0.40s; }

/* Hero com animações mais suaves */
.po-hero-title {
  position: relative;
}

/* Microanimação no botão principal (hover) */
.po-btn-primary {
  position: relative;
  overflow: hidden;
}

.po-btn-primary::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(120deg, rgba(255,255,255,0.3), transparent 60%);
  transform: translateX(-140%);
  transition: transform 0.5s ease-out;
}

.po-btn-primary:hover::after {
  transform: translateX(110%);
}

/* Pulsar mais leve no botão anual */
.po-btn-pulse {
  animation: poPulse 1.8s infinite ease-out;
}

/* Ícones "flutuando" discretamente (se quiser usar em emotes do hero) */
@keyframes poFloat {
  0%   { transform: translateY(0px); }
  50%  { transform: translateY(-6px); }
  100% { transform: translateY(0px); }
}

.po-floating {
  animation: poFloat 3s ease-in-out infinite;
}

/* =====================================
   USE NAS SEÇÕES CHAVE
   (hero, benefícios, tour, preços)
===================================== */

/* Exemplo de sutil highlight no bloco de planos */
.po-pricing {
  position: relative;
}

.po-pricing::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: radial-gradient(circle at top, rgba(144,85,253,0.09), transparent 55%);
  opacity: 0.7;
}

/* Não deixar o radial colar demais nas bordas no mobile */
@media (max-width: 768px) {
  .po-pricing::before {
    opacity: 0.5;
  }
}/* End custom CSS */