/* ============================================================
   RevealLab — marketing / landing page
   Scoped .lp-* classes. Tokens only — never hardcode colors.
   Builds on theme.css + components.css (panels/pills/btns/cards).
   ============================================================ */

.lp-page{
  min-height:100%;
  background:var(--bg);
  color:var(--text);
}

/* shared section rhythm */
.lp-section{
  max-width:1120px;margin:0 auto;
  padding:84px 24px;
}
.lp-section--tight{padding:60px 24px}

.lp-eyebrow{
  display:inline-flex;align-items:center;gap:6px;
  font-size:11px;font-weight:700;letter-spacing:.09em;text-transform:uppercase;
  color:var(--brand-dark);background:var(--brand-tint);
  padding:5px 11px;border-radius:var(--r-pill);
}
.lp-h2{
  font-size:32px;line-height:1.12;font-weight:800;letter-spacing:-.02em;
  margin:16px 0 10px;color:var(--text);
}
.lp-sub{
  font-size:15px;line-height:1.6;color:var(--text-2);max-width:620px;margin:0;
}
.lp-sec-head{margin-bottom:38px}
.lp-sec-head--center{text-align:center}
.lp-sec-head--center .lp-sub{margin-left:auto;margin-right:auto}

/* ============================================================
   sticky top nav
   ============================================================ */
.lp-nav{
  position:sticky;top:0;z-index:50;
  background:rgba(255,255,255,.86);
  backdrop-filter:saturate(180%) blur(10px);
  border-bottom:1px solid var(--border);
}
.lp-nav__inner{
  max-width:1120px;margin:0 auto;
  display:flex;align-items:center;gap:18px;
  height:var(--topbar-h);padding:0 24px;
}
.lp-brand{display:flex;align-items:center;gap:9px;text-decoration:none;color:inherit}
.lp-brand__logo{display:inline-flex;color:var(--brand)}
.lp-brand__name{font-size:14px;font-weight:700;letter-spacing:-.01em;color:var(--text)}
.lp-brand__name .lp-brand__sub{color:var(--text-3);font-weight:600}
.lp-nav__links{
  margin-left:auto;display:flex;align-items:center;gap:4px;
}
.lp-nav__link{
  font-size:13px;font-weight:600;color:var(--text-2);text-decoration:none;
  padding:8px 12px;border-radius:var(--r-sm);transition:color .14s,background .14s;
}
.lp-nav__link:hover{color:var(--text);background:var(--surface-2)}
.lp-nav__cta{margin-left:8px;text-decoration:none}
@media (max-width:680px){
  .lp-nav__links .lp-nav__link{display:none}
}

/* ============================================================
   hero
   ============================================================ */
.lp-hero{
  position:relative;overflow:hidden;
  border-bottom:1px solid var(--border);
  background:
    radial-gradient(820px 380px at 12% -8%,var(--brand-tint) 0%,transparent 60%),
    radial-gradient(680px 340px at 96% 4%,var(--up-tint) 0%,transparent 58%);
}
.lp-hero__inner{
  max-width:1120px;margin:0 auto;padding:76px 24px 84px;
  display:grid;grid-template-columns:1.05fr .95fr;gap:54px;align-items:center;
}
.lp-hero__h1{
  font-size:46px;line-height:1.06;font-weight:800;letter-spacing:-.03em;
  margin:18px 0 0;color:var(--text);
}
.lp-hero__h1 .lp-hl{color:var(--brand)}
.lp-hero__h1 .lp-hl--no{
  color:var(--down);position:relative;white-space:nowrap;
}
.lp-hero__lead{
  font-size:16px;line-height:1.62;color:var(--text-2);
  margin:20px 0 0;max-width:520px;
}
.lp-hero__cta{display:flex;align-items:center;gap:12px;margin-top:30px;flex-wrap:wrap}
.lp-btn-lg{font-size:14px;padding:12px 20px;border-radius:var(--r);text-decoration:none}
.lp-trust-row{
  display:flex;align-items:center;gap:16px;margin-top:26px;flex-wrap:wrap;
  font-size:12px;color:var(--text-3);
}
.lp-trust-row__item{display:inline-flex;align-items:center;gap:6px}
.lp-trust-row__item svg{width:14px;height:14px;color:var(--up)}

