/* ═══════════════════════════════════════════════════════════
   Semper Signum — style.css
   Design tokens aligned to the NVIDIA Research Dashboard
   ═══════════════════════════════════════════════════════════ */

/* ── Reset ── */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}

/* ── Design Tokens (from NVIDIA report :root) ── */
:root{
  /* Tier 1 — Structural */
  --ink:#051C2C;
  --ink-90:#0E2A3F;
  --ink-70:#1E3A52;
  --ink-50:#3D5A72;
  --ink-30:#6B8299;
  --ink-15:#A3B5C5;
  --ink-08:#D4DDE5;
  --ink-04:#ECECEC;
  --ink-02:#F5F5F5;
  --white:#FFFFFF;

  /* Tier 2 — Accent */
  --accent:#2251FF;
  --accent-light:#4A90D9;
  --accent-muted:#E8EEFF;

  /* Tier 3 — Semantic */
  --positive:#1A7F5A;
  --positive-muted:#F0F8F4;
  --negative:#C53030;
  --negative-muted:#FEF4F4;
  --caution:#B7791F;
  --caution-muted:#FEFAF0;

  /* Tier 4 — Surfaces & Borders */
  --surface:var(--white);
  --card:var(--white);
  --border:var(--ink-08);
  --radius:8px;
  --radius-lg:10px;
  --shadow-xs:0 1px 2px rgba(5,28,44,0.03);
  --shadow-sm:0 1px 3px rgba(5,28,44,0.05),0 1px 2px rgba(5,28,44,0.03);
  --shadow-md:0 4px 12px rgba(5,28,44,0.07);
  --ease:180ms cubic-bezier(0.25,0.1,0.25,1);

  /* Layout — Standardized content widths */
  --content-wide:1100px;
  --content-read:800px;

  /* Fonts */
  --font-body:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;
  --font-serif:Georgia,'Times New Roman',serif;
}

html{scroll-behavior:smooth}

body{
  font-family:var(--font-body);
  background:var(--surface);
  color:var(--ink);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  font-feature-settings:'cv01','cv02','cv03','cv04';
}

a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}

/* ═══════════════════════════════════════════════════════════
   SHARED HEADER
   ═══════════════════════════════════════════════════════════ */
/* ⚠️ Header is self-contained — do NOT rely on body-level font/color inheritance.
   All typography is declared here to stay consistent across pages. */
.site-header{
  background:var(--white);
  border-bottom:1px solid var(--border);
  height:56px;
  transition:box-shadow var(--ease);
  /* Isolation: prevent page-level styles from leaking into the header */
  font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;
  font-size:12px;
  font-weight:400;
  line-height:1.55;
  letter-spacing:normal;
  color:var(--ink);
  -webkit-font-smoothing:antialiased;
}
.site-header.scrolled{
  box-shadow:var(--shadow-md);
}
#site-header{
  position:sticky;top:0;z-index:1000;
  height:56px;min-height:56px;max-height:56px;
}
.site-header-inner{
  max-width:none;width:100%;
  padding:0 40px 0 23px;height:56px;
  display:flex;align-items:center;justify-content:space-between;
}

/* Logo wordmark — serif, wide tracking */
.logo-wordmark{
  font-family:var(--font-serif);
  font-size:15px;font-weight:700;
  letter-spacing:4px;
  color:var(--ink);
  text-transform:uppercase;
  position:relative;
  padding-bottom:4px;
}
.logo-wordmark::after{
  content:'';position:absolute;
  bottom:0;left:0;right:0;
  height:1.5px;background:var(--ink);
}

/* Nav */
.nav-links{display:flex;gap:24px;align-items:center}
.nav-links a{
  font-size:12px;font-weight:500;
  color:var(--ink-50);
  transition:color var(--ease);
}
.nav-links a:hover,.nav-links a.active{color:var(--ink)}
.nav-links a.nav-cta{
  background:var(--accent);color:#FFFFFF !important;
  font-weight:800;
  padding:8px 20px;border-radius:6px;
  white-space:nowrap;line-height:1;
  display:inline-flex;align-items:center;justify-content:center;
  min-height:34px;box-sizing:border-box;
  transition:opacity var(--ease);
  text-decoration:none;
}
.nav-cta:hover{opacity:0.85}

/* Burger (mobile) */
.burger{display:none;background:none;border:none;cursor:pointer;padding:4px}
.burger span{display:block;width:20px;height:2px;background:var(--ink);margin:4px 0;transition:all var(--ease)}

/* ═══════════════════════════════════════════════════════════
   SHARED FOOTER — Dark Institutional Panel
   ═══════════════════════════════════════════════════════════ */
