/* ===== THEME SYSTEM ===== */
:root{
  --brand:#773DFA;
  --brand2:#5E2EF5;
  --radius:18px;
  --shadow: 0 16px 40px rgba(0,0,0,.25);
}

/* Desktop default: DARK TECH */
html.theme-dark{
  --bg:#0B0B14;
  --soft:#0E0E1A;
  --surface:#121226;
  --surface2:#0F0F1C;
  --text:#F2F2FF;
  --muted:rgba(242,242,255,.72);
  --border:rgba(255,255,255,.12);
  --glass: rgba(11,11,20,.72);
  --glassBorder: rgba(255,255,255,.10);
  --pillBg: rgba(119,61,250,.12);
  --pillBorder: rgba(119,61,250,.25);
}

/* Mobile: LIGHT (automático pelo JS no head) */
html.theme-light{
  --bg:#ffffff;
  --soft:#F7F7FF;
  --surface:#ffffff;
  --surface2:#FAFAFF;
  --text:#0B0B14;
  --muted:#5B5B72;
  --border:rgba(17,17,34,.10);
  --glass: rgba(255,255,255,.86);
  --glassBorder: rgba(17,17,34,.10);
  --pillBg: rgba(119,61,250,.08);
  --pillBorder: rgba(119,61,250,.22);
  --shadow: 0 16px 40px rgba(10,10,30,.10);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:"Manrope", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color:var(--text);
  background:var(--bg);
  line-height:1.45;
  overflow-x:hidden; /* evita “vazio à direita” por overflow */
}
img{max-width:100%; display:block}
a{color:inherit; text-decoration:none}

/* container refatorado (centraliza sempre) */
.container{
  width:100%;
  max-width:1120px;
  margin:0 auto;
  padding:0 20px;
}

.muted{color:var(--muted)}
.mini{font-size:.92rem}
.dot{opacity:.55; margin:0 .4rem}
code{font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace; font-size:.92em}

.pill{
  display:inline-flex;
  align-items:center;
  gap:.4rem;
  padding:.25rem .6rem;
  border:1px solid var(--pillBorder);
  background:var(--pillBg);
  border-radius:999px;
  font-weight:800;
  color:var(--brand);
}

/* Topbar */
.topbar{
  background:linear-gradient(90deg, rgba(119,61,250,.18), rgba(119,61,250,.04));
  border-bottom:1px solid var(--border);
}
.topbar__inner{
  padding:10px 0;
  display:flex;
  gap:.6rem;
  align-items:center;
  justify-content:center;
  flex-wrap:wrap;
}

/* Header */
.header{
  position:sticky;
  top:0;
  z-index:50;
  background:var(--glass);
  backdrop-filter: blur(10px);
  border-bottom:1px solid var(--glassBorder);
}
.header__inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:14px 0;
  gap:18px;
  min-width:0;
}
.brand__logo{height:34px; width:auto}

/* Nav */
.nav{display:flex; gap:18px; align-items:center}
.nav a{color:var(--muted); font-weight:800; font-size:.95rem}
.nav a:hover{color:var(--text)}

.header__cta{
  display:flex;
  gap:10px;
  align-items:center;
  min-width:0;
}

/* Buttons */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:.5rem;
  padding:10px 14px;
  border-radius:14px;
  font-weight:900;
  border:1px solid transparent;
  cursor:pointer;
  user-select:none;
  white-space:nowrap;
  max-width: 100%;
  transition: transform .15s ease, box-shadow .15s ease, background .15s ease, border-color .15s ease;
}
.btn--lg{padding:14px 18px; border-radius:16px}
.btn--block{width:100%}

.btn--primary{
  background:linear-gradient(180deg, var(--brand), var(--brand2));
  color:#fff;
  box-shadow: 0 10px 26px rgba(119,61,250,.25);
}
.btn--primary:hover{transform: translateY(-1px); box-shadow: 0 14px 30px rgba(119,61,250,.30)}

