  /* =====================================================
       VARIÁVEIS — altere aqui para mudar todo o tema
       ===================================================== */
    :root {
      --p:        #534AB7;
      --p-lt:     #EEEDFE;
      --p-md:     #7F77DD;
      --p-dk:     #3C3489;
      --p-xlt:    #F5F4FF;
      --green:    #1D9E75;
      --green-lt: #E1F5EE;
      --red:      #D85A30;
      --amber:    #BA7517;
      --ink:      #0F0E1A;
      --ink-2:    #2D2B45;
      --ink-3:    #6B6888;
      --surface:  #FAFAF8;
      --border:   rgba(83,74,183,.12);
      --radius:   12px;
      --radius-lg:20px;
    }

    /* =====================================================
       BASE
       ===================================================== */
    * { box-sizing: border-box; }
    html, body {
      overflow-x: hidden;
      max-width: 100%;
    }
    body {
      font-family: 'Sora', sans-serif;
      background: var(--surface);
      color: var(--ink);
      -webkit-font-smoothing: antialiased;
    }
    a { text-decoration: none; color: inherit; }
    img { max-width: 100%; }
    section { padding: 96px 0; }

    /* =====================================================
       TIPOGRAFIA UTILITÁRIA
       ===================================================== */
    .fw-500 { font-weight: 500; }
    .fw-600 { font-weight: 600; }
    .fw-700 { font-weight: 700; }
    .fw-800 { font-weight: 800; }
    .text-ink    { color: var(--ink); }
    .text-ink-2  { color: var(--ink-2); }
    .text-ink-3  { color: var(--ink-3); }
    .text-purple { color: var(--p); }
    .text-green  { color: var(--green); }
    .text-red    { color: var(--red); }
    .text-amber  { color: var(--amber); }
    .section-label {
      font-size: 11px;
      font-weight: 700;
      letter-spacing: .1em;
      text-transform: uppercase;
      color: var(--p);
      margin-bottom: 12px;
    }
    .section-title {
      font-size: clamp(28px, 4vw, 42px);
      font-weight: 800;
      letter-spacing: -1px;
      line-height: 1.1;
      color: var(--ink);
    }
    .section-sub {
      font-size: 17px;
      color: var(--ink-3);
      line-height: 1.7;
      max-width: 520px;
    }
/*BTN SUBir*/
#scrollTopBtn {
  position: fixed;
  bottom: 20px;
  right: 20px;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: var(--ink-3);
  color: #fff;
  border: none;
  cursor: pointer;
  font-size: 20px;
  opacity: 0;
  transform: translateY(8px);
  transition: opacity 0.25s ease, transform 0.25s ease;
  pointer-events: none;
  z-index: 1000;
}