/* hero visual — mini honesty gap */
.lp-gapviz{
  display:flex;flex-direction:column;gap:14px;
}
.lp-gapviz__title{
  display:flex;align-items:center;gap:8px;
  font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--text-3);
  margin-bottom:2px;
}
.lp-gapviz__cards{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.lp-mini{
  position:relative;overflow:hidden;
  display:flex;flex-direction:column;gap:12px;
  padding:16px 16px 8px;border-radius:var(--r-lg);
  background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow);
}
.lp-mini--naive{
  border-color:var(--down);
  background:linear-gradient(180deg,var(--down-tint) 0%,var(--surface) 50%);
}
.lp-mini--honest{
  border:2px solid var(--up);
  background:linear-gradient(180deg,var(--up-tint) 0%,var(--surface) 50%);
  box-shadow:0 8px 26px rgba(21,163,90,.16);
}
.lp-mini__top{display:flex;align-items:center;justify-content:space-between;gap:8px}
.lp-mini__label{font-size:11px;font-weight:600;color:var(--text-2)}
.lp-mini__nums{display:flex;gap:16px;align-items:flex-end}
.lp-mini__stat{display:flex;flex-direction:column;gap:1px}
.lp-mini__v{font-size:26px;font-weight:800;line-height:1;letter-spacing:-.01em;display:inline-flex;align-items:baseline}
.lp-mini__u{font-size:12px;font-weight:700;margin-left:2px;opacity:.7}
.lp-mini__k{font-size:9.5px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--text-3);margin-top:4px}
.lp-mini__spark{width:100%;height:48px;margin-top:auto;display:block}
.lp-gapviz__cap{
  font-size:12px;line-height:1.5;color:var(--text-2);
  padding:10px 13px;background:var(--surface-2);border:1px solid var(--border);
  border-left:3px solid var(--brand);border-radius:var(--r-sm);
}
.lp-gapviz__cap b{color:var(--text);font-weight:700}

@media (max-width:880px){
  .lp-hero__inner{grid-template-columns:1fr;gap:42px;padding:54px 24px 64px}
  .lp-hero__h1{font-size:38px}
}
@media (max-width:520px){
  .lp-hero__h1{font-size:30px}
  .lp-gapviz__cards{grid-template-columns:1fr}
}

/* ============================================================
   how it works — 3 steps
   ============================================================ */
.lp-steps{
  display:grid;grid-template-columns:repeat(3,1fr);gap:18px;
}
.lp-step{
  position:relative;padding:24px 22px;
}
.lp-step__n{
  position:absolute;top:18px;right:20px;
  font-size:34px;font-weight:800;line-height:1;color:var(--surface-3);
  font-variant-numeric:tabular-nums;letter-spacing:-.02em;
}
.lp-step__ico{
  width:44px;height:44px;border-radius:12px;
  display:inline-flex;align-items:center;justify-content:center;
  background:var(--brand-tint);color:var(--brand);margin-bottom:16px;
}
.lp-step__ico svg{width:22px;height:22px}
.lp-step--2 .lp-step__ico{background:var(--purple-tint);color:var(--purple)}
.lp-step--3 .lp-step__ico{background:var(--up-tint);color:var(--up)}
.lp-step__title{font-size:15px;font-weight:700;margin:0 0 6px;color:var(--text)}
.lp-step__body{font-size:13px;line-height:1.58;color:var(--text-2);margin:0}
.lp-step__body b{color:var(--text);font-weight:600}
@media (max-width:820px){.lp-steps{grid-template-columns:1fr}}

/* ============================================================
   what we support — the honesty section
   ============================================================ */