.btn--ghost{
  background:var(--surface);
  border-color: rgba(119,61,250,.22);
  color:var(--text);
}
.btn--ghost:hover{border-color: rgba(119,61,250,.45); transform: translateY(-1px)}

.menuBtn{
  display:none;
  width:42px; height:42px;
  border-radius:14px;
  border:1px solid var(--border);
  background:var(--surface);
  cursor:pointer;
  flex:0 0 auto;
}
.menuBtn span{
  display:block;
  height:2px;
  background:var(--text);
  margin:6px 10px;
  border-radius:2px;
}

/* Mobile menu */
.mobileMenu{
  border-top:1px solid var(--border);
  background:var(--surface);
}
.mobileMenu__inner{
  padding:14px 0 18px;
  display:flex;
  flex-direction:column;
  gap:12px;
}
.mobileMenu__inner a{
  padding:10px 0;
  font-weight:900;
  color:var(--muted);
}
.mobileMenu__actions{
  margin-top:6px;
  display:flex;
  flex-direction:column;
  gap:10px;
}
.mobileMenu__actions .btn{ width:100%; }

/* Hero */
.hero{
  padding:40px 0 18px;
  background:
    radial-gradient(900px 320px at 20% 10%, rgba(119,61,250,.22), transparent 60%),
    radial-gradient(700px 240px at 80% 0%, rgba(119,61,250,.12), transparent 55%),
    linear-gradient(180deg, var(--bg), var(--bg));
}
.hero__grid{
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap:28px;
  align-items:start;
  min-width:0;
}
.kicker{
  display:inline-flex;
  font-weight:900;
  color:var(--brand);
  background:rgba(119,61,250,.12);
  border:1px solid rgba(119,61,250,.22);
  padding:8px 12px;
  border-radius:999px;
  margin:0 0 12px;
}
h1{
  margin:0 0 10px;
  font-size: clamp(2.0rem, 3.2vw, 3.1rem);
  line-height:1.08;
  letter-spacing:-.02em;
}
.lead{
  margin:0 0 14px;
  font-size:1.08rem;
  color:var(--muted);
}
.hero__bullets{
  margin:0 0 18px;
  padding-left:18px;
  color:var(--text);
  font-weight:800;
}
.hero__actions{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  margin:10px 0 10px;
}

.trustRow{
  margin-top:16px;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
}
.trustRow__item{
  display:flex;
  gap:10px;
  padding:12px;
  border:1px solid var(--border);
  background:var(--surface);
  border-radius:var(--radius);
  box-shadow: 0 10px 30px rgba(0,0,0,.06);
}
.trustIcon{font-size:1.1rem}
.trustTitle{margin:0; font-weight:900}
.trustRow__item p{margin:0}

.hero__visual{display:flex; flex-direction:column; gap:12px; min-width:0}
.mockup{
  border-radius: 22px;
  border:1px solid var(--border);
  background: linear-gradient(180deg, var(--surface), var(--surface2));
  box-shadow: var(--shadow);
  overflow:hidden;
}
.mockup__top{
  display:flex;
  gap:8px;
  padding:14px;
  border-bottom:1px solid var(--border);
  background: linear-gradient(90deg, rgba(119,61,250,.12), rgba(119,61,250,.03));
  flex-wrap: nowrap;     
  overflow-x: auto;
  scrollbar-width: none;
  -webkit-overflow-scrolling: touch;
}

.mockup__top::-webkit-scrollbar{ display:none; }

/* Chips clicáveis */
.chipBtn{
  font-weight:900;
  font-size:.92rem;
  color:var(--text);
  background:var(--surface);
  border:1px solid rgba(119,61,250,.20);
  padding:7px 12px;
  border-radius:999px;
  cursor:pointer;
  transition: transform .12s ease, border-color .12s ease, background .12s ease;
}
.chipBtn:hover{transform: translateY(-1px); border-color: rgba(119,61,250,.45)}
.chipBtn.is-active{
  background: rgba(119,61,250,.16);
  border-color: rgba(119,61,250,.55);
}

