/* Direction B — inner-page styles.
   Light, data-forward aesthetic. Imports the home styles for shared classes. */
@import url("./styles.css");

/* ── Page-level hero (lighter than home hero) ───────────────────────────── */
.bp-pagehero {
  position: relative;
  padding: 48px 32px 32px;
  background: #FFFFFF;
  border-bottom: 1px solid var(--border-subtle);
  overflow: hidden;
}
.bp-pagehero-bg {
  display: none;
  pointer-events: none;
}
.bp-pagehero-inner { position: relative; z-index: 2; max-width: 1240px; margin: 0 auto; }
.bp-pagehero-eyebrow {
  display: inline-flex; align-items: center; gap: 10px;
  font-family: var(--font-sans); font-size: 12px; font-weight: 500;
  letter-spacing: 0.28em; text-transform: uppercase; color: var(--nq-cyan);
  margin-bottom: 24px;
}
.bp-pagehero-eyebrow .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--nq-cyan); }
.bp-pagehero h1 {
  font-family: var(--font-display); font-weight: 900;
  font-size: clamp(48px, 7vw, 96px); line-height: 0.94;
  letter-spacing: -0.04em; color: var(--nq-navy);
  margin: 0; max-width: 20ch; text-wrap: balance;
}
.bp-pagehero h1 .cyan { color: var(--nq-cyan); }
.bp-pagehero-lede { font-size: 19px; line-height: 1.65; color: var(--fg-2); max-width: 60ch; margin: 28px 0 0; }
.bp-pagehero-meta {
  display: flex; gap: 28px; margin-top: 32px;
  font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--fg-3);
}
.bp-pagehero-meta .cat { color: var(--nq-cyan); }

/* ── Generic prose body section ──────────────────────────────────────────── */
.bp-prose { background: white; color: var(--nq-navy); padding: 48px 32px; }
.bp-prose.cream { background: var(--nq-cream); }
.bp-prose-inner { max-width: 760px; margin: 0 auto; }
.bp-prose h2 { font-family: var(--font-display); font-weight: 900; font-size: clamp(32px, 4vw, 48px); line-height: 1.05; letter-spacing: -0.03em; color: var(--nq-navy); margin: 0 0 20px; text-wrap: balance; }
.bp-prose h2 .cyan { color: var(--nq-cyan); }
.bp-prose h3 { font-family: var(--font-display); font-weight: 700; font-size: 22px; letter-spacing: -0.005em; margin: 40px 0 14px; color: var(--nq-navy); }
.bp-prose p { font-size: 17px; line-height: 1.75; color: var(--fg-2); margin: 0 0 20px; max-width: 64ch; }
.bp-prose p strong { color: var(--nq-navy); font-weight: 700; }
.bp-prose ul, .bp-prose ol { padding-left: 22px; margin: 0 0 20px; }
.bp-prose ul li, .bp-prose ol li { font-size: 16px; line-height: 1.7; color: var(--fg-2); margin-bottom: 6px; }
.bp-prose ul li::marker { color: var(--nq-cyan); }
.bp-prose blockquote { border-left: 3px solid var(--nq-cyan); padding-left: 20px; margin: 28px 0; font-family: var(--font-display); font-weight: 700; font-size: 22px; line-height: 1.35; color: var(--nq-navy); }
.bp-prose hr { border: 0; border-top: 1px solid var(--border-subtle); margin: 40px 0; }
.bp-prose a { color: var(--nq-navy-700); border-bottom: 1px solid var(--nq-cyan); padding-bottom: 1px; }
.bp-prose a:hover { color: var(--nq-cyan); }

/* ── Service cards (3-up grid, light) ───────────────────────────────────── */
.bp-services { background: var(--nq-cream); padding: 48px 32px; }
.bp-services-inner { max-width: 1240px; margin: 0 auto; }
.bp-services-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; margin-top: 48px; }
.bp-svc {
  background: white; border: 1px solid var(--border-subtle);
  border-radius: var(--r-lg);
  padding: 32px 28px;
  display: flex; flex-direction: column; gap: 14px;
  transition: all var(--dur-base) var(--ease-standard);
  position: relative;
}
.bp-svc:hover { box-shadow: var(--shadow-md); border-color: var(--nq-navy-300); transform: translateY(-2px); }
.bp-svc::before {
  counter-increment: stepb; content: "0" counter(stepb);
  position: absolute; top: 28px; right: 28px;
  font-family: var(--font-mono); font-variant-numeric: tabular-nums;
  font-size: 11px; color: var(--nq-cyan); letter-spacing: 0.18em;
}
.bp-services-grid { counter-reset: stepb; }
.bp-svc-icon { width: 40px; height: 40px; display: flex; align-items: center; justify-content: center; background: var(--nq-sky-100); border-radius: var(--r-md); }
.bp-svc-icon svg { width: 20px; height: 20px; stroke: var(--nq-navy); fill: none; stroke-width: 1.6; stroke-linecap: round; stroke-linejoin: round; }
.bp-svc h3 { font-family: var(--font-display); font-weight: 700; font-size: 22px; letter-spacing: -0.005em; color: var(--nq-navy); margin: 0; }
.bp-svc p { font-size: 14px; line-height: 1.65; color: var(--fg-2); margin: 0; }
.bp-svc ul { display: flex; flex-direction: column; gap: 8px; margin: auto 0 0; padding-top: 16px; border-top: 1px solid var(--border-subtle); }
.bp-svc li { font-family: var(--font-mono); font-size: 11.5px; letter-spacing: 0.04em; color: var(--fg-2); padding-left: 16px; position: relative; }
.bp-svc li::before { content: ""; position: absolute; left: 0; top: 8px; width: 8px; height: 1px; background: var(--nq-cyan); }
/* Icon cards: icon + title + number on one header line (corner number suppressed) */
.bp-svc:has(.bp-svc-head)::before { display: none; }
.bp-svc-head { display: flex; align-items: center; gap: 12px; width: 100%; }
.bp-svc-head h3 { margin: 0; }
.bp-svc-num {
  margin-left: auto; flex-shrink: 0;
  font-family: var(--font-mono); font-variant-numeric: tabular-nums;
  font-size: 11px; letter-spacing: 0.18em; color: var(--nq-gold);
}

/* ── Team grid ──────────────────────────────────────────────────────────── */
.bp-team { background: white; padding: 48px 32px; }
.bp-team-inner { max-width: 1240px; margin: 0 auto; }
.bp-team-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 24px; margin-top: 48px; }
.bp-team-card {
  background: var(--nq-cream); border: 1px solid var(--border-subtle);
  border-radius: var(--r-lg); padding: 32px;
  display: flex; gap: 24px; align-items: flex-start;
}
.bp-team-avatar {
  width: 80px; height: 80px; border-radius: 50%;
  background: linear-gradient(135deg, #08265C, #053C82);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--font-display); font-weight: 900; font-size: 26px;
  color: white; flex: 0 0 80px;
}
.bp-team-text { flex: 1; }
.bp-team-text h4 { font-family: var(--font-display); font-weight: 700; font-size: 22px; margin: 0 0 4px; color: var(--nq-navy); letter-spacing: -0.005em; }
.bp-team-text .role { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--nq-cyan); margin: 0 0 14px; }
.bp-team-text p { font-size: 14px; line-height: 1.65; color: var(--fg-2); margin: 0; }