.site-footer{
  background:var(--ink);
  padding:0 0 0 0;
  overflow:hidden;
  border-top:2px solid var(--accent);
  text-align:left;
  color:rgba(255,255,255,0.55);
}
.footer-cta-strip{
  padding:18px 40px;
  display:flex;align-items:center;justify-content:center;gap:24px;
  border-bottom:1px solid rgba(255,255,255,0.08);
  background:transparent;
}
.footer-cta-text{
  font-size:14px;font-weight:500;color:rgba(255,255,255,0.65);
}
.footer-cta-btn{
  display:inline-block;
  background:var(--accent);color:#fff;
  font-size:13px;font-weight:700;
  padding:10px 28px;border-radius:8px;
  white-space:nowrap;
  box-shadow:0 2px 8px rgba(34,81,255,0.2);
  transition:transform 0.2s ease,box-shadow 0.2s ease;
}
.footer-cta-btn:hover{
  transform:translateY(-1px);
  box-shadow:0 4px 12px rgba(34,81,255,0.3);
}
.footer-inner{
  display:flex;justify-content:space-between;align-items:flex-start;
  gap:48px;max-width:1200px;margin:0 auto;
  padding:36px 40px 0;
}
.footer-brand{flex:1;min-width:240px}
.footer-columns{display:flex;gap:40px;flex-shrink:0}
.footer-col{display:flex;flex-direction:column;gap:8px;min-width:120px}
.footer-col-heading{font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:#fff;margin-bottom:4px}
.footer-col a{font-size:12px;color:rgba(255,255,255,0.55);transition:color var(--ease);line-height:1.6}
.footer-col a:hover{color:#fff}
.footer-contact{margin-top:16px}
.footer-bottom{max-width:1200px;margin:0 auto;padding:20px 40px;border-top:1px solid rgba(255,255,255,0.08);margin-top:28px}
.footer-wordmark{
  font-family:var(--font-serif);
  font-size:14px;font-weight:700;
  letter-spacing:4px;
  color:#fff;
  text-transform:uppercase;
  margin-bottom:8px;
}
.footer-descriptor{
  font-size:12px;font-weight:600;color:rgba(255,255,255,0.55);
  letter-spacing:0.5px;margin-bottom:2px;
}
.footer-tagline{
  font-size:11px;color:rgba(255,255,255,0.35);
  line-height:1.5;
}
.footer-nav{
  display:flex;gap:16px;justify-content:flex-start;margin-top:6px;
}
.footer-nav a,.footer-col a{
  font-size:11px;font-weight:500;
  color:rgba(255,255,255,0.55);
  transition:color var(--ease);
}
.footer-nav a:hover{color:#fff}
.footer-email{
  font-size:11px;color:rgba(255,255,255,0.45);
  margin-bottom:6px;
}
.footer-email a{
  color:var(--accent-light);transition:opacity var(--ease);
}
.footer-email a:hover{opacity:0.7}
.footer-founder{
  font-size:11px;color:rgba(255,255,255,0.45);
  display:flex;align-items:center;justify-content:flex-start;gap:6px;
}
.footer-founder a{
  color:var(--accent-light);transition:opacity var(--ease);
  display:inline-flex;align-items:center;
}
.footer-founder a:hover{opacity:0.7}
.footer-linkedin-icon{
  width:14px;height:14px;
  fill:#fff;
  display:block;
}
.footer-legal{
  font-size:10px;color:rgba(255,255,255,0.3);
  line-height:1.6;
}

/* ═══════════════════════════════════════════════════════════
   HERO (compact, dark)
   ═══════════════════════════════════════════════════════════ */
.hero{
  background:radial-gradient(ellipse at 50% 0%, #0E2A3F 0%, #051C2C 70%);
  padding:72px 24px 64px;
  text-align:center;
}
.hero-eyebrow{
  font-size:11px;font-weight:600;
  text-transform:uppercase;letter-spacing:2px;
  color:var(--accent-light);
  margin-bottom:20px;
}
.hero h1{
  color:var(--white);
  font-size:40px;font-weight:800;
  letter-spacing:-0.5px;line-height:1.2;
  margin-bottom:20px;
  max-width:720px;margin-left:auto;margin-right:auto;
}
.hero-sub{
  color:rgba(255,255,255,0.55);
  font-size:15px;margin-bottom:36px;
  max-width:620px;margin-left:auto;margin-right:auto;
  line-height:1.7;
}
.hero-ctas{
  display:flex;gap:14px;justify-content:center;flex-wrap:wrap;
}
.btn-hero-primary{
  display:inline-block;
  background:var(--accent);color:var(--white);
  font-size:14px;font-weight:700;
  padding:14px 36px;border-radius:var(--radius);
  transition:opacity var(--ease);
  box-shadow:0 4px 16px rgba(34,81,255,0.3);
}
.btn-hero-primary:hover{opacity:0.85}
.btn-hero-secondary{
  display:inline-block;
  background:rgba(255,255,255,0.08);color:rgba(255,255,255,0.7);
  font-size:14px;font-weight:600;
  padding:14px 36px;border-radius:var(--radius);
  border:1px solid rgba(255,255,255,0.12);
  transition:all var(--ease);
}
.btn-hero-secondary:hover{
  background:rgba(255,255,255,0.12);color:var(--white);
}

/* ═══════════════════════════════════════════════════════════
   TWO OFFERINGS
   ═══════════════════════════════════════════════════════════ */
.offerings{
  max-width:1000px;margin:0 auto;
  padding:64px 24px 48px;
  text-align:center;
}
.offerings-heading{
  font-size:22px;font-weight:800;color:var(--ink);
  margin-bottom:12px;letter-spacing:-0.3px;
}
.offerings-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:20px;
  text-align:left;margin-top:32px;
}
.offering-card{
  padding:32px 28px;
  background:var(--white);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  transition:box-shadow var(--ease);
}
.offering-card:hover{
  box-shadow:var(--shadow-md);
}
.offering-icon{
  font-size:28px;margin-bottom:16px;
  color:var(--accent);
}
.offering-card h3{
  font-size:16px;font-weight:700;color:var(--ink);
  margin-bottom:10px;
}
.offering-card p{
  font-size:13px;color:var(--ink-50);line-height:1.65;
  margin-bottom:16px;
}
.offering-link{
  font-size:12px;font-weight:700;color:var(--accent);
  transition:opacity var(--ease);
}
.offering-link:hover{opacity:0.7}

/* ═══════════════════════════════════════════════════════════
   SHOWCASE HEADING (demo section)
   ═══════════════════════════════════════════════════════════ */
.showcase-heading{
  font-size:20px;font-weight:800;color:var(--ink);
  text-align:center;margin-bottom:8px;letter-spacing:-0.3px;
}
.showcase-sub{
  font-size:13px;color:var(--ink-50);
  text-align:center;margin-bottom:32px;
}

/* ═══════════════════════════════════════════════════════════
   REPORT SHOWCASE
   ═══════════════════════════════════════════════════════════ */
.showcase{
  max-width:1100px;margin:0 auto;
  padding:48px 24px 64px;
}
.showcase-frame{
  background:var(--white);
  border:1px solid var(--border);
  border-radius:12px;overflow:hidden;
  box-shadow:0 12px 48px rgba(5,28,44,0.12);
}
.showcase-bar{
  background:var(--ink);
  padding:10px 16px;
  display:flex;align-items:center;gap:6px;
}
.showcase-dot{width:8px;height:8px;border-radius:50%}
.showcase-dot:nth-child(1){background:#ff5f57}
.showcase-dot:nth-child(2){background:#ffbd2e}
.showcase-dot:nth-child(3){background:#28c840}
.showcase-tabs{
  display:flex;gap:0;
  background:var(--white);
  border-bottom:1px solid var(--border);
  overflow-x:auto;
}
.showcase-tab{
  padding:12px 20px;
  font-size:11px;font-weight:600;
  color:var(--ink-30);
  border-bottom:2px solid transparent;
  white-space:nowrap;cursor:default;
}
.showcase-tab.active{
  color:var(--accent);
  border-bottom-color:var(--accent);
}
.showcase-body{padding:28px;min-height:360px}
.showcase-header{
  background:var(--ink);color:var(--white);
  padding:12px 18px;border-radius:var(--radius);
  font-size:12px;font-weight:700;
  margin-bottom:20px;
  display:flex;justify-content:space-between;align-items:center;
}
.showcase-kpis{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:12px;margin-bottom:20px;
}
.showcase-kpi{
  background:var(--ink-02);
  border:1px solid var(--border);
  border-left:3px solid var(--accent);
  border-radius:6px;padding:14px 16px;
}
.showcase-kpi-label{
  font-size:9px;text-transform:uppercase;
  letter-spacing:0.6px;color:var(--ink-30);font-weight:600;
}
.showcase-kpi-val{
  font-size:20px;font-weight:800;color:var(--ink);
}
.showcase-kpi-sub{
  font-size:10px;color:var(--ink-30);margin-top:2px;
}
.showcase-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:16px;
}
.showcase-card{
  background:var(--ink-02);
  border:1px solid var(--border);
  border-radius:var(--radius);padding:20px;
}
.showcase-card h4{
  font-size:11px;font-weight:700;color:var(--ink);
  margin-bottom:8px;text-transform:uppercase;letter-spacing:0.3px;
}
.showcase-card p{
  font-size:12px;color:var(--ink-50);line-height:1.6;
}
.showcase-chart-placeholder{
  height:120px;display:flex;align-items:flex-end;gap:8px;padding-top:12px;
}
.showcase-chart-bar{
  flex:1;background:var(--accent);
  border-radius:4px 4px 0 0;opacity:0.8;
}
.showcase-cta{text-align:center;padding:32px 0 8px}

/* Buttons */
.btn-large{
  display:inline-block;
  background:var(--accent);color:var(--white);
  font-size:16px;font-weight:700;
  padding:18px 48px;border-radius:var(--radius-lg);
  transition:opacity var(--ease);
  box-shadow:0 4px 16px rgba(34,81,255,0.3);
}
.btn-large:hover{opacity:0.85}

/* ═══════════════════════════════════════════════════════════
   VALUE PROPS
   ═══════════════════════════════════════════════════════════ */
.props{
  max-width:1000px;margin:0 auto;
  padding:64px 24px;
  text-align:center;
}
.props-heading{
  font-size:22px;font-weight:800;color:var(--ink);
  margin-bottom:32px;letter-spacing:-0.3px;
}
.props-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:20px;
  text-align:left;
}
.prop{
  display:flex;gap:14px;align-items:flex-start;
  padding:24px;
  background:var(--white);
  border:1px solid var(--border);
  border-radius:var(--radius);
}
.prop-dot{
  width:8px;height:8px;border-radius:50%;
  background:var(--accent);flex-shrink:0;margin-top:5px;
}
.prop-text h3{
  font-size:13px;font-weight:700;color:var(--ink);margin-bottom:4px;
}
.prop-text p{
  font-size:12px;color:var(--ink-50);line-height:1.6;
}

/* ═══════════════════════════════════════════════════════════
   CONTACT FORM
   ═══════════════════════════════════════════════════════════ */
.contact{
  max-width:600px;margin:0 auto;
  padding:48px 24px 72px;text-align:center;
  scroll-margin-top:72px;
}
.contact h2{
  font-size:24px;font-weight:800;color:var(--ink);margin-bottom:8px;
}
.contact>p{
  font-size:13px;color:var(--ink-50);margin-bottom:32px;
}
.form{
  display:flex;flex-direction:column;gap:12px;text-align:left;
}
.form input,.form textarea{
  width:100%;padding:12px 16px;
  border:1px solid var(--border);border-radius:var(--radius);
  font-family:var(--font-body);font-size:13px;
  background:var(--white);color:var(--ink);
  outline:none;transition:border-color var(--ease);
}
.form input:focus,.form textarea:focus{
  border-color:var(--accent);
}
.form textarea{resize:vertical;min-height:80px}
.form button{
  background:var(--accent);color:var(--white);
  border:none;padding:14px;border-radius:var(--radius);
  font-family:var(--font-body);font-size:14px;font-weight:600;
  cursor:pointer;transition:opacity var(--ease);
}
.form button:hover{opacity:0.85}
.form button:disabled{opacity:0.5;cursor:not-allowed}

/* Confirmation message */
.form-confirmation{
  display:none;
  padding:24px;
  background:#eef3ff;
  border:1px solid var(--accent);
  border-radius:var(--radius);
  color:var(--ink);
  font-size:14px;line-height:1.6;
  text-align:center;
}
.form-confirmation.visible{display:block}

/* ═══════════════════════════════════════════════════════════
   METHODOLOGY / COMMITMENT TO RIGOR
   ═══════════════════════════════════════════════════════════ */
.methodology{
  max-width:800px;margin:0 auto;
  padding:48px 24px 48px;
  border-top:1px solid var(--border);
}
.methodology h3{
  font-size:16px;font-weight:800;color:var(--ink);
  margin-bottom:16px;text-align:center;
}
.methodology p{
  font-size:12px;color:var(--ink-50);
  line-height:1.75;margin-bottom:12px;
}
.methodology p:last-child{margin-bottom:0}
.methodology strong{color:var(--ink);font-weight:600}

/* ═══════════════════════════════════════════════════════════
   STICKY CTA BAR (demo page)
   ═══════════════════════════════════════════════════════════ */
.sticky-cta{
  position:fixed;bottom:0;left:0;right:0;
  background:var(--ink);
  border-top:1px solid rgba(255,255,255,0.08);
  padding:12px 24px;
  display:flex;align-items:center;justify-content:center;gap:16px;
  z-index:999;
  transform:translateY(100%);
  transition:transform 0.3s ease;
}
.sticky-cta.visible{transform:translateY(0)}
.sticky-cta p{
  color:rgba(255,255,255,0.6);
  font-size:13px;font-weight:500;
}
.sticky-cta .btn-sticky{
  background:var(--accent);color:var(--white);
  font-size:12px;font-weight:600;
  padding:8px 20px;border-radius:6px;
  transition:opacity var(--ease);
}
.sticky-cta .btn-sticky:hover{opacity:0.85}

/* Mobile note */
.mobile-note{
  display:none;
  background:var(--caution-muted);
  border-bottom:1px solid var(--caution);
  padding:10px 24px;
  text-align:center;
  font-size:11px;color:var(--ink-50);
}
.mobile-note button{
  background:none;border:none;
  color:var(--ink-30);font-size:14px;
  cursor:pointer;margin-left:8px;
  vertical-align:middle;
}

/* ═══════════════════════════════════════════════════════════
   RESPONSIVE
   ═══════════════════════════════════════════════════════════ */
@media(max-width:768px){
  .burger{display:block}
  .nav-links{
    display:none;
    position:absolute;top:56px;left:0;right:0;
    background:var(--white);
    border-bottom:1px solid var(--border);
    flex-direction:column;
    padding:16px 24px;gap:12px;
    box-shadow:var(--shadow-md);
  }
  .nav-links.open{display:flex}
  .showcase-kpis{grid-template-columns:1fr 1fr}
  .showcase-grid{grid-template-columns:1fr}
  .props-grid{grid-template-columns:1fr}
  .hero h1{font-size:28px}
  .hero-sub{font-size:13px}
  .offerings-grid{grid-template-columns:1fr}
  .mobile-note{display:block}
  .footer-cta-strip{flex-direction:column;text-align:center;padding:24px 20px;gap:14px}
  .footer-inner{flex-direction:column;gap:24px;padding:28px 20px 0}
  .footer-columns{flex-wrap:wrap;gap:24px}
  .footer-founder{justify-content:flex-start}
  .footer-bottom{padding:16px 20px}
  .footer-email a,.footer-founder{word-break:break-all}
}
@media(max-width:480px){
  .showcase-kpis{grid-template-columns:1fr}
  .site-header-inner{padding:0 16px}
  .logo-wordmark{font-size:12px;letter-spacing:3px}
}

/* ═══════════════════════════════════════════════════════════
   WEBFLOW-STYLE LIGHT THEME — .page-core-offering
   Premium light aesthetic: Inter font, generous spacing,
   refined shadows, subtle animations. NVIDIA report unaffected.
   ═══════════════════════════════════════════════════════════ */

/* ── Scroll reveal ── */
.page-core-offering .reveal{
  opacity:0;transform:translateY(28px);
  transition:opacity 0.8s cubic-bezier(0.16,1,0.3,1),transform 0.8s cubic-bezier(0.16,1,0.3,1);
}
.page-core-offering .reveal.in-view{
  opacity:1;transform:translateY(0);
}

/* ── Global ── */
.page-core-offering{
  background:#FFFFFF;
  color:var(--ink);
  font-family:'Inter',var(--font-body);
}

/* ── Section typography ── */
.page-core-offering .section-eyebrow{
  font-size:11px;font-weight:700;
  text-transform:uppercase;letter-spacing:3px;
  color:var(--accent);
  margin-bottom:16px;
  text-align:center;
}
.page-core-offering .showcase .section-eyebrow{
  color:rgba(255,255,255,0.45);
}
.page-core-offering .section-heading{
  font-size:36px;font-weight:800;
  color:var(--ink);text-align:center;
  letter-spacing:-0.8px;margin-bottom:14px;
  line-height:1.15;
}
.page-core-offering .section-sub{
  font-size:16px;color:var(--ink-50);
  text-align:center;margin-bottom:52px;
  max-width:560px;margin-left:auto;margin-right:auto;
  line-height:1.7;
}
.page-core-offering .section-rule{
  width:48px;height:2px;
  background:linear-gradient(90deg,var(--accent),var(--accent-light));
  margin:0 auto 44px;border-radius:2px;
}

/* ═══ HERO (light, atmospheric) ═══ */
.page-core-offering .hero{
  position:relative;overflow:hidden;
  background:linear-gradient(180deg,#F5F5F5 0%,#EBEBEB 100%);
  padding:140px 24px 100px;
  text-align:center;
}
.page-core-offering .hero-orb{
  position:absolute;
  top:-200px;left:50%;transform:translateX(-50%);
  width:900px;height:900px;
  background:radial-gradient(circle,rgba(34,81,255,0.06) 0%,rgba(74,144,217,0.03) 40%,transparent 70%);
  pointer-events:none;
  animation:orbPulseLight 10s ease-in-out infinite alternate;
}
@keyframes orbPulseLight{
  0%{opacity:0.6;transform:translateX(-50%) scale(1)}
  100%{opacity:1;transform:translateX(-50%) scale(1.1)}
}
.page-core-offering .hero-eyebrow{
  font-size:11px;font-weight:700;
  text-transform:uppercase;letter-spacing:3.5px;
  color:var(--accent);
  margin-bottom:28px;
  position:relative;
}
.page-core-offering .hero h1{
  color:var(--ink);
  font-size:clamp(32px,5vw,44px);font-weight:900;
  letter-spacing:-1.5px;line-height:1.12;
  margin-bottom:24px;
  max-width:900px;margin-left:auto;margin-right:auto;
  position:relative;
}
.page-core-offering .hero-gradient-text{
  background:linear-gradient(135deg,var(--ink) 0%,var(--accent) 100%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;
}
.page-core-offering .hero-sub{
  color:var(--ink-50);
  font-size:17px;margin-bottom:48px;
  max-width:620px;margin-left:auto;margin-right:auto;
  line-height:1.75;position:relative;
}
.page-core-offering .hero-ctas{
  display:flex;gap:16px;justify-content:center;flex-wrap:wrap;
  position:relative;
}
.page-core-offering .btn-hero-primary{
  display:inline-block;
  background:var(--ink);color:#fff;
  font-size:15px;font-weight:700;
  padding:16px 44px;border-radius:12px;
  transition:all 0.3s cubic-bezier(0.16,1,0.3,1);
  box-shadow:0 4px 16px rgba(5,28,44,0.15);
}
.page-core-offering .btn-hero-primary:hover{
  box-shadow:0 8px 28px rgba(5,28,44,0.22);
  transform:translateY(-2px);
}
.page-core-offering .btn-hero-secondary{
  display:inline-block;
  background:transparent;color:var(--ink-50);
  font-size:15px;font-weight:600;
  padding:16px 44px;border-radius:12px;
  border:1.5px solid var(--ink-08);
  transition:all 0.3s cubic-bezier(0.16,1,0.3,1);
}
.page-core-offering .btn-hero-secondary:hover{
  border-color:var(--ink-15);color:var(--ink);
  box-shadow:0 4px 12px rgba(5,28,44,0.06);
}
.page-core-offering .hero-scroll-hint{
  margin-top:60px;
  color:var(--ink-15);
  animation:scrollBounceLight 2.5s ease-in-out infinite;
}
@keyframes scrollBounceLight{
  0%,100%{transform:translateY(0);opacity:0.4}
  50%{transform:translateY(8px);opacity:0.7}
}

/* Hero pills */
.page-core-offering .hero-pills{
  display:flex;gap:16px;justify-content:center;flex-wrap:wrap;
  margin-bottom:44px;position:relative;
  max-width:720px;margin-left:auto;margin-right:auto;
}
.page-core-offering .hero-pill{
  display:flex;align-items:center;gap:10px;
  background:#fff;
  border:1px solid var(--ink-04);
  border-radius:100px;
  padding:10px 22px 10px 14px;
  box-shadow:0 2px 8px rgba(5,28,44,0.04);
  transition:all 0.3s cubic-bezier(0.16,1,0.3,1);
}
.page-core-offering .hero-pill:hover{
  box-shadow:0 6px 20px rgba(5,28,44,0.08);
  transform:translateY(-1px);
}
.page-core-offering .hero-pill-label{
  font-size:10px;font-weight:800;
  text-transform:uppercase;letter-spacing:1px;
  color:#fff;background:var(--ink);
  padding:4px 10px;border-radius:100px;
  white-space:nowrap;
}
.page-core-offering .hero-pill-text{
  font-size:13px;font-weight:500;
  color:var(--ink-50);
  white-space:nowrap;
}

/* Trust banner */
.page-core-offering .trust-banner{
  background:#F5F5F5;
  border-top:none;
  border-bottom:none;
  padding:20px 24px;
  text-align:center;
}
.page-core-offering .trust-banner-inner{
  display:flex;align-items:center;justify-content:center;
  gap:24px;flex-wrap:wrap;
}
.page-core-offering .trust-item{
  font-size:12px;font-weight:600;
  color:var(--ink-30);
  letter-spacing:0.3px;
  text-transform:uppercase;
}
.page-core-offering .trust-sep{
  width:4px;height:4px;border-radius:50%;
  background:var(--ink-15);
  flex-shrink:0;
}

/* ═══ OFFERINGS (elevated cards) ═══ */
.page-core-offering .offerings{
  max-width:1060px;margin:0 auto;
  padding:100px 24px 80px;
  text-align:center;
}
.page-core-offering .offerings-grid{
  display:grid;grid-template-columns:1fr;gap:24px;
  text-align:left;margin-top:0;
}
.page-core-offering .offering-card{
  padding:40px 36px;
  background:#fff;
  border:1px solid var(--ink-04);
  border-radius:16px;
  transition:all 0.35s cubic-bezier(0.16,1,0.3,1);
  box-shadow:0 1px 3px rgba(5,28,44,0.04);
}
.page-core-offering .offering-card:hover{
  border-color:var(--ink-08);
  box-shadow:0 12px 40px rgba(5,28,44,0.08);
  transform:translateY(-3px);
}
.page-core-offering .offering-icon-wrap{
  width:48px;height:48px;
  display:flex;align-items:center;justify-content:center;
  border-radius:12px;
  background:var(--accent-muted);
  color:var(--accent);
  margin-bottom:22px;
}
.page-core-offering .offering-card h3{
  font-size:22px;font-weight:700;color:var(--ink);
  margin-bottom:12px;line-height:1.35;
}
.page-core-offering .offering-card p{
  font-size:15px;color:var(--ink-50);
  line-height:1.7;margin-bottom:20px;
}
.page-core-offering .offering-link{
  font-size:13px;font-weight:700;
  color:var(--accent);
  transition:opacity 0.2s ease;
}
.page-core-offering .offering-link:hover{opacity:0.7}

/* ── Option 2: Gradient Background Cards ── */
.page-core-offering .offering-card.card-light{
  background:linear-gradient(135deg, #ffffff 0%, #F0F0F0 100%);
  border:1px solid var(--ink-08);
}
.page-core-offering .offering-card.card-premium{
  background:linear-gradient(135deg, #1b2a4a 0%, #2d4a7a 100%);
  border:1px solid #2d4a7a;
}
.page-core-offering .card-premium h3{color:#fff}
.page-core-offering .card-premium p{color:rgba(255,255,255,0.75)}
.page-core-offering .card-premium .offering-link{color:#7db4ff}
.page-core-offering .card-premium .offering-icon-wrap{
  background:rgba(255,255,255,0.12);
  color:#7db4ff;
}
.page-core-offering .card-premium:hover{
  border-color:#4a6a9a;
  box-shadow:0 12px 40px rgba(5,28,44,0.25);
}

/* ═══ SHOWCASE (dark navy full-bleed) ═══ */
.page-core-offering .showcase{
  max-width:none;
  padding:80px max(24px, calc((100% - 1100px)/2)) 100px;
  background:var(--ink);
}
.page-core-offering .showcase .section-heading{
  color:#FFFFFF;
}
.page-core-offering .showcase .section-sub{
  color:rgba(255,255,255,0.65);
}
.page-core-offering .showcase-frame{
  background:#fff;
  border:none;
  border-radius:16px;overflow:hidden;
  box-shadow:0 16px 56px rgba(0,0,0,0.35);
}
.page-core-offering .showcase-chart-bar.highlight{
  background:var(--ink);opacity:1;
}
.page-core-offering .showcase-cta{text-align:center;padding:36px 0 12px}
.page-core-offering .showcase .btn-large{
  display:inline-block;
  background:#FFFFFF;color:var(--ink);
  font-size:15px;font-weight:700;
  padding:18px 48px;border-radius:12px;
  transition:all 0.3s cubic-bezier(0.16,1,0.3,1);
  box-shadow:0 4px 16px rgba(0,0,0,0.2);
}
.page-core-offering .showcase .btn-large:hover{
  box-shadow:0 8px 28px rgba(0,0,0,0.3);
  transform:translateY(-2px);
}
/* Default btn-large (used outside showcase) */
.page-core-offering .btn-large{
  display:inline-block;
  background:var(--ink);color:#fff;
  font-size:15px;font-weight:700;
  padding:18px 48px;border-radius:12px;
  transition:all 0.3s cubic-bezier(0.16,1,0.3,1);
  box-shadow:0 4px 16px rgba(5,28,44,0.15);
}
.page-core-offering .btn-large:hover{
  box-shadow:0 8px 28px rgba(5,28,44,0.22);
  transform:translateY(-2px);
}

/* ═══ VALUE PROPS (numbered list) ═══ */
.page-core-offering .props{
  max-width:800px;margin:0 auto;
  padding:100px 24px 80px;
  text-align:center;
}
.page-core-offering .props-list{
  text-align:left;
  display:flex;flex-direction:column;gap:0;
}
.page-core-offering .prop-item{
  display:flex;gap:28px;align-items:flex-start;
  padding:36px 0;
  border-bottom:1px solid var(--ink-04);
}
.page-core-offering .prop-item:first-child{
  border-top:1px solid var(--ink-04);
}
.page-core-offering .prop-num{
  font-size:32px;font-weight:800;
  color:var(--accent);
  flex-shrink:0;
  width:48px;
  line-height:1;
  padding-top:2px;
}
.page-core-offering .prop-content h3{
  font-size:16px;font-weight:700;color:var(--ink);
  margin-bottom:8px;
}
.page-core-offering .prop-content p{
  font-size:14px;color:var(--ink-50);
  line-height:1.7;
}

/* ═══ CONTACT (light form) ═══ */
.page-core-offering .contact{
  max-width:none;
  padding:80px max(24px, calc((100% - 560px)/2)) 100px;
  text-align:center;
  scroll-margin-top:72px;
  background:#F5F5F5;
}
.page-core-offering .form{
  display:flex;flex-direction:column;gap:14px;text-align:left;
}
.page-core-offering .form input,
.page-core-offering .form textarea{
  width:100%;padding:14px 18px;
  border:1.5px solid var(--ink-08);
  border-radius:10px;
  font-family:'Inter',var(--font-body);font-size:14px;
  background:#fff;
  color:var(--ink);
  outline:none;
  transition:border-color 0.25s ease,box-shadow 0.25s ease;
}
.page-core-offering .form input::placeholder,
.page-core-offering .form textarea::placeholder{
  color:var(--ink-30);
}
.page-core-offering .form input:focus,
.page-core-offering .form textarea:focus{
  border-color:var(--accent);
  box-shadow:0 0 0 3px rgba(34,81,255,0.08);
}
.page-core-offering .form textarea{resize:vertical;min-height:90px}
.page-core-offering .form button{
  background:var(--ink);
  color:#fff;
  border:none;padding:16px;border-radius:10px;
  font-family:'Inter',var(--font-body);font-size:14px;font-weight:700;
  cursor:pointer;
  transition:all 0.3s cubic-bezier(0.16,1,0.3,1);
  box-shadow:0 4px 16px rgba(5,28,44,0.15);
}
.page-core-offering .form button:hover{
  box-shadow:0 8px 24px rgba(5,28,44,0.22);
  transform:translateY(-1px);
}
.page-core-offering .form button:disabled{opacity:0.4;cursor:not-allowed;transform:none}
.page-core-offering .form-confirmation{
  display:none;
  padding:24px;
  background:#eef3ff;
  border:1px solid var(--accent);
  border-radius:12px;
  color:var(--ink);
  font-size:14px;line-height:1.6;
  text-align:center;
}
.page-core-offering .form-confirmation.visible{display:block}

/* ═══ METHODOLOGY ═══ */
.page-core-offering .methodology{
  max-width:800px;margin:0 auto;
  padding:60px 32px;
}
.page-core-offering .methodology h3{
  font-size:16px;font-weight:800;color:var(--ink);
  margin-bottom:20px;text-align:center;
}
.page-core-offering .methodology p{
  font-size:13px;color:var(--ink-50);
  line-height:1.8;margin-bottom:14px;
}
.page-core-offering .methodology p:last-child{margin-bottom:0}
.page-core-offering .methodology strong{color:var(--ink);font-weight:600}

/* ═══ RESPONSIVE — .page-core-offering ═══ */
@media(max-width:768px){
  .page-core-offering .hero{padding:100px 20px 72px}
  .page-core-offering .hero h1{font-size:36px;letter-spacing:-1px}
  .page-core-offering .hero-sub{font-size:15px}
  .page-core-offering .hero-orb{width:500px;height:500px;top:-120px}
  .page-core-offering .hero-pills{flex-direction:column;align-items:center}
  .page-core-offering .hero-pill-text{white-space:normal}
  .page-core-offering .trust-banner-inner{gap:16px}
  .page-core-offering .trust-sep{display:none}
  .page-core-offering .offerings-grid{grid-template-columns:1fr}
  .page-core-offering .section-heading{font-size:28px}
  .page-core-offering .prop-item{gap:20px}
  .page-core-offering .prop-num{font-size:24px;width:36px}
  .page-core-offering .showcase-kpis{grid-template-columns:1fr 1fr}
  .page-core-offering .showcase-grid{grid-template-columns:1fr}
}
@media(max-width:480px){
  .page-core-offering .hero h1{font-size:28px}
  .page-core-offering .hero{padding:80px 16px 60px}
  .page-core-offering .showcase-kpis{grid-template-columns:1fr}
  .page-core-offering .prop-item{flex-direction:column;gap:8px}
  .page-core-offering .prop-num{width:auto}
}

/* ═══════════════════════════════════════════════════════════
   BLOG — Index & Post Pages (.page-blog)
   ═══════════════════════════════════════════════════════════ */

/* ── Blog Index ── */
.page-blog .blog-hero{
  background:radial-gradient(ellipse at 50% 0%,#0E2A3F 0%,#051C2C 70%);
  padding:28px 24px 24px;
  text-align:center;
  border-bottom:1px solid rgba(255,255,255,0.08);
}
.page-blog .blog-hero h1{
  color:var(--white);
  font-size:22px;
  font-weight:600;
  letter-spacing:-0.2px;
  margin-bottom:6px;
}
.page-blog .blog-hero p{
  color:rgba(255,255,255,0.45);
  font-size:12px;
  max-width:540px;
  margin:0 auto;
  line-height:1.5;
}
.page-blog .blog-grid{
  max-width:880px;margin:0 auto;padding:48px 24px 80px;
  display:grid;grid-template-columns:1fr 1fr;gap:28px;
}
.page-blog .blog-card{
  background:var(--card);border:1px solid var(--border);
  border-radius:var(--radius-lg);padding:32px 28px;
  transition:box-shadow var(--ease),transform var(--ease);
  display:flex;flex-direction:column;
}
.page-blog .blog-card:hover{
  box-shadow:var(--shadow-md);transform:translateY(-3px);
}
.page-blog .blog-card-date{
  font-size:11px;font-weight:600;text-transform:uppercase;
  letter-spacing:1.5px;color:var(--accent);margin-bottom:12px;
}
.page-blog .blog-card h2{
  font-size:19px;font-weight:700;color:var(--ink);
  line-height:1.35;margin-bottom:12px;
}
.page-blog .blog-card p{
  font-size:13.5px;color:var(--ink-50);line-height:1.7;
  flex:1;margin-bottom:20px;
}
.page-blog .blog-card-link{
  font-size:12px;font-weight:600;color:var(--accent);
  letter-spacing:0.5px;transition:opacity var(--ease);
}
.page-blog .blog-card-link:hover{opacity:0.7}

/* Latest Articles Section */
.page-blog .blog-latest{
  max-width:1200px;margin:0 auto;padding:60px 24px 40px;
}
.page-blog .section-title{
  font-size:24px;font-weight:700;color:var(--ink);
  margin-bottom:28px;letter-spacing:-0.3px;
}
.page-blog .latest-grid{
  display:grid;grid-template-columns:1.2fr 0.8fr;gap:32px;align-items:start;
}
.page-blog .latest-hero-card{
  background:var(--card);border:1px solid var(--border);
  border-radius:var(--radius-lg);padding:40px;
  display:flex;flex-direction:column;
  transition:box-shadow var(--ease),transform var(--ease);
}
.page-blog .latest-hero-card:hover{
  box-shadow:var(--shadow-md);transform:translateY(-4px);
}
.page-blog .latest-hero-card .card-date{
  font-size:11px;font-weight:600;text-transform:uppercase;
  letter-spacing:1.5px;color:var(--accent);margin-bottom:14px;
}
.page-blog .latest-hero-card h3{
  font-size:24px;font-weight:700;color:var(--ink);
  line-height:1.3;margin-bottom:14px;
}
.page-blog .latest-hero-card p{
  font-size:14px;color:var(--ink-50);line-height:1.7;flex:1;
}
.page-blog .latest-list{
  display:flex;flex-direction:column;gap:20px;
}
.page-blog .latest-list-item{
  display:block;padding:20px 0;border-bottom:1px solid var(--border);
  transition:opacity var(--ease);
}
.page-blog .latest-list-item:last-child{
  border-bottom:none;
}
.page-blog .latest-list-item:hover{
  opacity:0.7;
}
.page-blog .latest-list-item .item-date{
  font-size:10px;font-weight:600;text-transform:uppercase;
  letter-spacing:1.2px;color:var(--ink-30);margin-bottom:8px;
}
.page-blog .latest-list-item h4{
  font-size:16px;font-weight:600;color:var(--ink);
  line-height:1.4;margin-bottom:6px;
}
.page-blog .latest-list-item p{
  font-size:13px;color:var(--ink-50);line-height:1.6;
}

/* Browse All Section */
.page-blog .blog-browse{
  max-width:1200px;margin:0 auto;padding:60px 24px 80px;
  border-top:1px solid var(--border);
}
.page-blog .browse-grid{
  display:grid;grid-template-columns:repeat(2,1fr);gap:28px;
}

/* ── Blog Post ── */
.page-blog .post-hero{
  background:radial-gradient(ellipse at 50% 0%,#0E2A3F 0%,#051C2C 70%);
  padding:120px 24px 52px;text-align:center;
}
.page-blog .post-hero h1{
  color:var(--white);font-size:34px;font-weight:800;
  letter-spacing:-0.5px;line-height:1.25;
  max-width:800px;margin:0 auto 14px;
}
.page-blog .post-meta{
  display:flex;gap:16px;justify-content:center;align-items:center;
  font-size:12px;color:rgba(255,255,255,0.45);
}
.page-blog .post-meta span{display:flex;align-items:center;gap:4px}

.page-blog .post-body{
  max-width:840px;margin:0 auto;padding:48px 24px 80px;
}
.page-blog .post-back{
  display:inline-block;font-size:12px;font-weight:600;
  color:var(--accent);margin-bottom:32px;
  letter-spacing:0.3px;transition:opacity var(--ease);
}
.page-blog .post-back:hover{opacity:0.7}

.page-blog .post-body h2{
  font-weight:700;color:var(--ink);
  letter-spacing:-0.3px;
}
.page-blog .post-body h3{
  font-size:17px;font-weight:600;color:var(--ink-90);
  margin:28px 0 12px;
}
.page-blog .post-body p{
  font-size:15px;color:var(--ink-70);line-height:1.85;
  margin-bottom:18px;
}
.page-blog .post-body ul,.page-blog .post-body ol{
  padding-left:24px;margin-bottom:18px;
}
.page-blog .post-body li{
  font-size:15px;color:var(--ink-70);line-height:1.85;
  margin-bottom:6px;
}
.page-blog .post-body strong{color:var(--ink)}

/* ── Callout Box ── */
.page-blog .callout{
  background:var(--ink-02);border-left:3px solid var(--accent);
  border-radius:0 var(--radius) var(--radius) 0;
  padding:20px 24px;margin:24px 0;
}
.page-blog .callout p{
  font-size:14px;color:var(--ink-50);margin-bottom:0;line-height:1.7;
}
.page-blog .callout strong{color:var(--ink)}

/* ── Stat Highlight (Post 1 style) ── */
.page-blog .stat-row{
  display:grid;grid-template-columns:repeat(3,1fr);gap:16px;
  margin:28px 0;
}
.page-blog .stat-card{
  background:var(--card);border:1px solid var(--border);
  border-radius:var(--radius);padding:20px;text-align:center;
}
.page-blog .stat-card .stat-num{
  font-size:28px;font-weight:800;color:var(--accent);
  letter-spacing:-0.5px;line-height:1.2;
}
.page-blog .stat-card .stat-label{
  font-size:11px;color:var(--ink-30);margin-top:6px;
  text-transform:uppercase;letter-spacing:1px;font-weight:600;
}

/* ── Pull Quote ── */
.page-blog .pull-quote{
  border-top:1px solid var(--border);border-bottom:1px solid var(--border);
  padding:24px 0;margin:32px 0;text-align:center;
}
.page-blog .pull-quote p{
  font-size:18px;font-weight:600;color:var(--ink);
  line-height:1.5;font-style:italic;margin-bottom:0;
}

/* ── Data Table (Post 2 style) ── */
.page-blog .post-body table{
  width:100%;border-collapse:collapse;margin:24px 0;
  font-size:13px;
}
.page-blog .post-body th{
  text-align:left;font-weight:600;color:var(--ink);
  padding:10px 12px;border-bottom:2px solid var(--ink-08);
  font-size:11px;text-transform:uppercase;letter-spacing:1px;
}
.page-blog .post-body td{
  padding:10px 12px;border-bottom:1px solid var(--ink-04);
  color:var(--ink-70);
}
.page-blog .post-body tr:last-child td{border-bottom:none}

/* ── Tier Breakdown (Post 2 style) ── */
.page-blog .tier-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:16px;
  margin:28px 0;
}
.page-blog .tier-card{
  background:var(--card);border:1px solid var(--border);
  border-radius:var(--radius);padding:22px 18px;
}
.page-blog .tier-card .tier-label{
  font-size:10px;font-weight:700;text-transform:uppercase;
  letter-spacing:1.5px;color:var(--accent);margin-bottom:8px;
}
.page-blog .tier-card .tier-value{
  font-size:22px;font-weight:800;color:var(--ink);
  margin-bottom:4px;
}
.page-blog .tier-card .tier-desc{
  font-size:12px;color:var(--ink-30);line-height:1.5;
}

/* ── Post Bottom Nav ── */
.page-blog .post-bottom-nav{
  border-top:1px solid var(--border);padding-top:32px;margin-top:48px;
  text-align:center;
}

/* ── Key Takeaways Box (McKinsey-style) ── */
.page-blog .key-takeaways{
  background:linear-gradient(135deg,rgba(14,42,63,0.04) 0%,rgba(14,42,63,0.08) 100%);
  border-left:4px solid var(--accent);
  border-radius:0 var(--radius-lg) var(--radius-lg) 0;
  padding:28px 32px;margin:32px 0;
}
.page-blog .key-takeaways-label{
  font-size:11px;font-weight:700;text-transform:uppercase;
  letter-spacing:1.8px;color:var(--accent);margin-bottom:16px;
}
.page-blog .key-takeaways ul{
  list-style:none;padding:0;margin:0;
}
.page-blog .key-takeaways li{
  position:relative;padding-left:20px;
  font-size:14.5px;color:var(--ink-70);line-height:1.7;
  margin-bottom:10px;
}
.page-blog .key-takeaways li:last-child{margin-bottom:0}
.page-blog .key-takeaways li::before{
  content:"";position:absolute;left:0;top:9px;
  width:8px;height:8px;border-radius:50%;
  background:var(--accent);opacity:0.5;
}
.page-blog .key-takeaways li strong{color:var(--ink)}

/* ── Table of Contents ── */
.page-blog .toc{
  border:1px solid var(--border);border-radius:var(--radius-lg);
  padding:24px 28px;margin:28px 0 36px;
  background:var(--card);
}
.page-blog .toc-label{
  font-size:11px;font-weight:700;text-transform:uppercase;
  letter-spacing:1.8px;color:var(--ink-30);margin-bottom:14px;
}
.page-blog .toc ol{
  list-style:none;padding:0;margin:0;counter-reset:toc;
}
.page-blog .toc li{
  counter-increment:toc;margin-bottom:8px;
}
.page-blog .toc li:last-child{margin-bottom:0}
.page-blog .toc li a{
  font-size:14px;color:var(--ink-50);text-decoration:none;
  transition:color var(--ease);display:flex;align-items:baseline;gap:8px;
}
.page-blog .toc li a::before{
  content:counter(toc,decimal-leading-zero);
  font-size:11px;font-weight:700;color:var(--accent);
  min-width:18px;
}
.page-blog .toc li a:hover{color:var(--accent)}

/* ── Post Byline ── */
.page-blog .post-byline{
  display:flex;align-items:center;justify-content:center;gap:8px;
  font-size:12px;color:rgba(255,255,255,0.45);margin-top:12px;
}
.page-blog .post-byline .byline-sep{
  width:3px;height:3px;border-radius:50%;
  background:rgba(255,255,255,0.3);
}

/* ── Hero Image ── */
.page-blog .post-hero-image{
  max-width:840px;margin:-20px auto 0;padding:0 24px;
}
.page-blog .post-hero-image img{
  width:100%;height:auto;border-radius:var(--radius-lg);
  box-shadow:var(--shadow-md);
}

/* ── Exhibit Wrapper (McKinsey-style numbered figures) ── */
.page-blog .exhibit{
  margin:32px 0;padding:0;
}
.page-blog .exhibit-label{
  font-size:11px;font-weight:700;text-transform:uppercase;
  letter-spacing:1.5px;color:var(--accent);margin-bottom:6px;
}
.page-blog .exhibit figcaption{
  font-size:13px;font-weight:600;color:var(--ink);
  margin-bottom:16px;line-height:1.4;
}
.page-blog .exhibit table{margin-top:0}

/* ── Mid-Article CTA ── */
.page-blog .mid-cta{
  background:radial-gradient(ellipse at 50% 0%,#0E2A3F 0%,#051C2C 100%);
  border-radius:var(--radius-lg);padding:32px 36px;
  margin:40px 0;text-align:center;
}
.page-blog .mid-cta-label{
  font-size:10px;font-weight:700;text-transform:uppercase;
  letter-spacing:2px;color:var(--accent);margin-bottom:10px;
}
.page-blog .mid-cta p{
  font-size:15px;color:rgba(255,255,255,0.7);
  line-height:1.7;margin-bottom:16px;
}
.page-blog .mid-cta a{
  display:inline-block;font-size:12px;font-weight:700;
  color:var(--white);letter-spacing:0.5px;
  border:1px solid rgba(255,255,255,0.25);border-radius:var(--radius);
  padding:10px 24px;transition:all var(--ease);text-decoration:none;
}
.page-blog .mid-cta a:hover{
  background:rgba(255,255,255,0.08);border-color:rgba(255,255,255,0.4);
}

/* ── Share Bar ── */
.page-blog .share-bar{
  display:flex;align-items:center;gap:12px;margin-bottom:32px;
}
.page-blog .share-bar-label{
  font-size:11px;font-weight:600;text-transform:uppercase;
  letter-spacing:1.2px;color:var(--ink-30);
}
.page-blog .share-bar a{
  display:flex;align-items:center;justify-content:center;
  width:34px;height:34px;border-radius:50%;
  border:1px solid var(--border);color:var(--ink-30);
  text-decoration:none;transition:all var(--ease);
  font-size:14px;
}
.page-blog .share-bar a:hover{
  border-color:var(--accent);color:var(--accent);
  background:rgba(14,42,63,0.04);
}
.page-blog .share-bar a svg{width:15px;height:15px;fill:currentColor}

/* ── Typography spacing improvements ── */
.page-blog .post-body h2{
  font-size:24px;margin:52px 0 18px;
  padding-top:20px;border-top:1px solid var(--ink-04);
}
.page-blog .post-body h2:first-of-type{border-top:none;padding-top:0}

/* ═══ RESPONSIVE — .page-blog ═══ */
@media(max-width:900px){
  .page-blog .latest-grid{grid-template-columns:1fr}
  .page-blog .latest-list{border-top:1px solid var(--border);padding-top:24px}
}
@media(max-width:768px){
  .page-blog .blog-grid{grid-template-columns:1fr;padding:32px 20px 60px}
  .page-blog .blog-hero{padding:24px 20px 20px}
  .page-blog .blog-hero h1{font-size:20px}
  .page-blog .post-hero{padding:100px 20px 44px}
  .page-blog .post-hero h1{font-size:26px}
  .page-blog .stat-row{grid-template-columns:1fr}
  .page-blog .tier-grid{grid-template-columns:1fr}
  .page-blog .post-body{padding:32px 20px 60px}
  .page-blog .key-takeaways{padding:22px 24px}
  .page-blog .toc{padding:20px 22px}
  .page-blog .mid-cta{padding:28px 24px}
  .page-blog .post-hero-image{padding:0 20px}
  .page-blog .exhibit{overflow-x:auto}
  .page-blog .browse-grid{grid-template-columns:1fr}
  .page-blog .latest-hero-card{padding:28px 24px}
  .page-blog .latest-hero-card h3{font-size:20px}
}
@media(max-width:480px){
  .page-blog .blog-hero h1{font-size:24px}
  .page-blog .post-hero h1{font-size:22px}
  .page-blog .post-body h2{font-size:20px}
  .page-blog .stat-card .stat-num{font-size:22px}
  .page-blog .key-takeaways li{font-size:13.5px}
  .page-blog .mid-cta{padding:24px 20px}
}

/* ═══ LEGAL PAGES (privacy, terms) ═══ */
.page-legal .legal-content{
  max-width:720px;margin:0 auto;
  padding:120px 32px 80px;
  font-family:'Inter',sans-serif;color:var(--ink-80);
  line-height:1.7;
}
.page-legal .legal-content h1{
  font-size:32px;font-weight:800;color:var(--ink);margin:0 0 8px;
}
.page-legal .legal-updated{
  font-size:13px;color:var(--ink-40);margin:0 0 40px;
}
.page-legal .legal-content h2{
  font-size:18px;font-weight:700;color:var(--ink);
  margin:36px 0 12px;
}
.page-legal .legal-content p{
  font-size:14px;margin:0 0 16px;
}
.page-legal .legal-content ul{
  font-size:14px;margin:0 0 16px;padding-left:24px;
}
.page-legal .legal-content li{margin-bottom:6px}
.page-legal .legal-content a{color:var(--accent);text-decoration:none}
.page-legal .legal-content a:hover{text-decoration:underline}
@media(max-width:768px){
  .page-legal .legal-content{padding:100px 20px 60px}
  .page-legal .legal-content h1{font-size:26px}
}

/* ═══════════════════════════════════════════════════════════
   HOMEPAGE — .page-home
   ═══════════════════════════════════════════════════════════ */

/* Scroll reveal */
.page-home .reveal{
  opacity:0;transform:translateY(28px);
  transition:opacity 0.8s cubic-bezier(0.16,1,0.3,1),transform 0.8s cubic-bezier(0.16,1,0.3,1);
}
.page-home .reveal.in-view{opacity:1;transform:translateY(0)}

.page-home{
  background:#FFFFFF;
  font-family:'Inter',var(--font-body);
}

/* Section typography */
.page-home .section-eyebrow{
  font-size:11px;font-weight:700;
  text-transform:uppercase;letter-spacing:3px;
  color:var(--accent);margin-bottom:16px;text-align:center;
}
.page-home .section-heading{
  font-size:36px;font-weight:800;color:var(--ink);
  text-align:center;letter-spacing:-0.8px;margin-bottom:14px;line-height:1.15;
}
.page-home .section-sub{
  font-size:16px;color:var(--ink-50);text-align:center;
  margin-bottom:52px;max-width:560px;margin-left:auto;margin-right:auto;line-height:1.7;
}
.page-home .section-rule{
  width:48px;height:2px;
  background:linear-gradient(90deg,var(--accent),var(--accent-light));
  margin:0 auto 44px;border-radius:2px;
}

/* Hero — Flash-Zoom Brand Reveal */
.page-home .hero{
  position:relative;width:100%;height:100vh;
  overflow:hidden;background:var(--ink);padding:0;text-align:center;
}
.page-home .tunnel{
  position:absolute;inset:0;z-index:1;
  display:flex;align-items:center;justify-content:center;
}
.page-home .ring{
  position:absolute;border:1px solid rgba(34,81,255,0.12);border-radius:6px;
  display:flex;align-items:center;justify-content:center;opacity:0;
}
.page-home .ring-1 {width:40px;height:24px;animation:zoomRing 3.64s cubic-bezier(0.4,0,0.2,1) 0s forwards}
.page-home .ring-2 {width:40px;height:24px;animation:zoomRing 3.64s cubic-bezier(0.4,0,0.2,1) .195s forwards}
.page-home .ring-3 {width:40px;height:24px;animation:zoomRing 3.64s cubic-bezier(0.4,0,0.2,1) .39s forwards}
.page-home .ring-4 {width:40px;height:24px;animation:zoomRing 3.64s cubic-bezier(0.4,0,0.2,1) .585s forwards}
.page-home .ring-5 {width:40px;height:24px;animation:zoomRing 3.64s cubic-bezier(0.4,0,0.2,1) .78s forwards}
.page-home .ring-6 {width:40px;height:24px;animation:zoomRing 3.64s cubic-bezier(0.4,0,0.2,1) .975s forwards}
.page-home .ring-7 {width:40px;height:24px;animation:zoomRing 3.64s cubic-bezier(0.4,0,0.2,1) 1.17s forwards}
.page-home .ring-8 {width:40px;height:24px;animation:zoomRing 3.64s cubic-bezier(0.4,0,0.2,1) 1.365s forwards}
.page-home .ring-9 {width:40px;height:24px;animation:zoomRing 3.64s cubic-bezier(0.4,0,0.2,1) 1.56s forwards}
.page-home .ring-10{width:40px;height:24px;animation:zoomRing 3.64s cubic-bezier(0.4,0,0.2,1) 1.755s forwards}
.page-home .ring-11{width:40px;height:24px;animation:zoomRing 3.64s cubic-bezier(0.4,0,0.2,1) 1.95s forwards}
.page-home .ring-12{width:40px;height:24px;animation:zoomRing 3.64s cubic-bezier(0.4,0,0.2,1) 2.145s forwards}
@keyframes zoomRing{
  0%{opacity:0;transform:scale(0.3);border-color:rgba(34,81,255,0)}
  10%{opacity:1;border-color:rgba(34,81,255,0.25)}
  50%{opacity:.8;transform:scale(8);border-color:rgba(34,81,255,0.15)}
  85%{opacity:.3;transform:scale(40);border-color:rgba(34,81,255,0.05)}
  100%{opacity:0;transform:scale(60);border-color:rgba(34,81,255,0)}
}
.page-home .zoom-label{
  position:absolute;font-size:11px;font-weight:600;letter-spacing:.5px;
  padding:5px 12px;border-radius:4px;white-space:nowrap;opacity:0;
  background:rgba(34,81,255,0.1);color:rgba(34,81,255,0.7);
  border:1px solid rgba(34,81,255,0.15);
}
.page-home .zl-1 {animation:zoomLabel 2.34s cubic-bezier(0.4,0,0.2,1) .26s forwards;--ox:-30px;--oy:-20px}
.page-home .zl-2 {animation:zoomLabel 2.34s cubic-bezier(0.4,0,0.2,1) .65s forwards;--ox:40px;--oy:-35px}
.page-home .zl-3 {animation:zoomLabel 2.34s cubic-bezier(0.4,0,0.2,1) 1.04s forwards;--ox:-50px;--oy:25px}
.page-home .zl-4 {animation:zoomLabel 2.34s cubic-bezier(0.4,0,0.2,1) 1.43s forwards;--ox:25px;--oy:40px}
.page-home .zl-5 {animation:zoomLabel 2.34s cubic-bezier(0.4,0,0.2,1) .455s forwards;--ox:-20px;--oy:-45px}
.page-home .zl-6 {animation:zoomLabel 2.34s cubic-bezier(0.4,0,0.2,1) .845s forwards;--ox:55px;--oy:10px}
.page-home .zl-7 {animation:zoomLabel 2.34s cubic-bezier(0.4,0,0.2,1) 1.235s forwards;--ox:-45px;--oy:50px}
.page-home .zl-8 {animation:zoomLabel 2.34s cubic-bezier(0.4,0,0.2,1) 1.625s forwards;--ox:35px;--oy:-15px}
.page-home .zl-9 {animation:zoomLabel 2.34s cubic-bezier(0.4,0,0.2,1) .585s forwards;--ox:0px;--oy:-55px}
.page-home .zl-10{animation:zoomLabel 2.34s cubic-bezier(0.4,0,0.2,1) 1.82s forwards;--ox:-60px;--oy:0px}
@keyframes zoomLabel{
  0%{opacity:0;transform:translate(var(--ox),var(--oy)) scale(0.5)}
  15%{opacity:.9;transform:translate(var(--ox),var(--oy)) scale(0.9)}
  60%{opacity:.6;transform:translate(calc(var(--ox)*4),calc(var(--oy)*4)) scale(3)}
  100%{opacity:0;transform:translate(calc(var(--ox)*10),calc(var(--oy)*10)) scale(8);filter:blur(4px)}
}
.page-home .speed-line{
  position:absolute;top:50%;left:50%;width:2px;height:0;
  background:linear-gradient(to bottom,rgba(34,81,255,0.4),transparent);
  transform-origin:top center;opacity:0;
}
.page-home .sl-1 {transform:rotate(0deg);animation:speedStreak 2.08s ease-out 2.08s forwards}
.page-home .sl-2 {transform:rotate(30deg);animation:speedStreak 2.08s ease-out 2.145s forwards}
.page-home .sl-3 {transform:rotate(60deg);animation:speedStreak 2.08s ease-out 2.21s forwards}
.page-home .sl-4 {transform:rotate(90deg);animation:speedStreak 2.08s ease-out 2.015s forwards}
.page-home .sl-5 {transform:rotate(120deg);animation:speedStreak 2.08s ease-out 2.275s forwards}
.page-home .sl-6 {transform:rotate(150deg);animation:speedStreak 2.08s ease-out 2.106s forwards}
.page-home .sl-7 {transform:rotate(180deg);animation:speedStreak 2.08s ease-out 2.184s forwards}
.page-home .sl-8 {transform:rotate(210deg);animation:speedStreak 2.08s ease-out 2.054s forwards}
.page-home .sl-9 {transform:rotate(240deg);animation:speedStreak 2.08s ease-out 2.236s forwards}
.page-home .sl-10{transform:rotate(270deg);animation:speedStreak 2.08s ease-out 2.132s forwards}
.page-home .sl-11{transform:rotate(300deg);animation:speedStreak 2.08s ease-out 2.028s forwards}
.page-home .sl-12{transform:rotate(330deg);animation:speedStreak 2.08s ease-out 2.314s forwards}
.page-home .sl-13{transform:rotate(15deg);animation:speedStreak 2.08s ease-out 2.08s forwards}
.page-home .sl-14{transform:rotate(45deg);animation:speedStreak 2.08s ease-out 2.158s forwards}
.page-home .sl-15{transform:rotate(75deg);animation:speedStreak 2.08s ease-out 2.249s forwards}
.page-home .sl-16{transform:rotate(105deg);animation:speedStreak 2.08s ease-out 2.067s forwards}
.page-home .sl-17{transform:rotate(135deg);animation:speedStreak 2.08s ease-out 2.197s forwards}
.page-home .sl-18{transform:rotate(165deg);animation:speedStreak 2.08s ease-out 2.119s forwards}
.page-home .sl-19{transform:rotate(195deg);animation:speedStreak 2.08s ease-out 2.041s forwards}
.page-home .sl-20{transform:rotate(225deg);animation:speedStreak 2.08s ease-out 2.262s forwards}
.page-home .sl-21{transform:rotate(255deg);animation:speedStreak 2.08s ease-out 2.093s forwards}
.page-home .sl-22{transform:rotate(285deg);animation:speedStreak 2.08s ease-out 2.171s forwards}
.page-home .sl-23{transform:rotate(315deg);animation:speedStreak 2.08s ease-out 2.288s forwards}
.page-home .sl-24{transform:rotate(345deg);animation:speedStreak 2.08s ease-out 2.223s forwards}
@keyframes speedStreak{
  0%{height:0;opacity:0}
  20%{opacity:.8}
  50%{height:clamp(200px,40vh,500px);opacity:.5}
  100%{height:clamp(200px,40vh,500px);opacity:0}
}
.page-home .white-flash{
  position:absolute;inset:0;z-index:5;
  background:var(--white);opacity:0;
  animation:flashBurst 1.04s cubic-bezier(0.16,1,0.3,1) 3.12s forwards;
  pointer-events:none;
}
@keyframes flashBurst{0%{opacity:0}15%{opacity:1}100%{opacity:1}}
.page-home .result{
  position:absolute;inset:0;z-index:10;
  background:linear-gradient(180deg,#F5F5F5 0%,#EBEBEB 100%);
  display:flex;align-items:center;justify-content:center;flex-direction:column;
  opacity:0;animation:resultIn 1.3s cubic-bezier(0.16,1,0.3,1) 3.64s forwards;
}
@keyframes resultIn{0%{opacity:0}100%{opacity:1}}
.page-home .result-content{
  text-align:center;padding:0 24px;
  display:flex;flex-direction:column;align-items:center;
}
.page-home .brand-wordmark{
  font-family:Georgia,'Times New Roman',serif;
  font-size:clamp(64px,12vw,140px);font-weight:700;
  letter-spacing:clamp(8px,2.5vw,36px);text-transform:uppercase;
  color:var(--ink);line-height:1;position:relative;
  opacity:0;transform:scale(1.3);
  animation:wordmarkSlam 1s cubic-bezier(0.16,1,0.3,1) 3.9s forwards;
}
@keyframes wordmarkSlam{
  0%{opacity:0;transform:scale(1.3);filter:blur(12px)}
  40%{opacity:1;filter:blur(0)}
  70%{transform:scale(0.98)}
  100%{opacity:1;transform:scale(1);filter:blur(0)}
}
.page-home .brand-wordmark::after{
  content:'';position:absolute;bottom:-8px;left:0;right:0;height:2px;
  background:var(--ink);transform:scaleX(0);
  animation:lineReveal .8s cubic-bezier(0.16,1,0.3,1) 4.5s forwards;
}
@keyframes lineReveal{0%{transform:scaleX(0)}100%{transform:scaleX(1)}}
.page-home .brand-tagline{
  font-size:clamp(13px,1.8vw,18px);font-weight:500;
  color:var(--ink-50);letter-spacing:clamp(3px,0.8vw,8px);
  text-transform:uppercase;margin-top:clamp(20px,3vw,36px);
  opacity:0;animation:tagUp .9s cubic-bezier(0.16,1,0.3,1) 4.8s forwards;
}
@keyframes tagUp{
  0%{opacity:0;transform:translateY(16px)}
  100%{opacity:1;transform:translateY(0)}
}
.page-home .speed-compare{
  display:flex;gap:2px;border-radius:12px;overflow:hidden;
  margin-top:clamp(24px,4vw,48px);box-shadow:0 4px 20px rgba(5,28,44,0.08);
  width:100%;max-width:560px;
  opacity:0;transform:translateY(10px);
  animation:tagUp 1s cubic-bezier(0.16,1,0.3,1) 5.2s forwards;
}
.page-home .speed-compare .col{
  background:var(--white);padding:24px 20px;flex:1;
  text-align:center;position:relative;
}
.page-home .speed-compare .col.highlight{background:var(--ink);color:var(--white)}
.page-home .speed-compare .col.highlight .sc-label{color:rgba(255,255,255,0.4)}
.page-home .speed-compare .col.highlight .sc-val{color:var(--white)}
.page-home .speed-compare .col.highlight .sc-sub{color:rgba(255,255,255,0.5)}
.page-home .speed-compare .col.highlight::after{
  content:'';position:absolute;top:-2px;left:20%;right:20%;height:3px;
  background:var(--accent);border-radius:0 0 3px 3px;
}
.page-home .sc-label{
  font-size:9px;font-weight:700;text-transform:uppercase;
  letter-spacing:1.5px;color:var(--ink-30);margin-bottom:6px;
}
.page-home .sc-val{font-size:28px;font-weight:800;color:var(--ink)}
.page-home .sc-sub{font-size:10px;color:var(--ink-50);margin-top:4px}
.page-home .cta-group{
  display:flex;gap:14px;justify-content:center;
  margin-top:clamp(32px,5vw,52px);
  opacity:0;animation:tagUp .8s cubic-bezier(0.16,1,0.3,1) 5s forwards;
}
.page-home .hero .btn-primary{
  display:inline-block;background:var(--accent);color:var(--white);
  font-size:13px;font-weight:700;padding:14px 36px;border-radius:8px;
  box-shadow:0 4px 16px rgba(34,81,255,0.35);text-decoration:none;
  letter-spacing:.5px;
  transition:transform .3s cubic-bezier(0.16,1,0.3,1),box-shadow .3s ease;
}
.page-home .hero .btn-primary:hover{
  transform:translateY(-2px);box-shadow:0 8px 24px rgba(34,81,255,0.45);
}
.page-home .hero .btn-secondary{
  display:inline-block;background:transparent;color:var(--ink-50);
  font-size:13px;font-weight:600;padding:14px 36px;border-radius:8px;
  border:1.5px solid var(--ink-08);text-decoration:none;
  letter-spacing:.5px;transition:all .3s ease;
}
.page-home .hero .btn-secondary:hover{border-color:var(--ink-30);color:var(--ink)}
.page-home .hero-scroll-hint{
  position:absolute;bottom:24px;left:0;right:0;
  display:flex;justify-content:center;
  z-index:11;opacity:0;
  animation:tagUp .8s cubic-bezier(0.16,1,0.3,1) 5.8s forwards;
  color:var(--ink-15);
}
@media(prefers-reduced-motion:reduce){
  .page-home .ring,.page-home .zoom-label,
  .page-home .speed-line,.page-home .white-flash{display:none}
  .page-home .result{opacity:1;animation:none}
  .page-home .brand-wordmark{opacity:1;transform:none;animation:none}
  .page-home .brand-wordmark::after{transform:scaleX(1);animation:none}
  .page-home .brand-tagline,.page-home .speed-compare,
  .page-home .cta-group,.page-home .hero-scroll-hint{opacity:1;transform:none;animation:none}
}

/* Trust banner */
.page-home .trust-banner{
  background:#F5F5F5;padding:20px 24px;text-align:center;
}
.page-home .trust-banner-inner{
  display:flex;align-items:center;justify-content:center;gap:24px;flex-wrap:wrap;
}
.page-home .trust-item{
  font-size:12px;font-weight:600;color:var(--ink-30);
  letter-spacing:0.3px;text-transform:uppercase;
}
.page-home .trust-sep{
  width:4px;height:4px;border-radius:50%;background:var(--ink-15);flex-shrink:0;
}

/* Analytical scope grid */
.scope-section{
  max-width:1000px;margin:0 auto;padding:80px 24px;text-align:center;
}
.scope-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:20px;
  text-align:center;margin-top:40px;
}
.scope-item{
  padding:28px 20px;background:var(--white);
  border:1px solid var(--border);border-radius:var(--radius-lg);
  transition:box-shadow var(--ease);
}
.scope-item:hover{box-shadow:var(--shadow-md)}
.scope-num{
  font-size:32px;font-weight:800;color:var(--accent);
  margin-bottom:8px;letter-spacing:-0.5px;
}
.scope-label{
  font-size:12px;font-weight:600;color:var(--ink-50);
  line-height:1.5;
}
.scope-note{
  max-width:700px;margin:40px auto 0;
  font-size:14px;color:var(--ink-50);line-height:1.7;
}
.scope-note a{color:var(--accent);font-weight:600}

/* Value props (reuse page-core-offering pattern but scoped to .page-home) */
.page-home .props{
  max-width:800px;margin:0 auto;padding:80px 24px;text-align:center;
}
.page-home .props-list{text-align:left;display:flex;flex-direction:column;gap:0}
.page-home .prop-item{
  display:flex;gap:28px;align-items:flex-start;
  padding:36px 0;border-bottom:1px solid var(--ink-04);
}
.page-home .prop-item:first-child{border-top:1px solid var(--ink-04)}
.page-home .prop-num{
  font-size:32px;font-weight:800;color:var(--accent);
  flex-shrink:0;width:48px;line-height:1;padding-top:2px;
}
.page-home .prop-content h3{font-size:16px;font-weight:700;color:var(--ink);margin-bottom:8px}
.page-home .prop-content p{font-size:14px;color:var(--ink-50);line-height:1.7}

/* Comparison table */
.compare-section{
  max-width:1100px;margin:0 auto;padding:80px 24px;text-align:center;
}
.compare-table{
  width:100%;border-collapse:collapse;margin-top:40px;text-align:left;
  background:var(--white);border-radius:var(--radius-lg);overflow:hidden;
  box-shadow:var(--shadow-sm);
}
.compare-table th{
  padding:14px 18px;font-size:11px;font-weight:700;
  text-transform:uppercase;letter-spacing:0.5px;
  color:var(--ink-30);background:var(--ink-02);
  border-bottom:2px solid var(--border);
}
.compare-table th:first-child{color:var(--ink-50)}
.compare-table th.compare-highlight{
  color:var(--accent);background:var(--accent-muted);
}
.compare-table td{
  padding:14px 18px;font-size:13px;color:var(--ink-50);
  border-bottom:1px solid var(--ink-04);line-height:1.5;
}
.compare-table td:first-child{
  font-weight:600;color:var(--ink);font-size:12px;
  text-transform:uppercase;letter-spacing:0.3px;
}
.compare-table td.compare-highlight{
  color:var(--ink);font-weight:600;
  background:rgba(34,81,255,0.02);
}
.compare-table tr:last-child td{border-bottom:none}
.compare-closing{
  font-size:15px;font-weight:600;color:var(--ink);
  margin-top:28px;
}

/* Pricing preview */
.pricing-preview{
  max-width:900px;margin:0 auto;padding:60px 24px;text-align:center;
}
.pricing-preview-cards{
  display:flex;gap:20px;justify-content:center;flex-wrap:wrap;margin-top:32px;
}
.pricing-preview-card{
  padding:24px 32px;background:var(--white);
  border:1px solid var(--border);border-radius:var(--radius-lg);
  min-width:200px;
}
.pricing-preview-card .pp-label{
  font-size:10px;font-weight:700;text-transform:uppercase;
  letter-spacing:1px;color:var(--ink-30);margin-bottom:8px;
}
.pricing-preview-card .pp-price{
  font-size:24px;font-weight:800;color:var(--ink);
}
.pricing-preview-card .pp-note{
  font-size:12px;color:var(--ink-50);margin-top:4px;
}
.pricing-preview-link{
  display:inline-block;margin-top:28px;
  font-size:14px;font-weight:700;color:var(--accent);
}

/* Free report CTA */
.free-trial-section{
  max-width:none;padding:80px 24px;
  background:var(--ink);text-align:center;
}
.free-trial-section .section-heading{color:#fff}
.free-trial-section .section-sub{color:rgba(255,255,255,0.55)}
.free-trial-form{
  max-width:480px;margin:0 auto;
  display:flex;flex-direction:column;gap:12px;
}
.free-trial-form input{
  width:100%;padding:14px 18px;
  border:1.5px solid rgba(255,255,255,0.15);border-radius:10px;
  font-family:'Inter',var(--font-body);font-size:14px;
  background:rgba(255,255,255,0.06);color:#fff;outline:none;
  transition:border-color 0.25s ease;
}
.free-trial-form input::placeholder{color:rgba(255,255,255,0.35)}
.free-trial-form input:focus{border-color:var(--accent)}
.free-trial-form .form-row{display:flex;gap:12px}
.free-trial-form .form-row input{flex:1}
.free-trial-form button{
  background:var(--accent);color:#fff;border:none;
  padding:16px;border-radius:10px;
  font-family:'Inter',var(--font-body);font-size:14px;font-weight:700;
  cursor:pointer;transition:all 0.3s cubic-bezier(0.16,1,0.3,1);
  box-shadow:0 4px 16px rgba(34,81,255,0.3);
}
.free-trial-form button:hover{
  box-shadow:0 8px 28px rgba(34,81,255,0.4);transform:translateY(-1px);
}
.free-trial-note{
  font-size:12px;color:rgba(255,255,255,0.35);margin-top:12px;
}

/* Blog teasers */
.blog-teasers{
  max-width:1000px;margin:0 auto;padding:80px 24px;text-align:center;
}
.blog-teasers-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px;
  margin-top:40px;text-align:left;
}
.blog-teaser-card{
  background:var(--white);border:1px solid var(--border);
  border-radius:var(--radius-lg);padding:28px 24px;
  transition:all 0.3s cubic-bezier(0.16,1,0.3,1);
  display:flex;flex-direction:column;
}
.blog-teaser-card:hover{
  box-shadow:var(--shadow-md);transform:translateY(-3px);
}
.blog-teaser-date{
  font-size:10px;font-weight:600;text-transform:uppercase;
  letter-spacing:1.5px;color:var(--accent);margin-bottom:10px;
}
.blog-teaser-card h3{
  font-size:16px;font-weight:700;color:var(--ink);
  line-height:1.35;margin-bottom:10px;
}
.blog-teaser-card p{
  font-size:13px;color:var(--ink-50);line-height:1.65;flex:1;
}

/* ═══════════════════════════════════════════════════════════
   PRICING PAGE — .page-pricing
   ═══════════════════════════════════════════════════════════ */

.page-pricing{
  background:#FFFFFF;font-family:'Inter',var(--font-body);
}
.page-pricing .reveal{
  opacity:0;transform:translateY(28px);
  transition:opacity 0.8s cubic-bezier(0.16,1,0.3,1),transform 0.8s cubic-bezier(0.16,1,0.3,1);
}
.page-pricing .reveal.in-view{opacity:1;transform:translateY(0)}

/* Pricing split hero (info left + form card right) */
.pricing-split{
  background:linear-gradient(180deg,#f7f8fa 0%,#fff 100%);
  padding:80px 24px 64px;
}
.pricing-split-inner{
  max-width:960px;margin:0 auto;
  display:grid;grid-template-columns:1fr 1fr;gap:56px;
  align-items:center;
}
.pricing-split-eyebrow{
  font-size:10px;font-weight:700;
  text-transform:uppercase;letter-spacing:2.5px;
  color:var(--accent);margin-bottom:16px;
}
.pricing-split-left h1{
  font-size:30px;font-weight:800;
  color:var(--ink);letter-spacing:-0.5px;
  line-height:1.2;margin-bottom:14px;
}
.pricing-split-left>p{
  font-size:15px;color:var(--ink-50);
  line-height:1.7;margin-bottom:24px;
}
.pricing-split-bullets{
  list-style:none;padding:0;
}
.pricing-split-bullets li{
  font-size:13px;color:var(--ink-50);
  padding:7px 0;
  display:flex;align-items:center;gap:10px;
}
.ps-check{
  width:18px;height:18px;
  border-radius:50%;
  background:var(--accent-muted);
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
}
.ps-check svg{width:10px;height:10px}
.pricing-split-card{
  background:var(--white);
  border:1px solid var(--ink-08);
  border-radius:16px;
  padding:36px 32px;
  box-shadow:0 8px 32px rgba(5,28,44,0.06);
}
.pricing-split-card-label{
  font-size:10px;font-weight:700;
  text-transform:uppercase;letter-spacing:1.5px;
  color:var(--ink-30);margin-bottom:6px;
}
.pricing-split-card h3{
  font-size:20px;font-weight:700;
  color:var(--ink);margin-bottom:4px;
}
.pricing-split-card-sub{
  font-size:13px;color:var(--ink-50);
  margin-bottom:24px;line-height:1.5;
}
.pricing-split-card .free-trial-form{
  display:flex;flex-direction:column;gap:10px;
}
.pricing-split-card .free-trial-form input{
  width:100%;padding:12px 16px;
  border:1.5px solid var(--ink-08);border-radius:8px;
  background:#fff;color:var(--ink);
  font-family:'Inter',var(--font-body);font-size:14px;
  outline:none;transition:border-color 0.2s;
}
.pricing-split-card .free-trial-form input::placeholder{color:var(--ink-30)}
.pricing-split-card .free-trial-form input:focus{border-color:var(--accent)}
.pricing-split-card .free-trial-form .form-row{display:flex;gap:10px}
.pricing-split-card .free-trial-form button{
  background:var(--accent);color:#fff;
  border:none;padding:14px;border-radius:8px;
  font-family:'Inter',var(--font-body);font-size:14px;font-weight:700;
  cursor:pointer;transition:all 0.25s;
  box-shadow:0 4px 16px rgba(34,81,255,0.25);
}
.pricing-split-card .free-trial-form button:hover{
  transform:translateY(-1px);
  box-shadow:0 6px 20px rgba(34,81,255,0.35);
}
.pricing-split-card-note{
  font-size:11px;color:var(--ink-30);
  text-align:center;margin-top:10px;
}

/* Speed tier cards */
.speed-tiers{
  max-width:900px;margin:0 auto;padding:60px 24px;text-align:center;
}
.speed-tiers-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:32px;
}
.speed-card{
  padding:32px 24px;background:var(--white);
  border:1px solid var(--border);border-radius:var(--radius-lg);
  transition:all 0.3s cubic-bezier(0.16,1,0.3,1);
}
.speed-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}
.speed-card-label{
  font-size:10px;font-weight:700;text-transform:uppercase;
  letter-spacing:1.5px;color:var(--ink-30);margin-bottom:6px;
}
.speed-card-time{
  font-size:28px;font-weight:800;color:var(--ink);
  margin-bottom:4px;letter-spacing:-0.5px;
}
.speed-card-price{
  font-size:20px;font-weight:800;color:var(--accent);
  margin-bottom:4px;
}
.speed-card-loyalty{
  font-size:11px;color:var(--ink-30);margin-bottom:16px;
}
.speed-card .btn-speed{
  display:inline-block;background:var(--ink);color:#fff;
  font-size:12px;font-weight:700;padding:10px 28px;border-radius:8px;
  transition:all var(--ease);
}
.speed-card .btn-speed:hover{opacity:0.85}
.speed-note{
  font-size:13px;color:var(--ink-50);margin-top:24px;line-height:1.6;
}

/* Coverage plan cards */
.coverage-plans{
  max-width:1060px;margin:0 auto;padding:60px 24px 80px;text-align:center;
}
.coverage-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:32px;
}
.coverage-card{
  padding:36px 28px;background:var(--white);
  border:1px solid var(--border);border-radius:var(--radius-lg);
  text-align:left;position:relative;
  transition:all 0.3s cubic-bezier(0.16,1,0.3,1);
}
.coverage-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}
.coverage-card.popular{
  border-color:var(--accent);
  box-shadow:0 4px 20px rgba(34,81,255,0.12);
}
.coverage-badge{
  position:absolute;top:-12px;left:50%;transform:translateX(-50%);
  background:var(--accent);color:#fff;
  font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1px;
  padding:4px 16px;border-radius:100px;white-space:nowrap;
}
.coverage-card-name{
  font-size:11px;font-weight:700;text-transform:uppercase;
  letter-spacing:1px;color:var(--ink-30);margin-bottom:8px;
}
.coverage-card-price{
  font-size:36px;font-weight:800;color:var(--ink);
  margin-bottom:2px;letter-spacing:-1px;
}
.coverage-card-price span{font-size:14px;font-weight:500;color:var(--ink-50)}
.coverage-card-per{
  font-size:12px;color:var(--ink-30);margin-bottom:20px;
}
.coverage-card-features{
  list-style:none;padding:0;margin:0 0 24px;
}
.coverage-card-features li{
  font-size:13px;color:var(--ink-50);
  padding:8px 0;border-bottom:1px solid var(--ink-04);
  display:flex;align-items:center;gap:8px;
}
.coverage-card-features li:last-child{border-bottom:none}
.coverage-card-features .feat-check{
  color:var(--positive);font-weight:700;font-size:14px;flex-shrink:0;
}
.coverage-card .btn-coverage{
  display:block;text-align:center;
  background:var(--ink);color:#fff;
  font-size:13px;font-weight:700;padding:12px 24px;border-radius:8px;
  transition:all var(--ease);
}
.coverage-card .btn-coverage:hover{opacity:0.85}
.coverage-card.popular .btn-coverage{background:var(--accent)}
.coverage-anchor{
  font-size:14px;color:var(--ink-50);margin-top:28px;line-height:1.6;
}
.coverage-anchor strong{color:var(--ink)}
.coverage-terms{
  font-size:12px;color:var(--ink-30);margin-top:16px;line-height:1.6;
}

/* Charter rate banner */
.charter-banner{
  max-width:800px;margin:0 auto;padding:0 24px 60px;
}
.charter-inner{
  background:linear-gradient(135deg,var(--accent-muted) 0%,#f0f4ff 100%);
  border:1px solid rgba(34,81,255,0.15);border-radius:var(--radius-lg);
  padding:28px 32px;text-align:center;
}
.charter-inner h3{
  font-size:16px;font-weight:700;color:var(--ink);margin-bottom:8px;
}
.charter-inner p{
  font-size:14px;color:var(--ink-50);line-height:1.6;
}
.charter-count{
  display:inline-block;margin-top:12px;
  font-size:13px;font-weight:700;color:var(--accent);
}

/* Report contents */
.report-contents{
  max-width:900px;margin:0 auto;padding:60px 24px;text-align:center;
}
.contents-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:12px;
  margin-top:32px;text-align:left;
}
.contents-item{
  padding:14px 18px;background:var(--ink-02);
  border-radius:var(--radius);
  font-size:13px;font-weight:500;color:var(--ink-50);
  border-left:3px solid var(--accent);
}

/* System build */
.system-build{
  max-width:800px;margin:0 auto;padding:40px 24px 60px;
  text-align:center;border-top:1px solid var(--border);
}
.system-build h3{
  font-size:16px;font-weight:700;color:var(--ink);margin-bottom:8px;
}
.system-build p{
  font-size:14px;color:var(--ink-50);line-height:1.6;margin-bottom:16px;
}
.system-build a{
  font-size:13px;font-weight:700;color:var(--accent);
}

/* FAQ accordion */
.faq-section{
  max-width:700px;margin:0 auto;padding:60px 24px 80px;
}
.faq-item{
  border-bottom:1px solid var(--ink-04);
}
.faq-item:first-child{border-top:1px solid var(--ink-04)}
.faq-q{
  display:flex;justify-content:space-between;align-items:center;
  padding:20px 0;cursor:pointer;
  font-size:15px;font-weight:600;color:var(--ink);
  background:none;border:none;width:100%;text-align:left;
  font-family:'Inter',var(--font-body);
}
.faq-q:hover{color:var(--accent)}
.faq-arrow{
  font-size:18px;color:var(--ink-30);
  transition:transform 0.25s ease;flex-shrink:0;margin-left:16px;
}
.faq-item.open .faq-arrow{transform:rotate(180deg)}
.faq-a{
  max-height:0;overflow:hidden;
  transition:max-height 0.35s ease,padding 0.35s ease;
}
.faq-item.open .faq-a{max-height:300px;padding-bottom:20px}
.faq-a p{
  font-size:14px;color:var(--ink-50);line-height:1.7;
}

/* ═══════════════════════════════════════════════════════════
   PRICING PAGE v2 — Scannable layout with px-* classes
   ═══════════════════════════════════════════════════════════ */

/* ── Staggered hero entrance ── */
@keyframes pxFadeUp{
  from{opacity:0;transform:translateY(24px)}
  to{opacity:1;transform:translateY(0)}
}
@keyframes pxBounce{
  0%,100%{transform:translateY(0);opacity:0.3}
  50%{transform:translateY(8px);opacity:0.6}
}

/* ── Section typography (scoped) ── */
.page-pricing .px-section-eyebrow{
  font-size:11px;font-weight:700;
  text-transform:uppercase;letter-spacing:3px;
  color:var(--accent);
  margin-bottom:16px;text-align:center;
}
.page-pricing .px-section-heading{
  font-size:36px;font-weight:800;
  color:var(--ink);text-align:center;
  letter-spacing:-0.8px;margin-bottom:14px;line-height:1.15;
}

/* ═══ HERO ═══ */
.px-hero{
  background:radial-gradient(ellipse at 50% 0%,#0E2A3F 0%,#051C2C 70%);
  padding:100px 24px 56px;
  text-align:center;
  position:relative;
  overflow:hidden;
}
.px-hero::before{
  content:'';position:absolute;inset:0;
  background-image:radial-gradient(rgba(255,255,255,0.035) 1px,transparent 1px);
  background-size:32px 32px;
  pointer-events:none;
}
.px-hero::after{
  content:'';position:absolute;bottom:0;left:0;right:0;
  height:1px;
  background:linear-gradient(90deg,transparent,rgba(34,81,255,0.25),transparent);
}
.px-hero-inner{
  max-width:560px;margin:0 auto;position:relative;z-index:1;
}
.px-eyebrow{
  font-size:10px;font-weight:700;
  text-transform:uppercase;letter-spacing:3.5px;
  color:var(--accent-light);
  margin-bottom:24px;
  animation:pxFadeUp 0.8s cubic-bezier(0.16,1,0.3,1) 0.1s both;
}
.px-hero h1{
  font-size:clamp(28px,4.5vw,38px);font-weight:900;
  color:#fff;letter-spacing:-1.2px;
  line-height:1.12;margin-bottom:18px;
  animation:pxFadeUp 0.8s cubic-bezier(0.16,1,0.3,1) 0.2s both;
}
.px-hero-sub{
  font-size:15px;color:rgba(255,255,255,0.50);
  line-height:1.75;margin-bottom:28px;
  max-width:480px;margin-left:auto;margin-right:auto;
  animation:pxFadeUp 0.8s cubic-bezier(0.16,1,0.3,1) 0.3s both;
}
.px-hero-pills{
  display:flex;gap:10px;justify-content:center;flex-wrap:wrap;
  margin-bottom:32px;
  animation:pxFadeUp 0.8s cubic-bezier(0.16,1,0.3,1) 0.4s both;
}
.px-hero-pills span{
  font-size:11px;font-weight:600;
  color:rgba(255,255,255,0.45);
  padding:6px 14px;
  border:1px solid rgba(255,255,255,0.08);
  border-radius:100px;
  letter-spacing:0.3px;
}
.px-hero-card{
  background:rgba(255,255,255,0.04);
  border:1px solid rgba(255,255,255,0.08);
  border-radius:16px;
  padding:28px 24px;
  animation:pxFadeUp 0.8s cubic-bezier(0.16,1,0.3,1) 0.5s both;
}
.px-hero-card .free-trial-form{max-width:none}
.px-hero-scroll{
  margin-top:36px;
  animation:pxBounce 2.5s ease-in-out infinite;
}

/* ═══ THREE PATHS ═══ */
.px-paths{
  max-width:1000px;margin:0 auto;
  padding:80px 24px 60px;text-align:center;
}
.px-paths-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:20px;margin-top:40px;text-align:left;
}
.px-path{
  display:flex;flex-direction:column;
  padding:32px 28px;
  background:var(--white);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  transition:all 0.35s cubic-bezier(0.16,1,0.3,1);
  text-decoration:none;color:inherit;
}
.px-path:hover{
  box-shadow:0 8px 32px rgba(5,28,44,0.08);
  transform:translateY(-3px);
  border-color:var(--ink-08);
}
.px-path-num{
  font-size:13px;font-weight:800;
  color:var(--ink-15);
  margin-bottom:16px;
  letter-spacing:1px;
}
.px-path h3{
  font-size:18px;font-weight:700;
  color:var(--ink);
  margin-bottom:8px;
}
.px-path-price{
  font-size:28px;font-weight:800;
  color:var(--accent);
  margin-bottom:12px;letter-spacing:-0.5px;
}
.px-path-price span{
  font-size:14px;font-weight:500;color:var(--ink-50);
}
.px-path p{
  font-size:13px;color:var(--ink-50);
  line-height:1.6;flex:1;
  margin-bottom:16px;
}
.px-path-link{
  font-size:12px;font-weight:700;
  color:var(--accent);
}
.px-path-accent{
  background:var(--ink);
  border-color:var(--ink);
}
.px-path-accent h3{color:#fff}
.px-path-accent .px-path-num{color:rgba(255,255,255,0.15)}
.px-path-accent .px-path-price{color:#7db4ff}
.px-path-accent .px-path-price span{color:rgba(255,255,255,0.5)}
.px-path-accent p{color:rgba(255,255,255,0.55)}
.px-path-accent .px-path-link{color:#7db4ff}
.px-path-accent:hover{
  box-shadow:0 12px 40px rgba(5,28,44,0.3);
  border-color:var(--ink);
  transform:translateY(-4px);
}

/* ═══ ON-DEMAND SPEED TIERS ═══ */
.px-ondemand{
  max-width:900px;margin:0 auto;
  padding:60px 24px 80px;text-align:center;
  border-top:1px solid var(--border);
}
.px-speed-grid{
  display:flex;align-items:center;justify-content:center;
  gap:0;margin-top:40px;
}
.px-speed{
  flex:1;max-width:260px;
  padding:32px 24px;
  background:var(--white);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  transition:all 0.3s cubic-bezier(0.16,1,0.3,1);
}
.px-speed:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}
.px-speed-label{
  font-size:10px;font-weight:700;
  text-transform:uppercase;letter-spacing:1.5px;
  color:var(--ink-30);margin-bottom:6px;
}
.px-speed-time{
  font-size:36px;font-weight:900;
  color:var(--ink);letter-spacing:-1px;
  margin-bottom:4px;
}
.px-speed-price{
  font-size:22px;font-weight:800;
  color:var(--accent);margin-bottom:4px;
}
.px-speed-loyalty{
  font-size:11px;color:var(--ink-30);
  margin-bottom:20px;
}
.px-speed-btn{
  display:inline-block;
  background:var(--ink);color:#fff;
  font-size:12px;font-weight:700;
  padding:10px 28px;border-radius:8px;
  transition:opacity var(--ease);
  text-decoration:none;
}
.px-speed-btn:hover{opacity:0.85}
.px-speed-divider{
  width:32px;height:32px;
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
  color:var(--ink-15);
}
.px-speed-divider svg{width:20px;height:20px}
.px-speed-note{
  font-size:13px;color:var(--ink-50);
  margin-top:28px;line-height:1.6;
}

/* ═══ COVERAGE PLANS ═══ */
.px-coverage{
  max-width:none;
  padding:80px 24px;text-align:center;
  background:var(--ink-02);
}
.px-coverage-sub{
  font-size:15px;color:var(--ink-50);
  max-width:600px;margin:0 auto 40px;
  line-height:1.7;
}
.px-coverage-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:24px;
  max-width:1060px;margin:0 auto;
}
.px-plan{
  padding:36px 28px;background:var(--white);
  border:1px solid var(--border);border-radius:var(--radius-lg);
  text-align:left;position:relative;
  transition:all 0.3s cubic-bezier(0.16,1,0.3,1);
}
.px-plan:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}
.px-plan-popular{
  border-color:var(--accent);
  box-shadow:0 4px 24px rgba(34,81,255,0.12);
}
.px-plan-badge{
  position:absolute;top:-12px;left:50%;transform:translateX(-50%);
  background:var(--accent);color:#fff;
  font-size:10px;font-weight:700;
  text-transform:uppercase;letter-spacing:1px;
  padding:4px 16px;border-radius:100px;white-space:nowrap;
}
.px-plan-name{
  font-size:11px;font-weight:700;
  text-transform:uppercase;letter-spacing:1px;
  color:var(--ink-30);margin-bottom:8px;
}
.px-plan-price{
  font-size:36px;font-weight:800;
  color:var(--ink);letter-spacing:-1px;
  margin-bottom:2px;
}
.px-plan-price span{font-size:14px;font-weight:500;color:var(--ink-50)}
.px-plan-per{
  font-size:12px;color:var(--ink-30);margin-bottom:20px;
}
.px-plan ul{
  list-style:none;padding:0;margin:0 0 24px;
}
.px-plan ul li{
  font-size:13px;color:var(--ink-50);
  padding:8px 0;border-bottom:1px solid var(--ink-04);
  display:flex;align-items:center;gap:8px;
}
.px-plan ul li:last-child{border-bottom:none}
.px-plan ul li::before{
  content:'✓';
  color:var(--positive);font-weight:700;font-size:14px;flex-shrink:0;
}
.px-plan-btn{
  display:block;text-align:center;
  background:var(--ink);color:#fff;
  font-size:13px;font-weight:700;
  padding:12px 24px;border-radius:8px;
  transition:opacity var(--ease);
  text-decoration:none;
}
.px-plan-btn:hover{opacity:0.85}
.px-plan-popular .px-plan-btn{background:var(--accent)}
.px-coverage-savings{
  font-size:14px;color:var(--ink-50);margin-top:28px;line-height:1.6;
  max-width:1060px;margin-left:auto;margin-right:auto;
}
.px-coverage-savings strong{color:var(--ink)}
.px-coverage-terms{
  font-size:12px;color:var(--ink-30);margin-top:12px;line-height:1.6;
  max-width:1060px;margin-left:auto;margin-right:auto;
}

/* ═══ FOUNDING RATE ═══ */
.px-founding{
  max-width:800px;margin:0 auto;padding:0 24px;
}
.px-founding-inner{
  background:linear-gradient(135deg,var(--ink) 0%,#1a3a5c 100%);
  border-radius:var(--radius-lg);
  padding:40px;text-align:center;
  position:relative;overflow:hidden;
}
.px-founding-inner::before{
  content:'';position:absolute;inset:0;
  background-image:radial-gradient(rgba(255,255,255,0.03) 1px,transparent 1px);
  background-size:20px 20px;
  pointer-events:none;
}
.px-founding-tag{
  font-size:10px;font-weight:700;
  text-transform:uppercase;letter-spacing:2.5px;
  color:var(--accent-light);margin-bottom:14px;
  position:relative;
}
.px-founding-inner h3{
  font-size:20px;font-weight:800;
  color:#fff;margin-bottom:10px;
  position:relative;
}
.px-founding-inner p{
  font-size:14px;color:rgba(255,255,255,0.55);
  line-height:1.6;position:relative;
  max-width:480px;margin:0 auto;
}
.px-founding-count{
  display:inline-block;margin-top:18px;
  font-size:14px;font-weight:800;
  color:#fff;
  background:rgba(255,255,255,0.08);
  padding:8px 24px;border-radius:100px;
  border:1px solid rgba(255,255,255,0.1);
  position:relative;
}

/* ═══ ADVANTAGE STATS ═══ */
.px-advantage{
  max-width:900px;margin:0 auto;
  padding:80px 24px;text-align:center;
}
.px-advantage-grid{
  display:grid;grid-template-columns:repeat(2,1fr);
  gap:20px;margin-top:40px;text-align:left;
}
.px-stat{
  padding:32px 28px;
  background:var(--ink-02);
  border-radius:var(--radius-lg);
  border-left:4px solid var(--accent);
}
.px-stat-label{
  font-size:11px;font-weight:700;
  text-transform:uppercase;letter-spacing:1.5px;
  color:var(--accent);margin-bottom:6px;
}
.px-stat-value{
  font-size:32px;font-weight:900;
  color:var(--ink);letter-spacing:-0.5px;
  margin-bottom:8px;
}
.px-stat-value span{
  font-size:16px;font-weight:500;color:var(--ink-50);
}
.px-stat-context{
  font-size:13px;color:var(--ink-50);line-height:1.6;
}

/* ═══ INSIDE EVERY REPORT ═══ */
.px-contents{
  max-width:900px;margin:0 auto;
  padding:60px 24px 80px;text-align:center;
  border-top:1px solid var(--border);
}
.px-contents-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:10px;margin-top:32px;text-align:left;
}
.px-contents-item{
  padding:12px 16px;
  background:var(--ink-02);
  border-radius:6px;
  font-size:13px;font-weight:500;
  color:var(--ink-50);
  border-left:3px solid var(--accent);
  transition:all 0.2s ease;
}
.px-contents-item:hover{
  background:var(--accent-muted);
  color:var(--ink);
}
.px-contents-link{margin-top:24px}
.px-contents-link a{
  font-size:14px;font-weight:700;color:var(--accent);
  text-decoration:none;transition:opacity var(--ease);
}
.px-contents-link a:hover{opacity:0.7}

/* ═══ ENTERPRISE ═══ */
.px-enterprise{
  padding:0 24px 80px;
}
.px-enterprise-inner{
  max-width:800px;margin:0 auto;
  background:var(--ink-02);
  border-radius:var(--radius-lg);
  padding:40px;text-align:center;
  border:1px solid var(--border);
}
.px-enterprise-tag{
  font-size:10px;font-weight:700;
  text-transform:uppercase;letter-spacing:2px;
  color:var(--accent);margin-bottom:12px;
}
.px-enterprise-inner h3{
  font-size:18px;font-weight:700;
  color:var(--ink);margin-bottom:10px;
}
.px-enterprise-inner p{
  font-size:14px;color:var(--ink-50);
  line-height:1.6;margin-bottom:16px;
}
.px-enterprise-link{
  font-size:13px;font-weight:700;
  color:var(--accent);text-decoration:none;
}
.px-enterprise-link:hover{opacity:0.7}

/* ═══ FAQ ═══ */
.px-faq{
  max-width:700px;margin:0 auto;
  padding:60px 24px 80px;
  border-top:1px solid var(--border);
}
.px-faq .faq-item{
  border-bottom:1px solid var(--ink-04);
}
.px-faq .faq-item:first-child{border-top:1px solid var(--ink-04)}
.px-faq .faq-q{
  display:flex;justify-content:space-between;align-items:center;
  padding:20px 0;cursor:pointer;
  font-size:15px;font-weight:600;color:var(--ink);
  background:none;border:none;width:100%;text-align:left;
  font-family:'Inter',var(--font-body);
  transition:color var(--ease);
}
.px-faq .faq-q:hover{color:var(--accent)}
.px-faq .faq-arrow{
  font-size:18px;color:var(--ink-30);
  transition:transform 0.25s ease;flex-shrink:0;margin-left:16px;
}
.px-faq .faq-item.open .faq-arrow{transform:rotate(180deg)}
.px-faq .faq-a{
  max-height:0;overflow:hidden;
  transition:max-height 0.35s ease,padding 0.35s ease;
}
.px-faq .faq-item.open .faq-a{max-height:300px;padding-bottom:20px}
.px-faq .faq-a p{
  font-size:14px;color:var(--ink-50);line-height:1.7;
}

/* ═══ RESPONSIVE — Pricing v2 ═══ */
@media(max-width:768px){
  .px-hero{padding:100px 20px 48px}
  .px-hero h1{font-size:32px}
  .px-hero-pills{gap:8px}
  .px-hero-pills span{font-size:10px;padding:5px 12px}
  .px-hero-card{padding:24px 20px}
  .px-hero-card .free-trial-form .form-row{flex-direction:column}
  .px-section-heading{font-size:28px}
  .px-paths-grid{grid-template-columns:1fr}
  .px-speed-grid{flex-direction:column;gap:16px}
  .px-speed-divider{display:none}
  .px-speed{max-width:none}
  .px-coverage{padding:60px 20px}
  .px-coverage-grid{grid-template-columns:1fr}
  .px-plan-badge{position:static;transform:none;margin-bottom:12px;display:inline-block}
  .px-advantage-grid{grid-template-columns:1fr}
  .px-contents-grid{grid-template-columns:1fr 1fr}
  .px-founding-inner{padding:28px 24px}
  .px-enterprise-inner{padding:32px 24px}
}
@media(max-width:480px){
  .px-hero h1{font-size:26px}
  .px-hero{padding:80px 16px 48px}
  .px-hero-sub{font-size:14px}
  .px-contents-grid{grid-template-columns:1fr}
  .px-section-heading{font-size:24px}
}

/* ═══════════════════════════════════════════════════════════
   METHODOLOGY PAGE — .page-methodology
   ═══════════════════════════════════════════════════════════ */

.page-methodology{
  background:#FFFFFF;font-family:'Inter',var(--font-body);
}
.methodology-hero{
  background:linear-gradient(180deg,#F5F5F5 0%,#fff 100%);
  padding:120px 24px 60px;text-align:center;
}
.methodology-hero h1{
  font-size:36px;font-weight:900;color:var(--ink);
  letter-spacing:-0.8px;margin-bottom:16px;
}
.methodology-hero p{
  font-size:16px;color:var(--ink-50);
  max-width:640px;margin:0 auto;line-height:1.7;
}
.methodology-body{
  max-width:800px;margin:0 auto;padding:40px 24px 80px;
}
.methodology-body h2{
  font-size:20px;font-weight:800;color:var(--ink);
  margin:48px 0 16px;letter-spacing:-0.3px;
}
.methodology-body h2:first-of-type{margin-top:0}
.methodology-body p{
  font-size:14px;color:var(--ink-50);line-height:1.8;margin-bottom:16px;
}
.methodology-body ul{
  padding-left:20px;margin-bottom:16px;
}
.methodology-body li{
  font-size:14px;color:var(--ink-50);line-height:1.8;margin-bottom:6px;
}
.methodology-body strong{color:var(--ink);font-weight:600}
.methodology-sources{
  display:grid;grid-template-columns:repeat(2,1fr);gap:16px;
  margin:24px 0;
}
.methodology-source{
  padding:20px;background:var(--ink-02);
  border-radius:var(--radius);border-left:3px solid var(--accent);
}
.methodology-source h4{
  font-size:12px;font-weight:700;color:var(--ink);
  margin-bottom:4px;text-transform:uppercase;letter-spacing:0.5px;
}
.methodology-source p{font-size:12px;color:var(--ink-50);margin-bottom:0;line-height:1.5}
.methodology-closing{
  background:var(--ink-02);border-radius:var(--radius-lg);
  padding:28px 32px;margin-top:48px;
  border-left:4px solid var(--accent);
}
.methodology-closing p{margin-bottom:0;font-weight:500;color:var(--ink)}
.methodology-answer-block{
  background:var(--ink-02);border-radius:var(--radius-lg);
  padding:24px 28px;margin-bottom:40px;
  border-left:4px solid var(--accent);
}
.methodology-answer-block p{margin-bottom:0;font-size:15px;line-height:1.7;color:var(--ink)}
.methodology-table-wrap{overflow-x:auto;margin:24px 0 32px}
.methodology-table{
  width:100%;border-collapse:collapse;font-size:13px;
}
.methodology-table thead th{
  background:var(--ink-04);color:var(--ink);font-weight:700;
  padding:10px 14px;text-align:left;
  border-bottom:2px solid var(--ink-10);
  white-space:nowrap;
}
.methodology-table tbody td{
  padding:9px 14px;border-bottom:1px solid var(--ink-04);
  color:var(--ink-70);vertical-align:top;
}
.methodology-table tbody td:first-child{
  color:var(--ink-30);font-variant-numeric:tabular-nums;
  width:32px;
}
.methodology-table tbody td:nth-child(2){
  font-weight:600;color:var(--ink);white-space:nowrap;
}
.methodology-table tbody tr:hover td{background:var(--ink-02)}

/* ═══════════════════════════════════════════════════════════
   RESPONSIVE — new pages
   ═══════════════════════════════════════════════════════════ */
@media(max-width:768px){
  .page-home .hero{height:100svh}
  .page-home .speed-compare{max-width:420px}
  .page-home .speed-compare .col{padding:18px 14px}
  .page-home .sc-val{font-size:22px}
  .page-home .cta-group{flex-direction:column;align-items:center;gap:10px}
  .page-home .trust-banner-inner{gap:16px}
  .page-home .trust-sep{display:none}
  .page-home .section-heading{font-size:28px}
  .page-home .prop-item{gap:20px}
  .page-home .prop-num{font-size:24px;width:36px}
  .scope-grid{grid-template-columns:1fr 1fr}
  .compare-table{font-size:11px}
  .compare-table th,.compare-table td{padding:10px 12px}
  .pricing-preview-cards{flex-direction:column;align-items:center}
  .free-trial-form .form-row{flex-direction:column}
  .blog-teasers-grid{grid-template-columns:1fr}
  .methodology-sources{grid-template-columns:1fr}
  .methodology-hero{padding:100px 20px 48px}
  .methodology-hero h1{font-size:28px}
}
@media(max-width:480px){
  .page-home .brand-wordmark{font-size:clamp(36px,11vw,64px);letter-spacing:clamp(4px,1.5vw,8px)}
  .page-home .brand-tagline{font-size:11px;letter-spacing:2px}
  .page-home .speed-compare{flex-direction:column;max-width:240px}
  .page-home .hero .btn-primary,.page-home .hero .btn-secondary{padding:12px 28px;font-size:12px}
  .page-home .prop-item{flex-direction:column;gap:8px}
  .page-home .prop-num{width:auto}
  .scope-grid{grid-template-columns:1fr}
}