.mockup__body{padding:16px}
.mockPreview{
  width:100%;
  height:260px;
  border-radius:16px;
  border:1px dashed rgba(119,61,250,.35);
  background: rgba(119,61,250,.06);
  object-fit: cover;
}
.mockup__hint{
  margin-top:12px;
  font-size:.95rem;
  color:var(--muted);
}

.badges{display:flex; flex-wrap:wrap; gap:10px}
.badge{
  display:inline-flex;
  gap:8px;
  align-items:center;
  padding:10px 12px;
  border-radius:999px;
  border:1px solid var(--border);
  background:var(--surface);
  font-weight:900;
  box-shadow: 0 10px 30px rgba(0,0,0,.06);
}

/* Sections */
.section{padding:56px 0}
.section--soft{background:var(--soft); border-top:1px solid var(--border); border-bottom:1px solid var(--border)}
.sectionHead{margin-bottom:18px}
.sectionHead h2{
  margin:0 0 8px;
  font-size: clamp(1.6rem, 2.2vw, 2.2rem);
  letter-spacing:-.02em;
}
.lead2{margin:0; color:var(--muted); font-size:1.05rem}
.sectionEyebrow{font-weight:900; color:var(--muted); margin:0 0 12px}

/* Cards/grids */
.grid3{display:grid; grid-template-columns:repeat(3, 1fr); gap:14px}
.grid2{display:grid; grid-template-columns:repeat(2, 1fr); gap:14px}

.card{
  border:1px solid var(--border);
  background:var(--surface);
  border-radius:var(--radius);
  padding:18px;
  box-shadow: 0 12px 30px rgba(0,0,0,.06);
}
.card h3{margin:0 0 10px; letter-spacing:-.02em}
.card p{margin:0; color:var(--muted)}
.card--accent{
  border-color: rgba(119,61,250,.22);
  background: linear-gradient(180deg, rgba(119,61,250,.14), var(--surface));
}

.list{margin:0; padding-left:18px; color:var(--muted)}
.list li{margin:6px 0}

.benefit{
  display:flex;
  gap:12px;
  align-items:flex-start;
  padding:18px;
  border-radius:var(--radius);
  border:1px solid var(--border);
  background:var(--surface);
}
.benefit__icon{
  width:42px;height:42px;
  display:flex;align-items:center;justify-content:center;
  border-radius:14px;
  background:rgba(119,61,250,.14);
  border:1px solid rgba(119,61,250,.22);
  font-weight:900;
}
.benefit h3{margin:0 0 6px; letter-spacing:-.02em}
.benefit p{margin:0; color:var(--muted)}

.featureBlocks{
  margin-top:18px;
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:14px;
}
.featureBlock{
  border:1px solid var(--border);
  background:var(--surface);
  border-radius:var(--radius);
  padding:18px;
}
.featureBlock h3{margin:0 0 8px}
.featureBlock p{margin:0 0 12px; color:var(--muted)}
.tags{display:flex; flex-wrap:wrap; gap:8px}
.tag{
  font-weight:900;
  font-size:.92rem;
  padding:7px 10px;
  border-radius:999px;
  border:1px solid rgba(119,61,250,.20);
  background:rgba(119,61,250,.10);
  color:var(--text);
}

/* Steps */
.steps{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:14px;
}
.step{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:18px;
  box-shadow: 0 12px 30px rgba(0,0,0,.06);
}
.step__num{
  width:38px;height:38px;
  border-radius:14px;
  display:flex;align-items:center;justify-content:center;
  background:rgba(119,61,250,.14);
  border:1px solid rgba(119,61,250,.22);
  font-weight:900;
  margin-bottom:10px;
}
.step h3{margin:0 0 8px}
.step p{margin:0; color:var(--muted)}

.centerCta{margin-top:18px; text-align:center}
.center{text-align:center}

/* Integrations */
.integrations{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:14px;
}
.integrationCard{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:18px;
}
.integrationCard h3{margin:0 0 8px}
.integrationCard p{margin:0; color:var(--muted)}