/* ── Insights / Blog grid ───────────────────────────────────────────────── */
.bp-insights { background: white; padding: 48px 32px; }
.bp-insights-inner { max-width: 1240px; margin: 0 auto; }
.bp-filter { display: flex; gap: 10px; flex-wrap: wrap; margin-top: 8px; }
.bp-filter .chip {
  font-family: var(--font-sans); font-weight: 500; font-size: 12px;
  letter-spacing: 0.08em; padding: 8px 16px; border-radius: var(--r-pill);
  border: 1px solid var(--border-strong); background: white; color: var(--fg-1);
  cursor: pointer; transition: all var(--dur-base) var(--ease-standard);
}
.bp-filter .chip.on { background: var(--nq-navy); color: white; border-color: var(--nq-navy); }
.bp-filter .chip:hover { border-color: var(--nq-navy); }
.bp-insights-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; margin-top: 36px; }
.bp-post {
  background: white; border: 1px solid var(--border-subtle); border-radius: var(--r-lg);
  overflow: hidden; text-decoration: none; color: inherit;
  display: flex; flex-direction: column;
  transition: all var(--dur-base) var(--ease-standard);
}
.bp-post:hover { box-shadow: var(--shadow-md); border-color: var(--nq-navy-300); transform: translateY(-2px); }
.bp-post-cover {
  aspect-ratio: 16 / 10; position: relative; overflow: hidden;
  background: linear-gradient(135deg, #08265C 0%, #053C82 100%);
}
.bp-post-cover.gradient-a { background: linear-gradient(135deg, #08265C 0%, #053C82 60%, #053C82 100%); }
.bp-post-cover.gradient-b { background: linear-gradient(135deg, #053C82 0%, #053C82 70%); }
.bp-post-cover.gradient-c { background: linear-gradient(135deg, #04143A 0%, #08265C 50%, #053C82 100%); }
.bp-post-cover svg { position: absolute; inset: 0; width: 100%; height: 100%; opacity: 0.35; }
.bp-post-body { padding: 24px; display: flex; flex-direction: column; gap: 12px; flex: 1; }
.bp-post-meta { display: flex; gap: 14px; font-family: var(--font-mono); font-size: 11px; color: var(--fg-3); letter-spacing: 0.16em; text-transform: uppercase; }
.bp-post-meta .cat { color: var(--nq-cyan); }
.bp-post h3 { font-family: var(--font-display); font-weight: 700; font-size: 20px; letter-spacing: -0.01em; line-height: 1.25; color: var(--nq-navy); margin: 0; }
.bp-post p { font-size: 14px; line-height: 1.55; color: var(--fg-2); margin: 0; }
.bp-post-cta { font-family: var(--font-mono); font-size: 11px; color: var(--nq-cyan); letter-spacing: 0.18em; text-transform: uppercase; margin-top: auto; padding-top: 4px; }

/* ── Accordion (FAQ) ────────────────────────────────────────────────────── */
.bp-faq { background: white; padding: 48px 32px; color: var(--nq-navy); }
.bp-faq-inner { max-width: 880px; margin: 0 auto; }
.bp-faq-group + .bp-faq-group { margin-top: 56px; }
.bp-faq-group h2 { font-family: var(--font-display); font-weight: 900; font-size: clamp(28px, 3vw, 40px); line-height: 1; letter-spacing: -0.025em; color: var(--nq-navy); margin: 0; }
.bp-faq-list { display: flex; flex-direction: column; gap: 0; margin-top: 24px; border-top: 1px solid var(--border-subtle); }
.bp-faq-item { border-bottom: 1px solid var(--border-subtle); }
.bp-faq-item summary {
  display: flex; align-items: center; justify-content: space-between; gap: 24px;
  padding: 22px 4px; cursor: pointer;
  font-family: var(--font-display); font-weight: 700;
  font-size: 18px; letter-spacing: -0.005em; color: var(--nq-navy);
  list-style: none;
}
.bp-faq-item summary::-webkit-details-marker { display: none; }
.bp-faq-item summary::after {
  content: "+"; font-family: var(--font-mono); font-weight: 400;
  font-size: 24px; color: var(--nq-cyan);
  transition: transform var(--dur-base) var(--ease-standard);
}
.bp-faq-item[open] summary::after { content: "−"; }
.bp-faq-item .ans { padding: 0 4px 24px; font-size: 15px; line-height: 1.7; color: var(--fg-2); max-width: 72ch; }
.bp-faq-item .ans a { color: var(--nq-navy-700); border-bottom: 1px solid var(--nq-cyan); }

/* ── Inline FAQ preview — two audience columns side-by-side (who-we-serve) ── */
.bp-faq.bp-faq-inline { background: var(--nq-bone); padding: 96px 32px; }
.bp-faq-inline .bp-faq-inner { max-width: 1240px; }
.bp-faq-inline-head { display: flex; align-items: flex-end; justify-content: space-between; gap: 40px; margin-bottom: 56px; flex-wrap: wrap; border-bottom: 1px solid var(--border-subtle); padding-bottom: 28px; }
.bp-faq-inline-head .l { max-width: 56ch; }
.bp-faq-inline-head h2 { font-family: var(--font-display); font-weight: 900; font-size: clamp(32px, 3.6vw, 52px); line-height: 1; letter-spacing: -0.03em; color: var(--nq-navy); margin: 12px 0 14px; }
.bp-faq-inline-head h2 .cyan { color: var(--nq-navy-700); }
.bp-faq-inline-head p { font-size: 16px; line-height: 1.6; color: var(--fg-2); margin: 0; max-width: 50ch; }
.bp-faq-see-all { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--nq-navy-700); border-bottom: 1px solid var(--nq-navy-700); padding-bottom: 4px; white-space: nowrap; transition: color var(--dur-base), border-color var(--dur-base); }
.bp-faq-see-all:hover { color: var(--nq-navy); border-bottom-color: var(--nq-navy); }
.bp-faq-inline-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; }
.bp-faq-inline-col .nq-eyebrow { margin-bottom: 8px; }
.bp-faq-inline-col h3 { font-family: var(--font-display); font-weight: 700; font-size: 22px; letter-spacing: -0.015em; color: var(--nq-navy); margin: 0 0 20px; }
.bp-faq-inline-col .bp-faq-list { margin-top: 0; }
.bp-faq-inline-col .bp-faq-item summary { padding: 18px 4px; font-size: 16px; }
.bp-faq-inline-col .bp-faq-item .ans { font-size: 14px; padding-bottom: 20px; }
@media (max-width: 880px) {
  .bp-faq-inline-grid { grid-template-columns: 1fr; gap: 48px; }
  .bp-faq.bp-faq-inline { padding: 64px 28px; }
}

/* ── "Common questions" aside link inside dark mini-CTA ─────────────────── */
.bp-mini-cta-aside {
  display: inline-flex; align-items: center; gap: 10px;
  margin-top: 22px;
  font-family: var(--font-mono); font-size: 11.5px;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: rgba(255,255,255,0.72);
  border-bottom: 1px solid rgba(255,255,255,0.28);
  padding-bottom: 4px;
  transition: color var(--dur-base) var(--ease-standard),
              border-color var(--dur-base) var(--ease-standard);
}
.bp-mini-cta-aside:hover { color: white; border-bottom-color: white; }
.bp-mini-cta-aside .arrow { font-family: var(--font-mono); transition: transform var(--dur-base) var(--ease-standard); }
.bp-mini-cta-aside:hover .arrow { transform: translateX(2px); }

/* Stack primary button + aside link in centered mini-CTAs (process, etc.) */
.bp-mini-cta-stack { display: flex; flex-direction: column; align-items: flex-start; gap: 18px; }

/* ── Firm-FAQ split — logo on left, questions on right ──────────────────── */
.bp-faq.bp-faq-firm { background: white; padding: 96px 32px; }
.bp-faq-firm .bp-faq-inner { max-width: 1240px; }
.bp-faq-firm-grid {
  display: grid;
  grid-template-columns: 0.85fr 1.15fr;
  gap: 96px;
  align-items: start;
}
.bp-faq-firm-mark {
  position: sticky; top: 96px;
  padding-top: 8px;
}
.bp-faq-firm-mark img {
  display: block;
  width: 100%;
  max-width: 320px;
  height: auto;
}
.bp-faq-firm-mark .caption {
  font-family: var(--font-mono);
  font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--fg-3);
  margin-top: 40px; padding-top: 24px;
  border-top: 1px solid var(--border-subtle);
  line-height: 1.9;
  max-width: 28ch;
}
.bp-faq-firm-mark .caption strong { color: var(--nq-navy); font-weight: 500; }
.bp-faq-firm-col h2 { font-family: var(--font-display); font-weight: 900; font-size: clamp(28px, 3vw, 40px); line-height: 1; letter-spacing: -0.025em; color: var(--nq-navy); margin: 12px 0 0; }
.bp-faq-firm-col .bp-faq-list { margin-top: 28px; }
@media (max-width: 880px) {
  .bp-faq.bp-faq-firm { padding: 64px 28px; }
  .bp-faq-firm-grid { grid-template-columns: 1fr; gap: 48px; }
  .bp-faq-firm-mark { position: static; }
  .bp-faq-firm-mark img { max-width: 220px; }
}

/* ── Legal / disclosure document split — sticky left rail + prose ───────── */
.bp-doc { background: white; padding: 80px 32px 96px; }
.bp-doc-inner { max-width: 1240px; margin: 0 auto; display: grid; grid-template-columns: 0.85fr 1.4fr; gap: 96px; align-items: start; }
.bp-doc-rail { position: sticky; top: 96px; padding-top: 8px; }
.bp-doc-rail img.mark { display: block; width: 100%; max-width: 280px; height: auto; }
.bp-doc-rail .caption { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--fg-3); margin-top: 36px; padding-top: 22px; border-top: 1px solid var(--border-subtle); line-height: 1.9; max-width: 30ch; }
.bp-doc-rail .caption strong { color: var(--nq-navy); font-weight: 500; }
.bp-doc-rail nav.toc { margin-top: 32px; padding-top: 22px; border-top: 1px solid var(--border-subtle); }
.bp-doc-rail nav.toc h4 { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--fg-3); margin: 0 0 16px; }
.bp-doc-rail nav.toc ul { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 12px; }
.bp-doc-rail nav.toc a { font-family: var(--font-sans); font-size: 14px; color: var(--nq-navy); border-bottom: 1px solid transparent; transition: border-color var(--dur-base) var(--ease-standard), color var(--dur-base) var(--ease-standard); padding-bottom: 2px; }
.bp-doc-rail nav.toc a:hover { border-bottom-color: var(--nq-navy-700); }
.bp-doc-body { font-size: 16px; line-height: 1.75; color: var(--fg-2); }
.bp-doc-body h2 { font-family: var(--font-display); font-weight: 900; font-size: clamp(28px, 3vw, 40px); line-height: 1; letter-spacing: -0.025em; color: var(--nq-navy); margin: 0 0 28px; scroll-margin-top: 96px; }
.bp-doc-body h3 { font-family: var(--font-display); font-weight: 700; font-size: 22px; letter-spacing: -0.01em; color: var(--nq-navy); margin: 48px 0 14px; scroll-margin-top: 96px; }
.bp-doc-body p { margin: 0 0 16px; max-width: 68ch; }
.bp-doc-body ul { margin: 0 0 20px; padding-left: 20px; max-width: 68ch; }
.bp-doc-body ul li { margin-bottom: 8px; }
.bp-doc-body a { color: var(--nq-navy-700); border-bottom: 1px solid var(--nq-cyan); }
.bp-doc-body hr { border: 0; border-top: 1px solid var(--border-subtle); margin: 36px 0 18px; }
.bp-doc-body strong { color: var(--nq-navy); }
@media (max-width: 880px) {
  .bp-doc { padding: 64px 28px; }
  .bp-doc-inner { grid-template-columns: 1fr; gap: 48px; }
  .bp-doc-rail { position: static; }
  .bp-doc-rail img.mark { max-width: 220px; }
}

/* ── Contact form ───────────────────────────────────────────────────────── */
.bp-contact { background: var(--nq-cream); padding: 48px 32px; }
.bp-contact-inner { max-width: 1240px; margin: 0 auto; display: grid; grid-template-columns: 1fr 1.1fr; gap: 64px; align-items: start; }
.bp-contact-side h2 { font-family: var(--font-display); font-weight: 900; font-size: clamp(32px, 4vw, 56px); line-height: 1; letter-spacing: -0.03em; color: var(--nq-navy); margin: 0 0 20px; }
.bp-contact-side h2 .cyan { color: var(--nq-cyan); }
.bp-contact-side p { font-size: 17px; line-height: 1.65; color: var(--fg-2); margin: 0 0 28px; max-width: 44ch; }
.bp-contact-detail { display: flex; flex-direction: column; gap: 14px; margin-top: 36px; padding-top: 24px; border-top: 1px solid var(--border-subtle); }
.bp-contact-detail-row { display: flex; flex-direction: column; gap: 4px; }
.bp-contact-detail-row .l { font-family: var(--font-mono); font-size: 11px; color: var(--fg-3); letter-spacing: 0.18em; text-transform: uppercase; }
.bp-contact-detail-row .v { color: var(--nq-navy); font-size: 15px; }
.bp-contact-detail-row a { color: var(--nq-cyan); }

.bp-form { background: white; border: 1px solid var(--border-subtle); border-radius: var(--r-lg); padding: 36px; display: flex; flex-direction: column; gap: 18px; }
.bp-field { display: flex; flex-direction: column; gap: 8px; }
.bp-field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.bp-lbl { font-family: var(--font-sans); font-weight: 500; font-size: 12px; letter-spacing: 0.06em; color: var(--fg-2); }
.bp-inp {
  font-family: var(--font-sans); font-size: 15px; color: var(--nq-navy);
  background: white; border: 1px solid var(--nq-fog-200);
  border-radius: var(--r-md); padding: 12px 14px; outline: none;
  transition: all var(--dur-base) var(--ease-standard);
}
.bp-inp:focus { border-color: var(--nq-navy-700); box-shadow: 0 0 0 3px rgba(8,38,92,0.12); }
.bp-inp::placeholder { color: var(--fg-4); }
textarea.bp-inp { resize: vertical; min-height: 100px; font-family: var(--font-sans); }
.bp-seg { display: flex; border: 1px solid var(--nq-fog-200); border-radius: var(--r-md); overflow: hidden; background: white; }
.bp-seg-opt { flex: 1; background: transparent; color: var(--fg-2); border: 0; border-right: 1px solid var(--nq-fog-200); font-family: var(--font-sans); font-size: 13px; padding: 11px 14px; cursor: pointer; transition: all var(--dur-base) var(--ease-standard); }
.bp-seg-opt:last-child { border-right: 0; }
.bp-seg-opt:hover { color: var(--nq-navy); }
.bp-seg-opt.on { background: var(--nq-navy); color: white; font-weight: 600; }
.bp-form-success { padding: 24px; background: var(--nq-sky-100); border: 1px solid var(--nq-cyan); border-radius: var(--r-md); }
.bp-form-success h4 { font-family: var(--font-display); font-weight: 700; font-size: 20px; color: var(--nq-navy); margin: 0 0 8px; }
.bp-form-success p { font-size: 14px; line-height: 1.6; color: var(--fg-2); margin: 0; }

/* ── Login page ─────────────────────────────────────────────────────────── */
.bp-login {
  min-height: 100vh; padding: 48px 32px 28px;
  display: grid; place-items: center;
  background: linear-gradient(180deg, #FFFFFF 0%, var(--nq-cream) 100%);
  position: relative; overflow: hidden;
}
.bp-login-bg { position: absolute; inset: 0; pointer-events: none; opacity: 0.05; display: flex; align-items: center; justify-content: center; }
.bp-login-bg img { width: 60%; max-width: 900px; }
.bp-login-card {
  position: relative; z-index: 2;
  background: white;
  border: 1px solid var(--border-subtle);
  border-radius: var(--r-lg);
  padding: 48px;
  width: 100%; max-width: 520px;
  box-shadow: var(--shadow-md);
}
.bp-login-card .mark { width: 48px; height: 48px; margin-bottom: 24px; }
.bp-login-card h1 { font-family: var(--font-display); font-weight: 900; font-size: 36px; letter-spacing: -0.025em; color: var(--nq-navy); margin: 0 0 10px; }
.bp-login-card .lede { color: var(--fg-2); font-size: 15px; line-height: 1.6; margin: 0 0 28px; }
.bp-login-portals { display: flex; flex-direction: column; gap: 12px; margin-bottom: 24px; }
.bp-login-portal {
  display: flex; align-items: center; justify-content: space-between;
  padding: 18px 22px;
  background: var(--nq-bone); border: 1px solid var(--border-subtle);
  border-radius: var(--r-md);
  text-decoration: none; color: inherit;
  transition: all var(--dur-base) var(--ease-standard);
}
.bp-login-portal:hover { background: var(--nq-sky-100); border-color: var(--nq-cyan); }
.bp-login-portal .name { font-family: var(--font-display); font-weight: 700; font-size: 16px; color: var(--nq-navy); }
.bp-login-portal .desc { font-size: 13px; color: var(--fg-3); margin-top: 4px; }
.bp-login-portal .arrow { font-family: var(--font-mono); font-size: 18px; color: var(--nq-cyan); }
.bp-login-foot { font-size: 13px; color: var(--fg-3); text-align: center; }
.bp-login-foot a { color: var(--nq-navy-700); border-bottom: 1px solid var(--nq-cyan); padding-bottom: 1px; }

/* ── Mini CTA — bold dark-navy closing moment with side contact form ───── */
.bp-mini-cta {
  background: var(--nq-navy);
  color: white;
  padding: 48px 32px;
  position: relative;
  overflow: hidden;
}
.bp-mini-cta::before {
  content: ""; position: absolute; inset: 0;
  background: url('assets/brandmark-white.svg') 95% 50% / auto 220% no-repeat;
  opacity: 0.04;
  pointer-events: none;
}
.bp-mini-cta-inner {
  max-width: 1240px;
  margin: 0 auto;
  position: relative;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: center;
}
.bp-mini-cta-side h2 {
  font-family: var(--font-display); font-weight: 900;
  font-size: clamp(36px, 4.5vw, 60px);
  line-height: 1; letter-spacing: -0.035em;
  color: white;
  margin: 0 0 20px;
  text-wrap: balance;
}
.bp-mini-cta-side p {
  font-size: 17px; line-height: 1.6;
  color: rgba(255,255,255,0.72);
  margin: 0 0 28px;
  max-width: 46ch;
}
.bp-mini-cta-side .nq-btn-primary {
  background: white;
  color: var(--nq-navy);
  border-color: white;
}
.bp-mini-cta-side .nq-btn-primary:hover {
  background: var(--nq-navy-100);
  color: var(--nq-navy);
  box-shadow: var(--shadow-md);
}

/* Side contact form */
.bp-mini-form {
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: var(--r-lg);
  padding: 32px;
  display: flex; flex-direction: column; gap: 16px;
  backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px);
}
.bp-mini-form .field { display: flex; flex-direction: column; gap: 6px; }
.bp-mini-form .field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.bp-mini-form label {
  font-family: var(--font-sans); font-weight: 500;
  font-size: 11.5px; letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.72);
}
.bp-mini-form input,
.bp-mini-form textarea {
  font-family: var(--font-sans); font-size: 14.5px;
  color: white;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.16);
  border-radius: var(--r-md);
  padding: 11px 13px;
  outline: none;
  transition: border-color var(--dur-base) var(--ease-standard),
              background var(--dur-base) var(--ease-standard),
              box-shadow var(--dur-base) var(--ease-standard);
}
.bp-mini-form input:focus,
.bp-mini-form textarea:focus {
  border-color: white;
  background: rgba(255,255,255,0.10);
  box-shadow: 0 0 0 3px rgba(255,255,255,0.10);
}
.bp-mini-form input::placeholder,
.bp-mini-form textarea::placeholder { color: rgba(255,255,255,0.42); }
.bp-mini-form textarea { resize: vertical; min-height: 92px; font-family: var(--font-sans); }
.bp-mini-form button {
  font-family: var(--font-sans); font-weight: 500; font-size: 14px;
  letter-spacing: 0.04em; line-height: 1;
  padding: 13px 22px; border-radius: var(--r-md);
  background: white; color: var(--nq-navy);
  border: 1px solid white;
  cursor: pointer;
  transition: all var(--dur-base) var(--ease-standard);
  margin-top: 4px;
  align-self: flex-start;
  display: inline-flex; align-items: center; gap: 10px;
}
.bp-mini-form button:hover {
  background: var(--nq-navy-100);
  box-shadow: var(--shadow-md);
}
.bp-mini-form button .arrow {
  font-family: var(--font-mono);
  transition: transform var(--dur-base) var(--ease-standard);
}
.bp-mini-form button:hover .arrow { transform: translateX(2px); }
.bp-mini-form .sent {
  padding: 18px 20px;
  background: rgba(255,255,255,0.12);
  border: 1px solid rgba(255,255,255,0.24);
  border-radius: var(--r-md);
}
.bp-mini-form .sent h4 {
  font-family: var(--font-display); font-weight: 700;
  font-size: 17px; color: white; margin: 0 0 6px;
}
.bp-mini-form .sent p {
  font-size: 13.5px; line-height: 1.55;
  color: rgba(255,255,255,0.78); margin: 0;
}