.lp-support{background:var(--surface);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.lp-support__grid{
  display:grid;grid-template-columns:1fr 1fr;gap:20px;
}
.lp-col{
  padding:22px 22px 8px;height:100%;
}
.lp-col--yes{border-top:3px solid var(--up)}
.lp-col--no{border-top:3px solid var(--down)}
.lp-col__head{display:flex;align-items:center;gap:10px;margin-bottom:6px}
.lp-col__badge{
  width:30px;height:30px;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;
}
.lp-col--yes .lp-col__badge{background:var(--up-tint);color:var(--up)}
.lp-col--no .lp-col__badge{background:var(--down-tint);color:var(--down)}
.lp-col__title{font-size:15px;font-weight:700;color:var(--text)}
.lp-col__sub{font-size:11.5px;color:var(--text-3);margin:0 0 14px;padding-left:40px}
.lp-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:1px}
.lp-list li{
  display:flex;align-items:flex-start;gap:10px;
  padding:9px 4px;border-bottom:1px solid var(--surface-2);
  font-size:13px;line-height:1.5;color:var(--text);
}
.lp-list li:last-child{border-bottom:none}
.lp-list li b{font-weight:600}
.lp-list li span{color:var(--text-3);font-weight:500}
.lp-tick{flex-shrink:0;margin-top:1px;display:inline-flex}
.lp-tick svg{width:16px;height:16px}
.lp-col--yes .lp-tick{color:var(--up)}
.lp-col--no .lp-tick{color:var(--down)}
.lp-callout{
  margin-top:26px;
  display:flex;align-items:flex-start;gap:13px;
  padding:16px 18px;border-radius:var(--r);
  background:var(--brand-tint);border:1px solid var(--border);
  border-left:3px solid var(--brand);
}
.lp-callout__ico{flex-shrink:0;color:var(--brand);display:inline-flex;margin-top:1px}
.lp-callout__ico svg{width:20px;height:20px}
.lp-callout__txt{font-size:13.5px;line-height:1.58;color:var(--text-2)}
.lp-callout__txt b{color:var(--text);font-weight:700}
@media (max-width:820px){.lp-support__grid{grid-template-columns:1fr}}

/* ============================================================
   pricing
   ============================================================ */
.lp-price-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:18px;align-items:stretch;
}
.lp-tier{
  display:flex;flex-direction:column;padding:26px 24px;
}
.lp-tier--feat{
  border:2px solid var(--brand);box-shadow:var(--shadow-lg);position:relative;
  transform:translateY(-8px);
}
.lp-tier__flag{
  position:absolute;top:-12px;left:50%;transform:translateX(-50%);
  font-size:10px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;
  color:#fff;background:var(--brand);padding:4px 12px;border-radius:var(--r-pill);
  white-space:nowrap;
}
.lp-tier__name{font-size:13px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--text-2);margin:0}
.lp-tier__price{display:flex;align-items:baseline;gap:3px;margin:14px 0 2px}
.lp-tier__amt{font-size:38px;font-weight:800;letter-spacing:-.02em;line-height:1;color:var(--text);font-variant-numeric:tabular-nums}
.lp-tier__per{font-size:13px;font-weight:600;color:var(--text-3)}
.lp-tier__tag{font-size:12.5px;color:var(--text-2);margin:0 0 18px;min-height:18px}
.lp-tier__feats{list-style:none;margin:0 0 22px;padding:0;display:flex;flex-direction:column;gap:11px;flex:1}
.lp-tier__feats li{display:flex;align-items:flex-start;gap:9px;font-size:13px;line-height:1.45;color:var(--text)}
.lp-tier__feats li svg{width:15px;height:15px;color:var(--up);flex-shrink:0;margin-top:1px}
.lp-tier__feats li.lp-feat-muted{color:var(--text-3)}
.lp-tier__feats li.lp-feat-muted svg{color:var(--text-3)}
.lp-tier__cta{width:100%;justify-content:center;text-decoration:none}
@media (max-width:820px){
  .lp-price-grid{grid-template-columns:1fr;max-width:420px;margin:0 auto}
  .lp-tier--feat{transform:none}
}