/* Pricing */
.pricing{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:14px;
}
.priceCard{
  border:1px solid var(--border);
  background:var(--surface);
  border-radius:var(--radius);
  padding:18px;
  box-shadow: 0 12px 30px rgba(0,0,0,.06);
}
.priceCard--featured{
  border-color: rgba(119,61,250,.35);
  box-shadow: 0 18px 44px rgba(119,61,250,.18);
}
.planName{margin:0; font-weight:900; color:var(--muted)}
.planPrice{
  margin:10px 0 10px;
  font-size:2rem;
  font-weight:900;
  letter-spacing:-.02em;
}
.planPrice span{font-size:1rem; color:var(--muted); font-weight:800}

/* Testimonials */
.testimonials{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:14px;
}
.testimonialCard{
  border:1px solid var(--border);
  background:var(--surface);
  border-radius:var(--radius);
  padding:18px;
}
.quote{margin:0 0 10px; font-weight:900}

/* FAQ */
.faq{display:grid; gap:10px}
.faqItem{
  border:1px solid var(--border);
  background:var(--surface);
  border-radius:var(--radius);
  padding:14px 16px;
}
.faqItem summary{
  cursor:pointer;
  font-weight:900;
  letter-spacing:-.01em;
}
.faqItem p{margin:10px 0 0; color:var(--muted)}

/* Final CTA */
.finalCta{margin-top:22px}
.finalCta__box{
  border-radius:24px;
  padding:22px;
  border:1px solid rgba(119,61,250,.25);
  background:
    radial-gradient(700px 260px at 20% 10%, rgba(119,61,250,.22), transparent 60%),
    linear-gradient(180deg, rgba(119,61,250,.10), var(--surface));
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
}
.finalCta__box h3{margin:0 0 6px; letter-spacing:-.02em}
.finalCta__box p{margin:0}
.finalCta__actions{display:flex; gap:10px; flex-wrap:wrap}