@media (max-width: 980px) {
  .bp-mini-cta-inner { grid-template-columns: 1fr; gap: 40px; }
  .bp-mini-form .field-row { grid-template-columns: 1fr; }
}

@media (max-width: 980px) {
  .bp-services-grid, .bp-team-grid, .bp-insights-grid { grid-template-columns: 1fr; }
  .bp-contact-inner { grid-template-columns: 1fr; gap: 40px; }
  .bp-field-row { grid-template-columns: 1fr; }
}


/* ════════════════════════════════════════════════════════════════════════════
   ELIGIBILITY CERTIFICATION MODAL — CIT compliance gate
   ════════════════════════════════════════════════════════════════════════════ */
.b-cert-overlay {
  position: fixed; inset: 0;
  background: rgba(4, 20, 58, 0.62);
  backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px);
  z-index: 100;
  display: flex; align-items: center; justify-content: center;
  padding: 32px 24px;
  overflow-y: auto;
}
.b-cert-card {
  background: white; border-radius: var(--r-lg);
  max-width: 760px; width: 100%;
  padding: 20px 44px;
  box-shadow: var(--shadow-lg);
  max-height: 92vh; overflow-y: auto;
  border: 1px solid var(--border-subtle);
}
.b-cert-card .label {
  font-family: var(--font-mono); font-size: 11px;
  color: var(--nq-navy-700); letter-spacing: 0.22em;
  text-transform: uppercase; margin-bottom: 10px;
}
.b-cert-card h2 {
  font-family: var(--font-display); font-weight: 700;
  font-size: 22px; letter-spacing: -0.005em;
  color: var(--nq-navy); margin: 0 0 8px;
  line-height: 1.25;
  text-wrap: balance;
}
.b-cert-card .lead {
  font-size: 14.5px; line-height: 1.65;
  color: var(--fg-1); margin: 18px 0 14px;
}
.b-cert-card .further { font-weight: 500; color: var(--nq-navy); margin: 8px 0 12px; font-size: 13.5px; letter-spacing: 0.02em; }
.b-cert-card ol {
  padding-left: 22px; margin: 0 0 20px;
  display: flex; flex-direction: column; gap: 10px;
}
.b-cert-card li {
  font-size: 13.5px; line-height: 1.55;
  color: var(--fg-2);
}
.b-cert-card li::marker { color: var(--nq-navy-700); font-weight: 600; }
.b-cert-card .checkbox-row {
  display: flex; align-items: flex-start; gap: 12px;
  padding: 16px 18px; background: var(--nq-cream);
  border-radius: var(--r-md);
  margin: 22px 0 20px;
  border: 1px solid var(--border-subtle);
}
.b-cert-card .checkbox-row input[type="checkbox"] {
  width: 18px; height: 18px; flex: 0 0 18px;
  margin-top: 2px; accent-color: var(--nq-navy);
  cursor: pointer;
}
.b-cert-card .checkbox-row label {
  font-size: 14px; line-height: 1.5;
  color: var(--nq-navy); cursor: pointer;
  user-select: none; font-weight: 500;
}
.b-cert-card .actions {
  display: flex; gap: 12px; justify-content: flex-end;
  flex-wrap: wrap;
  padding-top: 18px;
  border-top: 1px solid var(--border-subtle);
}
.b-cert-card .actions .nq-btn[aria-disabled="true"] {
  opacity: 0.4;
  cursor: not-allowed;
  pointer-events: none;
}
.b-cert-content-locked { filter: blur(10px); pointer-events: none; user-select: none; }
body.b-cert-locked { overflow: hidden; }

@media (max-width: 640px) {
  .b-cert-card { padding: 28px 24px; }
  .b-cert-card .actions { justify-content: stretch; }
  .b-cert-card .actions .nq-btn { flex: 1; justify-content: center; }
}


/* ════════════════════════════════════════════════════════════════════════════
   ABOUT PAGE — leadership portrait, philosophy block, pull-quote
   ════════════════════════════════════════════════════════════════════════════ */

/* Philosophy bulleted principles — calm vertical list */
.bp-philosophy-list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 14px 32px;
  margin: 32px 0 0;
  padding: 0;
  list-style: none;
}
.bp-philosophy-list li {
  font-size: 16px; line-height: 1.5; color: var(--fg-1);
  padding-left: 22px; position: relative;
}
.bp-philosophy-list li::before {
  content: ""; position: absolute; left: 0; top: 11px;
  width: 10px; height: 1px; background: var(--nq-navy);
}