/* ============================================================
   faq
   ============================================================ */
.lp-faq{background:var(--surface);border-top:1px solid var(--border)}
.lp-faq__grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.lp-qa{padding:20px 22px}
.lp-qa__q{
  display:flex;align-items:flex-start;gap:10px;
  font-size:14.5px;font-weight:700;color:var(--text);margin:0 0 9px;line-height:1.4;
}
.lp-qa__q svg{width:17px;height:17px;color:var(--brand);flex-shrink:0;margin-top:2px}
.lp-qa__a{font-size:13px;line-height:1.62;color:var(--text-2);margin:0;padding-left:27px}
.lp-qa__a b{color:var(--text);font-weight:600}
.lp-qa__a code{
  font-family:var(--mono);font-size:11.5px;background:var(--surface-2);
  border:1px solid var(--border);border-radius:4px;padding:1px 5px;color:var(--text);
}
@media (max-width:760px){.lp-faq__grid{grid-template-columns:1fr}}

/* ============================================================
   final CTA + footer
   ============================================================ */
.lp-final{
  text-align:center;
  background:
    radial-gradient(700px 320px at 50% 120%,var(--brand-tint) 0%,transparent 62%);
  border-top:1px solid var(--border);
}
.lp-final__h2{font-size:30px;font-weight:800;letter-spacing:-.02em;margin:0 0 10px}
.lp-final__sub{font-size:15px;color:var(--text-2);margin:0 auto 28px;max-width:520px}
.lp-final .lp-hero__cta{justify-content:center}

.lp-footer{
  border-top:1px solid var(--border);background:var(--surface);
}
.lp-footer__inner{
  max-width:1120px;margin:0 auto;padding:28px 24px;
  display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;
}
.lp-footer__brand{display:flex;align-items:center;gap:9px;color:var(--text-2)}
.lp-footer__brand svg{color:var(--brand)}
.lp-footer__brand b{color:var(--text);font-weight:700;font-size:13px}
.lp-footer__copy{font-size:12px;color:var(--text-3)}
.lp-footer__links{display:flex;gap:18px}
.lp-footer__links a{font-size:12.5px;color:var(--text-2);text-decoration:none}
.lp-footer__links a:hover{color:var(--text)}

/* gentle scroll-reveal for sections beyond the fold */
.lp-rise{animation:fadeIn .5s ease both}

/* ============================================================
   top announcement banner
   ============================================================ */
