/* =================================================================
   LP — Shared landing-page primitives
   Loaded by V3Layout.astro · used by /integrations, /pricing, /about,
   and any future landing surface.

   Page root: <main class="lp lp-{pagename}">
   Page-unique styles live in each page's <style> block, scoped to
   .lp-{pagename} so they can't leak.

   Tokens already defined globally in v3-styles.css:
     --surface-page · --fg-1 · --fg-3 · --gold-500/600/700 · --font-display
   ================================================================= */

.lp{
  background:var(--surface-page);
  color:var(--fg-1);
}
.lp .wrap{
  max-width:1240px;
  margin:0 auto;
  padding:0 32px;
}

/* -------------------------- Buttons -------------------------- */
.lp-btn{
  display:inline-flex; align-items:center; gap:8px;
  padding:13px 22px;
  border-radius:12px;
  font-size:15px;
  font-weight:600;
  text-decoration:none;
  font-family:inherit;
  cursor:pointer; border:none;
  transition:opacity .15s ease, background .15s ease, border-color .15s ease, transform .15s ease;
}
.lp-btn--primary{
  background:var(--fg-1);
  color:#fff !important;
}
.lp-btn--primary:hover{
  opacity:.88;
  color:#fff !important;
  background:var(--fg-1);
}
.lp-btn--ghost{
  background:transparent;
  color:var(--fg-1) !important;
  border:1px solid rgba(11,11,12,.16);
}
.lp-btn--ghost:hover{
  border-color:var(--fg-1);
  color:var(--fg-1) !important;
  background:rgba(11,11,12,.04);
}
.lp-btn--dark{
  background:var(--fg-1);
  color:#fff !important;
}
.lp-btn--dark:hover{
  background:#1a1a1a;
  color:#fff !important;
}
.lp-btn--full{ width:100%; justify-content:center; }
.lp-btn--lg{ padding:16px 28px; font-size:16px; }

/* On dark sections */
.lp-section--dark .lp-btn--ghost{
  color:#fff;
  border-color:rgba(255,255,255,.20);
}
.lp-section--dark .lp-btn--ghost:hover{ border-color:#fff; }

/* -------------------------- Hero -------------------------- */
.lp-hero{
  padding:96px 0 72px;
  background:
    radial-gradient(ellipse 60% 80% at 0% 100%, rgba(225,200,126,0.10), transparent 70%),
    linear-gradient(180deg, #FAFAF7 0%, #F7F1E0 100%);
  border-bottom:1px solid rgba(11,11,12,0.06);
}
.lp-eyebrow{
  font-size:12px; font-weight:600;
  letter-spacing:.10em; text-transform:uppercase;
  color:var(--fg-3);
  margin-bottom:18px;
}
.lp-eyebrow--accent{ color:var(--gold-700); }
.lp-hero h1{
  font-family:var(--font-display);
  font-weight:500;
  font-size:clamp(40px, 5vw, 64px);
  letter-spacing:-.026em;
  line-height:1.05;
  margin:0 0 24px;
  color:var(--fg-1);
  max-width:920px;
}
.lp-hero h1 em{ font-style:normal; color:var(--gold-600); font-weight:500; }
.lp-lede{
  font-size:18px;
  line-height:1.55;
  color:var(--fg-3);
  max-width:740px;
  margin:0 0 32px;
}
.lp-lede strong{ color:var(--fg-1); font-weight:600; }
.lp-hero-actions{ display:flex; gap:12px; flex-wrap:wrap; }

/* -------------------------- Section shells -------------------------- */
.lp-section{
  padding:96px 0;
  border-bottom:1px solid rgba(11,11,12,0.04);
}
.lp-section--dark{
  background:#0B0B0C;
  color:rgba(250,250,247,0.92);
  border-bottom:none;
}
.lp-section.lp-section--dark h2{ color:#fff; }
.lp-section--dark p{ color:rgba(250,250,247,0.72); }
.lp-section--dark .lp-section-sub{ color:rgba(250,250,247,0.62); }
.lp-section--accent{
  background:linear-gradient(180deg, #FAF5E5 0%, #FAFAF7 100%);
  border-bottom:1px solid rgba(225,200,126,0.24);
}
.lp-section--alt{ background:#fff; }

.lp-section-head{
  text-align:center;
  margin-bottom:48px;
}
.lp-section-head--left{ text-align:left; }
.lp-section-eyebrow{
  display:inline-flex; align-items:center; gap:10px;
  font-size:12px; font-weight:600;
  letter-spacing:.08em; text-transform:uppercase;
  color:var(--fg-3);
  margin-bottom:18px;
}
.lp-section--dark .lp-section-eyebrow{ color:rgba(250,250,247,0.62); }
.lp-section-eyebrow--gold{ color:var(--gold-700); }
.lp-section h2{
  font-family:var(--font-display);
  font-weight:500;
  font-size:clamp(32px, 4vw, 48px);
  letter-spacing:-.024em;
  line-height:1.08;
  margin:0 0 14px;
  color:var(--fg-1);
}
.lp-section h2 em{ font-style:normal; color:var(--gold-600); font-weight:500; }
.lp-section--dark h2 em{ color:var(--gold-500); }
.lp-section-sub{
  font-size:17px;
  line-height:1.55;
  color:var(--fg-3);
  max-width:720px;
  margin:0 auto;
}
.lp-section-head--left .lp-section-sub{ margin:0; }

/* Common inline pills used in eyebrows */
.lp-tag-mono{
  font-size:11px; font-weight:700;
  letter-spacing:.08em;
  padding:3px 8px; border-radius:6px;
  background:var(--gold-500); color:#0B0B0C;
  font-family:var(--font-mono, monospace);
}
.lp-tag-pill{
  font-size:10px; font-weight:700;
  letter-spacing:.08em;
  padding:3px 8px; border-radius:999px;
  background:var(--gold-500); color:#0B0B0C;
}

/* -------------------------- Closing CTA band -------------------------- */
.lp-cta{
  padding:96px 0;
  text-align:center;
  background:
    radial-gradient(ellipse 60% 80% at 50% 0%, rgba(225,200,126,.16), transparent 70%),
    linear-gradient(180deg, var(--surface-page) 0%, #FAF5E5 100%);
}
.lp-cta h2{
  font-family:var(--font-display);
  font-weight:500;
  font-size:clamp(40px, 5vw, 64px);
  letter-spacing:-.026em;
  line-height:1.05;
  margin:0 0 18px;
  color:var(--fg-1);
}
.lp-cta h2 em{ font-style:normal; color:var(--gold-600); font-weight:500; }
.lp-cta p{
  font-size:17px; line-height:1.6;
  color:var(--fg-3);
  max-width:640px;
  margin:0 auto 32px;
}
.lp-cta-actions{
  display:flex; gap:12px;
  justify-content:center; flex-wrap:wrap;
}

/* -------------------------- Responsive -------------------------- */
@media (max-width:920px){
  .lp .wrap{ padding:0 20px; }
  .lp-hero{ padding:64px 0 48px; }
  .lp-section{ padding:64px 0; }
  .lp-section-head{ margin-bottom:32px; }
  .lp-cta{ padding:64px 0; }
}