/* Pull-quote — sits between philosophy and leader */
.bp-pullquote {
  background: var(--nq-navy); color: white;
  padding: 48px 32px;
  text-align: center;
  position: relative; overflow: hidden;
}
.bp-pullquote::before {
  content: ""; position: absolute; inset: 0;
  background: url('assets/brandmark-white.svg') 50% 50% / auto 280% no-repeat;
  opacity: 0.04;
  pointer-events: none;
}
.bp-pullquote-inner { max-width: 980px; margin: 0 auto; position: relative; }
.bp-pullquote-mark {
  font-family: var(--font-display); font-weight: 900;
  font-size: 96px; line-height: 0.6;
  color: white; opacity: 0.18;
  margin-bottom: 14px;
}
.bp-pullquote q {
  font-family: var(--font-display); font-weight: 400;
  font-size: clamp(26px, 3.2vw, 38px);
  line-height: 1.3;
  letter-spacing: -0.015em;
  color: white;
  quotes: none;
  display: block;
  text-wrap: balance;
}
.bp-pullquote q::before, .bp-pullquote q::after { content: ""; }
.bp-pullquote cite {
  display: block; margin-top: 28px;
  font-family: var(--font-sans); font-style: normal;
  font-size: 12.5px; font-weight: 500;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: rgba(255,255,255,0.7);
}

/* Leader portrait — photo + bio side-by-side */
.bp-leader { background: white; padding: 56px 32px; }
.bp-leader-inner {
  max-width: 1240px; margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1.3fr;
  gap: 64px;
  align-items: start;
}
.bp-leader-portrait {
  position: relative;
  border-radius: var(--r-lg);
  overflow: hidden;
  box-shadow: var(--shadow-md);
  background: var(--nq-cream);
}
.bp-leader-portrait img {
  display: block; width: 100%; height: auto;
}
.bp-leader-portrait::after {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 60%, rgba(8,38,92,0.18));
  pointer-events: none;
}
.bp-leader-text { padding-top: 8px; }
.bp-leader-text .eyebrow {
  font-family: var(--font-sans); font-size: 12px; font-weight: 500;
  letter-spacing: 0.28em; text-transform: uppercase;
  color: var(--nq-navy-700);
  margin: 0 0 18px;
}
.bp-leader-text h2 {
  font-family: var(--font-display); font-weight: 900;
  font-size: clamp(36px, 4.5vw, 56px);
  line-height: 1.0; letter-spacing: -0.035em;
  color: var(--nq-navy); margin: 0 0 6px;
}
.bp-leader-text .role {
  font-family: var(--font-mono); font-size: 13px;
  letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--nq-navy-700);
  margin: 0 0 24px;
}
.bp-leader-text p {
  font-size: 16px; line-height: 1.7;
  color: var(--fg-2); margin: 0 0 16px;
  max-width: 60ch;
}
.bp-leader-text p strong { color: var(--nq-navy); font-weight: 700; }

@media (max-width: 980px) {
  .bp-philosophy-list { grid-template-columns: 1fr; }
  .bp-leader-inner { grid-template-columns: 1fr; gap: 36px; }
  .bp-leader-portrait { max-width: 480px; margin: 0 auto; }
}


/* ════════════════════════════════════════════════════════════════════════════
   ABOUT PAGE — philosophy & name sections (consistent 1240px container)
   ════════════════════════════════════════════════════════════════════════════ */

.bp-philosophy {
  background: var(--nq-cream);
  padding: 56px 32px;
}
.bp-philosophy-inner {
  max-width: 1240px; margin: 0 auto;
  text-align: center;
}
.bp-philosophy-inner > h2 {
  font-family: var(--font-display); font-weight: 900;
  font-size: clamp(36px, 4.5vw, 56px);
  line-height: 1.02; letter-spacing: -0.035em;
  color: var(--nq-navy);
  margin: 0 0 28px;
  text-wrap: balance;
}
.bp-philosophy-prose {
  max-width: 64ch; margin: 0 auto 56px;
  text-align: left;
}
.bp-philosophy-prose p {
  font-size: 17px; line-height: 1.7;
  color: var(--fg-2); margin: 0 0 18px;
}
.bp-philosophy-prose p:last-child { margin-bottom: 0; }

/* 5 cards in a row, wrap to 3+2 on tablet, then 1-up on mobile */
.bp-philosophy-cards {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 16px;
  text-align: left;
}
.bp-philosophy-card {
  background: white;
  border: 1px solid var(--border-subtle);
  border-radius: var(--r-lg);
  padding: 28px 22px 26px;
  display: flex; flex-direction: column; gap: 10px;
  transition: all var(--dur-base) var(--ease-standard);
}
.bp-philosophy-card:hover {
  box-shadow: var(--shadow-md);
  border-color: var(--nq-navy-300);
  transform: translateY(-2px);
}
.bp-philosophy-card .num {
  font-family: var(--font-mono); font-variant-numeric: tabular-nums;
  font-size: 12px; letter-spacing: 0.22em;
  color: var(--nq-navy-700);
}
.bp-philosophy-card h3 {
  font-family: var(--font-display); font-weight: 700;
  font-size: 18px; line-height: 1.2; letter-spacing: -0.005em;
  color: var(--nq-navy); margin: 0;
}
.bp-philosophy-card p {
  font-size: 14px; line-height: 1.55;
  color: var(--fg-2); margin: 0;
}

@media (max-width: 1100px) {
  .bp-philosophy-cards { grid-template-columns: repeat(3, 1fr); }
  .bp-philosophy-cards .bp-philosophy-card:nth-child(4),
  .bp-philosophy-cards .bp-philosophy-card:nth-child(5) {
    /* keep last two centered in the second row on tablet */
  }
}
@media (max-width: 720px) {
  .bp-philosophy-cards { grid-template-columns: 1fr 1fr; }
  .bp-name-etym { grid-template-columns: 1fr; }
  .bp-name-etym-cell.middle {
    border-left: 0; border-right: 0;
    border-top: 1px solid var(--border-subtle);
    border-bottom: 1px solid var(--border-subtle);
  }
}


/* ════════════════════════════════════════════════════════════════════════════
   ABOUT — "The name" two-column block (light blue background)
   ════════════════════════════════════════════════════════════════════════════ */
.bp-name {
  background: var(--nq-navy-100);
  padding: 56px 32px;
}
.bp-name-inner {
  max-width: 1240px; margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px;
  align-items: start;
}
/* Push the right column down so the phonetics strip aligns with the first
   paragraph of the left column (which sits below the eyebrow + H2). */
.bp-name-col-right { padding-top: 148px; }
.bp-name-col-left h2 {
  font-family: var(--font-display); font-weight: 900;
  font-size: clamp(48px, 6vw, 80px);
  line-height: 1.0; letter-spacing: -0.04em;
  color: var(--nq-navy);
  margin: 0 0 24px;
}
.bp-name-col-left p {
  font-size: 17px; line-height: 1.7;
  color: var(--fg-1); margin: 0 0 18px;
  max-width: 56ch;
}
.bp-name-col-left p:last-child { margin-bottom: 0; }
.bp-name-col-left p strong { color: var(--nq-navy); font-weight: 700; }

/* "Listen" pronunciation button */
.bp-name-speak {
  display: inline-flex; align-items: center; gap: 12px;
  background: white;
  border: 1px solid var(--border-strong);
  border-radius: var(--r-pill);
  padding: 10px 18px 10px 14px;
  font-family: var(--font-sans);
  cursor: pointer;
  margin-top: 28px;
  transition: all var(--dur-base) var(--ease-standard);
}
.bp-name-speak:hover {
  background: var(--nq-navy);
  border-color: var(--nq-navy);
  color: white;
}
.bp-name-speak svg {
  width: 18px; height: 18px;
  color: var(--nq-navy);
  transition: color var(--dur-base) var(--ease-standard);
}
.bp-name-speak:hover svg { color: white; }
.bp-name-speak .label {
  font-size: 13px; font-weight: 500;
  letter-spacing: 0.08em; text-transform: uppercase;
  color: var(--nq-navy);
  transition: color var(--dur-base) var(--ease-standard);
}
.bp-name-speak:hover .label { color: white; }
.bp-name-speak .pron-inline {
  font-family: var(--font-mono); font-size: 12.5px;
  color: var(--fg-3);
  padding-left: 12px; border-left: 1px solid var(--border-subtle);
  transition: color var(--dur-base) var(--ease-standard), border-color var(--dur-base);
}
.bp-name-speak:hover .pron-inline {
  color: rgba(255,255,255,0.7);
  border-color: rgba(255,255,255,0.2);
}
.bp-name-speak.is-speaking { background: var(--nq-navy); border-color: var(--nq-navy); }
.bp-name-speak.is-speaking svg,
.bp-name-speak.is-speaking .label { color: white; }
.bp-name-speak.is-speaking svg {
  animation: bpSpeakPulse 0.9s ease-in-out infinite;
}
@keyframes bpSpeakPulse {
  0%, 100% { transform: scale(1); }
  50%      { transform: scale(1.18); }
}

/* Etymology — two-cell now: NAVIGATE + QUANTITATIVE */
.bp-name-etym {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: 0; align-items: center;
  padding: 24px 0;
  border-top: 1px solid var(--border-strong);
  border-bottom: 1px solid var(--border-strong);
}
.bp-name-etym-cell {
  padding: 14px 24px;
  text-align: center;
}
.bp-name-etym-cell.middle {
  padding: 0 16px;
}
.bp-name-etym-cell .word {
  font-family: var(--font-display); font-weight: 700;
  font-size: 13px; letter-spacing: 0.26em;
  text-transform: uppercase; color: var(--nq-navy);
}
.bp-name-etym-cell.middle .word {
  font-size: 22px;
  letter-spacing: 0;
  color: var(--nq-navy-700);
  text-transform: none;
}
.bp-name-etym-cell .pron {
  font-family: var(--font-mono); font-size: 12px;
  color: var(--fg-3); margin-top: 6px;
}

@media (max-width: 900px) {
  .bp-name-inner { grid-template-columns: 1fr; gap: 40px; }
  .bp-name-col-right { padding-top: 0; }
}


/* ════════════════════════════════════════════════════════════════════════════
   ABOUT — Office & registration (two columns: map left, text right)
   ════════════════════════════════════════════════════════════════════════════ */
.bp-office {
  background: white;
  padding: 56px 32px;
}
.bp-office-inner {
  max-width: 1240px; margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1.1fr;
  gap: 64px;
  align-items: stretch;
}
.bp-office-map {
  background: var(--nq-cream);
  border: 1px solid var(--border-subtle);
  border-radius: var(--r-lg);
  min-height: 340px;
  display: flex; align-items: center; justify-content: center;
  position: relative; overflow: hidden;
}
/* Faint navy grid pattern to suggest a map */
.bp-office-map::before {
  content: ""; position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(8,38,92,0.08) 1px, transparent 1px),
    linear-gradient(90deg, rgba(8,38,92,0.08) 1px, transparent 1px);
  background-size: 28px 28px;
  pointer-events: none;
}
.bp-office-map-inner {
  position: relative; z-index: 1;
  text-align: center;
  color: var(--nq-navy);
}
.bp-office-map-inner svg {
  width: 72px; height: 72px; display: block; margin: 0 auto 14px;
  color: var(--nq-navy);
}
.bp-office-map-label {
  font-family: var(--font-display); font-weight: 700;
  font-size: 18px; letter-spacing: -0.005em;
  color: var(--nq-navy);
}
.bp-office-map-sub {
  font-family: var(--font-mono); font-size: 11px;
  letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--fg-3); margin-top: 6px;
}

