/* ============================================================
   RAFAEL KENJI · app-page.css — página /app
   Hero cinematográfico + seções exclusivas. Tema claro.
============================================================ */

/* ===== HERO ===== */
.ap-hero{
  position:relative;overflow:hidden;
  background:linear-gradient(165deg,#0b1f33 0%,#0e2c47 55%,#0b1f33 100%);
  color:#fff;padding:150px 0 120px;isolation:isolate;
}
.ap-hero-bg{position:absolute;inset:0;z-index:0;overflow:hidden}
.ap-hero-bg #apDust{position:absolute;inset:0;width:100%;height:100%}
.ap-grid{
  position:absolute;inset:-2px;opacity:.5;
  background-image:linear-gradient(rgba(127,235,216,.06) 1px,transparent 1px),linear-gradient(90deg,rgba(127,235,216,.06) 1px,transparent 1px);
  background-size:46px 46px;
  -webkit-mask-image:radial-gradient(ellipse 80% 70% at 50% 40%,#000,transparent 75%);
  mask-image:radial-gradient(ellipse 80% 70% at 50% 40%,#000,transparent 75%);
}
.ap-orb{position:absolute;border-radius:50%;filter:blur(60px);opacity:.55;pointer-events:none}
.ap-orb.o1{width:460px;height:460px;background:radial-gradient(circle,rgba(4,196,164,.6),transparent 68%);top:-140px;right:-80px;animation:apFloat 14s ease-in-out infinite}
.ap-orb.o2{width:380px;height:380px;background:radial-gradient(circle,rgba(18,62,104,.9),transparent 66%);bottom:-120px;left:-60px;animation:apFloat 18s ease-in-out infinite reverse}
.ap-orb.o3{width:300px;height:300px;background:radial-gradient(circle,rgba(214,178,94,.28),transparent 68%);top:40%;left:52%;animation:apFloat 22s ease-in-out infinite}
@keyframes apFloat{0%,100%{transform:translate(0,0)}50%{transform:translate(28px,-32px)}}
.ap-hero-inner{position:relative;z-index:2;max-width:860px;margin:0 auto;text-align:center}
.ap-kick{
  display:inline-flex;align-items:center;gap:9px;
  font-size:12px;font-weight:700;letter-spacing:.24em;text-transform:uppercase;
  color:#7febd8;border:1px solid rgba(127,235,216,.4);border-radius:50px;
  padding:9px 20px;margin-bottom:26px;background:rgba(4,196,164,.06);
}
.ap-kick::before{content:"";width:7px;height:7px;border-radius:50%;background:#04c4a4;box-shadow:0 0 10px #04c4a4;animation:rkxBlink 2.2s ease-in-out infinite}
.ap-title{
  font-size:clamp(32px,6vw,58px);font-weight:900;line-height:1.08;margin:0 0 22px;letter-spacing:-.02em;color:#fff;
}
.ap-title span{
  background:linear-gradient(120deg,#04c4a4,#7febd8);
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
}
.ap-sub{font-size:clamp(16px,2.2vw,20px);color:#c3d6e6;max-width:680px;margin:0 auto 34px;line-height:1.6}
.ap-sub b{color:#fff;font-weight:600}
.ap-hero-cta{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;align-items:center}
.ap-ghost-btn{
  display:inline-flex;align-items:center;gap:8px;padding:16px 28px;border-radius:50px;
  color:#fff;text-decoration:none;font-weight:700;font-size:16px;
  border:1px solid rgba(255,255,255,.28);transition:background .25s,border-color .25s;
}
.ap-ghost-btn:hover{background:rgba(255,255,255,.08);border-color:#7febd8;color:#fff;text-decoration:none}
.ap-hero-badges{display:flex;gap:22px;justify-content:center;flex-wrap:wrap;margin-top:34px}
.ap-hero-badges span{font-size:13px;color:#9fb8cc;display:inline-flex;align-items:center;gap:8px}
.ap-hero-badges i{color:#04c4a4}
.rkx-btn.lg{padding:20px 40px;font-size:18px}

/* ===== KENJIA how ===== */
.ap-kenjia-sec{background:linear-gradient(180deg,#fff,#f4faf9)}
.ap-how{display:grid;grid-template-columns:1fr auto 1fr auto 1fr;gap:18px;align-items:stretch;margin-top:54px}
@media(max-width:820px){.ap-how{grid-template-columns:1fr}.ap-how-arrow{display:none}}
.ap-how-step{
  background:#fff;border:1px solid rgba(11,31,51,.09);border-radius:18px;padding:28px 24px;text-align:center;
  box-shadow:0 12px 34px rgba(11,31,51,.07);position:relative;
}
.ap-how-n{
  display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:50%;
  background:linear-gradient(135deg,#04c4a4,#037c69);color:#fff;font-weight:900;font-size:19px;margin-bottom:14px;
  box-shadow:0 8px 22px rgba(4,196,164,.4);
}
.ap-how-step h4{font-size:18px;font-weight:800;color:#0b1f33;margin:0 0 8px}
.ap-how-step p{font-size:14px;color:#5c6b7a;margin:0}
.ap-how-arrow{display:flex;align-items:center;color:#04c4a4;font-size:26px}

/* ===== recursos ===== */
.ap-feats-sec{background:#fff}
.ap-feats{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:20px}
@media(max-width:900px){.ap-feats{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.ap-feats{grid-template-columns:1fr}}
.ap-feat{
  background:linear-gradient(180deg,#fff,#f7fbfa);border:1px solid rgba(11,31,51,.08);border-radius:18px;
  padding:26px 24px;transition:transform .35s cubic-bezier(.2,.7,.2,1),box-shadow .35s,border-color .35s;
  position:relative;overflow:hidden;
}
.ap-feat::after{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,#04c4a4,transparent);opacity:0;transition:opacity .3s}
.ap-feat:hover{transform:translateY(-6px);box-shadow:0 24px 50px rgba(11,31,51,.12);border-color:rgba(4,196,164,.4)}
.ap-feat:hover::after{opacity:1}
.ap-feat .ic{width:46px;height:46px;border-radius:13px;display:flex;align-items:center;justify-content:center;background:rgba(4,196,164,.1);color:#037c69;font-size:19px;margin-bottom:14px}
.ap-feat h4{font-size:17px;font-weight:800;color:#0b1f33;margin:0 0 6px}
.ap-feat p{font-size:14px;color:#5c6b7a;margin:0;line-height:1.55}

/* ===== stats ===== */
.ap-stats-sec{background:linear-gradient(165deg,#0b1f33,#0e2c47);padding:70px 15px;color:#fff}
.ap-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
@media(max-width:760px){.ap-stats{grid-template-columns:repeat(2,1fr)}}
.ap-stat{text-align:center;padding:22px 12px;border-right:1px solid rgba(127,235,216,.14)}
.ap-stat:last-child{border-right:none}
@media(max-width:760px){.ap-stat{border-right:none;border-bottom:1px solid rgba(127,235,216,.12);padding-bottom:22px}}
.ap-stat .n{font-size:clamp(38px,6vw,54px);font-weight:900;background:linear-gradient(120deg,#04c4a4,#7febd8);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;line-height:1}
.ap-stat .l{font-size:13px;letter-spacing:.06em;color:#9fb8cc;margin-top:10px;text-transform:uppercase;font-weight:600}

/* ===== CTA final ===== */
.ap-cta-sec{position:relative;overflow:hidden;background:#0b1f33;padding:100px 15px;color:#fff;isolation:isolate}
.ap-cta-bg{position:absolute;inset:0;z-index:0}
.ap-cta-bg .ap-orb.o1{width:420px;height:420px;background:radial-gradient(circle,rgba(4,196,164,.5),transparent 68%);top:-100px;left:8%}
.ap-cta-bg .ap-orb.o2{width:360px;height:360px;background:radial-gradient(circle,rgba(214,178,94,.3),transparent 66%);bottom:-120px;right:6%}
.ap-cta{position:relative;z-index:2;max-width:720px;margin:0 auto;text-align:center}
.ap-exclusivo{display:inline-flex;align-items:center;gap:8px;font-size:12px;font-weight:700;color:#f0d79a;background:rgba(214,178,94,.14);border:1px solid rgba(214,178,94,.45);border-radius:50px;padding:9px 18px;margin-bottom:22px}
.ap-cta h2{font-size:clamp(28px,4.6vw,42px);font-weight:900;line-height:1.14;margin:0 0 16px;color:#fff}
.ap-cta h2 em{font-style:normal;background:linear-gradient(120deg,#04c4a4,#7febd8);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.ap-cta p{font-size:17px;color:#c3d6e6;max-width:560px;margin:0 auto 30px;line-height:1.6}
.ap-cta-note{font-size:13px;color:#8ba7bd;margin-top:16px}

to{transform:scale(1.65);opacity:0}}

@media(prefers-reduced-motion:reduce){
  .ap-orb,.rkx-fab-page::before{animation:none}
}

/* ===== COMPARAÇÃO ===== */
.ap-compare-sec{background:linear-gradient(180deg,#f4faf9,#fff)}
.ap-compare{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:20px}
@media(max-width:760px){.ap-compare{grid-template-columns:1fr}}
.ap-col{border-radius:20px;padding:30px 28px;border:1px solid rgba(11,31,51,.08)}
.ap-col-head{display:flex;align-items:center;gap:10px;font-size:17px;font-weight:800;margin-bottom:18px;letter-spacing:.01em}
.ap-col ul{list-style:none;padding:0;margin:0;display:grid;gap:13px}
.ap-col li{position:relative;padding-left:26px;font-size:14.5px;line-height:1.5;color:#42536280}
.ap-col li::before{position:absolute;left:0;top:1px;font-family:Arial;font-weight:900}
.ap-col-bad{background:#fbf4f4;border-color:rgba(200,80,80,.16)}
.ap-col-bad .ap-col-head{color:#b64a4a}
.ap-col-bad li{color:#7a6b6b}
.ap-col-bad li::before{content:"✕";color:#d68a8a;font-size:12px}
.ap-col-good{background:linear-gradient(180deg,#eefaf6,#fff);border-color:rgba(4,196,164,.3);box-shadow:0 20px 50px rgba(4,196,164,.12)}
.ap-col-good .ap-col-head{color:#037c69}
.ap-col-good li{color:#2a4a41}
.ap-col-good li::before{content:"✓";color:#04c4a4;font-weight:900}

/* ===== DEPOIMENTOS ===== */
.ap-voices-sec{background:#fff}
.ap-voices{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:20px}
@media(max-width:820px){.ap-voices{grid-template-columns:1fr}}
.ap-voice{margin:0;background:linear-gradient(180deg,#fff,#f7fbfa);border:1px solid rgba(11,31,51,.08);border-radius:18px;padding:26px 24px;box-shadow:0 12px 34px rgba(11,31,51,.06);transition:transform .35s,box-shadow .35s}
.ap-voice:hover{transform:translateY(-5px);box-shadow:0 24px 50px rgba(11,31,51,.1)}
.ap-stars{color:#d6b25e;letter-spacing:.15em;font-size:15px;margin-bottom:12px;text-shadow:0 0 14px rgba(214,178,94,.4)}
.ap-voice blockquote{margin:0 0 14px;font-size:14.5px;line-height:1.6;color:#2a3b48;font-style:italic}
.ap-voice figcaption{font-size:13px;color:#5c6b7a;font-weight:600}
.ap-voices-note{text-align:center;margin-top:26px}
.ap-voices-note a{color:#037c69;font-weight:700;text-decoration:none;font-size:15px}
.ap-voices-note a:hover{text-decoration:underline}

/* ===== FAQ ===== */
.ap-faq-sec{background:linear-gradient(180deg,#f4faf9,#fff)}
.ap-faq-wrap{max-width:820px}
.ap-faq{margin-top:14px}
.ap-faq details{background:#fff;border:1px solid rgba(11,31,51,.09);border-radius:14px;margin-bottom:12px;overflow:hidden;transition:border-color .25s,box-shadow .25s}
.ap-faq details[open]{border-color:rgba(4,196,164,.4);box-shadow:0 12px 30px rgba(11,31,51,.07)}
.ap-faq summary{cursor:pointer;list-style:none;padding:19px 22px;display:flex;justify-content:space-between;align-items:center;gap:20px;font-size:16px;font-weight:700;color:#0b1f33;transition:color .2s}
.ap-faq summary::-webkit-details-marker{display:none}
.ap-faq summary::after{content:"+";font-size:24px;color:#04c4a4;transition:transform .25s;flex-shrink:0;line-height:1}
.ap-faq details[open] summary{color:#037c69}
.ap-faq details[open] summary::after{transform:rotate(45deg)}
.ap-faq .a,.ap-faq details p{padding:0 22px 20px;margin:0;font-size:14.5px;line-height:1.65;color:#5c6b7a}
.ap-faq details p b{color:#0b1f33}

/* ===== BANCO DE RECEITAS ===== */
.ap-bank-sec{background:linear-gradient(180deg,#fff,#f4faf9)}
.ap-bank{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:20px}
@media(max-width:900px){.ap-bank{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.ap-bank{grid-template-columns:1fr}}
.ap-bank-card{
  position:relative;background:#fff;border:1px solid rgba(11,31,51,.08);border-radius:18px;
  padding:26px 22px;box-shadow:0 12px 34px rgba(11,31,51,.06);overflow:hidden;
  transition:transform .35s cubic-bezier(.2,.7,.2,1),box-shadow .35s,border-color .35s;
}
.ap-bank-card:hover{transform:translateY(-6px);box-shadow:0 24px 50px rgba(11,31,51,.12);border-color:rgba(4,196,164,.4)}
.ap-bank-card .ic{width:48px;height:48px;border-radius:14px;display:flex;align-items:center;justify-content:center;background:rgba(4,196,164,.1);color:#037c69;font-size:20px;margin-bottom:14px}
.ap-bank-card h4{font-size:16px;font-weight:800;color:#0b1f33;margin:0 0 7px;line-height:1.25}
.ap-bank-card p{font-size:13.5px;color:#5c6b7a;margin:0;line-height:1.55}
.ap-bank-hi{background:linear-gradient(165deg,#0b1f33,#0e2c47);border-color:transparent}
.ap-bank-hi::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#04c4a4,#7febd8,#04c4a4)}
.ap-bank-hi .ic{background:rgba(4,196,164,.16);color:#7febd8}
.ap-bank-hi h4{color:#fff}
.ap-bank-hi p{color:#b9cfe0}
.ap-bank-note{text-align:center;margin-top:26px;font-size:14px;color:#037c69;font-weight:600}
.ap-bank-note i{margin-right:6px}

/* ===== estrelas CSS (garantia visual, independe de canvas/JS) ===== */
.ap-stars-css{position:absolute;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.ap-stars-css::before,.ap-stars-css::after{
  content:"";position:absolute;inset:0;
  background-image:
    radial-gradient(1.4px 1.4px at 12% 22%, rgba(127,235,216,.9), transparent),
    radial-gradient(1.2px 1.2px at 28% 68%, rgba(127,235,216,.7), transparent),
    radial-gradient(1.6px 1.6px at 46% 34%, rgba(255,255,255,.8), transparent),
    radial-gradient(1.2px 1.2px at 63% 58%, rgba(127,235,216,.7), transparent),
    radial-gradient(1.5px 1.5px at 78% 26%, rgba(255,255,255,.7), transparent),
    radial-gradient(1.3px 1.3px at 88% 64%, rgba(127,235,216,.8), transparent),
    radial-gradient(1.1px 1.1px at 36% 82%, rgba(127,235,216,.6), transparent),
    radial-gradient(1.4px 1.4px at 70% 88%, rgba(255,255,255,.6), transparent),
    radial-gradient(1.2px 1.2px at 18% 48%, rgba(127,235,216,.7), transparent),
    radial-gradient(1.3px 1.3px at 54% 14%, rgba(255,255,255,.7), transparent);
  animation:apTwinkle 4.5s ease-in-out infinite;
}
.ap-stars-css::after{animation-delay:2.2s;opacity:.6;transform:scale(1.3)}
@keyframes apTwinkle{0%,100%{opacity:.35}50%{opacity:.95}}
@media(prefers-reduced-motion:reduce){.ap-stars-css::before,.ap-stars-css::after{animation:none;opacity:.6}}