.lp-topbar{
  /* brand-family gradient: keeps white text >=4.5:1 across the whole bar */
  background:linear-gradient(90deg,var(--brand-dark),var(--brand) 65%,var(--brand-dark));
  color:#fff;
}
.lp-topbar__inner{
  max-width:1120px;margin:0 auto;padding:0 24px;min-height:36px;
  display:flex;align-items:center;justify-content:center;gap:8px 16px;flex-wrap:wrap;
  font-size:12px;line-height:1.3;
}
.lp-topbar b{font-weight:700}
.lp-topbar__sep{opacity:.5}
.lp-topbar__ico{width:13px;height:13px;vertical-align:-2px;margin-right:2px}
.lp-topbar a{color:#fff;text-decoration:none;border-bottom:1px solid rgba(255,255,255,.55);padding-bottom:1px;transition:border-color .14s}
.lp-topbar a:hover{border-bottom-color:#fff}
.lp-topbar a:focus-visible{outline:2px solid #fff;outline-offset:2px;border-radius:3px}
.lp-topbar__live{display:inline-flex;align-items:center;gap:8px}
.lp-topbar__dot{
  width:7px;height:7px;border-radius:50%;background:#fff;
  box-shadow:0 0 0 0 rgba(255,255,255,.7);animation:lp-livepulse 1.9s infinite;
}
@keyframes lp-livepulse{
  0%{box-shadow:0 0 0 0 rgba(255,255,255,.55)}
  70%{box-shadow:0 0 0 7px rgba(255,255,255,0)}
  100%{box-shadow:0 0 0 0 rgba(255,255,255,0)}
}
@media (max-width:680px){.lp-hide-s{display:none}}

/* ============================================================
   hero background art (sealed / revealed equity curve)
   ============================================================ */
.lp-heroart{
  position:absolute;inset:0;width:100%;height:100%;z-index:0;
  pointer-events:none;opacity:.7;
  /* fade the art out toward the right so the grid never bleeds behind the
     honesty-gap cards — the "future" half of the curve dissolves, on-theme */
  -webkit-mask-image:linear-gradient(90deg,#000 0%,#000 46%,transparent 72%);
  mask-image:linear-gradient(90deg,#000 0%,#000 46%,transparent 72%);
}
.lp-hero .lp-hero__inner{position:relative;z-index:1}
/* lift the primary hero CTA with a token gradient + shadow */
.lp-hero__cta .btn--primary,.lp-final .btn--primary{
  background:linear-gradient(135deg,var(--brand),var(--brand-dark));
  border-color:var(--brand-dark);box-shadow:var(--shadow-lg);
}
.lp-hero__cta .btn--primary:hover,.lp-final .btn--primary:hover{
  background:var(--brand-dark);box-shadow:var(--shadow);transform:translateY(-1px);
}

/* ============================================================
   reveal ledger — scrolling realized-R tape
   ============================================================ */
.lp-tape{
  position:relative;z-index:1;overflow:hidden;white-space:nowrap;
  background:var(--surface-2);
  border-top:1px solid var(--border);border-bottom:1px solid var(--border);
}
.lp-tape::before,.lp-tape::after{
  content:"";position:absolute;top:0;bottom:0;width:64px;z-index:2;pointer-events:none;
}
.lp-tape::before{left:0;background:linear-gradient(90deg,var(--surface-2),transparent)}
.lp-tape::after{right:0;background:linear-gradient(270deg,var(--surface-2),transparent)}
.lp-tape__track{
  display:inline-flex;padding:11px 0;
  animation:lp-tapescroll 40s linear infinite;will-change:transform;
}
.lp-tape:hover .lp-tape__track{animation-play-state:paused}
.lp-tape__item{
  display:inline-flex;align-items:center;gap:8px;
  padding:0 22px;border-right:1px solid var(--border);
}
.lp-tape__sig{font-size:12px;font-weight:600;color:var(--text)}
.lp-tape__r{font-family:var(--mono);font-size:13px;font-weight:700;font-variant-numeric:tabular-nums}
.lp-tape__mk{font-size:11px;font-weight:700}
.lp-tape__r.up,.lp-tape__mk.up{color:var(--up)}
.lp-tape__r.down,.lp-tape__mk.down{color:var(--down)}
@keyframes lp-tapescroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ============================================================
   integration / trust strip
   ============================================================ */
.lp-built{background:var(--surface);border-bottom:1px solid var(--border)}
.lp-built__inner{
  max-width:1120px;margin:0 auto;padding:15px 24px;
  display:flex;align-items:center;justify-content:center;gap:12px 28px;flex-wrap:wrap;
}
.lp-built__label{
  font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-3);
}
.lp-built__item{
  display:inline-flex;align-items:center;gap:8px;
  font-size:12.5px;font-weight:600;color:var(--text-2);
}
.lp-built__item svg{width:16px;height:16px;color:var(--brand);flex-shrink:0}

/* honor reduced-motion for the new entrance/loop motion */
@media (prefers-reduced-motion:reduce){
  .lp-tape__track{animation:none}
  .lp-topbar__dot{animation:none}
}

/* on stacked layouts the art becomes subtle texture, never a line through copy */
@media (max-width:880px){
  .lp-heroart{opacity:.45}
}