.bp-office-text > h2 {
  font-family: var(--font-display); font-weight: 900;
  font-size: clamp(36px, 4.5vw, 56px);
  line-height: 1.02; letter-spacing: -0.035em;
  color: var(--nq-navy);
  margin: 0 0 24px;
}
.bp-office-text p {
  font-size: 16px; line-height: 1.7;
  color: var(--fg-2); margin: 0 0 18px;
  max-width: 60ch;
}
.bp-office-text p strong { color: var(--nq-navy); font-weight: 700; }
.bp-office-text a {
  color: var(--nq-navy-700);
  border-bottom: 1px solid var(--nq-navy);
  padding-bottom: 1px;
}
.bp-office-text a:hover { color: var(--nq-navy); }

@media (max-width: 900px) {
  .bp-office-inner { grid-template-columns: 1fr; gap: 36px; }
  .bp-office-map { min-height: 260px; }
}


/* ════════════════════════════════════════════════════════════════════════════
   ABOUT — Philosophy 3-column layout
   ════════════════════════════════════════════════════════════════════════════ */
.bp-philosophy-tri {
  display: grid;
  grid-template-columns: 0.7fr 1.8fr 0.7fr;
  gap: 24px;
  align-items: stretch;
  margin-top: 48px;
  text-align: left;
}
.bp-philosophy-col {
  display: flex; flex-direction: column; gap: 14px;
}
.bp-philosophy-col-mid {
  justify-content: center;
  padding: 8px 24px;
}
.bp-philosophy-col-mid p {
  font-size: 17px; line-height: 1.7;
  color: var(--fg-2); margin: 0 0 20px;
}
.bp-philosophy-col-mid p:last-child { margin-bottom: 0; }

/* Make outer-column cards equal-height and visually lighter / smaller */
.bp-philosophy-col-left .bp-philosophy-card,
.bp-philosophy-col-right .bp-philosophy-card {
  flex: 1;
  padding: 20px 18px;
  gap: 8px;
}
.bp-philosophy-col-left .bp-philosophy-card h3,
.bp-philosophy-col-right .bp-philosophy-card h3 {
  font-size: 16px;
}
.bp-philosophy-col-left .bp-philosophy-card p,
.bp-philosophy-col-right .bp-philosophy-card p {
  font-size: 13px; line-height: 1.5;
}
.bp-philosophy-col-left .bp-philosophy-card .num,
.bp-philosophy-col-right .bp-philosophy-card .num {
  font-size: 11px;
}

/* Entrance animation: side cards slide in from their closest edge */
.bp-philosophy-col-left .bp-philosophy-card {
  opacity: 0; transform: translateX(-56px);
  transition: opacity 0.85s var(--ease-emphasis),
              transform 0.85s var(--ease-emphasis),
              box-shadow var(--dur-base) var(--ease-standard),
              border-color var(--dur-base) var(--ease-standard);
  will-change: opacity, transform;
}
.bp-philosophy-col-right .bp-philosophy-card {
  opacity: 0; transform: translateX(56px);
  transition: opacity 0.85s var(--ease-emphasis),
              transform 0.85s var(--ease-emphasis),
              box-shadow var(--dur-base) var(--ease-standard),
              border-color var(--dur-base) var(--ease-standard);
  will-change: opacity, transform;
}
.bp-philosophy.in .bp-philosophy-col-left .bp-philosophy-card,
.bp-philosophy.in .bp-philosophy-col-right .bp-philosophy-card {
  opacity: 1; transform: translateX(0);
}
.bp-philosophy.in .bp-philosophy-col-left  .bp-philosophy-card:nth-child(1) { transition-delay: 0ms; }
.bp-philosophy.in .bp-philosophy-col-right .bp-philosophy-card:nth-child(1) { transition-delay: 90ms; }
.bp-philosophy.in .bp-philosophy-col-left  .bp-philosophy-card:nth-child(2) { transition-delay: 200ms; }
.bp-philosophy.in .bp-philosophy-col-right .bp-philosophy-card:nth-child(2) { transition-delay: 290ms; }

@media (prefers-reduced-motion: reduce) {
  .bp-philosophy-col-left .bp-philosophy-card,
  .bp-philosophy-col-right .bp-philosophy-card {
    opacity: 1 !important; transform: none !important;
    transition: box-shadow var(--dur-base), border-color var(--dur-base);
  }
}

@media (max-width: 900px) {
  .bp-philosophy-tri { grid-template-columns: 1fr; }
  .bp-philosophy-col-mid { padding: 0; }
}


/* ════════════════════════════════════════════════════════════════════════════
   STRATEGIES — animated donut chart trio (tactical reallocation)
   ════════════════════════════════════════════════════════════════════════════ */
.bp-donut-trio {
  background: var(--nq-cream);
  padding: 56px 32px;
}
.bp-donut-trio-inner { max-width: 1240px; margin: 0 auto; }

.bp-donut-head {
  display: grid; grid-template-columns: 1fr 1fr; gap: 64px;
  align-items: end; margin-bottom: 64px;
}
.bp-donut-head .nq-eyebrow { color: var(--nq-navy-700); }
.bp-donut-head h2 {
  font-family: var(--font-display); font-weight: 900;
  font-size: clamp(36px, 4.5vw, 56px);
  line-height: 1.02; letter-spacing: -0.035em;
  color: var(--nq-navy);
  margin: 12px 0 0; text-wrap: balance;
}
.bp-donut-head p {
  font-size: 16px; line-height: 1.65; color: var(--fg-2);
  max-width: 56ch; margin: 0;
}
.bp-donut-head p strong { color: var(--nq-navy); font-weight: 600; }

.bp-donut-cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}

.bp-donut {
  background: white;
  border: 1px solid var(--border-subtle);
  border-radius: var(--r-lg);
  padding: 32px 28px;
  display: flex; flex-direction: column; gap: 24px;
  transition: box-shadow var(--dur-base) var(--ease-standard),
              border-color var(--dur-base) var(--ease-standard),
              transform var(--dur-base) var(--ease-standard);
}
.bp-donut:hover {
  box-shadow: var(--shadow-md);
  border-color: var(--nq-navy-300);
  transform: translateY(-2px);
}
.bp-donut header { display: flex; flex-direction: column; gap: 4px; }
.bp-donut-eyebrow {
  font-family: var(--font-sans); font-weight: 700;
  font-size: 13px; letter-spacing: 0.26em;
  color: var(--nq-navy);
}
.bp-donut-cap {
  font-family: var(--font-mono); font-size: 11px;
  letter-spacing: 0.06em; color: var(--fg-3);
}

.bp-donut-chart {
  position: relative;
  width: 220px; height: 220px;
  margin: 0 auto;
}
.bp-donut-chart svg {
  display: block; width: 100%; height: 100%;
}
.bp-donut-chart .seg {
  transform: rotate(-90deg);
  transform-origin: 100px 100px;
  transition: stroke-dasharray 1.4s cubic-bezier(0.16, 1, 0.3, 1),
              stroke-dashoffset 1.4s cubic-bezier(0.16, 1, 0.3, 1);
}
.bp-donut-center {
  position: absolute;
  inset: 0;
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  pointer-events: none;
}
.bp-donut-state {
  font-family: var(--font-display); font-weight: 700;
  font-size: 18px; letter-spacing: 0.14em;
  color: var(--nq-navy);
  transition: color 0.4s ease;
}
.bp-donut-state[data-state="RISK OFF"] { color: var(--nq-navy-700); }
.bp-donut-state[data-state="NEUTRAL"]  { color: var(--nq-navy); }
.bp-donut-state[data-state="RISK ON"]  { color: var(--nq-navy); }
.bp-donut-sub {
  font-family: var(--font-mono); font-size: 11px;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--fg-3); margin-top: 4px;
}

.bp-donut-legend {
  display: flex; flex-direction: column; gap: 10px;
  padding-top: 18px; border-top: 1px solid var(--border-subtle);
  margin: 0;
}
.bp-donut-legend li {
  display: grid;
  grid-template-columns: 12px 1fr auto;
  align-items: center; gap: 12px;
  font-size: 13px;
}
.bp-donut-legend .sw {
  width: 12px; height: 12px; border-radius: 2px;
}
.bp-donut-legend .name { color: var(--fg-1); }
.bp-donut-legend .pct {
  font-family: var(--font-mono); font-variant-numeric: tabular-nums;
  color: var(--nq-navy); font-weight: 600; font-size: 13.5px;
}

.bp-donut-disclaimer {
  font-size: 12.5px; line-height: 1.65;
  color: var(--fg-3);
  max-width: 86ch; margin: 40px auto 0;
  text-align: center;
}
.bp-donut-disclaimer a { color: var(--nq-navy); border-bottom: 1px solid var(--border-strong); }
.bp-donut-disclaimer a:hover { color: var(--nq-navy-700); border-color: var(--nq-navy-700); }

@media (max-width: 980px) {
  .bp-donut-head, .bp-donut-cards { grid-template-columns: 1fr; }
  .bp-donut-cards { gap: 20px; }
}

@media (prefers-reduced-motion: reduce) {
  .bp-donut-chart .seg { transition: none; }
}


/* ════════════════════════════════════════════════════════════════════════════
   STRATEGIES — Institutions & Advisors pair (above the CTA)
   ════════════════════════════════════════════════════════════════════════════ */
.bp-pair {
  background: white;
  padding: 56px 32px;
}
.bp-pair-inner { max-width: 1240px; margin: 0 auto; }
.bp-pair-head {
  display: grid; grid-template-columns: 1fr 1fr; gap: 64px;
  align-items: end; margin-bottom: 56px;
}
.bp-pair-head .nq-eyebrow { color: var(--nq-navy-700); }
.bp-pair-head h2 {
  font-family: var(--font-display); font-weight: 900;
  font-size: clamp(36px, 4.5vw, 56px);
  line-height: 1.02; letter-spacing: -0.035em;
  color: var(--nq-navy);
  margin: 12px 0 0; text-wrap: balance;
}
.bp-pair-head p {
  font-size: 16px; line-height: 1.65; color: var(--fg-2);
  max-width: 50ch; margin: 0;
}

.bp-pair-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
}
.bp-pair-card {
  background: var(--nq-cream);
  border: 1px solid var(--border-subtle);
  border-radius: var(--r-lg);
  padding: 36px 32px;
  display: flex; flex-direction: column; gap: 16px;
  text-decoration: none; color: inherit;
  transition: all var(--dur-base) var(--ease-standard);
  position: relative;
  min-height: 240px;
}
.bp-pair-card:hover {
  background: white;
  box-shadow: var(--shadow-md);
  border-color: var(--nq-navy-300);
  transform: translateY(-2px);
}
.bp-pair-card.restricted {
  background: var(--nq-navy);
  color: white;
  border-color: var(--nq-navy);
}
.bp-pair-card.restricted:hover {
  background: var(--nq-navy-900);
  border-color: var(--nq-navy-900);
}