/* Footer */
.footer{
  background:#07070F;
  color:#fff;
  padding:26px 0 18px;
  margin-top:30px;
}
.footer__inner{
  display:flex;
  justify-content:space-between;
  gap:18px;
  align-items:flex-start;
}
.footer__brand img{height:30px; width:auto}
.footer__links{display:grid; gap:8px}
.footer__links a{color:rgba(255,255,255,.78); font-weight:900}
.footer__links a:hover{color:#fff}
.footer__bottom{margin-top:16px; border-top:1px solid rgba(255,255,255,.10); padding-top:12px}

/* Sticky CTA (mobile) */
.stickyCta{
  position:fixed;
  left:0; right:0;
  bottom:0;
  background: var(--glass);
  backdrop-filter: blur(10px);
  border-top:1px solid var(--glassBorder);
  padding:10px 12px;
  display:none;
  gap:10px;
  z-index:60;
}
.stickyCta .btn{border-radius:14px}

/* ===== MOBILE FIXES (header/footer/ctas) ===== */
@media (max-width: 980px){
  .nav{display:none}
  .menuBtn{display:inline-block}

  /* some com o ghost no header (já existe no menu e sticky) */
  .header__cta .btn--ghost{ display:none; }

  /* CTA do header menor e sem overflow */
  .header__cta{ gap: 8px; }
  .header__cta .btn--primary{
    padding: 10px 12px;
    font-size: .95rem;
    line-height: 1.15;
    white-space: normal;
    max-width: 210px;
    text-align: center;
  }

  .hero__grid{grid-template-columns: 1fr}
  .grid3{grid-template-columns:1fr}
  .grid2{grid-template-columns:1fr}
  .featureBlocks{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr}
  .integrations{grid-template-columns:1fr}
  .pricing{grid-template-columns:1fr}
  .testimonials{grid-template-columns:1fr}
  .footer__inner{flex-direction:column}
  .stickyCta{display:grid; grid-template-columns:1fr 1fr}
  .finalCta__box{flex-direction:column; align-items:flex-start}
  .mockPreview{height:230px;}
}

@media (max-width: 480px){
  /* sticky em 1 coluna */
  .stickyCta{ grid-template-columns: 1fr !important; }

  /* CTA final empilha */
  .finalCta__actions{ width:100%; }
  .finalCta__actions .btn{
    width: 100%;
    white-space: normal;
    text-align:center;
  }
}

/* ===== HOVER (desktop only) ===== */
@media (hover: hover) and (pointer: fine){
  .card, .benefit, .featureBlock, .integrationCard, .priceCard, .testimonialCard, .faqItem, .mockup, .badge, .step{
    transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
  }
  .card:hover, .benefit:hover, .featureBlock:hover, .integrationCard:hover, .priceCard:hover, .testimonialCard:hover, .faqItem:hover, .mockup:hover, .badge:hover, .step:hover{
    transform: translateY(-2px);
    border-color: rgba(119,61,250,.35);
  }
}

/* =========================
   REVEAL ON SCROLL (sem conflito com transitions)
   ========================= */
.reveal{
  opacity: 0;
  transform: translateY(12px);
  will-change: opacity, transform;
}

.reveal.is-visible{
  animation: revealUp .65s cubic-bezier(.2,.8,.2,1) var(--d, 0ms) both;
}

/* Mobile: movimento levemente menor */
@media (max-width: 980px){
  .reveal{ transform: translateY(10px); }
}

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

/* Acessibilidade */
@media (prefers-reduced-motion: reduce){
  .reveal{
    opacity: 1 !important;
    transform: none !important;
    animation: none !important;
    will-change: auto !important;
  }
}

/* =========================
   Glow tech sutil (featured + mockup)
   ========================= */
.priceCard--featured{
  position: relative;
  box-shadow:
    0 18px 44px rgba(119,61,250,.18),
    0 0 0 1px rgba(119,61,250,.22);
}

@media (hover: hover) and (pointer: fine){
  .priceCard--featured:hover{
    box-shadow:
      0 22px 52px rgba(119,61,250,.26),
      0 0 0 1px rgba(119,61,250,.30);
  }
  .mockup:hover{
    border-color: rgba(119,61,250,.35);
  }
}

/* Reduced motion geral (mantém suas transições base ok) */
@media (prefers-reduced-motion: reduce){
  *{transition:none !important}
  html{scroll-behavior:auto}
}

/* ===== NAV underline tech (hover/focus) ===== */
.nav a{
  position: relative;
  padding: 8px 2px 12px; /* cria espaço embaixo do texto */
}

.nav a::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  bottom:4px;                 /* espaço abaixo da palavra */
  height:2px;
  border-radius:999px;
  background: linear-gradient(90deg, var(--brand), var(--brand2));
  transform: scaleX(0);
  transform-origin: left;
  opacity:.9;
  transition: transform .18s ease;
}

.nav a:hover::after,
.nav a:focus-visible::after{
  transform: scaleX(1);
}

/* Acessibilidade: foco visível */
.nav a:focus-visible{
  outline: 2px solid rgba(119,61,250,.45);
  outline-offset: 6px;
  border-radius: 10px;
}

/* ===== Footer grid (logo grande / infos / links) ===== */
.footer__grid{
  display:grid;
  grid-template-columns: 260px 1fr 220px; /* ajuste fino aqui */
  gap: 24px;
  align-items: start;
}

.footer__left{
  width: 260px;           /* igual à 1ª coluna */
  display:flex;
  align-items:flex-start;
}

.footer__logoBig{
  width: 100%;
  max-width: 260px;       /* pode subir pra 300 se quiser */
  height: 64px;           /* aumenta a logo */
  object-fit: contain;
}

.footer__title{
  margin: 0 0 6px;
  font-weight: 900;
  letter-spacing: -0.01em;
  color: #fff;
}

.footer__text{
  margin: 0 0 12px;
  color: rgba(255,255,255,.75);
}

.footer__meta{
  display:flex;
  flex-wrap: wrap;
  gap: 10px 14px;
}

.footer__metaItem{
  font-weight: 800;
  font-size: .92rem;
  color: rgba(255,255,255,.78);
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.04);
  padding: 8px 10px;
  border-radius: 999px;
}