#scrollTopBtn.visible {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}
    /* =====================================================
       BOTÕES
       ===================================================== */
    .btn-purple {
      background: var(--p);
      color: #fff;
      border: none;
      font-weight: 600;
      border-radius: 8px;
      padding: 12px 28px;
      font-family: 'Sora', sans-serif;
      transition: all .2s;
    }
    .btn-purple:hover {
      background: var(--p-dk);
      color: #fff;
      transform: translateY(-1px);
      box-shadow: 0 8px 24px rgba(83,74,183,.35);
    }
    .btn-outline-purple {
      background: transparent;
      color: var(--p);
      border: 1.5px solid var(--border);
      font-weight: 600;
      border-radius: 8px;
      padding: 12px 28px;
      font-family: 'Sora', sans-serif;
      transition: all .2s;
    }
    .btn-outline-purple:hover {
      border-color: var(--p);
      background: var(--p-lt);
      color: var(--p);
    }
    .btn-white {
      background: #fff;
      color: var(--p);
      border: none;
      font-weight: 700;
      border-radius: 10px;
      padding: 15px 40px;
      font-family: 'Sora', sans-serif;
      font-size: 16px;
      transition: all .2s;
    }
    .btn-white:hover {
      background: var(--p-lt);
      transform: translateY(-2px);
      box-shadow: 0 12px 40px rgba(0,0,0,.3);
    }

    /* =====================================================
       NAV
       ===================================================== */
      .text-logo{color: var(--p); font-size: 12px; font-weight: 600;}
    #mainNav {
      background: var(--p-xlt);
      backdrop-filter: blur(20px);
      -webkit-backdrop-filter: blur(20px);
      border-bottom: 1px solid var(--border);
      transition: box-shadow .3s;
    }
    #mainNav.scrolled {
      box-shadow: 0 4px 24px rgba(0,0,0,.08);
    }
    #mainNav .nav-link {
      font-size: 14px;
      font-weight: 500;
      color: var(--ink-3);
      padding: 8px 14px;
      transition: color .2s;
    }
    #mainNav .nav-link:hover { color: var(--p); }

    /* =====================================================
       HERO
       ===================================================== */
    #hero {
      min-height: 100vh;
      padding: 100px 0 60px;
      position: relative;
      overflow: hidden;
      background-color: #FAF9FF !important;
    }
    /* Blobs de fundo */
    .blob {
      position: absolute;
      border-radius: 50%;
      filter: blur(80px);
      opacity: .16;
      pointer-events: none;
    }
    .blob-1 { width: 600px; height: 600px; background: var(--p-lt);     top: -200px; right: -100px; animation: float1 8s ease-in-out infinite; }
    .blob-2 { width: 400px; height: 400px; background: var(--p);     bottom: -100px; left: -80px; animation: float2 10s ease-in-out infinite; }
    .blob-3 { width: 280px; height: 280px; background: var(--p); top: 40%; left: 35%; animation: float1 12s ease-in-out infinite reverse; }
    @keyframes float1 { 0%,100%{transform:translate(0,0) scale(1)} 50%{transform:translate(30px,-40px) scale(1.05)} }
    @keyframes float2 { 0%,100%{transform:translate(0,0) scale(1)} 50%{transform:translate(-20px,30px) scale(1.08)} }

    .hero-eyebrow {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      background: var(--p-lt);
      border: 1px solid var(--border);
      color: var(--p-dk);
      border-radius: 100px;
      padding: 6px 18px;
      font-size: 12px;
      font-weight: 600;
      letter-spacing: .04em;
      text-transform: uppercase;
      margin-bottom: 24px;
    }
    .eyebrow-dot {
      width: 6px; height: 6px;
      border-radius: 50%;
      background: var(--p);
      animation: pulse 2s infinite;
    }
    @keyframes pulse { 0%,100%{opacity:1} 50%{opacity:.3} }
    .hero-title {
      font-size: clamp(36px, 6vw, 64px);
      font-weight: 800;
      line-height: 1.08;
      letter-spacing: -2px;
    }
    .hero-title em {
      font-style: normal;
      color: var(--p);
    }
    .hero-sub {
      font-size: 18px;
      color: var(--ink-3);
      line-height: 1.7;
      max-width: 520px;
    }
    .hero-trust {
      font-size: 13px;
      color: var(--ink-3);
    }
    .hero-trust strong { color: var(--p); }

    /* Mockup hero */
    .mockup-frame {
      background: var(--p-lt);
      border-radius: var(--radius-lg);
      padding: 20px 20px 0;
      border: 1px solid var(--border);
      box-shadow: 0 40px 80px rgba(83,74,183,.18), 0 0 0 1px rgba(255,255,255,.8) inset;
    }
    .mockup-dots { display: flex; gap: 6px; margin-bottom: 14px; }
    .mdot { width: 10px; height: 10px; border-radius: 50%; }
    .mockup-screen {
      background: #fff;
      border-radius: 12px 12px 0 0;
      overflow: hidden;
      border: 1px solid var(--border);
      display: flex;
      min-height: 320px;
    }
    /* sidebar mock */
    .ms { width: 170px; border-right: 1px solid #F1EFE8; padding: 12px 8px; flex-shrink: 0; }
    .ms-brand { display: flex; align-items: center; gap: 8px; padding: 0 4px 10px; border-bottom: 1px solid #F1EFE8; margin-bottom: 8px; }
    .ms-ico { width: 26px; height: 26px; background: var(--p); border-radius: 5px; flex-shrink: 0; }
    .ms-name { font-size: 10px; font-weight: 700; color: var(--ink); }
    .ms-fam  { font-size: 9px; color: var(--ink-3); }
    .ms-item { display: flex; align-items: center; gap: 6px; padding: 6px 8px; border-radius: 5px; font-size: 10px; color: var(--ink-3); margin-bottom: 2px; }
    .ms-item.active { background: var(--p-lt); color: var(--p); font-weight: 600; }
    .ms-dot { width: 12px; height: 12px; background: currentColor; border-radius: 2px; flex-shrink: 0; opacity: .5; }
    .ms-item.active .ms-dot { opacity: 1; }
    /* main mock */
    .mm { flex: 1; padding: 14px; background: #FAFAF8; }
    .mm-hdr { display: flex; justify-content: space-between; align-items: center; margin-bottom: 10px; }
    .mm-title { font-size: 13px; font-weight: 700; color: var(--ink); }
    .mm-sub   { font-size: 9px; color: var(--ink-3); }
    .mm-add   { background: var(--p); color: #fff; padding: 4px 9px; border-radius: 5px; font-size: 9px; font-weight: 700; }
    .mm-alert { background: #fff; border: 1px solid #F1EFE8; border-left: 3px solid var(--amber); border-radius: 6px; padding: 7px 9px; margin-bottom: 9px; display: flex; align-items: center; gap: 7px; }
    .mm-at { font-size: 9px; font-weight: 600; color: var(--ink); }
    .mm-as { font-size: 8px; color: var(--ink-3); }
    .mm-badge-a { background: #FAEEDA; color: var(--amber); font-size: 8px; font-weight: 700; padding: 2px 6px; border-radius: 4px; margin-left: auto; }
    .mm-cards { display: grid; grid-template-columns: repeat(4,1fr); gap: 6px; margin-bottom: 9px; }
    .mc { background: #fff; border: 1px solid #F1EFE8; border-radius: 6px; padding: 8px; }
    .mc-l { font-size: 8px; color: var(--ink-3); margin-bottom: 2px; }
    .mc-v { font-size: 12px; font-weight: 700; }
    .mc-s { font-size: 8px; color: var(--ink-3); }
    .mm-grid-2 { display: grid; grid-template-columns: 1fr 150px; gap: 7px; }
    .mm-card { background: #fff; border: 1px solid #F1EFE8; border-radius: 6px; overflow: hidden; }
    .mm-ch { display: flex; justify-content: space-between; padding: 7px 9px; border-bottom: 1px solid #F1EFE8; }
    .mm-ct { font-size: 9px; font-weight: 700; color: var(--ink); }
    .mm-cl { font-size: 8px; color: var(--p); }
    .mm-row { display: flex; align-items: center; padding: 6px 9px; border-bottom: 1px solid #F1EFE8; gap: 6px; }
    .mm-row:last-child { border: none; }
    .mm-rd { flex: 1; font-size: 9px; font-weight: 600; color: var(--ink); }
    .mm-rc { font-size: 8px; color: var(--ink-3); }
    .val-pos { color: var(--green); font-size: 9px; font-weight: 700; }
    .val-neg { color: var(--red);   font-size: 9px; font-weight: 700; }
    .bs { font-size: 7px; padding: 1px 5px; border-radius: 3px; font-weight: 600; }
    .bs-g { background: var(--green-lt); color: var(--green); }
    .bs-a { background: #FAEEDA;         color: var(--amber); }
    .cat-row { padding: 4px 9px; }
    .cat-l  { font-size: 8px; color: var(--ink-3); margin-bottom: 2px; }
    .cat-tr { height: 3px; background: #F1EFE8; border-radius: 2px; overflow: hidden; margin-bottom: 1px; }
    .cat-fi { height: 100%; border-radius: 2px; background: var(--p); }
    .cat-v  { font-size: 8px; font-weight: 600; color: var(--ink-3); text-align: right; }

    /* =====================================================
       STATS STRIP
       ===================================================== */
    #stats {
      background: var(--p-xlt);
      padding: 32px 0;
      border-top: 1px solid var(--border);
      border-bottom: 1px solid var(--border);
    }
    .stat-num { font-size: 30px; font-weight: 800; color: var(--p); letter-spacing: -1px; }
    .stat-txt { font-size: 12px; color: var(--ink-3); font-weight: 500; margin-top: 2px; }

    /* =====================================================
       FEATURES
       ===================================================== */
    #features { background: #fff; }
    .feat-card {
      background: #fff;
      border: 1px solid var(--border);
      border-radius: var(--radius-lg);
      padding: 32px;
      height: 100%;
      transition: background .2s, transform .2s, box-shadow .2s;
      position: relative;
      overflow: hidden;
    }
    .feat-card::before {
      content: '';
      position: absolute;
      top: 0; left: 0; right: 0;
      height: 2px;
      background: linear-gradient(90deg, var(--p), var(--p-md));
      transform: scaleX(0);
      transform-origin: left;
      transition: transform .3s;
    }
    .feat-card:hover { background: var(--p-xlt); transform: translateY(-3px); box-shadow: 0 12px 32px rgba(83,74,183,.1); }
    .feat-card:hover::before { transform: scaleX(1); }
    .feat-icon {
      width: 48px; height: 48px;
      background: var(--p-lt);
      border-radius: 12px;
      display: flex; align-items: center; justify-content: center;
      font-size: 22px;
      margin-bottom: 20px;
    }
    .feat-tag {
      display: inline-block;
      margin-top: 14px;
      font-size: 11px; font-weight: 600;
      color: var(--p);
      background: var(--p-lt);
      padding: 3px 10px;
      border-radius: 6px;
    }

    /* =====================================================
       INDIVIDUAL VS FAMÍLIA
       ===================================================== */
    #uso { background: #fff; }
    .uso-card {
      border-radius: var(--radius-lg);
      padding: 40px;
      height: 100%;
    }
    .uso-card-individual { background: var(--p-xlt); border: 1px solid var(--border); }
    .uso-card-familia    { background: var(--ink); border: 1px solid rgba(255,255,255,.1); }
    .uso-check-purple { color: var(--p);    font-weight: 700; }
    .uso-check-light  { color: var(--p-md); font-weight: 700; }

    /* =====================================================
       FAMÍLIA
       ===================================================== */
    #familia { background: var(--p-xlt); }
    .member-card {
      display: flex; align-items: center; gap: 12px;
      background: #fff;
      border-radius: var(--radius);
      padding: 14px 18px;
      border: 1px solid var(--border);
      box-shadow: 0 2px 8px rgba(0,0,0,.04);
      transition: transform .2s, box-shadow .2s;
      margin-bottom: 10px;
    }
    .member-card:hover { transform: translateX(4px); box-shadow: 0 4px 16px rgba(83,74,183,.1); }
    .member-card.dashed { border-style: dashed; opacity: .7; cursor: pointer; }
    .member-card.dashed:hover { opacity: 1; border-color: var(--p); }
    .member-av {
      width: 40px; height: 40px;
      border-radius: 50%;
      display: flex; align-items: center; justify-content: center;
      color: #fff; font-size: 13px; font-weight: 700;
      flex-shrink: 0;
    }
    .member-badge {
      font-size: 11px; padding: 3px 9px;
      border-radius: 6px; font-weight: 600;
      margin-left: auto;
    }
    .ff-check {
      width: 24px; height: 24px;
      background: var(--p); border-radius: 50%;
      display: flex; align-items: center; justify-content: center;
      color: #fff; font-size: 11px; font-weight: 700;
      flex-shrink: 0; margin-top: 2px;
    }

    /* =====================================================
       CARTÕES
       ===================================================== */
    #cartoes { background: #fff; }
    .cartao-card {
      background: #fff;
      border: 1px solid var(--border);
      border-radius: var(--radius-lg);
      padding: 22px;
      border-top-width: 4px;
      transition: transform .2s, box-shadow .2s;
      height: 100%;
    }
    .cartao-card:hover { transform: translateY(-4px); box-shadow: 0 16px 40px rgba(83,74,183,.12); }
    .cartao-track { height: 5px; background: #F1EFE8; border-radius: 3px; overflow: hidden; }
    .cartao-fill  { height: 100%; border-radius: 3px; }
    .cpill { font-size: 10px; padding: 3px 9px; border-radius: 5px; font-weight: 600; }
    .cpill-g { background: var(--green-lt); color: var(--green); }
    .cpill-a { background: #FAEEDA;         color: var(--amber); }

    /* =====================================================
       RELATÓRIO
       ===================================================== */
    #relatorio { background: var(--surface); }
    .rel-wrap {
      background: #fff;
      border: 1px solid var(--border);
      border-radius: var(--radius-lg);
      padding: 28px;
      box-shadow: 0 8px 32px rgba(0,0,0,.06);
    }
    .rel-tab {
      font-size: 11px; padding: 5px 12px;
      border-radius: 6px;
      border: 1px solid var(--border);
      background: #fff; color: var(--ink-3);
      cursor: pointer; font-weight: 500;
      font-family: 'Sora', sans-serif;
    }
    .rel-tab.active { background: var(--p); color: #fff; border-color: var(--p); }
    .rel-card { background: var(--surface); border-radius: 8px; padding: 14px; }
    .rc-l { font-size: 10px; color: var(--ink-3); margin-bottom: 4px; font-weight: 500; }
    .rc-v { font-size: 22px; font-weight: 800; letter-spacing: -1px; }
    .chart-area { height: 140px; display: flex; align-items: flex-end; gap: 6px; padding: 0 2px; }
    .cg-wrap { flex: 1; display: flex; gap: 3px; align-items: flex-end; }
    .bar-r  { border-radius: 3px 3px 0 0; flex: 1; background: var(--green); opacity: .8; transition: opacity .2s; }
    .bar-r:hover { opacity: 1; }
    .bar-d  { border-radius: 3px 3px 0 0; flex: 1; background: var(--red); opacity: .65; }
    .bar-d:hover { opacity: .9; }
    .chart-lbl  { font-size: 9px; color: var(--ink-3); flex: 1; text-align: center; }
    .chart-dot  { width: 10px; height: 10px; border-radius: 2px; }

    /* =====================================================
       PRICING
       ===================================================== */
    #precos { background: var(--ink); }
    #precos .section-title { color: #fff; }
    #precos .section-sub   { color: rgba(255,255,255,.6); }
    #precos .section-label { color: var(--p-md); }
    /* Trial banner */
    .trial-banner {
      background: rgba(255,255,255,.06);
      border: 1px solid rgba(255,255,255,.15);
      border-radius: var(--radius-lg);
      padding: 28px 32px;
    }
    .trial-banner-title { font-size: 21px; font-weight: 800; color: #fff; }
    .trial-banner-sub   { font-size: 14px; color: rgba(255,255,255,.55); line-height: 1.6; }
    /* Price cards */
    .price-card {
      background: rgba(255,255,255,.05);
      border: 1px solid rgba(255,255,255,.1);
      border-radius: var(--radius-lg);
      padding: 32px;
      height: 100%;
      transition: border-color .2s, transform .2s;
    }
    .price-card:hover { border-color: rgba(255,255,255,.25); transform: translateY(-3px); }
    .price-card.hot   { background: var(--p); border-color: var(--p); }
    .pc-badge {
      display: inline-block; font-size: 10px; font-weight: 700;
      padding: 4px 10px; border-radius: 6px; margin-bottom: 14px; letter-spacing: .04em;
    }
    .pc-badge-pop  { background: rgba(255,255,255,.2); color: #fff; }
    .pc-badge-year { background: var(--green-lt); color: var(--green); }
    .pc-name   { font-size: 18px; font-weight: 700; color: #fff; margin-bottom: 6px; }
    .pc-desc   { font-size: 13px; color: rgba(255,255,255,.55); margin-bottom: 20px; line-height: 1.6; }
    .pc-amount { font-size: 40px; font-weight: 800; color: #fff; letter-spacing: -2px; }
    .pc-period { font-size: 13px; color: rgba(255,255,255,.55); }
    .pc-save   { font-size: 11px; font-weight: 700; background: var(--green-lt); color: var(--green); padding: 2px 8px; border-radius: 5px; margin-left: 6px; }
    .pc-anual  { font-size: 12px; color: rgba(255,255,255,.4); margin-top: 4px; }
    .pc-ul     { list-style: none; padding: 0; margin: 0 0 24px; display: flex; flex-direction: column; gap: 10px; }
    .pc-ul li  { font-size: 13px; color: rgba(255,255,255,.75); display: flex; align-items: center; gap: 8px; }
    .pc-ul li::before { content:'✓'; color: var(--p-md); font-weight: 700; flex-shrink: 0; }
    .price-card.hot .pc-ul li::before { color: rgba(255,255,255,.9); }
    .btn-pc {
      width: 100%; padding: 13px; border-radius: 8px;
      font-size: 14px; font-weight: 700; cursor: pointer;
      border: 1.5px solid rgba(255,255,255,.3); color: #fff; background: transparent;
      transition: all .2s; font-family: 'Sora', sans-serif;
    }
    .btn-pc:hover { background: rgba(255,255,255,.1); border-color: rgba(255,255,255,.6); }
    .btn-pc-solid { background: #fff; color: var(--p); border-color: #fff; }
    .btn-pc-solid:hover { background: var(--p-lt); transform: translateY(-1px); box-shadow: 0 8px 24px rgba(0,0,0,.2); }
    .guarantee-item { font-size: 13px; color: rgba(255,255,255,.5); display: flex; align-items: center; gap: 6px; }

    /* =====================================================
       DEPOIMENTOS
       ===================================================== */
    #depoimentos { background: var(--surface); }
    .depo-card {
      background: #fff;
      border: 1px solid var(--border);
      border-radius: var(--radius-lg);
      padding: 28px;
      height: 100%;
      transition: transform .2s, box-shadow .2s;
    }
    .depo-card:hover { transform: translateY(-4px); box-shadow: 0 16px 40px rgba(83,74,183,.1); }
    .depo-stars { font-size: 14px; letter-spacing: 3px; color: var(--p); margin-bottom: 14px; }
    .depo-av {
      width: 36px; height: 36px; border-radius: 50%;
      display: flex; align-items: center; justify-content: center;
      color: #fff; font-size: 12px; font-weight: 700; flex-shrink: 0;
    }

    /* =====================================================
       PWA INSTALL
       ===================================================== */
    #pwa { background: var(--p-xlt); border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); }
    .btn-pwa {
      display: flex; align-items: center; gap: 12px;
      padding: 13px 18px; border-radius: 10px;
      font-size: 14px; font-weight: 600; cursor: pointer;
      border: none; font-family: 'Sora', sans-serif;
      text-align: left; width: 100%; transition: all .2s;
    }
    .btn-pwa-android { background: var(--ink); color: #fff; }
    .btn-pwa-android:hover { background: var(--ink-2); transform: translateY(-1px); box-shadow: 0 8px 24px rgba(15,14,26,.25); }
    .btn-pwa-ios { background: #fff; color: var(--ink); border: 1.5px solid var(--border); }
    .btn-pwa-ios:hover { border-color: var(--p); background: var(--p-lt); color: var(--p); }
    .btn-pwa-generic { background: var(--p); color: #fff; }
    .btn-pwa-generic:hover { background: var(--p-dk); transform: translateY(-1px); box-shadow: 0 8px 24px rgba(83,74,183,.3); }
    .pwa-note { font-size: 11px; color: var(--ink-3); margin-top: 6px; }

    /* =====================================================
       FAQ
       ===================================================== */
    #faq { background: var(--p-xlt); }
    .faq-item {
      background: #fff;
      border: 1px solid var(--border);
      border-radius: var(--radius);
      overflow: hidden;
      margin-bottom: 4px;
    }
    .faq-q {
      padding: 18px 22px; font-size: 15px; font-weight: 600;
      cursor: pointer; display: flex; justify-content: space-between;
      align-items: center; color: var(--ink); transition: color .2s;
      user-select: none;
    }
    .faq-q:hover { color: var(--p); }
    .faq-item.open .faq-q { color: var(--p); }
    .faq-icon { font-size: 20px; color: var(--p); transition: transform .3s; flex-shrink: 0; }
    .faq-item.open .faq-icon { transform: rotate(45deg); }
    .faq-a { max-height: 0; overflow: hidden; transition: max-height .35s ease, padding .35s; padding: 0 22px; }
    .faq-a.open { max-height: 200px; padding: 0 22px 18px; }
    .faq-a p { font-size: 14px; color: var(--ink-3); line-height: 1.75; margin: 0; }

    /* =====================================================
       CTA FINAL
       ===================================================== */
    #cta {
      background: var(--ink);
      padding: 96px 0;
      position: relative;
      overflow: hidden;
    }
    #cta::before {
      content: '';
      position: absolute;
      top: -200px; left: 50%; transform: translateX(-50%);
      width: 800px; height: 800px;
      background: radial-gradient(circle, rgba(83,74,183,.3) 0%, transparent 70%);
      pointer-events: none;
    }
    .cta-title { font-size: clamp(32px,5vw,52px); font-weight: 800; letter-spacing: -1.5px; color: #fff; }
    .cta-sub   { font-size: 17px; color: rgba(255,255,255,.6); line-height: 1.7; max-width: 460px; margin: 0 auto; }
    .cta-note  { font-size: 13px; color: rgba(255,255,255,.4); margin-top: 14px; }

    /* =====================================================
       FOOTER
       ===================================================== */
    #footer {
      background: var(--ink-2);
      padding: 36px 0;
      border-top: 1px solid rgba(255,255,255,.06);
    }
    .footer-link { font-size: 13px; color: rgba(255,255,255,.4); transition: color .2s; }
    .footer-link:hover { color: rgba(255,255,255,.8); }
    .footer-copy { font-size: 12px; color: rgba(255,255,255,.3); }

    /* =====================================================
       MODAL PWA
       ===================================================== */
    .pwa-modal { display: none; position: fixed; inset: 0; background: rgba(0,0,0,.5); z-index: 9999; align-items: flex-end; justify-content: center; }
    .pwa-modal.show { display: flex; }
    .pwa-modal-box { background: #fff; border-radius: 20px 20px 0 0; padding: 28px 24px 40px; max-width: 480px; width: 100%; animation: slideUp .3s ease; }
    @keyframes slideUp { from{transform:translateY(100%)} to{transform:translateY(0)} }
    .pwa-modal-title { font-size: 17px; font-weight: 700; margin-bottom: 16px; color: var(--ink); display: flex; justify-content: space-between; align-items: center; }
    .pwa-step { display: flex; gap: 12px; align-items: flex-start; margin-bottom: 14px; }
    .pwa-step-n { width: 26px; height: 26px; border-radius: 50%; background: var(--p); color: #fff; font-size: 12px; font-weight: 700; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
    .pwa-step-text { font-size: 14px; color: var(--ink-3); line-height: 1.5; }
    .pwa-step-text strong { color: var(--ink); }

    /* =====================================================
       ANIMAÇÃO SCROLL
       ===================================================== */
    .reveal { opacity: 0; transform: translateY(20px); transition: opacity .5s ease, transform .5s ease; }
    .reveal.visible { opacity: 1; transform: translateY(0); }

    /* =====================================================
       RESPONSIVO EXTRA
       ===================================================== */
    @media (max-width: 768px) {
      section { padding: 64px 0; }
      .hero-title { letter-spacing: -1px; }
      .mockup-frame { display: none; } /* esconde mockup no mobile para performance */
    }