.bp-pair-num {
  font-family: var(--font-mono); font-size: 11px;
  color: var(--nq-navy-700);
  letter-spacing: 0.22em;
}
.bp-pair-card.restricted .bp-pair-num {
  color: var(--nq-navy-300);
}
.bp-pair-card h3 {
  font-family: var(--font-display); font-weight: 700;
  font-size: 24px; line-height: 1.15; letter-spacing: -0.015em;
  color: var(--nq-navy); margin: 0;
}
.bp-pair-card.restricted h3 { color: white; }
.bp-pair-card p {
  font-size: 14.5px; line-height: 1.65;
  color: var(--fg-2); margin: 0;
}
.bp-pair-card.restricted p { color: rgba(255,255,255,0.78); }
.bp-pair-cta {
  margin-top: auto;
  padding-top: 16px;
  border-top: 1px solid var(--border-subtle);
  font-family: var(--font-sans); font-weight: 500;
  font-size: 12px; letter-spacing: 0.1em;
  color: var(--nq-navy);
  text-transform: uppercase;
}
.bp-pair-cta::after { content: " →"; font-family: var(--font-mono); }
.bp-pair-card.restricted .bp-pair-cta {
  color: var(--nq-navy-300);
  border-top-color: rgba(255,255,255,0.14);
}

@media (max-width: 900px) {
  .bp-pair-head, .bp-pair-grid { grid-template-columns: 1fr; }
}


/* ── bp-prose .navy variant: brand-navy background, white type ──────────── */
.bp-prose.navy {
  background: var(--nq-navy);
  color: rgba(255,255,255,0.85);
}
.bp-prose.navy h2,
.bp-prose.navy h3 { color: white; }
.bp-prose.navy h2 .cyan { color: var(--nq-navy-300); }
.bp-prose.navy p { color: rgba(255,255,255,0.78); }
.bp-prose.navy p strong { color: white; }
.bp-prose.navy ul li,
.bp-prose.navy ol li { color: rgba(255,255,255,0.78); }
.bp-prose.navy ul li::marker,
.bp-prose.navy ol li::marker { color: var(--nq-navy-300); }
.bp-prose.navy blockquote {
  color: white;
  border-left-color: var(--nq-navy-300);
}
.bp-prose.navy hr { border-color: rgba(255,255,255,0.14); }
.bp-prose.navy a {
  color: white;
  border-color: rgba(255,255,255,0.5);
}
.bp-prose.navy a:hover { color: var(--nq-navy-100); border-color: white; }
.bp-prose.navy .bp-pagehero-eyebrow { color: var(--nq-navy-300); }

/* Wide variant for prose sections that need to align with 1240px containers */
.bp-prose.bp-prose-wide { padding: 96px 32px; }
.bp-prose.bp-prose-wide .bp-prose-inner { max-width: 1240px; }
.bp-prose-twocol {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  margin-top: 16px;
  max-width: 1100px;
}
.bp-prose-twocol p { max-width: none; }
@media (max-width: 880px) {
  .bp-prose-twocol { grid-template-columns: 1fr; gap: 24px; }
}


/* ════════════════════════════════════════════════════════════════════════════
   STRATEGIES — bridge section (2/3 - 1/3 two-column on dark navy)
   ════════════════════════════════════════════════════════════════════════════ */
.bp-bridge {
  background: var(--nq-navy);
  color: white;
  padding: 48px 32px;
}
.bp-bridge-inner {
  max-width: 1240px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 2fr 1fr;
  gap: 64px;
  align-items: start;
}
.bp-bridge-col-text .bp-pagehero-eyebrow { color: var(--nq-navy-300); }
.bp-bridge-col-text h2 {
  font-family: var(--font-display); font-weight: 900;
  font-size: clamp(36px, 4.5vw, 56px);
  line-height: 1.02; letter-spacing: -0.035em;
  color: white;
  margin: 0 0 24px;
}
.bp-bridge-col-text h2 .cyan { color: var(--nq-navy-300); }
.bp-bridge-col-text p {
  font-size: 17px; line-height: 1.7;
  color: rgba(255,255,255,0.78);
  margin: 0;
  max-width: 56ch;
}

.bp-bridge-col-cards {
  display: flex; flex-direction: column;
  gap: 10px;
  padding-top: 8px;
}
.bp-bridge-title {
  font-family: var(--font-sans); font-weight: 600;
  font-size: 11px; letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--nq-navy-300);
  margin-bottom: 6px;
}
.bp-bridge-card {
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: var(--r-md);
  padding: 14px 16px;
  display: flex; flex-direction: column; gap: 3px;
  transition: all var(--dur-base) var(--ease-standard);
}
.bp-bridge-card:hover {
  background: rgba(255,255,255,0.07);
  border-color: var(--nq-navy-300);
  transform: translateX(4px);
}
.bp-bridge-card h4 {
  font-family: var(--font-display); font-weight: 700;
  font-size: 14px; letter-spacing: -0.005em;
  color: white;
  margin: 0;
}
.bp-bridge-card p {
  font-size: 12.5px; line-height: 1.5;
  color: rgba(255,255,255,0.7);
  margin: 0;
}

@media (max-width: 900px) {
  .bp-bridge-inner { grid-template-columns: 1fr; gap: 36px; }
}


/* ── NCM stack (process page centerpiece) ───────────────────────────────── */
.bp-ncm-stack {
  background: var(--nq-navy); color: white;
  padding: 96px 32px;
  position: relative; overflow: hidden;
}
.bp-ncm-stack::before {
  content: ""; position: absolute; inset: 0;
  background: url('assets/brandmark-white.svg') 95% 50% / auto 200% no-repeat;
  opacity: 0.025; pointer-events: none;
}
.bp-ncm-inner { max-width: 1240px; margin: 0 auto; position: relative; }
.bp-ncm-stack .b-section-head { color: white; }
.bp-ncm-stack .b-section-head h2 { color: white; }
.bp-ncm-stack .b-section-head h2 .cyan { color: var(--nq-navy-300); }
.bp-ncm-stack .b-section-head .nq-eyebrow { color: rgba(255,255,255,0.55); }
.bp-ncm-stack .b-section-head p { color: rgba(255,255,255,0.72); }