/* Responsivo: empilha bonito */
@media (max-width: 980px){
  .footer__grid{
    grid-template-columns: 1fr;
  }
  .footer__left{
    width: 100%;
  }
  .footer__logoBig{
    height: 54px;
    max-width: 280px;
  }

  .footer__right{
    display:flex;
    flex-wrap: wrap;
    gap: 10px 14px;
  }

  .footer__right a{
    color: rgba(255,255,255,.78);
  }
}

.heroStrip{
  margin-top: 18px;
  padding-bottom: 10px;
}

.heroStrip__viewport{
  display: flex;
  gap: 12px;
  overflow-x: auto;
  padding: 14px;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  position: relative;

  /* visual premium */
  border: 1px solid var(--border);
  border-radius: 22px;
  background:
    radial-gradient(800px 120px at 20% 0%, rgba(119,61,250,.22), transparent 60%),
    radial-gradient(800px 120px at 80% 100%, rgba(119,61,250,.14), transparent 60%),
    linear-gradient(180deg, var(--surface), var(--surface2));
  box-shadow: 0 16px 40px rgba(0,0,0,.22);
}

.heroStrip__viewport::-webkit-scrollbar{ display:none; }

/* animação sutil do fundo (tech) */
@media (prefers-reduced-motion: no-preference){
  .heroStrip__viewport{
    background-size: 140% 140%;
    animation: stripGlow 7s ease-in-out infinite;
  }
  @keyframes stripGlow{
    0%   { background-position: 0% 0%; }
    50%  { background-position: 100% 80%; }
    100% { background-position: 0% 0%; }
  }
}

.heroStrip__item{
  flex: 0 0 auto;
  scroll-snap-align: start;
  scroll-snap-stop: always;

  padding: 12px 14px;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: var(--surface);
  font-weight: 900;
  white-space: nowrap;
  box-shadow: 0 10px 26px rgba(0,0,0,.10);
  transition: border-color .2s ease, background .2s ease, transform .2s ease;
}

/* destaque do item "ativo" do auto-advance */
.heroStrip__item.is-current{
  border-color: rgba(119,61,250,.55);
  background: rgba(119,61,250,.16);
}

/* mobile: 1 por vez */
@media (max-width: 980px){
  .heroStrip__item{
    min-width: calc(100% - 70px);
    text-align: center;
    white-space: normal;
    display:flex;
    align-items:center;
    justify-content:center;
  }
}

/* desktop: somente 2 chips visíveis por vez */
@media (min-width: 981px){
  .heroStrip__item{
    flex: 0 0 calc(50% - 6px); /* 2 por vez */
    white-space: normal;
    text-align: center;
    display:flex;
    align-items:center;
    justify-content:center;
    min-height: 46px;
  }
}

/* fades laterais (mantém seu efeito) */
.heroStrip__viewport::before,
.heroStrip__viewport::after{
  content:"";
  position: sticky;
  top: 0;
  width: 42px;
  height: 100%;
  pointer-events: none;
  z-index: 2;
}

.heroStrip__viewport::before{
  left: 0;
  background: linear-gradient(90deg, var(--bg), transparent);
}

.heroStrip__viewport::after{
  right: 0;
  background: linear-gradient(270deg, var(--bg), transparent);
}

.card--solution{
  position: relative;
  overflow: hidden;
  border: 1px solid rgba(119,61,250,.28);
  background:
    radial-gradient(800px 180px at 20% 0%, rgba(119,61,250,.30), transparent 60%),
    radial-gradient(700px 160px at 80% 100%, rgba(119,61,250,.18), transparent 65%),
    linear-gradient(180deg, rgba(119,61,250,.10), var(--surface));
  box-shadow:
    0 22px 56px rgba(119,61,250,.18),
    0 10px 26px rgba(0,0,0,.10);
}