.bp-ncm-viz {
  margin-top: 56px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.10);
  border-radius: var(--r-lg);
  padding: 36px;
}
.bp-ncm-row { margin-bottom: 32px; }
.bp-ncm-row:last-child { margin-bottom: 0; }
.bp-ncm-row-h {
  display: flex; justify-content: space-between; align-items: baseline; gap: 16px;
  margin-bottom: 12px;
  font-family: var(--font-mono);
  font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase;
  color: rgba(255,255,255,0.55);
  flex-wrap: wrap;
}
.bp-ncm-row-h .lab strong { color: white; font-weight: 500; letter-spacing: 0.18em; }
.bp-ncm-row-h .legend { display: inline-flex; gap: 18px; align-items: center; flex-wrap: wrap; }
.bp-ncm-row-h .legend span { display: inline-flex; align-items: center; gap: 6px; }
.bp-ncm-row-h .legend .sw { width: 14px; height: 2px; display: inline-block; }
.bp-ncm-row-h .v { font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.14em; }
.bp-ncm-row-h .v.on { color: #6DD8B9; }
.bp-ncm-row-h .v.off { color: #E48A8A; }
.bp-ncm-row-h .v.dot::before { content: "●"; margin-right: 6px; font-size: 9px; }
.bp-ncm-row-h .v.on.dot::before { color: #6DD8B9; animation: ncmPulse 2.2s ease-in-out infinite; }
@keyframes ncmPulse {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.35; }
}

/* Price chart */
.bp-ncm-price { display: block; width: 100%; height: auto; }
.bp-ncm-price .grid line { stroke: rgba(255,255,255,0.06); stroke-width: 1; }
.bp-ncm-price .price-line { fill: none; stroke: rgba(255,255,255,0.7); stroke-width: 1.4; stroke-linecap: round; stroke-linejoin: round; stroke-dasharray: 3000; stroke-dashoffset: 3000; animation: ncmDraw 3.2s ease-out 0.2s forwards; }
.bp-ncm-price .ma-fast { fill: none; stroke: var(--nq-navy-300); stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round; stroke-dasharray: 3000; stroke-dashoffset: 3000; animation: ncmDraw 3.2s ease-out 0.8s forwards; }
.bp-ncm-price .ma-slow { fill: none; stroke: #6DD8B9; stroke-width: 1.6; stroke-linecap: round; stroke-linejoin: round; stroke-dasharray: 6 5; opacity: 0; animation: ncmFadeIn 1.2s ease-out 1.6s forwards; }
.bp-ncm-price .cross-mark { opacity: 0; }
.bp-ncm-price .cross-mark.c1 { animation: ncmPop 0.5s var(--ease-standard) 2.6s forwards; }
.bp-ncm-price .cross-mark.c2 { animation: ncmPop 0.5s var(--ease-standard) 3.0s forwards; }
.bp-ncm-price .cross-mark.c3 { animation: ncmPop 0.5s var(--ease-standard) 3.4s forwards; }
.bp-ncm-price .cross-dot { fill: white; }
.bp-ncm-price .cross-ring { fill: none; stroke: white; stroke-width: 1; opacity: 0.35; }

/* Up-state crossovers → green; down-state crossovers → red */
.bp-ncm-price .cross-mark.up .cross-dot { fill: #6DD8B9; }
.bp-ncm-price .cross-mark.up .cross-ring { stroke: #6DD8B9; }
.bp-ncm-price .cross-mark.up .cross-rotor { stroke: #6DD8B9; }
.bp-ncm-price .cross-mark.up .cross-pulse { stroke: #6DD8B9; }
.bp-ncm-price .cross-mark.down .cross-dot { fill: #E48A8A; }
.bp-ncm-price .cross-mark.down .cross-ring { stroke: #E48A8A; }
.bp-ncm-price .cross-mark.down .cross-rotor { stroke: #E48A8A; }
.bp-ncm-price .cross-mark.down .cross-pulse { stroke: #E48A8A; }

/* Rotating dashed ring around each crossover dot */
.bp-ncm-price .cross-rotor {
  fill: none;
  stroke-width: 1.3;
  stroke-dasharray: 3 4;
  stroke-linecap: round;
  opacity: 0.85;
  transform-box: fill-box;
  transform-origin: center;
  animation: ncmRotate 6s linear infinite;
}
.bp-ncm-price .cross-mark.c1 .cross-rotor { animation-delay: 0s; }
.bp-ncm-price .cross-mark.c2 .cross-rotor { animation-delay: -1.5s; }
.bp-ncm-price .cross-mark.c3 .cross-rotor { animation-delay: -3s; }
@keyframes ncmRotate {
  from { transform: rotate(0deg); }
  to   { transform: rotate(360deg); }
}

/* Outward-expanding pulse ring */
.bp-ncm-price .cross-pulse {
  fill: none;
  stroke-width: 1.5;
  transform-box: fill-box;
  transform-origin: center;
  animation: ncmCrossPulse 2.6s ease-out infinite;
}
.bp-ncm-price .cross-mark.c1 .cross-pulse { animation-delay: 0s; }
.bp-ncm-price .cross-mark.c2 .cross-pulse { animation-delay: 0.9s; }
.bp-ncm-price .cross-mark.c3 .cross-pulse { animation-delay: 1.8s; }
@keyframes ncmCrossPulse {
  0%   { transform: scale(0.7); opacity: 0.7; }
  80%  { opacity: 0; }
  100% { transform: scale(2.8); opacity: 0; }
}
.bp-ncm-price .cross-tag {
  font-family: var(--font-mono); font-size: 9.5px;
  letter-spacing: 0.18em; text-transform: uppercase;
  fill: white;
}
.bp-ncm-price .cross-tag.up { fill: #6DD8B9; }
.bp-ncm-price .cross-tag.down { fill: #E48A8A; }
@keyframes ncmDraw { to { stroke-dashoffset: 0; } }
@keyframes ncmFadeIn { from { opacity: 0; } to { opacity: 0.6; } }
@keyframes ncmPop {
  0% { opacity: 0; transform: scale(0.3); }
  60% { opacity: 1; transform: scale(1.2); }
  100% { opacity: 1; transform: scale(1); }
}

/* Signals row — three thin oscillating bands */
.bp-ncm-signal {
  display: grid; grid-template-columns: 90px 1fr 60px;
  align-items: center; gap: 16px;
  padding: 10px 0;
  border-top: 1px solid rgba(255,255,255,0.06);
}
.bp-ncm-signal:first-child { border-top: 0; }
.bp-ncm-signal .sig-name { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: rgba(255,255,255,0.6); }
.bp-ncm-signal .sig-val { font-family: var(--font-mono); font-size: 13px; color: white; text-align: right; font-variant-numeric: tabular-nums; }
.bp-ncm-signal .sig-val.pos { color: #6DD8B9; }
.bp-ncm-signal .sig-val.neg { color: #E48A8A; }
.bp-ncm-signal-svg { display: block; width: 100%; height: 36px; overflow: hidden; }
.bp-ncm-signal-svg .baseline { stroke: rgba(255,255,255,0.12); stroke-width: 1; stroke-dasharray: 2 4; }
.bp-ncm-signal-svg .wave { fill: none; stroke: rgba(255,255,255,0.7); stroke-width: 1.5; stroke-linecap: round; stroke-linejoin: round; }
.bp-ncm-signal-svg .scroll-1 { animation: ncmScroll 14s linear infinite; }
.bp-ncm-signal-svg .scroll-2 { animation: ncmScroll 10s linear infinite; }
.bp-ncm-signal-svg .scroll-3 { animation: ncmScroll 18s linear infinite; }
@keyframes ncmScroll { from { transform: translateX(0); } to { transform: translateX(-800px); } }

/* Composite oscillator */
.bp-ncm-composite-svg { display: block; width: 100%; height: 80px; overflow: hidden; }
.bp-ncm-composite-svg .zone-up { fill: rgba(109, 216, 185, 0.07); }
.bp-ncm-composite-svg .zone-down { fill: rgba(228, 138, 138, 0.05); }
.bp-ncm-composite-svg .baseline { stroke: rgba(255,255,255,0.20); stroke-width: 1; stroke-dasharray: 2 4; }
.bp-ncm-composite-svg .wave-fill { fill: var(--nq-navy-300); opacity: 0.15; }
.bp-ncm-composite-svg .wave { fill: none; stroke: var(--nq-navy-300); stroke-width: 2.2; stroke-linecap: round; stroke-linejoin: round; }
.bp-ncm-composite-svg .scroll { animation: ncmScroll 16s linear infinite; }

.bp-ncm-disclaimer {
  margin-top: 24px;
  font-family: var(--font-mono); font-size: 11px;
  letter-spacing: 0.16em; text-transform: uppercase;
  color: rgba(255,255,255,0.35);
  text-align: center;
}
.bp-ncm-disclaimer a { color: rgba(255,255,255,0.55); border-bottom: 1px solid rgba(255,255,255,0.2); }

@media (max-width: 720px) {
  .bp-ncm-stack { padding: 64px 24px; }
  .bp-ncm-viz { padding: 24px; }
  .bp-ncm-signal { grid-template-columns: 70px 1fr 54px; gap: 12px; }
  .bp-ncm-row-h .legend { width: 100%; }
}

/* ── Breathing 4-step loop (Asset C) ────────────────────────────────────── */
.b-method-loop .b-method-card { position: relative; isolation: isolate; }
.b-method-loop .b-method-card::after {
  content: "";
  position: absolute; inset: -1px;
  border-radius: inherit;
  border: 1.5px solid var(--nq-navy);
  opacity: 0;
  pointer-events: none;
  z-index: 1;
  box-shadow: 0 8px 24px rgba(8,38,92,0.10);
  animation: methodBreathe 8s ease-in-out infinite;
}
.b-method-loop .b-method-card:nth-child(1)::after { animation-delay: 0s; }
.b-method-loop .b-method-card:nth-child(2)::after { animation-delay: 2s; }
.b-method-loop .b-method-card:nth-child(3)::after { animation-delay: 4s; }
.b-method-loop .b-method-card:nth-child(4)::after { animation-delay: 6s; }
@keyframes methodBreathe {
  0%, 25%, 100% { opacity: 0; }
  4% { opacity: 1; }
  20% { opacity: 1; }
}

/* ── Ticker wall (Asset B) ───────────────────────────────────────────────── */
.bp-ticker-wall {
  background: var(--nq-bone);
  padding: 96px 0;
  overflow: hidden;
  position: relative;
}
.bp-ticker-wall .head {
  max-width: 1240px; margin: 0 auto 48px;
  padding: 0 32px;
}
.bp-ticker-wall .head h2 { font-family: var(--font-display); font-weight: 900; font-size: clamp(32px, 3.6vw, 52px); line-height: 1; letter-spacing: -0.03em; color: var(--nq-navy); margin: 12px 0 14px; max-width: 24ch; }
.bp-ticker-wall .head h2 .cyan { color: var(--nq-navy-700); }
.bp-ticker-wall .head p { font-size: 16px; line-height: 1.6; color: var(--fg-2); margin: 0; max-width: 60ch; }
.bp-ticker-marquee {
  display: flex; gap: 18px;
  padding: 0 32px;
  width: max-content;
  animation: tickerScroll 70s linear infinite;
}
.bp-ticker-wall:hover .bp-ticker-marquee { animation-play-state: paused; }
.bp-ticker-card {
  flex: 0 0 240px;
  background: white;
  border: 1px solid var(--border-subtle);
  border-radius: var(--r-lg);
  padding: 22px 22px 18px;
  display: flex; flex-direction: column; gap: 12px;
  transition: all var(--dur-base) var(--ease-standard);
}
.bp-ticker-card:hover {
  border-color: var(--nq-navy-300);
  box-shadow: var(--shadow-sm);
}
.bp-ticker-card .row1 { display: flex; align-items: baseline; justify-content: space-between; }
.bp-ticker-card .sym { font-family: var(--font-mono); font-weight: 600; font-size: 16px; color: var(--nq-navy); letter-spacing: 0.06em; }
.bp-ticker-card .state {
  font-family: var(--font-mono); font-size: 10px;
  letter-spacing: 0.18em; text-transform: uppercase;
  padding: 3px 8px;
  border-radius: var(--r-pill);
  border: 1px solid;
}
.bp-ticker-card .state.on  { color: #1F8A5B; border-color: rgba(31, 138, 91, 0.35); background: rgba(31, 138, 91, 0.06); }
.bp-ticker-card .state.off { color: #B14747; border-color: rgba(177, 71, 71, 0.30); background: rgba(177, 71, 71, 0.05); }
.bp-ticker-card .state.neu { color: var(--fg-3); border-color: var(--border-subtle); background: var(--nq-bone); }
.bp-ticker-card .ncm { font-family: var(--font-mono); font-size: 12px; color: var(--fg-2); letter-spacing: 0.06em; }
.bp-ticker-card .ncm .v { color: var(--nq-navy); font-weight: 500; }
.bp-ticker-card .spark { display: block; width: 100%; height: 32px; }
.bp-ticker-card .spark path { fill: none; stroke: var(--nq-navy); stroke-width: 1.4; stroke-linecap: round; stroke-linejoin: round; }
.bp-ticker-card.is-off .spark path { stroke: var(--fg-3); }
@keyframes tickerScroll { from { transform: translateX(0); } to { transform: translateX(-50%); } }

.bp-ticker-disclaimer {
  margin: 36px auto 0;
  max-width: 1240px;
  padding: 0 32px;
  font-family: var(--font-mono); font-size: 11px;
  letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--fg-3);
  text-align: center;
}


/* ── Audience picker (sticky, who-we-serve) ─────────────────────────────── */
.bp-audience-picker {
  position: sticky; top: 0; z-index: 40;
  background: rgba(255,255,255,0.94);
  backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px);
  border-bottom: 1px solid var(--border-subtle);
}
/* Push picker below the topbar (topbar is ~64px tall on this site) */
.nq-topbar + .bp-pagehero + .bp-audience-picker,
.bp-pagehero + .bp-audience-picker { top: 64px; }
.bp-audience-picker-inner {
  max-width: 1240px; margin: 0 auto;
  padding: 16px 32px;
  display: grid; grid-template-columns: 1fr 1fr 1fr;
  gap: 14px;
}
.bp-audience-tab {
  display: flex; flex-wrap: wrap; align-items: baseline;
  column-gap: 9px; row-gap: 7px;
  padding: 16px 18px 15px;
  background: #FBF1D7;
  border: 1px solid #EAD08C;
  border-radius: var(--r-lg);
  box-shadow: 0 1px 2px rgba(90,68,12,0.06);
  color: var(--nq-navy);
  transition: transform var(--dur-base) var(--ease-standard),
              box-shadow var(--dur-base) var(--ease-standard),
              background var(--dur-base) var(--ease-standard),
              border-color var(--dur-base) var(--ease-standard);
  position: relative;
  min-width: 0;
}
.bp-audience-tab .num {
  font-family: var(--font-mono); font-size: 11px;
  color: #A9842A; letter-spacing: 0.18em; font-weight: 600;
  flex-shrink: 0;
}
.bp-audience-tab .lab {
  font-family: var(--font-display); font-weight: 700;
  font-size: 18px; letter-spacing: -0.01em;
  color: var(--nq-navy);
  white-space: nowrap;
}
.bp-audience-tab .meta {
  font-family: var(--font-mono); font-size: 11px;
  letter-spacing: 0.12em; text-transform: uppercase;
  color: #8C7327;
  flex-basis: 100%;
  white-space: nowrap;
  text-overflow: ellipsis; overflow: hidden;
}
/* clickable arrow affordance */
.bp-audience-tab::after {
  content: "→";
  position: absolute; top: 14px; right: 16px;
  font-family: var(--font-mono); font-size: 15px;
  color: #C49A2C;
  transition: transform var(--dur-base) var(--ease-standard),
              color var(--dur-base) var(--ease-standard);
}
.bp-audience-tab:hover {
  background: #F8E6B0;
  border-color: #DFBF5C;
  box-shadow: 0 6px 16px rgba(135,100,18,0.16);
  transform: translateY(-2px);
}
.bp-audience-tab:hover::after { transform: translateX(3px); color: #9A7414; }
.bp-audience-tab.is-active {
  background: #EFC247;
  border-color: #DCAA24;
  box-shadow: 0 7px 18px rgba(190,150,30,0.26);
}
.bp-audience-tab.is-active .num { color: var(--nq-navy); }
.bp-audience-tab.is-active .meta { color: var(--nq-navy-700); }
.bp-audience-tab.is-active::after { color: var(--nq-navy); }
@media (max-width: 800px) {
  .bp-audience-picker-inner { grid-template-columns: 1fr 1fr 1fr; padding: 12px 20px; gap: 8px; }
  .bp-audience-tab { padding: 12px 12px 11px; gap: 6px; }
  .bp-audience-tab .meta { display: none; }
  .bp-audience-tab::after { top: 10px; right: 11px; font-size: 13px; }
}

/* ── Advisor gate (for-advisors-only) ───────────────────────────────────── */
.bp-gate-wrap {
  margin-top: 56px;
  display: grid;
  grid-template-columns: 0.85fr 1.15fr;
  gap: 64px;
  align-items: start;
}
.bp-gate-intro h3 {
  font-family: var(--font-display); font-weight: 700;
  font-size: 26px; letter-spacing: -0.015em;
  color: var(--nq-navy);
  margin: 0 0 16px;
}
.bp-gate-intro p {
  font-size: 15px; line-height: 1.7;
  color: var(--fg-2);
  margin: 0 0 14px; max-width: 44ch;
}
.bp-gate-intro .lock-icon {
  width: 36px; height: 36px;
  margin-bottom: 24px;
  color: var(--nq-navy);
}
.bp-gate-intro ul {
  list-style: none; padding: 0;
  margin: 16px 0 0;
  display: flex; flex-direction: column; gap: 10px;
}
.bp-gate-intro ul li {
  font-family: var(--font-mono); font-size: 12px;
  letter-spacing: 0.10em;
  color: var(--fg-2);
  padding-left: 22px; position: relative;
}
.bp-gate-intro ul li::before {
  content: ""; position: absolute; left: 0; top: 7px;
  width: 12px; height: 1.5px;
  background: var(--nq-navy-300);
}

.bp-gate-form {
  background: white;
  border: 1px solid var(--border-subtle);
  border-radius: var(--r-lg);
  padding: 32px;
  display: flex; flex-direction: column; gap: 16px;
  box-shadow: var(--shadow-sm);
}
.bp-gate-form .row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.bp-gate-form .f { display: flex; flex-direction: column; gap: 6px; }
.bp-gate-form label {
  font-family: var(--font-sans); font-weight: 500;
  font-size: 11.5px; letter-spacing: 0.08em;
  text-transform: uppercase; color: var(--fg-2);
}
.bp-gate-form input,
.bp-gate-form select {
  font-family: var(--font-sans); font-size: 15px;
  color: var(--nq-navy);
  background: white; border: 1px solid var(--nq-fog-200);
  border-radius: var(--r-md); padding: 11px 13px;
  outline: none;
  transition: border-color var(--dur-base), box-shadow var(--dur-base);
}
.bp-gate-form input:focus,
.bp-gate-form select:focus {
  border-color: var(--nq-navy-700);
  box-shadow: 0 0 0 3px rgba(8, 38, 92, 0.12);
}
.bp-gate-form .attest {
  display: flex; align-items: flex-start; gap: 12px;
  padding: 14px 16px;
  background: var(--nq-bone);
  border: 1px solid var(--border-subtle);
  border-radius: var(--r-md);
  font-size: 13px; line-height: 1.55;
  color: var(--fg-2);
  cursor: pointer;
}
.bp-gate-form .attest input { width: 16px; height: 16px; margin-top: 2px; accent-color: var(--nq-navy); }
.bp-gate-form button {
  font-family: var(--font-sans); font-weight: 500;
  font-size: 14px; letter-spacing: 0.04em;
  padding: 14px 22px; border-radius: var(--r-md);
  background: var(--nq-navy); color: white;
  border: 1px solid var(--nq-navy);
  cursor: pointer;
  transition: all var(--dur-base) var(--ease-standard);
  margin-top: 4px;
  align-self: stretch;
  display: inline-flex; align-items: center; justify-content: center; gap: 10px;
}
.bp-gate-form button:hover { background: var(--nq-navy-900); border-color: var(--nq-navy-900); box-shadow: var(--shadow-md); }
.bp-gate-form button .arrow { font-family: var(--font-mono); transition: transform var(--dur-base) var(--ease-standard); }
.bp-gate-form button:hover .arrow { transform: translateX(3px); }
.bp-gate-form .err {
  font-size: 12.5px; color: #B14747;
  margin: 0; display: none;
}
.bp-gate-form.is-error .err { display: block; }

/* Unlocked / gated-content reveal */
.bp-gated-content { display: none; margin-top: 56px; }
.bp-gated-content.is-unlocked {
  display: block;
  animation: ncmFadeUp 0.5s ease-out;
}
@keyframes ncmFadeUp {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}

.bp-gate-unlocked-banner {
  display: none;
  align-items: center; justify-content: space-between; gap: 16px;
  padding: 14px 20px;
  background: rgba(31, 138, 91, 0.06);
  border: 1px solid rgba(31, 138, 91, 0.25);
  border-radius: var(--r-md);
  margin-bottom: 32px;
  font-family: var(--font-mono); font-size: 12px;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: #1F8A5B;
}
.bp-gate-unlocked-banner.is-shown { display: flex; }
.bp-gate-unlocked-banner button {
  background: transparent; border: 0;
  font-family: var(--font-mono); font-size: 11px;
  letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--fg-3);
  cursor: pointer;
  padding: 4px 8px;
}
.bp-gate-unlocked-banner button:hover { color: var(--nq-navy); }

/* CIT card */
.bp-cit-card {
  background: white;
  border: 1px solid var(--border-subtle);
  border-radius: var(--r-lg);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
}
.bp-cit-card .cit-head {
  padding: 32px 36px 28px;
  border-bottom: 1px solid var(--border-subtle);
  background: var(--nq-bone);
}
.bp-cit-card .cit-head .eyebrow {
  font-family: var(--font-mono); font-size: 11px;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--fg-3);
  margin-bottom: 8px;
}
.bp-cit-card .cit-head h3 {
  font-family: var(--font-display); font-weight: 900;
  font-size: clamp(28px, 3vw, 36px); line-height: 1;
  letter-spacing: -0.025em;
  color: var(--nq-navy);
  margin: 0;
}
.bp-cit-card .cit-head p {
  font-size: 14px; line-height: 1.6;
  color: var(--fg-2);
  margin: 12px 0 0;
  max-width: 60ch;
}
.bp-cit-grid {
  display: grid; grid-template-columns: 1fr 1fr;
}
.bp-cit-grid .cit-stats {
  padding: 28px 36px;
  border-right: 1px solid var(--border-subtle);
}
.bp-cit-grid .cit-resources {
  padding: 28px 36px;
}
.bp-cit-stat {
  display: grid; grid-template-columns: 130px 1fr;
  align-items: baseline; gap: 16px;
  padding: 10px 0;
  border-top: 1px solid var(--border-subtle);
}
.bp-cit-stat:first-child { border-top: 0; padding-top: 0; }
.bp-cit-stat .l {
  font-family: var(--font-mono); font-size: 11px;
  letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--fg-3);
}
.bp-cit-stat .v {
  font-family: var(--font-sans); font-size: 14px;
  color: var(--nq-navy); font-weight: 500;
}
.bp-cit-stat .v.mono { font-family: var(--font-mono); font-variant-numeric: tabular-nums; }
.bp-cit-resources h4 {
  font-family: var(--font-mono); font-size: 11px;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--fg-3); margin: 0 0 16px;
}
.bp-cit-resource {
  display: flex; align-items: center; gap: 14px;
  padding: 14px 16px;
  border: 1px solid var(--border-subtle);
  border-radius: var(--r-md);
  margin-bottom: 10px;
  color: var(--nq-navy);
  transition: all var(--dur-base) var(--ease-standard);
}
.bp-cit-resource:hover {
  background: var(--nq-bone);
  border-color: var(--nq-navy-300);
  transform: translateX(3px);
}
.bp-cit-resource:last-child { margin-bottom: 0; }
.bp-cit-resource .icon {
  width: 32px; height: 32px;
  display: flex; align-items: center; justify-content: center;
  background: var(--nq-bone);
  border-radius: var(--r-sm);
  color: var(--nq-navy);
  flex-shrink: 0;
}
.bp-cit-resource .icon svg { width: 16px; height: 16px; stroke: currentColor; }
.bp-cit-resource .lab {
  font-family: var(--font-sans); font-weight: 500;
  font-size: 14px; color: var(--nq-navy);
}
.bp-cit-resource .ext {
  margin-left: auto;
  font-family: var(--font-mono); font-size: 10px;
  letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--fg-3);
  background: var(--nq-bone);
  padding: 3px 8px;
  border-radius: var(--r-xs);
}

.bp-cit-foot {
  padding: 18px 36px;
  border-top: 1px solid var(--border-subtle);
  background: var(--nq-bone);
  font-family: var(--font-mono); font-size: 10.5px;
  letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--fg-3);
}

@media (max-width: 900px) {
  .bp-gate-wrap { grid-template-columns: 1fr; gap: 40px; }
  .bp-gate-form { padding: 24px; }
  .bp-cit-grid { grid-template-columns: 1fr; }
  .bp-cit-grid .cit-stats { border-right: 0; border-bottom: 1px solid var(--border-subtle); }
}

/* 3-col inline FAQ override for who-we-serve */
.bp-faq-inline-grid.three-col {
  grid-template-columns: 1fr 1fr 1fr;
}
@media (max-width: 1000px) {
  .bp-faq-inline-grid.three-col { grid-template-columns: 1fr; gap: 48px; }
}

/* ════════════════════════════════════════════════════════════════════════
   GOLD ACCENT SYSTEM (site-wide)
   A single warm accent (#B68330, the brand --nq-warning gold) applied ONLY
   to high-signal accent surfaces: eyebrows, section index numbers, list
   markers, blockquote rules and link underlines. Body copy, heading
   highlights (.cyan spans), data-viz fills and CTA bands stay navy.
   Loaded last, so these win the cascade.
   ════════════════════════════════════════════════════════════════════════ */
:root {
  --nq-gold:        #B68330;
  --nq-gold-strong: #8A6213;
  --nq-gold-soft:   #F6E9CC;
}

/* Eyebrows / kickers → gold (incl. section-head overrides that forced navy) */
.nq-eyebrow,
.b-hero-eyebrow,
.bp-pagehero-eyebrow,
.b-principles-head .nq-eyebrow,
.b-audiences-head .nq-eyebrow,
.bp-donut-head .nq-eyebrow,
.bp-pair-head .nq-eyebrow,
.b-cert-card .label { color: var(--nq-gold); }
.b-hero-eyebrow .dot,
.bp-pagehero-eyebrow .dot { background: var(--nq-gold); }

/* Section index numbers (01 · 02 · 03) → gold */
.bp-svc::before,
.bp-pair-num,
.b-principle-num,
.b-method-card::before,
.bp-pagehero-meta .cat { color: var(--nq-gold); }

/* List markers + blockquote rule → gold */
.bp-prose ul li::marker { color: var(--nq-gold); }
.bp-prose blockquote { border-left-color: var(--nq-gold); }

/* Link underlines → gold (link TEXT stays navy for contrast) */
.bp-prose a,
.bp-faq-item .ans a,
.bp-doc-body a { border-bottom-color: var(--nq-gold); }
.bp-prose a:hover { color: var(--nq-gold-strong); }