.card--solution::before{
  content:"";
  position:absolute;
  inset:-2px;
  border-radius: calc(var(--radius) + 2px);
  padding: 2px;
  background: linear-gradient(135deg, rgba(119,61,250,.85), rgba(94,46,245,.25), rgba(119,61,250,.85));
  -webkit-mask:
    linear-gradient(#000 0 0) content-box,
    linear-gradient(#000 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  pointer-events:none;
  opacity: .85;
}

.card--solution p{
  margin: 0;
  font-size: 1.02rem;
  color: var(--text);
}

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

/* Badge “Solução” */
.cardBadge{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-weight: 900;
  font-size: .85rem;
  letter-spacing: .02em;
  padding: 7px 10px;
  border-radius: 999px;
  margin-bottom: 12px;
  color: var(--text);
  border: 1px solid rgba(119,61,250,.35);
  background: rgba(119,61,250,.18);
}

/* Hover só no desktop (fica mais premium) */
@media (hover: hover) and (pointer: fine){
  .card--solution:hover{
    transform: translateY(-3px);
    border-color: rgba(119,61,250,.45);
    box-shadow:
      0 26px 64px rgba(119,61,250,.24),
      0 12px 30px rgba(0,0,0,.14);
  }
}

html.theme-dark .brand__logo{
  content: url("assets/logo-white.png");
}

/* Mobile (light): usa logo escura */
html.theme-light .brand__logo{
  content: url("assets/logo-dark.png");
}

/* ===== Pricing: destaque PRO no Advanced ===== */
.priceCard--featured{
  position: relative;
  transform: translateY(-10px) scale(1.03); /* maior e “pra cima” */
  border: 1px solid rgba(119,61,250,.45) !important;
  background:
    radial-gradient(700px 200px at 20% 0%, rgba(119,61,250,.30), transparent 60%),
    radial-gradient(700px 200px at 80% 100%, rgba(119,61,250,.18), transparent 60%),
    linear-gradient(180deg, rgba(119,61,250,.10), var(--surface));
  box-shadow:
    0 26px 70px rgba(119,61,250,.22),
    0 14px 34px rgba(0,0,0,.14);
}

/* Borda “tech” com gradiente */
.priceCard--featured::before{
  content:"";
  position:absolute;
  inset:-2px;
  border-radius: calc(var(--radius) + 2px);
  padding:2px;
  background: linear-gradient(135deg, rgba(119,61,250,.95), rgba(94,46,245,.25), rgba(119,61,250,.95));
  -webkit-mask:
    linear-gradient(#000 0 0) content-box,
    linear-gradient(#000 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  pointer-events:none;
  opacity:.9;
}

/* Badge “Mais escolhido” */
.planBadge{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-weight: 900;
  font-size: .85rem;
  letter-spacing: .02em;
  padding: 8px 12px;
  border-radius: 999px;
  margin-bottom: 12px;
  color: var(--text);
  border: 1px solid rgba(119,61,250,.40);
  background: rgba(119,61,250,.18);
}

.planBadge::before{
  font-size: .95rem;
}

/* CTA no featured um pouco mais “forte” */
.priceCard--featured .btn--primary{
  box-shadow: 0 14px 36px rgba(119,61,250,.28);
}

/* Hover premium (desktop) */
@media (hover:hover) and (pointer:fine){
  .priceCard--featured{
    transition: transform .18s ease, box-shadow .18s ease;
  }
  .priceCard--featured:hover{
    transform: translateY(-12px) scale(1.04);
    box-shadow:
      0 30px 82px rgba(119,61,250,.28),
      0 16px 40px rgba(0,0,0,.16);
  }
}

/* Animação leve de glow (desktop, sem enjoar) */
@media (prefers-reduced-motion: no-preference) and (min-width: 981px){
  .priceCard--featured{
    animation: featuredGlow 4.6s ease-in-out infinite;
  }
  @keyframes featuredGlow{
    0%,100%{
      box-shadow: 0 26px 70px rgba(119,61,250,.18), 0 14px 34px rgba(0,0,0,.14);
    }
    50%{
      box-shadow: 0 30px 82px rgba(119,61,250,.28), 0 16px 40px rgba(0,0,0,.16);
    }
  }
}

/* Mobile: não “quebra” layout, reduz a escala */
@media (max-width: 980px){
  .priceCard--featured{
    transform: none;
  }
}

/* ===== Pricing Tail (plano sob medida) ===== */
.pricingTail{
  margin-top: 14px;
}

.customPlanCard{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  padding:16px 18px;
  border-radius: 22px;
  border: 1px solid rgba(119,61,250,.22);
  background:
    radial-gradient(800px 180px at 20% 0%, rgba(119,61,250,.20), transparent 60%),
    linear-gradient(180deg, rgba(119,61,250,.08), var(--surface));
  box-shadow: 0 14px 34px rgba(0,0,0,.10);
}

.customPlanCard__left{
  display:flex;
  align-items:flex-start;
  gap:12px;
  min-width:0;
}

.customPlanIcon{
  width:44px;
  height:44px;
  border-radius: 16px;
  display:flex;
  align-items:center;
  justify-content:center;
  background: rgba(119,61,250,.16);
  border: 1px solid rgba(119,61,250,.28);
  font-weight:900;
  flex: 0 0 auto;
}

.customPlanTitle{
  margin:0 0 4px;
  font-weight: 900;
  letter-spacing:-0.01em;
}

.customPlanText{
  margin:0;
  max-width: 58ch;
}

.customPlanBtn{
  white-space: nowrap;
}

/* Hover tech sutil (desktop) */
@media (hover:hover) and (pointer:fine){
  .customPlanCard{
    transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
  }
  .customPlanCard:hover{
    transform: translateY(-2px);
    border-color: rgba(119,61,250,.40);
    box-shadow: 0 18px 44px rgba(119,61,250,.12), 0 14px 34px rgba(0,0,0,.12);
  }
}

/* Mobile: empilha e botão 100% */
@media (max-width: 980px){
  .customPlanCard{
    flex-direction: column;
    align-items: stretch;
  }
  .customPlanBtn{
    width: 100%;
    text-align: center;
    white-space: normal;
  }
}

@media (min-width: 981px){
  .hero__grid{
    grid-template-columns: 0.95fr 1.05fr; /* direita um pouco maior */
    align-items: start;
  }

  /* opcional: aumenta um pouco a altura da screenshot no desktop */
  .mockPreview{
    height: 300px;
  }
}

/* mantém como você já tinha no mobile */
@media (max-width: 980px){
  .mockPreview{
    height: auto;
    aspect-ratio: 9 / 16;
    object-fit: contain;
    background: rgba(119,61,250,.06);
    border: 1px solid rgba(119,61,250,.22);
    padding: 8px;
  }
}

.testimonialTop{
  display:flex;
  align-items:center;
  gap:12px;
  margin-bottom: 12px;
}

.avatar{
  width: 46px;
  height: 46px;
  border-radius: 999px;          /* circular */
  flex: 0 0 auto;
  object-fit: cover;
  border: 2px solid rgba(119,61,250,.35); /* aro roxo */
  background: rgba(119,61,250,.10);
  box-shadow: 0 10px 22px rgba(0,0,0,.10);
}

.avatar--photo{
  display:block;
}

.avatar--initials{
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight: 900;
  letter-spacing: .02em;
  color: var(--text);
  background:
    radial-gradient(120px 70px at 30% 0%, rgba(119,61,250,.32), transparent 60%),
    linear-gradient(180deg, rgba(119,61,250,.18), var(--surface));
}

.whoName{
  margin:0;
  font-weight: 900;
  line-height: 1.1;
}

.whoRole{
  margin:2px 0 0;
}

/* quote mais “depoimento real” */
.testimonialCard .quote{
  margin:0;
  font-weight: 800;
  line-height: 1.45;
}

.testimonialCard .quote::before{
  content:"“";
  color: rgba(119,61,250,.75);
  font-weight: 900;
}
.testimonialCard .quote::after{
  content:"”";
  color: rgba(119,61,250,.75);
  font-weight: 900;
}