/* ============================================
   FUTURE PROOF — Design System v2
   Digital ecosystem & transformation partner
   Cinematic edition
   ============================================ */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=Space+Grotesk:wght@400;500;600;700&family=Source+Serif+4:opsz,wght@8..60,300;8..60,400;8..60,500;8..60,600&display=swap');

/* ---------- Tokens ---------- */
:root {
  --fp-ink: #07080A;
  --fp-ink-2: #0F1114;
  --fp-ink-3: #181A20;
  --fp-ink-4: #23262E;
  --fp-paper: #FBFAF6;
  --fp-paper-2: #F3F1EA;
  --fp-paper-3: #E7E3D7;
  --fp-paper-4: #D8D2C2;

  --fp-text-on-paper: #15171C;
  --fp-text-on-paper-soft: #4A4D55;
  --fp-text-on-paper-muted: #7A7C84;
  --fp-text-on-ink: #FBFAF6;
  --fp-text-on-ink-soft: #C5C3BC;
  --fp-text-on-ink-muted: #7F8089;

  --fp-accent: #1F4D4A;
  --fp-accent-deep: #143230;
  --fp-accent-light: #5C8A87;
  --fp-accent-on-ink: #A8C7C4;
  --fp-accent-soft: rgba(31, 77, 74, 0.08);
  --fp-gold: #B89B5A;
  --fp-gold-soft: rgba(184, 155, 90, 0.12);

  --fp-border-on-paper: rgba(7, 8, 10, 0.08);
  --fp-border-on-paper-strong: rgba(7, 8, 10, 0.14);
  --fp-border-on-ink: rgba(251, 250, 246, 0.08);
  --fp-border-on-ink-strong: rgba(251, 250, 246, 0.16);

  --fp-shadow-sm: 0 1px 2px rgba(7, 8, 10, 0.04), 0 1px 1px rgba(7, 8, 10, 0.03);
  --fp-shadow-md: 0 10px 30px -10px rgba(7, 8, 10, 0.12), 0 4px 12px -4px rgba(7, 8, 10, 0.06);
  --fp-shadow-lg: 0 30px 60px -20px rgba(7, 8, 10, 0.18), 0 12px 24px -8px rgba(7, 8, 10, 0.08);
  --fp-shadow-xl: 0 50px 100px -30px rgba(7, 8, 10, 0.24), 0 20px 40px -12px rgba(7, 8, 10, 0.10);

  --fp-display: 'Space Grotesk', system-ui, sans-serif;
  --fp-serif: 'Source Serif 4', 'Iowan Old Style', Georgia, serif;
  --fp-body: 'Inter', system-ui, sans-serif;

  --fp-container: 1280px;
  --fp-narrow: 920px;
  --fp-section-y: 160px;
  --fp-page-gutter: 48px;
  --fp-radius-sm: 8px;
  --fp-radius-md: 16px;
  --fp-radius-lg: 24px;
  --fp-radius-xl: 32px;

  --fp-ease: cubic-bezier(0.4, 0, 0.2, 1);
  --fp-ease-out: cubic-bezier(0.16, 1, 0.3, 1);
}

@media (max-width: 1280px) { :root { --fp-page-gutter: 40px; } }
@media (max-width: 1100px) { :root { --fp-section-y: 120px; --fp-page-gutter: 36px; } }
@media (max-width: 900px)  { :root { --fp-page-gutter: 32px; } }
@media (max-width: 700px)  { :root { --fp-section-y: 88px; --fp-page-gutter: 28px; } }
@media (max-width: 480px)  { :root { --fp-page-gutter: 24px; } }
@media (max-width: 360px)  { :root { --fp-page-gutter: 20px; } }

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

html {
  scroll-behavior: smooth;
  font-size: 16px;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
  width: 100%;
}

body {
  font-family: var(--fp-body);
  background: var(--fp-paper);
  color: var(--fp-text-on-paper);
  line-height: 1.65;
  font-size: 17px;
  overflow-x: hidden;
  width: 100%;
  max-width: 100%;
  position: relative;
}

a { color: inherit; text-decoration: none; }
ul, ol { list-style: none; }
img { max-width: 100%; display: block; }
button, input, textarea { font-family: inherit; }

::selection { background: var(--fp-accent); color: var(--fp-paper); }

.container {
  width: 100%;
  max-width: var(--fp-container);
  margin: 0 auto;
  padding-left: var(--fp-page-gutter);
  padding-right: var(--fp-page-gutter);
}

/* Edge-bleed escape — for carousels that need to scroll edge-to-edge */
.fp-bleed {
  margin-left: calc(var(--fp-page-gutter) * -1);
  margin-right: calc(var(--fp-page-gutter) * -1);
}

/* ============================================
   SCROLL PROGRESS INDICATOR (top bar)
   ============================================ */
.fp-scroll-progress {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  height: 2px;
  background: transparent;
  z-index: 110;
  pointer-events: none;
}
.fp-scroll-progress-bar {
  display: block;
  height: 100%;
  width: 100%;
  background: linear-gradient(90deg, var(--fp-accent) 0%, var(--fp-accent-light) 50%, var(--fp-gold) 100%);
  transform: scaleX(0);
  transform-origin: 0 50%;
  transition: transform 60ms linear;
  box-shadow: 0 0 12px rgba(31, 77, 74, 0.4);
}

/* ============================================
   MAGNETIC CTAs
   ============================================ */
.fp-magnet {
  transition: transform 0.4s var(--fp-ease-out), background 0.25s var(--fp-ease), color 0.25s var(--fp-ease), border-color 0.25s var(--fp-ease), box-shadow 0.25s var(--fp-ease);
  will-change: transform;
}

/* ============================================
   CURSOR SPOTLIGHT — on dark sections
   ============================================ */
.fp-spotlight {
  --fp-spot-x: 50%;
  --fp-spot-y: 50%;
  position: relative;
  isolation: isolate;
}
.fp-spotlight::after {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(
    600px circle at var(--fp-spot-x) var(--fp-spot-y),
    rgba(168, 199, 196, 0.10) 0%,
    rgba(184, 155, 90, 0.06) 30%,
    transparent 60%
  );
  opacity: 0;
  transition: opacity 0.5s var(--fp-ease);
  pointer-events: none;
  z-index: 0;
}
.fp-spotlight:hover::after { opacity: 1; }
.fp-spotlight > * { position: relative; z-index: 1; }

@media (pointer: coarse), (prefers-reduced-motion: reduce) {
  .fp-spotlight::after { display: none; }
}

/* ============================================
   3D TILT CARDS
   ============================================ */
.fp-tilt {
  --fp-tilt-rx: 0deg;
  --fp-tilt-ry: 0deg;
  --fp-tilt-glow-x: 50%;
  --fp-tilt-glow-y: 50%;
  transform-style: preserve-3d;
  transform: perspective(1000px) rotateX(var(--fp-tilt-rx)) rotateY(var(--fp-tilt-ry));
  transition: transform 0.55s var(--fp-ease-out), border-color 0.4s var(--fp-ease), box-shadow 0.4s var(--fp-ease), background 0.4s var(--fp-ease);
  will-change: transform;
}
.fp-tilt::after {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(
    280px circle at var(--fp-tilt-glow-x) var(--fp-tilt-glow-y),
    rgba(255, 255, 255, 0.18) 0%,
    transparent 55%
  );
  opacity: 0;
  border-radius: inherit;
  transition: opacity 0.4s var(--fp-ease);
  pointer-events: none;
  z-index: 2;
  mix-blend-mode: overlay;
}
.fp-tilt:hover::after { opacity: 1; }
.fp-tilt:hover {
  /* override the existing translateY hover so tilt wins */
  transform: perspective(1000px) rotateX(var(--fp-tilt-rx)) rotateY(var(--fp-tilt-ry)) translateY(-2px) !important;
}

@media (pointer: coarse), (prefers-reduced-motion: reduce) {
  .fp-tilt {
    transform: none !important;
    transition: border-color 0.4s var(--fp-ease), box-shadow 0.4s var(--fp-ease), background 0.4s var(--fp-ease);
  }
  .fp-tilt::after { display: none; }
}

/* ----- Mobile snap-carousel base behaviors ----- */
/* When a grid acts as a snap carousel, the parent can show a swipe hint via this class */
.fp-snap-hint {
  display: none;
}
@media (max-width: 760px) {
  .fp-snap-hint {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-top: -8px;
    font-family: var(--fp-body);
    font-size: 0.78rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--fp-text-on-paper-muted);
    opacity: 0.7;
  }
  .fp-snap-hint--on-ink { color: var(--fp-text-on-ink-muted); }
  .fp-snap-hint svg {
    width: 14px;
    height: 14px;
    animation: fp-swipe-hint 2.2s ease-in-out infinite;
  }
}
@keyframes fp-swipe-hint {
  0%, 100% { transform: translateX(0); }
  50% { transform: translateX(6px); }
}

.fp-narrow { max-width: var(--fp-narrow); }

.reveal {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity 1s var(--fp-ease-out), transform 1s var(--fp-ease-out);
}
.reveal.visible { opacity: 1; transform: translateY(0); }

/* Generic scroll-reveal applied via JS */
.fp-reveal {
  opacity: 0;
  transform: translateY(24px);
  transition:
    opacity 0.9s var(--fp-ease-out) var(--fp-reveal-delay, 0ms),
    transform 0.9s var(--fp-ease-out) var(--fp-reveal-delay, 0ms);
  will-change: opacity, transform;
}

.fp-revealed {
  opacity: 1;
  transform: translateY(0);
}

@media (prefers-reduced-motion: reduce) {
  .fp-reveal {
    opacity: 1;
    transform: none;
    transition: none;
  }
}

/* ============================================
   AMBIENT BACKGROUND
   ============================================ */
.fp-ambient {
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  overflow: hidden;
}

.fp-ambient-blob {
  position: absolute;
  border-radius: 50%;
  filter: blur(80px);
  opacity: 0.5;
  will-change: transform;
}

.fp-ambient-blob-1 {
  width: 720px; height: 720px;
  top: -200px; left: -180px;
  background: radial-gradient(circle, rgba(184, 155, 90, 0.18) 0%, transparent 70%);
  animation: fp-blob-drift-1 28s ease-in-out infinite alternate;
}
.fp-ambient-blob-2 {
  width: 800px; height: 800px;
  top: 40%; right: -250px;
  background: radial-gradient(circle, rgba(31, 77, 74, 0.14) 0%, transparent 70%);
  animation: fp-blob-drift-2 34s ease-in-out infinite alternate;
}
.fp-ambient-blob-3 {
  width: 600px; height: 600px;
  bottom: -150px; left: 30%;
  background: radial-gradient(circle, rgba(168, 199, 196, 0.18) 0%, transparent 70%);
  animation: fp-blob-drift-3 40s ease-in-out infinite alternate;
}

@keyframes fp-blob-drift-1 {
  0% { transform: translate(0, 0) scale(1); }
  100% { transform: translate(60px, 80px) scale(1.1); }
}
@keyframes fp-blob-drift-2 {
  0% { transform: translate(0, 0) scale(1); }
  100% { transform: translate(-80px, -40px) scale(1.05); }
}
@keyframes fp-blob-drift-3 {
  0% { transform: translate(0, 0) scale(1); }
  100% { transform: translate(40px, -60px) scale(1.12); }
}

.fp-ambient-grain {
  position: absolute;
  inset: 0;
  opacity: 0.4;
  mix-blend-mode: multiply;
  background-image: url("data:image/svg+xml;utf8,<svg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0.07 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
  background-size: 200px 200px;
}

@media (prefers-reduced-motion: reduce) {
  .fp-ambient-blob { animation: none; }
}

/* ============================================
   HEADER
   ============================================ */
.header {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 1000;
  padding: 18px 0;
  background: rgba(251, 250, 246, 0.55);
  backdrop-filter: blur(14px) saturate(140%);
  -webkit-backdrop-filter: blur(14px) saturate(140%);
  border-bottom: 1px solid transparent;
  box-shadow: 0 0 0 0 rgba(7, 8, 10, 0);
  transition:
    background 0.5s var(--fp-ease),
    backdrop-filter 0.5s var(--fp-ease),
    -webkit-backdrop-filter 0.5s var(--fp-ease),
    border-color 0.5s var(--fp-ease),
    padding 0.4s var(--fp-ease),
    box-shadow 0.5s var(--fp-ease);
}

.header.scrolled {
  padding: 11px 0;
  background: rgba(251, 250, 246, 0.85);
  backdrop-filter: blur(24px) saturate(180%);
  -webkit-backdrop-filter: blur(24px) saturate(180%);
  border-bottom-color: var(--fp-border-on-paper);
  box-shadow: 0 4px 30px -10px rgba(7, 8, 10, 0.08);
}

.header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 32px;
}

.logo {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  z-index: 1100;
  text-decoration: none;
  color: var(--fp-ink);
}

.fp-logo-mark {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 34px;
  height: 34px;
  border-radius: 10px;
  flex-shrink: 0;
  filter:
    drop-shadow(0 6px 14px rgba(31, 77, 74, 0.32))
    drop-shadow(0 2px 4px rgba(31, 77, 74, 0.18));
  transition: transform 0.4s var(--fp-ease), filter 0.4s var(--fp-ease);
}

.logo:hover .fp-logo-mark {
  transform: translateY(-1px) rotate(-2deg);
  filter:
    drop-shadow(0 10px 22px rgba(31, 77, 74, 0.42))
    drop-shadow(0 3px 6px rgba(31, 77, 74, 0.22));
}

.fp-mark-svg {
  width: 100%;
  height: 100%;
  display: block;
}

.fp-logo-word {
  font-family: var(--fp-display);
  font-weight: 500;
  font-size: 1.04rem;
  letter-spacing: -0.018em;
  color: var(--fp-ink);
}

.fp-logo-mark-inverse {
  /* Same teal sphere works on both light and dark */
}

.fp-logo-word-inverse {
  color: var(--fp-paper);
}

.desktop-nav {
  display: flex;
  align-items: center;
  gap: 38px;
}

.desktop-nav a {
  font-family: var(--fp-body);
  font-size: 0.94rem;
  font-weight: 500;
  color: var(--fp-text-on-paper-soft);
  position: relative;
  transition: color 0.25s var(--fp-ease);
}

.desktop-nav a::after {
  content: '';
  position: absolute;
  left: 0; right: 0; bottom: -6px;
  height: 1px;
  background: var(--fp-ink);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.3s var(--fp-ease);
}

.desktop-nav a:hover { color: var(--fp-ink); }
.desktop-nav a:hover::after { transform: scaleX(1); }

.start-btn {
  background: var(--fp-ink);
  color: var(--fp-paper);
  font-family: var(--fp-body);
  font-weight: 500;
  font-size: 0.92rem;
  padding: 11px 22px;
  border: 1px solid var(--fp-ink);
  border-radius: 999px;
  cursor: pointer;
  transition: background 0.3s var(--fp-ease), border-color 0.3s var(--fp-ease), transform 0.3s var(--fp-ease), box-shadow 0.3s var(--fp-ease);
  display: inline-flex;
  align-items: center;
  box-shadow: var(--fp-shadow-sm);
}

.start-btn:hover {
  background: var(--fp-accent);
  border-color: var(--fp-accent);
  transform: translateY(-1px);
  box-shadow: var(--fp-shadow-md);
}

.hamburger {
  display: none;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  width: 36px; height: 36px;
  background: transparent;
  border: none;
  cursor: pointer;
  z-index: 1100;
  padding: 8px;
}

.hamburger span {
  display: block;
  width: 20px; height: 1.5px;
  background: var(--fp-ink);
  transition: transform 0.3s var(--fp-ease), opacity 0.3s var(--fp-ease);
}

.hamburger.active span:nth-child(1) { transform: translateY(6.5px) rotate(45deg); }
.hamburger.active span:nth-child(2) { opacity: 0; }
.hamburger.active span:nth-child(3) { transform: translateY(-6.5px) rotate(-45deg); }

@media (max-width: 920px) {
  .desktop-nav, .header .start-btn { display: none; }
  .hamburger { display: inline-flex; }
}

.nav-overlay {
  position: fixed;
  inset: 0;
  background: var(--fp-paper);
  z-index: 1150;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.4s var(--fp-ease);
}

.nav-overlay.open {
  opacity: 1;
  pointer-events: auto;
}

.nav-overlay.open .nav-links a {
  animation: fp-nav-item-in 0.6s var(--fp-ease-out) both;
}

.nav-overlay.open .nav-links a:nth-child(1) { animation-delay: 0.05s; }
.nav-overlay.open .nav-links li:nth-child(2) a { animation-delay: 0.10s; }
.nav-overlay.open .nav-links li:nth-child(3) a { animation-delay: 0.15s; }
.nav-overlay.open .nav-links li:nth-child(4) a { animation-delay: 0.20s; }
.nav-overlay.open .nav-links li:nth-child(5) a { animation-delay: 0.25s; }
.nav-overlay.open .nav-links li:nth-child(6) a { animation-delay: 0.30s; }

@keyframes fp-nav-item-in {
  from { opacity: 0; transform: translateY(12px); }
  to   { opacity: 1; transform: translateY(0); }
}

.nav-close {
  position: absolute;
  top: 18px;
  right: 22px;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  border: 1px solid var(--fp-border-on-paper-strong);
  background: var(--fp-paper);
  color: var(--fp-ink);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  z-index: 1200;
  transition: background 0.25s var(--fp-ease), border-color 0.25s var(--fp-ease), transform 0.25s var(--fp-ease);
}

.nav-close:hover {
  background: var(--fp-ink);
  color: var(--fp-paper);
  border-color: var(--fp-ink);
  transform: scale(1.06) rotate(90deg);
}

.nav-links {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 28px;
}

.nav-links a {
  font-family: var(--fp-display);
  font-size: 1.8rem;
  font-weight: 500;
  letter-spacing: -0.02em;
  color: var(--fp-ink);
  transition: color 0.25s var(--fp-ease), transform 0.25s var(--fp-ease);
  display: inline-block;
}

.nav-links a:hover {
  color: var(--fp-accent);
  transform: translateX(4px);
}

.nav-links a.nav-start-link {
  margin-top: 16px;
  background: var(--fp-ink);
  color: var(--fp-paper);
  padding: 14px 28px;
  border-radius: 999px;
  font-size: 1.15rem;
  box-shadow: var(--fp-shadow-md);
}

.nav-links a.nav-start-link:hover {
  background: var(--fp-accent);
  color: var(--fp-paper);
  transform: translateY(-2px);
}

/* Keep hamburger above the overlay when active so it can be tapped to close */
.hamburger.active {
  z-index: 1200;
}

/* ============================================
   SECTIONS — base
   ============================================ */
.fp-section {
  padding: var(--fp-section-y) 0;
  position: relative;
  z-index: 1;
}

.fp-section-light { background: var(--fp-paper); color: var(--fp-text-on-paper); }
.fp-section-dark {
  background: var(--fp-ink);
  color: var(--fp-text-on-ink);
}

.fp-section-dark::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    radial-gradient(ellipse 60% 50% at 20% 0%, rgba(31, 77, 74, 0.22) 0%, transparent 60%),
    radial-gradient(ellipse 50% 60% at 100% 100%, rgba(184, 155, 90, 0.08) 0%, transparent 60%);
  pointer-events: none;
  z-index: 0;
}

.fp-section-dark > * { position: relative; z-index: 1; }

.fp-section-eyebrow {
  font-family: var(--fp-body);
  font-size: 0.82rem;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--fp-text-on-paper-muted);
  margin-bottom: 28px;
  display: inline-flex;
  align-items: center;
  gap: 12px;
}

.fp-section-dark .fp-section-eyebrow { color: var(--fp-text-on-ink-muted); }

.fp-eyebrow-num {
  font-family: var(--fp-display);
  font-size: 0.78rem;
  font-weight: 500;
  color: var(--fp-accent);
  padding: 4px 8px;
  border: 1px solid var(--fp-border-on-paper-strong);
  border-radius: 4px;
  letter-spacing: 0.04em;
  background: var(--fp-paper);
}

.fp-section-dark .fp-eyebrow-num {
  color: var(--fp-accent-on-ink);
  border-color: var(--fp-border-on-ink-strong);
  background: rgba(251, 250, 246, 0.04);
}

.fp-section-headline {
  font-family: var(--fp-display);
  font-weight: 500;
  font-size: clamp(2.2rem, 4.6vw, 3.4rem);
  line-height: 1.08;
  letter-spacing: -0.025em;
  margin-bottom: 28px;
  max-width: 22ch;
}

.fp-section-lede {
  font-family: var(--fp-body);
  font-size: clamp(1.08rem, 1.4vw, 1.22rem);
  line-height: 1.62;
  color: var(--fp-text-on-paper-soft);
  max-width: 64ch;
  margin-bottom: 0;
}

.fp-section-dark .fp-section-lede { color: var(--fp-text-on-ink-soft); }
.fp-section-lede-spaced { margin-top: 18px; }

/* ============================================
   BUTTONS
   ============================================ */
.fp-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  font-family: var(--fp-body);
  font-weight: 500;
  font-size: 0.98rem;
  padding: 14px 24px;
  border-radius: 999px;
  border: 1px solid transparent;
  cursor: pointer;
  transition: all 0.3s var(--fp-ease);
  text-decoration: none;
  white-space: nowrap;
  position: relative;
}

.fp-btn-primary {
  background: var(--fp-ink);
  color: var(--fp-paper);
  border-color: var(--fp-ink);
  box-shadow: var(--fp-shadow-md);
}

.fp-btn-primary:hover {
  background: var(--fp-accent);
  border-color: var(--fp-accent);
  transform: translateY(-2px);
  box-shadow: var(--fp-shadow-lg);
}

.fp-btn-primary svg { transition: transform 0.3s var(--fp-ease); }
.fp-btn-primary:hover svg { transform: translateX(3px); }

.fp-section-dark .fp-btn-primary {
  background: var(--fp-paper);
  color: var(--fp-ink);
  border-color: var(--fp-paper);
}

.fp-section-dark .fp-btn-primary:hover {
  background: var(--fp-accent-on-ink);
  border-color: var(--fp-accent-on-ink);
  color: var(--fp-ink);
}

.fp-btn-ghost {
  background: transparent;
  color: var(--fp-text-on-paper);
  border-color: var(--fp-border-on-paper-strong);
}

.fp-btn-ghost:hover {
  border-color: var(--fp-ink);
  background: rgba(7, 8, 10, 0.04);
  transform: translateY(-1px);
}

.fp-section-dark .fp-btn-ghost {
  color: var(--fp-text-on-ink);
  border-color: var(--fp-border-on-ink-strong);
}

.fp-section-dark .fp-btn-ghost:hover {
  background: rgba(251, 250, 246, 0.06);
  border-color: var(--fp-paper);
}

.fp-btn-large { padding: 18px 32px; font-size: 1.04rem; }

/* ============================================
   HERO
   ============================================ */
.fp-hero {
  position: relative;
  padding: 180px 0 80px;
  overflow: hidden;
}

@media (max-width: 1100px) { .fp-hero { padding: 150px 0 60px; } }
@media (max-width: 700px) { .fp-hero { padding: 120px 0 40px; } }

.fp-hero-inner { position: relative; z-index: 2; }

.fp-eyebrow {
  font-family: var(--fp-body);
  font-size: 0.82rem;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--fp-text-on-paper-muted);
  margin-bottom: 36px;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 8px 16px;
  border: 1px solid var(--fp-border-on-paper-strong);
  border-radius: 999px;
  background: rgba(251, 250, 246, 0.6);
  backdrop-filter: blur(8px);
}

.fp-eyebrow-dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--fp-accent);
  position: relative;
}

.fp-eyebrow-dot::after {
  content: '';
  position: absolute;
  inset: -4px;
  border-radius: 50%;
  background: var(--fp-accent);
  opacity: 0.3;
  animation: fp-pulse-dot 2.4s ease-in-out infinite;
}

@keyframes fp-pulse-dot {
  0%, 100% { transform: scale(1); opacity: 0.3; }
  50% { transform: scale(1.8); opacity: 0; }
}

.fp-hero-headline {
  font-family: var(--fp-display);
  font-weight: 500;
  font-size: clamp(2.6rem, 7.2vw, 5.6rem);
  line-height: 1.02;
  letter-spacing: -0.035em;
  max-width: 20ch;
  margin-bottom: 32px;
  color: var(--fp-ink);
}

.fp-hero-headline-accent {
  background: linear-gradient(120deg,
    #1F4D4A 0%,
    #2D6663 18%,
    #5C8A87 36%,
    #B89B5A 54%,
    #5C8A87 72%,
    #2D6663 88%,
    #1F4D4A 100%);
  background-size: 280% 100%;
  background-position: 0% 50%;
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
  animation: fp-headline-gradient 9s ease-in-out infinite;
}

@keyframes fp-headline-gradient {
  0%   { background-position: 0% 50%; }
  50%  { background-position: 100% 50%; }
  100% { background-position: 0% 50%; }
}

@media (prefers-reduced-motion: reduce) {
  .fp-hero-headline-accent { animation: none; }
}

/* Hero staggered entrance */
.fp-hero-inner > * {
  opacity: 0;
  transform: translateY(20px);
  animation: fp-hero-rise 1s var(--fp-ease-out) both;
}

.fp-hero-inner > .fp-eyebrow         { animation-delay: 0.08s; }
.fp-hero-inner > .fp-hero-headline   { animation-delay: 0.20s; }
.fp-hero-inner > .fp-hero-sub        { animation-delay: 0.36s; }
.fp-hero-inner > .fp-hero-ctas       { animation-delay: 0.50s; }

.fp-hero-eco {
  opacity: 0;
  transform: translateY(28px);
  animation: fp-hero-rise 1.4s var(--fp-ease-out) 0.7s both;
}

@keyframes fp-hero-rise {
  from { opacity: 0; transform: translateY(20px); }
  to   { opacity: 1; transform: translateY(0); }
}

@media (prefers-reduced-motion: reduce) {
  .fp-hero-inner > *,
  .fp-hero-eco {
    animation: none;
    opacity: 1;
    transform: none;
  }
}

.fp-hero-sub {
  font-family: var(--fp-body);
  font-size: clamp(1.1rem, 1.5vw, 1.26rem);
  line-height: 1.6;
  color: var(--fp-text-on-paper-soft);
  max-width: 60ch;
  margin-bottom: 44px;
}

.fp-hero-ctas {
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
}

.fp-hero-eco {
  margin-top: 80px;
  position: relative;
  width: 100%;
}

.fp-hero-eco-stage {
  position: relative;
  width: 100%;
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 24px;
}

.fp-hero-eco-svg {
  width: 100%;
  height: auto;
  display: block;
  filter: drop-shadow(0 30px 60px rgba(31, 77, 74, 0.12));
}

.fp-eco-label-lg {
  font-family: var(--fp-body);
  font-size: 14px;
  font-weight: 500;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  fill: var(--fp-text-on-paper);
}

.fp-eco-center-label {
  font-family: var(--fp-display);
  font-size: 14px;
  font-weight: 600;
  letter-spacing: 0.04em;
  fill: var(--fp-accent);
}

/* Mobile: scale the ecosystem visualization way up so labels are legible */
@media (max-width: 760px) {
  .fp-hero-eco {
    margin-top: 56px;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    width: 100vw;
  }
  .fp-hero-eco-stage {
    padding: 0 8px;
  }
  .fp-eco-label-lg {
    font-size: 22px;
  }
  .fp-eco-center-label {
    font-size: 20px;
  }
  .fp-hero-eco-svg {
    filter: drop-shadow(0 20px 40px rgba(31, 77, 74, 0.1));
  }
}

@media (max-width: 480px) {
  .fp-eco-label-lg {
    font-size: 26px;
  }
  .fp-eco-center-label {
    font-size: 22px;
  }
}

@media (prefers-reduced-motion: reduce) {
  .fp-hero-eco-svg circle { animation: none !important; }
  .fp-hero-eco-svg animate,
  .fp-hero-eco-svg animateMotion { display: none; }
}

/* ============================================
   TRUSTED BY MARQUEE
   ============================================ */
.fp-trusted {
  position: relative;
  z-index: 1;
  padding: 64px 0;
  background: var(--fp-paper);
  border-top: 1px solid var(--fp-border-on-paper);
  border-bottom: 1px solid var(--fp-border-on-paper);
}

.fp-trusted-label {
  font-family: var(--fp-body);
  font-size: 0.82rem;
  font-weight: 500;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--fp-text-on-paper-muted);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  margin-bottom: 40px;
}

.fp-trusted-dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--fp-gold);
}

.fp-marquee {
  overflow: hidden;
  position: relative;
  mask-image: linear-gradient(to right, transparent, #000 3%, #000 97%, transparent);
  -webkit-mask-image: linear-gradient(to right, transparent, #000 3%, #000 97%, transparent);
}

.fp-marquee-track {
  display: flex;
  align-items: center;
  gap: 88px;
  animation: fp-marquee 48s linear infinite;
  width: max-content;
  will-change: transform;
  /* Pad the wrap point with the same gap so the loop seam is invisible */
  padding-right: 88px;
}

.fp-marquee-logo {
  height: 44px;
  width: auto;
  max-width: 180px;
  object-fit: contain;
  flex-shrink: 0;
  opacity: 0.92;
  transition: transform 0.4s var(--fp-ease), opacity 0.3s var(--fp-ease);
}

.fp-marquee-logo:hover {
  opacity: 1;
  transform: scale(1.06);
}

@keyframes fp-marquee {
  0% { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

@media (max-width: 700px) {
  .fp-marquee-track { gap: 56px; }
  .fp-marquee-logo { height: 34px; max-width: 140px; }
  /* Track is half as wide on mobile, so the same 48s reads as crawling.
     Speed it up so the logos move at a lively, legible pace. */
  .fp-marquee-track { animation-duration: 26s; }
}

/* ============================================
   PRESS — "As featured in" typographic strip
   ============================================ */
.fp-press {
  position: relative;
  z-index: 1;
  background: var(--fp-paper);
  border-bottom: 1px solid var(--fp-border-on-paper);
  padding: 56px 0 64px;
}

.fp-press-label {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 20px;
  font-family: var(--fp-body);
  font-size: 0.78rem;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--fp-text-on-paper-muted);
  margin: 0 0 40px;
}

.fp-press-rule {
  display: inline-block;
  width: 36px;
  height: 1px;
  background: var(--fp-border-on-paper-strong);
}

.fp-press-list {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 32px 56px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.fp-press-item {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 44px;
  transition: opacity 0.25s var(--fp-ease), transform 0.25s var(--fp-ease);
  opacity: 0.92;
}

.fp-press-item:hover {
  opacity: 1;
  transform: translateY(-1px);
}

.fp-press-item img {
  height: 100%;
  width: auto;
  max-width: 200px;
  object-fit: contain;
  display: block;
  mix-blend-mode: multiply;
}

/* Per-logo visual balancing — wide wordmarks shrink, square badges grow */
.fp-press-item:nth-child(1) { height: 30px; } /* Forbes — very wide wordmark */
.fp-press-item:nth-child(2) { height: 42px; } /* WSJ — stacked wordmark */
.fp-press-item:nth-child(3) { height: 46px; } /* CNBC — peacock + text */
.fp-press-item:nth-child(4) { height: 56px; } /* USA Today — square badge */
.fp-press-item:nth-child(5) { height: 46px; } /* Fast Company — stacked wordmark */
.fp-press-item:nth-child(6) { height: 52px; } /* ABC — square sphere */

@media (max-width: 700px) {
  .fp-press { padding: 40px 0 48px; }
  .fp-press-list { gap: 22px 32px; }
  .fp-press-item img { max-width: 140px; }
  .fp-press-item:nth-child(1) { height: 22px; }
  .fp-press-item:nth-child(2) { height: 30px; }
  .fp-press-item:nth-child(3) { height: 34px; }
  .fp-press-item:nth-child(4) { height: 40px; }
  .fp-press-item:nth-child(5) { height: 34px; }
  .fp-press-item:nth-child(6) { height: 38px; }
}

/* ============================================
   DIAGNOSIS SECTION
   ============================================ */
.fp-diagnosis { margin-top: 72px; }

.fp-diag-head {
  display: grid;
  grid-template-columns: 1fr 56px 1fr;
  align-items: center;
  padding: 18px 0;
  border-bottom: 1px solid var(--fp-border-on-paper-strong);
  margin-bottom: 8px;
}

.fp-diag-head-label {
  font-family: var(--fp-body);
  font-size: 0.78rem;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--fp-text-on-paper-muted);
}

.fp-diag-head-arrow {
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--fp-accent);
}

.fp-diag-pair {
  display: grid;
  grid-template-columns: 1fr 56px 1fr;
  align-items: stretch;
  padding: 4px 0;
  position: relative;
}

.fp-diag-symptom,
.fp-diag-cost {
  font-family: var(--fp-body);
  font-size: 1.02rem;
  line-height: 1.55;
  padding: 22px 24px 22px 0;
  border-bottom: 1px solid var(--fp-border-on-paper);
  transition: background 0.3s var(--fp-ease);
}

.fp-diag-symptom { color: var(--fp-text-on-paper); font-weight: 500; }
.fp-diag-cost {
  grid-column: 3;
  color: var(--fp-text-on-paper-soft);
  padding-left: 24px;
  padding-right: 0;
}

.fp-diag-pair::before {
  content: '';
  position: absolute;
  left: 50%;
  top: 22px;
  bottom: 22px;
  width: 1px;
  background: var(--fp-border-on-paper-strong);
  transform: translateX(-0.5px);
}

.fp-diag-pair::after {
  content: '';
  position: absolute;
  left: calc(50% - 14px);
  top: 50%;
  transform: translateY(-50%);
  width: 28px;
  height: 28px;
  background: var(--fp-paper);
  border: 1px solid var(--fp-border-on-paper-strong);
  border-radius: 50%;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='10' viewBox='0 0 20 14' fill='none'><path d='M1 7H19M19 7L13 1M19 7L13 13' stroke='%231F4D4A' stroke-width='1.4' stroke-linecap='round' stroke-linejoin='round'/></svg>");
  background-repeat: no-repeat;
  background-position: center;
}

.fp-diag-pair:hover .fp-diag-symptom,
.fp-diag-pair:hover .fp-diag-cost {
  background: var(--fp-paper-2);
}

@media (max-width: 760px) {
  .fp-diag-head { display: none; }
  .fp-diag-pair {
    grid-template-columns: 1fr;
    margin-bottom: 4px;
    padding: 0;
  }
  .fp-diag-pair::before,
  .fp-diag-pair::after { display: none; }
  .fp-diag-symptom {
    padding: 18px 0 6px;
    border-bottom: none;
  }
  .fp-diag-cost {
    grid-column: 1;
    padding: 0 0 22px 18px;
    border-bottom: 1px solid var(--fp-border-on-paper);
    border-left: 2px solid var(--fp-accent);
  }
}

/* ============================================
   FRAME / STAGES
   ============================================ */
.fp-stages {
  margin-top: 88px;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  position: relative;
}

.fp-stage {
  padding: 36px 28px 36px 0;
  position: relative;
  border-top: 1px solid var(--fp-border-on-ink-strong);
}

.fp-stage:not(:last-child)::after {
  content: '';
  position: absolute;
  top: 0;
  right: 14px;
  width: 1px;
  height: 100%;
  background: var(--fp-border-on-ink);
}

.fp-stage-num {
  font-family: var(--fp-display);
  font-size: 0.82rem;
  font-weight: 500;
  letter-spacing: 0.06em;
  color: var(--fp-accent-on-ink);
  display: inline-block;
  margin-bottom: 16px;
  padding: 4px 10px;
  border: 1px solid var(--fp-border-on-ink-strong);
  border-radius: 4px;
  background: rgba(251, 250, 246, 0.04);
}

/* Framework stage glyph — visual marker for each stage */
.fp-stage-glyph {
  width: 64px;
  height: 64px;
  margin-bottom: 18px;
  color: var(--fp-accent-on-ink);
  opacity: 0;
  transform: translateY(8px) scale(0.92);
  transition: opacity 0.8s var(--fp-ease-out), transform 0.8s var(--fp-ease-out);
}

.fp-stage-glyph svg {
  width: 100%;
  height: 100%;
  display: block;
}

/* Reveal piggybacks on the existing .fp-reveal observer system */
.fp-stage.fp-revealed .fp-stage-glyph {
  opacity: 1;
  transform: translateY(0) scale(1);
}

@media (prefers-reduced-motion: reduce) {
  .fp-stage-glyph { opacity: 1; transform: none; transition: none; }
}

.fp-stage-title {
  font-family: var(--fp-display);
  font-weight: 500;
  font-size: 1.5rem;
  letter-spacing: -0.02em;
  margin-bottom: 12px;
  color: var(--fp-text-on-ink);
}

.fp-stage-body {
  font-family: var(--fp-body);
  font-size: 0.98rem;
  line-height: 1.58;
  color: var(--fp-text-on-ink-soft);
}

@media (max-width: 900px) {
  .fp-stages { grid-template-columns: repeat(2, 1fr); gap: 16px; }
  .fp-stage:not(:last-child)::after { display: none; }
  .fp-stage { padding-right: 16px; }
}

@media (max-width: 520px) {
  .fp-stages { grid-template-columns: 1fr; }
}

/* ============================================
   INTEGRATION — operational trust block (light)
   ============================================ */
.fp-integration { position: relative; }

.fp-integration-pillars {
  margin-top: 80px;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  position: relative;
}

.fp-integration-pillar {
  padding: 36px 36px 36px 0;
  border-top: 1px solid var(--fp-border-on-paper-strong);
  position: relative;
}

.fp-integration-pillar:not(:last-child)::after {
  content: '';
  position: absolute;
  top: 0;
  right: 18px;
  width: 1px;
  height: 100%;
  background: var(--fp-border-on-paper);
}

.fp-integration-pillar-title {
  font-family: var(--fp-display);
  font-weight: 500;
  font-size: 1.65rem;
  letter-spacing: -0.022em;
  color: var(--fp-ink);
  margin-bottom: 14px;
}

.fp-integration-pillar-body {
  font-family: var(--fp-body);
  font-size: 1.02rem;
  line-height: 1.6;
  color: var(--fp-text-on-paper-soft);
}

.fp-integration-coda {
  margin: 88px auto 0;
  max-width: 740px;
  text-align: center;
  position: relative;
}

.fp-integration-coda-rule {
  display: block;
  width: 60px;
  height: 1px;
  background: var(--fp-gold);
  opacity: 0.55;
  margin: 0 auto 32px;
}

.fp-integration-coda-line {
  font-family: var(--fp-serif);
  font-weight: 400;
  font-style: italic;
  font-size: clamp(1.22rem, 2.1vw, 1.62rem);
  line-height: 1.42;
  letter-spacing: -0.012em;
  color: var(--fp-text-on-paper);
}

@media (max-width: 900px) {
  .fp-integration-pillars { grid-template-columns: 1fr; gap: 0; margin-top: 56px; }
  .fp-integration-pillar { padding: 32px 0; }
  .fp-integration-pillar:not(:last-child)::after { display: none; }
  .fp-integration-coda { margin-top: 64px; }
}

/* ============================================
   MODAL ROUTER — full-screen audience selector overlay
   Fixed viewport-fitted experience with animated SVG network background,
   cursor-following glow, option shimmer + selection ripple, and
   affirmation intensification. First impression of Future Proof.
   ============================================ */

/* Background network */
.fp-modal-router-bg {
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  overflow: hidden;
}

.fp-modal-router-bg-svg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  display: block;
}

/* Lines — breathing opacity */
.fp-bg-lines line {
  opacity: 0.08;
  animation: fp-bg-line-breathe 7s ease-in-out infinite;
}
.fp-bg-lines line:nth-of-type(odd) { animation-delay: -2s; }
.fp-bg-lines line:nth-of-type(3n) { animation-delay: -4s; animation-duration: 9s; }
.fp-bg-lines line:nth-of-type(5n) { animation-duration: 11s; }

@keyframes fp-bg-line-breathe {
  0%, 100% { opacity: 0.05; }
  50% { opacity: 0.18; }
}

/* Nodes — breathing scale + opacity */
.fp-bg-nodes circle {
  opacity: 0.4;
  transform-origin: center;
  animation: fp-bg-node-breathe 4s ease-in-out infinite;
}
.fp-bg-nodes circle:nth-of-type(odd) { animation-delay: -1.3s; }
.fp-bg-nodes circle:nth-of-type(3n) { animation-duration: 5.4s; }
.fp-bg-nodes circle:nth-of-type(5n) { animation-duration: 6.2s; animation-delay: -0.7s; }

.fp-bg-node-primary {
  animation-duration: 5s !important;
  opacity: 0.55;
}

.fp-bg-node-hub {
  animation-duration: 6s !important;
  opacity: 0.7;
}

@keyframes fp-bg-node-breathe {
  0%, 100% { opacity: 0.3; transform: scale(1); }
  50% { opacity: 0.7; transform: scale(1.35); }
}

/* Halos behind hubs — slow drift */
.fp-bg-halos circle {
  animation: fp-bg-halo-drift 12s ease-in-out infinite;
  transform-origin: center;
}
.fp-bg-halos circle:nth-of-type(even) { animation-delay: -6s; }

@keyframes fp-bg-halo-drift {
  0%, 100% { transform: scale(1); opacity: 0.22; }
  50% { transform: scale(1.18); opacity: 0.4; }
}

/* Gold pulses — already animated via SMIL animateMotion */
.fp-bg-pulses circle {
  filter: drop-shadow(0 0 4px rgba(184, 155, 90, 0.6));
}

/* Cursor-follow radial glow */
.fp-modal-router-bg-cursor {
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: radial-gradient(
    480px circle at var(--fp-modal-mouse-x, 50%) var(--fp-modal-mouse-y, 50%),
    rgba(31, 77, 74, 0.08) 0%,
    rgba(184, 155, 90, 0.03) 35%,
    transparent 65%
  );
  transition: background 0.6s var(--fp-ease);
  opacity: 0;
  animation: fp-bg-cursor-reveal 1.6s ease-out 0.4s forwards;
}

@keyframes fp-bg-cursor-reveal {
  to { opacity: 1; }
}

/* Modal viewport tweaks to layer the network behind the card */
.fp-modal-router > .fp-modal-router-card,
.fp-modal-router > .fp-modal-router-brand,
.fp-modal-router > .fp-modal-router-close {
  position: relative;
  z-index: 2;
}

/* AFFIRMATION INTENSIFICATION — when modal is in affirming state */
.fp-modal-router.is-affirming .fp-bg-lines line {
  animation-duration: 3s;
  opacity: 0.18;
}
.fp-modal-router.is-affirming .fp-bg-nodes circle {
  animation-duration: 2.2s;
}
.fp-modal-router.is-affirming .fp-bg-halos circle {
  animation-duration: 4s;
  opacity: 0.5;
}
.fp-modal-router.is-affirming .fp-bg-pulses circle {
  filter: drop-shadow(0 0 8px rgba(184, 155, 90, 0.85));
}

/* OPTION HOVER — shimmer sweep */
.fp-modal-router-option {
  position: relative;
  overflow: hidden;
}

.fp-modal-router-option::before {
  content: '';
  position: absolute;
  top: 0;
  left: -60%;
  width: 50%;
  height: 100%;
  background: linear-gradient(
    90deg,
    transparent 0%,
    rgba(31, 77, 74, 0.06) 50%,
    transparent 100%
  );
  transform: skewX(-12deg);
  transition: left 0.7s var(--fp-ease-out);
  pointer-events: none;
  z-index: 0;
}

.fp-modal-router-option:hover::before {
  left: 130%;
}

/* Make sure option content sits above the shimmer */
.fp-modal-router-option > * {
  position: relative;
  z-index: 1;
}

/* SELECTION RIPPLE — emanates from the checkmark */
.fp-modal-router-option-check {
  position: relative;
  overflow: visible;
}

.fp-modal-router-option.is-selected .fp-modal-router-option-check::before {
  content: '';
  position: absolute;
  inset: -2px;
  border-radius: 50%;
  border: 2px solid var(--fp-accent);
  opacity: 0;
  pointer-events: none;
  animation: fp-check-ripple 0.85s var(--fp-ease-out);
}

@keyframes fp-check-ripple {
  0% { transform: scale(1); opacity: 0.7; }
  100% { transform: scale(3.2); opacity: 0; }
}

/* When hovering an option, lift its background slightly more dramatically */
@media (hover: hover) {
  .fp-modal-router-option:hover {
    background: linear-gradient(90deg, var(--fp-paper-2) 0%, transparent 100%);
  }
}

/* MODAL ROUTER — full-screen audience selector overlay
   Fixed viewport-fitted experience. No scroll above the fold.
   Fades to reveal the destination page when visitor self-routes or skips.
   ============================================ */
.fp-modal-router {
  position: fixed;
  inset: 0;
  z-index: 1500;
  background: var(--fp-paper);
  display: flex;
  flex-direction: column;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.6s var(--fp-ease), visibility 0.6s var(--fp-ease);
  pointer-events: none;
  overflow: hidden;
}

/* Default-open before JS runs — set by inline <head> script on first visit */
.fp-modal-router-pending .fp-modal-router,
.fp-modal-router.is-open {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

.fp-modal-router-pending { overflow: hidden; }

.fp-modal-router-backdrop {
  display: none;
}

.fp-modal-router-card {
  flex: 1;
  display: flex;
  flex-direction: column;
  /* safe center: vertically centered when it fits, but aligns to the top
     (instead of overflowing past it) when content is taller than the
     window — so nothing gets clipped and the Continue button stays reachable. */
  justify-content: safe center;
  align-items: flex-start;
  width: 100%;
  max-width: 760px;
  margin: 0 auto;
  padding: 72px var(--fp-page-gutter) 32px;
  background: transparent;
  border: 0;
  border-radius: 0;
  box-shadow: none;
  position: relative;
  transform: translateY(8px);
  opacity: 0.92;
  transition: transform 0.55s var(--fp-ease-out), opacity 0.55s var(--fp-ease-out);
  min-height: 0;
  overflow-y: auto;
  overscroll-behavior: contain;
  -webkit-overflow-scrolling: touch;
}

@media (max-width: 760px) {
  .fp-modal-router-card { padding: 64px var(--fp-page-gutter) 24px; }
}

@media (max-height: 720px) {
  .fp-modal-router-card { padding-top: 56px; padding-bottom: 20px; }
}

.fp-modal-router-pending .fp-modal-router-card,
.fp-modal-router.is-open .fp-modal-router-card {
  transform: translateY(0);
  opacity: 1;
}

/* View swap — question vs affirmation */
.fp-modal-router-view {
  width: 100%;
  display: flex;
  flex-direction: column;
}
.fp-modal-router-view[hidden] { display: none !important; }

/* AFFIRMATION VIEW */
.fp-modal-router-aff-eyebrow {
  font-family: var(--fp-body);
  font-size: 0.7rem;
  font-weight: 500;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--fp-accent);
  margin-bottom: 24px;
  animation: fp-aff-fade-in 0.5s var(--fp-ease-out) both;
}

.fp-modal-router-aff-headline {
  font-family: var(--fp-display);
  font-weight: 500;
  font-size: clamp(1.85rem, 4.4vw, 2.8rem);
  line-height: 1.06;
  letter-spacing: -0.03em;
  color: var(--fp-ink);
  margin: 0 0 20px;
  max-width: 22ch;
  background: linear-gradient(120deg, var(--fp-ink) 0%, var(--fp-accent) 60%, var(--fp-ink) 100%);
  background-size: 200% 100%;
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
  animation: fp-aff-fade-in 0.6s var(--fp-ease-out) 0.1s both, fp-aff-gradient 4s ease-in-out infinite alternate;
}

.fp-modal-router-aff-body {
  font-family: var(--fp-body);
  font-size: 1.1rem;
  line-height: 1.55;
  color: var(--fp-text-on-paper);
  margin: 0 0 28px;
  max-width: 56ch;
  letter-spacing: -0.005em;
  animation: fp-aff-fade-in 0.6s var(--fp-ease-out) 0.25s both;
}

.fp-modal-router-aff-transition {
  font-family: var(--fp-serif);
  font-style: italic;
  font-size: 0.96rem;
  line-height: 1.5;
  color: var(--fp-text-on-paper-soft);
  margin: 0 0 28px;
  max-width: 56ch;
  animation: fp-aff-fade-in 0.6s var(--fp-ease-out) 0.4s both;
}

/* Continue button — primary CTA on affirmation view */
.fp-modal-router-aff-cta {
  margin-top: 8px;
  animation: fp-aff-fade-in 0.55s var(--fp-ease-out) 0.5s both;
}

.fp-modal-router-aff-continue {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  background: var(--fp-ink);
  color: var(--fp-paper);
  border: 0;
  border-radius: 999px;
  padding: 16px 28px;
  font-family: var(--fp-body);
  font-size: 0.96rem;
  font-weight: 500;
  letter-spacing: 0.005em;
  cursor: pointer;
  transition: background 0.25s var(--fp-ease), transform 0.25s var(--fp-ease), gap 0.25s var(--fp-ease), box-shadow 0.25s var(--fp-ease);
  box-shadow: 0 6px 24px -8px rgba(7, 8, 10, 0.32);
}

.fp-modal-router-aff-continue:hover {
  background: var(--fp-accent);
  gap: 14px;
  box-shadow: 0 10px 32px -10px rgba(31, 77, 74, 0.55);
  transform: translateY(-1px);
}

.fp-modal-router-aff-continue:focus-visible {
  outline: 2px solid var(--fp-accent);
  outline-offset: 3px;
}

.fp-modal-router-aff-continue svg {
  transition: transform 0.25s var(--fp-ease);
}

.fp-modal-router-aff-continue:hover svg {
  transform: translateX(3px);
}

/* Legacy progress bar styles preserved (unused now but harmless if older HTML lingers) */
.fp-modal-router-aff-progress { display: none; }

/* ============================================
   IGNITE TRANSITION — when Continue CTA is pressed
   Network converges, gold radial burst expands, card fades.
   Plays ~900ms before page navigation fires.
   ============================================ */

/* Card and content fade + slight scale */
.fp-modal-router.is-igniting .fp-modal-router-card {
  opacity: 0;
  transform: scale(0.96);
  transition: opacity 0.45s var(--fp-ease-out), transform 0.6s var(--fp-ease-out);
  pointer-events: none;
}

.fp-modal-router.is-igniting .fp-modal-router-close,
.fp-modal-router.is-igniting .fp-modal-router-brand {
  opacity: 0;
  transition: opacity 0.35s var(--fp-ease-out);
}

/* Network background — pulse then converge */
.fp-modal-router.is-igniting .fp-bg-lines line {
  opacity: 0.5;
  filter: brightness(1.6);
  transition: opacity 0.25s var(--fp-ease-out), filter 0.25s var(--fp-ease-out);
}

.fp-modal-router.is-igniting .fp-bg-nodes circle {
  animation: fp-ignite-node 0.85s var(--fp-ease-out) forwards;
}

.fp-modal-router.is-igniting .fp-bg-halos circle {
  animation: fp-ignite-halo 0.85s var(--fp-ease-out) forwards;
}

.fp-modal-router.is-igniting .fp-bg-pulses circle {
  filter: drop-shadow(0 0 14px rgba(184, 155, 90, 1));
  transition: filter 0.3s var(--fp-ease-out);
}

@keyframes fp-ignite-node {
  0% { transform: scale(1); opacity: 0.7; }
  35% { transform: scale(2.4); opacity: 1; filter: brightness(2); }
  100% { transform: scale(0); opacity: 0; }
}

@keyframes fp-ignite-halo {
  0% { transform: scale(1); opacity: 0.4; }
  40% { transform: scale(1.8); opacity: 0.8; }
  100% { transform: scale(3.5); opacity: 0; }
}

/* The gold burst — radial gradient expanding from center */
.fp-modal-router::after {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(
    circle at center,
    rgba(184, 155, 90, 0.7) 0%,
    rgba(31, 77, 74, 0.45) 18%,
    rgba(168, 199, 196, 0.25) 35%,
    rgba(251, 250, 246, 0) 65%
  );
  opacity: 0;
  transform: scale(0.15);
  pointer-events: none;
  z-index: 3;
  border-radius: 50%;
  transform-origin: center;
}

.fp-modal-router.is-igniting::after {
  animation: fp-ignite-burst 0.9s var(--fp-ease-out) forwards;
}

@keyframes fp-ignite-burst {
  0% {
    opacity: 0;
    transform: scale(0.15);
  }
  30% {
    opacity: 1;
    transform: scale(0.6);
  }
  60% {
    opacity: 1;
    transform: scale(1.4);
  }
  100% {
    opacity: 0;
    transform: scale(2.6);
  }
}

@media (prefers-reduced-motion: reduce) {
  .fp-modal-router.is-igniting .fp-modal-router-card { transition: opacity 0.2s linear; transform: none; }
  .fp-modal-router.is-igniting .fp-bg-nodes circle,
  .fp-modal-router.is-igniting .fp-bg-halos circle { animation: none; opacity: 0; }
  .fp-modal-router.is-igniting::after { animation: none; opacity: 0; }
}

@keyframes fp-aff-fade-in {
  from { opacity: 0; transform: translateY(8px); }
  to { opacity: 1; transform: translateY(0); }
}

@keyframes fp-aff-gradient {
  0% { background-position: 0% 50%; }
  100% { background-position: 100% 50%; }
}

@keyframes fp-aff-progress {
  from { width: 0%; }
  to { width: 100%; }
}

@media (prefers-reduced-motion: reduce) {
  .fp-modal-router-aff-eyebrow,
  .fp-modal-router-aff-headline,
  .fp-modal-router-aff-body,
  .fp-modal-router-aff-transition,
  .fp-modal-router-aff-progress { animation: none; opacity: 1; transform: none; }
  .fp-modal-router-aff-headline { background: none; color: var(--fp-ink); -webkit-text-fill-color: currentColor; }
  .fp-modal-router-aff-progress-bar { animation: fp-aff-progress 3s linear forwards; }
}

.fp-modal-router-close {
  position: fixed;
  top: 22px;
  right: var(--fp-page-gutter);
  width: 40px;
  height: 40px;
  border: 1px solid var(--fp-border-on-paper);
  background: var(--fp-paper);
  border-radius: 50%;
  color: var(--fp-text-on-paper-muted);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.25s var(--fp-ease), color 0.25s var(--fp-ease), border-color 0.25s var(--fp-ease);
  z-index: 2;
}

.fp-modal-router-close:hover {
  background: var(--fp-paper-2);
  color: var(--fp-ink);
  border-color: var(--fp-border-on-paper-strong);
}

.fp-modal-router-eyebrow {
  font-family: var(--fp-body);
  font-size: 0.7rem;
  font-weight: 500;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--fp-text-on-paper-muted);
  margin-bottom: 18px;
}

.fp-modal-router-title {
  font-family: var(--fp-display);
  font-weight: 500;
  font-size: clamp(1.65rem, 3.6vw, 2.3rem);
  line-height: 1.08;
  letter-spacing: -0.028em;
  color: var(--fp-ink);
  margin-bottom: 14px;
  max-width: 22ch;
}

.fp-modal-router-sub {
  font-family: var(--fp-body);
  font-size: 1rem;
  line-height: 1.6;
  color: var(--fp-text-on-paper);
  margin-bottom: 28px;
  max-width: 60ch;
  letter-spacing: -0.005em;
  padding: 14px 0 14px 18px;
  border-left: 3px solid var(--fp-accent);
  background: linear-gradient(90deg, rgba(31, 77, 74, 0.04) 0%, transparent 70%);
}

/* Inline pill labels embedded in the sub copy — preview the exact
   visual reward the visitor sees on selecting a card. */
.fp-modal-router-inline-tag {
  display: inline-flex;
  align-items: center;
  padding: 2px 8px 3px;
  border-radius: 999px;
  font-size: 0.65em;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  vertical-align: 2px;
  margin: 0 2px;
  line-height: 1;
  white-space: nowrap;
}

.fp-modal-router-inline-tag--primary {
  background: var(--fp-accent);
  color: var(--fp-paper);
}

.fp-modal-router-inline-tag--secondary {
  background: rgba(31, 77, 74, 0.08);
  color: var(--fp-accent);
  border: 1px solid rgba(31, 77, 74, 0.25);
}

@media (max-height: 720px) {
  .fp-modal-router-title { font-size: clamp(1.45rem, 3vw, 1.9rem); margin-bottom: 10px; }
  .fp-modal-router-sub { margin-bottom: 18px; font-size: 0.92rem; }
  .fp-modal-router-option { padding: 11px 8px; min-height: 56px; }
  .fp-modal-router-option-title { font-size: 1rem; }
  .fp-modal-router-option-sub { font-size: 0.82rem; }
}

.fp-modal-router-hint {
  font-family: var(--fp-body);
  font-size: 0.86rem;
  line-height: 1.5;
  color: var(--fp-text-on-paper-muted);
  margin-bottom: 36px;
  max-width: 56ch;
  letter-spacing: 0.005em;
}

/* "Pick all that apply" prominent badge row */
.fp-modal-router-hint-row {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 22px;
  max-width: 64ch;
  flex-wrap: wrap;
}

.fp-modal-router-hint-badge {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  background: var(--fp-accent);
  color: var(--fp-paper);
  font-family: var(--fp-body);
  font-size: 0.8rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  padding: 7px 13px 7px 11px;
  border-radius: 999px;
  white-space: nowrap;
  box-shadow: 0 4px 12px -4px rgba(31, 77, 74, 0.32);
  flex-shrink: 0;
}

.fp-modal-router-hint-badge svg {
  flex-shrink: 0;
}

.fp-modal-router-hint-text {
  font-family: var(--fp-body);
  font-size: 0.92rem;
  line-height: 1.55;
  color: var(--fp-text-on-paper-soft);
  letter-spacing: 0.002em;
}

@media (max-width: 760px) {
  .fp-modal-router-hint-row {
    flex-direction: column;
    align-items: flex-start;
    gap: 12px;
    margin-bottom: 32px;
  }
  .fp-modal-router-hint-text {
    font-size: 0.88rem;
  }
}

.fp-modal-router-options {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 0;
  margin: 0 0 18px;
  padding: 0;
  border-top: 1px solid var(--fp-border-on-paper);
}

.fp-modal-router-option {
  display: grid;
  grid-template-columns: 26px 1fr auto;
  gap: 4px 18px;
  align-items: center;
  background: transparent;
  border: 0;
  border-bottom: 1px solid var(--fp-border-on-paper);
  border-radius: 0;
  padding: 14px 8px;
  text-align: left;
  cursor: pointer;
  font-family: inherit;
  color: inherit;
  text-decoration: none;
  transition: background 0.2s var(--fp-ease), padding 0.2s var(--fp-ease);
  position: relative;
  width: 100%;
  min-height: 64px;
}

/* Body column should still allow title + sub to stack */
.fp-modal-router-option .fp-modal-router-option-body {
  align-self: center;
}

.fp-modal-router-option::after {
  content: '';
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 3px;
  height: 0;
  background: var(--fp-accent);
  transition: height 0.3s var(--fp-ease);
}

.fp-modal-router-option:hover,
.fp-modal-router-option:focus-visible {
  background: var(--fp-paper-2);
  padding-left: 16px;
  outline: none;
}

.fp-modal-router-option:hover::after,
.fp-modal-router-option:focus-visible::after {
  height: 48%;
}

/* SELECTED STATE — unmistakable visual */
.fp-modal-router-option.is-selected {
  background: rgba(31, 77, 74, 0.06);
  padding-left: 16px;
}

.fp-modal-router-option.is-selected::after {
  height: 72%;
  width: 3px;
}

/* fp-modal-router-option-num — removed; step number now lives in the step header.
   The class can still be in old cached HTML but won't render any content. */
.fp-modal-router-option-num { display: none; }

.fp-modal-router-option-body {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.fp-modal-router-option-title {
  font-family: var(--fp-display);
  font-weight: 500;
  font-size: 1.05rem;
  letter-spacing: -0.018em;
  color: var(--fp-ink);
  line-height: 1.24;
}

.fp-modal-router-option-sub {
  font-family: var(--fp-body);
  font-size: 0.85rem;
  line-height: 1.45;
  color: var(--fp-text-on-paper-soft);
  letter-spacing: 0.002em;
}

/* Checkbox-style indicator on the LEFT (square + check) */
.fp-modal-router-option-check {
  width: 22px;
  height: 22px;
  border: 1.5px solid var(--fp-border-on-paper-strong);
  border-radius: 5px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--fp-paper);
  color: transparent;
  flex-shrink: 0;
  margin-top: 2px;
  transition: background 0.22s var(--fp-ease), border-color 0.22s var(--fp-ease), color 0.22s var(--fp-ease), transform 0.22s var(--fp-ease-out);
}

.fp-modal-router-option:hover .fp-modal-router-option-check {
  border-color: var(--fp-accent);
}

.fp-modal-router-option.is-selected .fp-modal-router-option-check {
  background: var(--fp-accent);
  border-color: var(--fp-accent);
  color: var(--fp-paper);
}

.fp-modal-router-option-check svg {
  opacity: 0;
  transition: opacity 0.18s var(--fp-ease);
}

.fp-modal-router-option.is-selected .fp-modal-router-option-check svg {
  opacity: 1;
}

/* Legacy primary-badge class (no longer rendered in markup, but kept hidden so
   any stale cached HTML doesn't show a stray element). */
.fp-modal-router-option-primary-badge { display: none; }

/* PRIMARY / SECONDARY TAG — replaces the two-step badge approach */
.fp-modal-router-option-tag {
  display: none;
  font-family: var(--fp-body);
  font-size: 0.68rem;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  padding: 5px 11px;
  border-radius: 999px;
  white-space: nowrap;
  align-self: center;
  line-height: 1;
}

.fp-modal-router-option.is-primary .fp-modal-router-option-tag {
  display: inline-flex;
  background: var(--fp-accent);
  color: var(--fp-paper);
  animation: fp-tag-in 0.35s var(--fp-ease-out);
}

.fp-modal-router-option.is-secondary .fp-modal-router-option-tag {
  display: inline-flex;
  background: rgba(31, 77, 74, 0.08);
  color: var(--fp-accent);
  border: 1px solid rgba(31, 77, 74, 0.25);
  animation: fp-tag-in 0.35s var(--fp-ease-out);
}

@keyframes fp-tag-in {
  from { opacity: 0; transform: scale(0.7); }
  to { opacity: 1; transform: scale(1); }
}

/* Secondary selections get a softer accent than primary */
.fp-modal-router-option.is-secondary {
  background: rgba(31, 77, 74, 0.035);
}
.fp-modal-router-option.is-secondary::after {
  opacity: 0.55;
  height: 56% !important;
}

/* LOCKED — applied to unselected options when the 2-pick max is reached.
   Visually dims them; the click handler ignores them anyway. */
.fp-modal-router-option.is-locked {
  opacity: 0.35;
  cursor: not-allowed;
}
.fp-modal-router-option.is-locked:hover {
  background: transparent;
  padding-left: 8px;
}
.fp-modal-router-option.is-locked:hover::after {
  height: 0;
}
.fp-modal-router-option.is-locked .fp-modal-router-option-check {
  border-style: dashed;
}

@media (prefers-reduced-motion: reduce) {
  .fp-modal-router-option-tag { animation: none; }
}

/* On narrow mobile, drop the tag into the body column above the title */
@media (max-width: 520px) {
  .fp-modal-router-option {
    grid-template-columns: 22px 1fr;
    grid-template-rows: auto auto;
    gap: 6px 14px;
    align-items: start;
  }
  .fp-modal-router-option .fp-modal-router-option-check { grid-row: 1 / 3; align-self: center; }
  .fp-modal-router-option .fp-modal-router-option-body { grid-column: 2; grid-row: 1; }
  .fp-modal-router-option-tag {
    grid-column: 2;
    grid-row: 2;
    justify-self: start;
    margin-top: 4px;
    font-size: 0.62rem;
    padding: 4px 9px;
  }
}

/* Footer row: status text, skip link, Continue CTA */
.fp-modal-router-footer {
  display: flex;
  flex-direction: column;
  gap: 14px;
  margin-top: 4px;
}

.fp-modal-router-status {
  font-family: var(--fp-body);
  font-size: 0.9rem;
  letter-spacing: 0.005em;
  line-height: 1.45;
  color: var(--fp-text-on-paper-soft);
  margin: 0;
  transition: color 0.25s var(--fp-ease);
  font-weight: 500;
}

.fp-modal-router-status.has-selections {
  color: var(--fp-accent);
}

.fp-modal-router-status strong {
  font-weight: 600;
  color: var(--fp-ink);
}
.fp-modal-router-status.has-selections strong {
  color: var(--fp-accent);
}

.fp-modal-router-actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
}

.fp-modal-router-skip {
  background: transparent;
  border: 0;
  font-family: var(--fp-body);
  font-size: 0.86rem;
  font-weight: 500;
  color: var(--fp-text-on-paper-muted);
  cursor: pointer;
  padding: 8px 0;
  letter-spacing: 0.01em;
  transition: color 0.25s var(--fp-ease);
}

.fp-modal-router-skip:hover {
  color: var(--fp-ink);
}

.fp-modal-router-continue {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: var(--fp-ink);
  color: var(--fp-paper);
  border: 0;
  border-radius: 999px;
  padding: 14px 26px;
  font-family: var(--fp-body);
  font-size: 0.94rem;
  font-weight: 500;
  letter-spacing: 0.01em;
  cursor: pointer;
  transition: background 0.25s var(--fp-ease), transform 0.2s var(--fp-ease), box-shadow 0.25s var(--fp-ease), opacity 0.25s var(--fp-ease);
  box-shadow: 0 4px 14px -4px rgba(7, 8, 10, 0.18);
}

.fp-modal-router-continue:hover:not(:disabled) {
  background: var(--fp-ink-2);
  transform: translateY(-1px);
  box-shadow: 0 8px 24px -6px rgba(7, 8, 10, 0.28);
}

.fp-modal-router-continue:disabled {
  background: var(--fp-paper-3);
  color: var(--fp-text-on-paper-muted);
  cursor: not-allowed;
  box-shadow: none;
  opacity: 0.7;
}

.fp-modal-router-continue svg {
  transition: transform 0.25s var(--fp-ease);
}

.fp-modal-router-continue:hover:not(:disabled) svg {
  transform: translateX(3px);
}

/* Brand mark inside the full-screen layer */
.fp-modal-router-brand {
  position: fixed;
  top: 22px;
  left: var(--fp-page-gutter);
  display: inline-flex;
  align-items: center;
  gap: 10px;
  z-index: 2;
}
.fp-modal-router-brand .fp-mark-svg { width: 32px; height: 32px; }
.fp-modal-router-brand-word {
  font-family: var(--fp-display);
  font-weight: 500;
  font-size: 1rem;
  letter-spacing: -0.01em;
  color: var(--fp-ink);
}

@media (max-width: 760px) {
  /* On mobile the card scrolls if absolutely necessary (very short viewports)
     but the design is tuned to fit comfortably on standard mobile heights */
  .fp-modal-router { overflow-y: auto; }
  .fp-modal-router-card {
    padding: 78px var(--fp-page-gutter) 28px;
    justify-content: flex-start;
    min-height: 100vh;
  }
  .fp-modal-router-eyebrow { margin-bottom: 14px; }
  .fp-modal-router-title { font-size: clamp(1.55rem, 6.4vw, 2rem); margin-bottom: 12px; }
  .fp-modal-router-sub { font-size: 0.94rem; margin-bottom: 12px; }
  .fp-modal-router-hint-row { margin-bottom: 18px; gap: 10px; }
  .fp-modal-router-option {
    grid-template-columns: 36px 1fr 26px;
    gap: 10px 14px;
    padding: 12px 0;
  }
  .fp-modal-router-option:hover,
  .fp-modal-router-option:focus-visible,
  .fp-modal-router-option.is-selected {
    padding-left: 8px;
  }
  .fp-modal-router-option-num { font-size: 0.7rem; }
  .fp-modal-router-option-title { font-size: 0.96rem; }
  .fp-modal-router-option-sub { font-size: 0.8rem; line-height: 1.4; }
  .fp-modal-router-option-check { width: 22px; height: 22px; }
  .fp-modal-router-option-check svg { width: 12px; height: 12px; }
  .fp-modal-router-options { margin-bottom: 12px; }
  .fp-modal-router-close { top: 16px; width: 36px; height: 36px; }
  .fp-modal-router-brand { top: 18px; }
  .fp-modal-router-footer { margin-top: 0; gap: 10px; }
  .fp-modal-router-actions {
    flex-direction: column;
    align-items: stretch;
    gap: 10px;
  }
  .fp-modal-router-continue {
    width: 100%;
    justify-content: center;
    padding: 14px 24px;
  }
  .fp-modal-router-skip { text-align: center; padding: 4px 0; }
  /* Affirmation tuning on mobile */
  .fp-modal-router-aff-headline { font-size: clamp(1.7rem, 7vw, 2.2rem); }
  .fp-modal-router-aff-body { font-size: 1rem; margin-bottom: 22px; }
  .fp-modal-router-aff-transition { font-size: 0.9rem; margin-bottom: 22px; }
  .fp-modal-router-aff-progress { width: 200px; }
}

/* Very small viewports — even tighter */
@media (max-width: 760px) and (max-height: 720px) {
  .fp-modal-router-card { padding-top: 72px; }
  .fp-modal-router-title { font-size: 1.4rem; }
  .fp-modal-router-option { padding: 10px 0; }
  .fp-modal-router-option-sub { display: none; }
}

@media (prefers-reduced-motion: reduce) {
  .fp-modal-router-card { transform: none; opacity: 1; }
  .fp-modal-router { transition: opacity 0.2s linear; }
}

/* ============================================
   QUIZ — Typeform-style "Find your path"
   3-question multiple-choice page that routes to the right archetype
   ============================================ */
.fp-quiz-page {
  background: var(--fp-paper);
  min-height: 100vh;
  overflow: hidden;
}

.fp-quiz-page .fp-ambient { display: none; }

.fp-quiz-header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 10;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 22px var(--fp-page-gutter);
  background: rgba(251, 250, 246, 0.85);
  backdrop-filter: blur(14px) saturate(140%);
  -webkit-backdrop-filter: blur(14px) saturate(140%);
  border-bottom: 1px solid var(--fp-border-on-paper);
}

.fp-quiz-logo {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  text-decoration: none;
  color: var(--fp-ink);
}

.fp-quiz-logo .fp-logo-mark { display: inline-flex; align-items: center; }
.fp-quiz-logo .fp-mark-svg { width: 32px; height: 32px; }

.fp-quiz-logo .fp-logo-word {
  font-family: var(--fp-display);
  font-weight: 500;
  font-size: 1.02rem;
  letter-spacing: -0.01em;
  color: var(--fp-ink);
}

.fp-quiz-skip {
  font-family: var(--fp-body);
  font-size: 0.82rem;
  font-weight: 500;
  color: var(--fp-text-on-paper-muted);
  letter-spacing: 0.04em;
  transition: color 0.25s var(--fp-ease);
}
.fp-quiz-skip:hover { color: var(--fp-ink); }

.fp-quiz-stage {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 100px var(--fp-page-gutter) 120px;
  position: relative;
}

.fp-quiz-question,
.fp-quiz-result {
  width: 100%;
  max-width: 760px;
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.5s var(--fp-ease-out), transform 0.5s var(--fp-ease-out);
  pointer-events: none;
  position: absolute;
  left: 50%;
  margin-left: -380px;
}

.fp-quiz-question.is-active,
.fp-quiz-result.is-active {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
  position: relative;
  left: auto;
  margin-left: auto;
}

.fp-quiz-meta {
  display: inline-flex;
  align-items: baseline;
  gap: 10px;
  margin-bottom: 28px;
  font-family: var(--fp-body);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  font-size: 0.72rem;
  font-weight: 500;
  color: var(--fp-text-on-paper-muted);
}

.fp-quiz-num {
  color: var(--fp-accent);
  font-weight: 600;
  letter-spacing: 0.06em;
  padding: 4px 10px;
  border: 1px solid var(--fp-accent);
  border-radius: 4px;
}

.fp-quiz-prompt {
  font-family: var(--fp-display);
  font-weight: 500;
  font-size: clamp(1.8rem, 4.4vw, 3.4rem);
  line-height: 1.08;
  letter-spacing: -0.03em;
  color: var(--fp-ink);
  margin-bottom: 44px;
  max-width: 22ch;
}

.fp-quiz-answers {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin: 0;
  padding: 0;
}

.fp-quiz-answer {
  width: 100%;
  display: flex;
  align-items: flex-start;
  gap: 16px;
  background: var(--fp-paper);
  border: 1px solid var(--fp-border-on-paper-strong);
  border-radius: var(--fp-radius-md);
  padding: 18px 22px;
  cursor: pointer;
  text-align: left;
  font-family: inherit;
  color: var(--fp-ink);
  transition: border-color 0.25s var(--fp-ease), background 0.25s var(--fp-ease), transform 0.18s var(--fp-ease), box-shadow 0.25s var(--fp-ease);
}

.fp-quiz-answer:hover,
.fp-quiz-answer:focus-visible {
  border-color: var(--fp-accent);
  background: linear-gradient(180deg, var(--fp-paper) 0%, var(--fp-paper-2) 100%);
  outline: none;
  transform: translateY(-1px);
  box-shadow: 0 6px 24px -10px rgba(31, 77, 74, 0.18);
}

.fp-quiz-answer.is-selected {
  border-color: var(--fp-accent);
  background: var(--fp-accent);
  color: var(--fp-paper);
  transform: translateY(0);
  box-shadow: 0 10px 32px -8px rgba(31, 77, 74, 0.4);
}

.fp-quiz-answer.is-selected .fp-quiz-key {
  background: var(--fp-paper);
  color: var(--fp-accent);
  border-color: var(--fp-paper);
}

.fp-quiz-key {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  width: 28px;
  height: 28px;
  border: 1px solid var(--fp-border-on-paper-strong);
  border-radius: 6px;
  font-family: var(--fp-display);
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--fp-text-on-paper-muted);
  letter-spacing: 0.04em;
  background: var(--fp-paper);
  transition: background 0.25s var(--fp-ease), color 0.25s var(--fp-ease), border-color 0.25s var(--fp-ease);
  margin-top: 2px;
}

.fp-quiz-answer-text {
  font-family: var(--fp-body);
  font-size: 1.02rem;
  line-height: 1.5;
  letter-spacing: -0.005em;
  flex: 1;
}

/* Result screen */
.fp-quiz-result-inner {
  text-align: center;
  max-width: 560px;
  margin: 0 auto;
}

.fp-quiz-result-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--fp-accent);
  margin: 0 auto 28px;
  animation: fp-quiz-result-pulse 1.4s ease-in-out infinite;
}

@keyframes fp-quiz-result-pulse {
  0%, 100% { transform: scale(1); opacity: 0.5; }
  50% { transform: scale(1.4); opacity: 1; }
}

.fp-quiz-result-eyebrow {
  font-family: var(--fp-body);
  font-size: 0.76rem;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--fp-text-on-paper-muted);
  margin-bottom: 14px;
}

.fp-quiz-result-title {
  font-family: var(--fp-display);
  font-weight: 500;
  font-size: clamp(2.2rem, 5.4vw, 3.8rem);
  letter-spacing: -0.03em;
  line-height: 1.06;
  color: var(--fp-ink);
  margin-bottom: 28px;
}

.fp-quiz-result-body {
  font-family: var(--fp-body);
  font-size: 1.05rem;
  line-height: 1.6;
  color: var(--fp-text-on-paper-soft);
  margin-bottom: 36px;
  max-width: 50ch;
  margin-left: auto;
  margin-right: auto;
}

.fp-quiz-result-redirect {
  font-family: var(--fp-body);
  font-size: 0.85rem;
  letter-spacing: 0.04em;
  color: var(--fp-text-on-paper-muted);
  margin-bottom: 14px;
}

.fp-quiz-result-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--fp-body);
  font-size: 0.94rem;
  font-weight: 500;
  color: var(--fp-accent);
  border-bottom: 1px solid var(--fp-accent);
  padding-bottom: 2px;
  transition: gap 0.25s var(--fp-ease);
}
.fp-quiz-result-link:hover { gap: 10px; }

/* Footer with progress dots */
.fp-quiz-footer {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 24px;
  padding: 22px var(--fp-page-gutter);
  background: linear-gradient(180deg, transparent 0%, var(--fp-paper) 60%);
  z-index: 10;
}

.fp-quiz-progress {
  display: inline-flex;
  align-items: center;
  gap: 10px;
}

.fp-quiz-progress-dot {
  display: inline-block;
  width: 28px;
  height: 3px;
  background: var(--fp-border-on-paper-strong);
  border-radius: 2px;
  transition: background 0.4s var(--fp-ease);
}

.fp-quiz-progress-dot.is-active {
  background: var(--fp-accent);
}

.fp-quiz-back {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: transparent;
  border: 0;
  font-family: var(--fp-body);
  font-size: 0.84rem;
  font-weight: 500;
  color: var(--fp-text-on-paper-muted);
  cursor: pointer;
  padding: 8px 12px;
  border-radius: 6px;
  transition: color 0.25s var(--fp-ease), background 0.25s var(--fp-ease);
}
.fp-quiz-back:hover {
  color: var(--fp-ink);
  background: var(--fp-paper-2);
}

.fp-quiz-hint {
  font-family: var(--fp-body);
  font-size: 0.78rem;
  color: var(--fp-text-on-paper-muted);
  letter-spacing: 0.04em;
  transition: opacity 0.4s var(--fp-ease);
}

@media (max-width: 760px) {
  .fp-quiz-stage { padding: 90px var(--fp-page-gutter) 130px; }
  .fp-quiz-question, .fp-quiz-result {
    margin-left: 0;
    left: 0;
    max-width: 100%;
  }
  .fp-quiz-question:not(.is-active),
  .fp-quiz-result:not(.is-active) {
    left: 0;
    margin-left: 0;
  }
  .fp-quiz-prompt { margin-bottom: 32px; }
  .fp-quiz-answer { padding: 16px 18px; }
  .fp-quiz-answer-text { font-size: 0.96rem; }
  .fp-quiz-hint { display: none; }
  .fp-quiz-footer { padding: 18px var(--fp-page-gutter); gap: 14px; }
  .fp-quiz-back { padding: 6px 10px; }
  .fp-quiz-progress-dot { width: 24px; }
}

/* ============================================
   ECOSYSTEM ASSESSMENT — strategic diagnostic overlay
   Triggered from anywhere on the 4 archetype landing pages via
   [data-fp-assessment-trigger]. Same visual language as the modal-router
   (paper background, network nodes, gold pulses) but tuned for a longer
   conversational experience.
   ============================================ */
.fp-assess {
  position: fixed;
  inset: 0;
  z-index: 1600;
  background: var(--fp-paper);
  display: flex;
  flex-direction: column;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.6s var(--fp-ease), visibility 0.6s var(--fp-ease);
  pointer-events: none;
  overflow: hidden;
}

.fp-assess.is-open {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

/* Background network — reuses modal-router visual vocabulary */
.fp-assess-bg {
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  overflow: hidden;
}

.fp-assess-bg-svg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}

.fp-assess-bg-lines line {
  opacity: 0.07;
  animation: fp-assess-line-breathe 8s ease-in-out infinite;
}
.fp-assess-bg-lines line:nth-of-type(odd) { animation-delay: -3s; }
.fp-assess-bg-lines line:nth-of-type(3n) { animation-duration: 11s; }

@keyframes fp-assess-line-breathe {
  0%, 100% { opacity: 0.04; }
  50% { opacity: 0.16; }
}

.fp-assess-bg-nodes circle {
  opacity: 0.4;
  transform-origin: center;
  animation: fp-assess-node-breathe 5s ease-in-out infinite;
}
.fp-assess-bg-nodes circle:nth-of-type(odd) { animation-delay: -2s; }
.fp-assess-bg-nodes circle:nth-of-type(3n) { animation-duration: 6.5s; }

.fp-assess-bg-node-primary { opacity: 0.55; animation-duration: 6s !important; }
.fp-assess-bg-node-hub { opacity: 0.7; animation-duration: 7s !important; }

@keyframes fp-assess-node-breathe {
  0%, 100% { opacity: 0.3; transform: scale(1); }
  50% { opacity: 0.65; transform: scale(1.3); }
}

/* Cursor-follow radial glow — mirrors the modal-router for visual consistency */
.fp-assess {
  --fp-assess-mouse-x: 50%;
  --fp-assess-mouse-y: 50%;
}
.fp-assess-bg-cursor {
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 1;
  background: radial-gradient(
    520px circle at var(--fp-assess-mouse-x, 50%) var(--fp-assess-mouse-y, 50%),
    rgba(31, 77, 74, 0.07) 0%,
    rgba(184, 155, 90, 0.03) 35%,
    transparent 65%
  );
  transition: background 0.55s var(--fp-ease);
  opacity: 0;
  animation: fp-assess-cursor-reveal 1.4s ease-out 0.4s forwards;
}
@keyframes fp-assess-cursor-reveal {
  to { opacity: 1; }
}
@media (pointer: coarse), (prefers-reduced-motion: reduce) {
  .fp-assess-bg-cursor { display: none; }
}

.fp-assess-bg-pulses circle {
  filter: drop-shadow(0 0 4px rgba(184, 155, 90, 0.55));
}

/* Stage + view */
.fp-assess-stage {
  position: relative;
  z-index: 2;
  flex: 1;
  display: flex;
  /* Center when content fits; gracefully fall back to top-aligned scroll
     when content overflows (long summary + intake form on small viewports). */
  align-items: safe center;
  justify-content: center;
  padding: 84px var(--fp-page-gutter) 80px;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior: contain;
  transition: opacity 0.28s var(--fp-ease), transform 0.32s var(--fp-ease);
}

/* Make the close button stay visible while content scrolls beneath it */
.fp-assess-close {
  z-index: 5;
}

/* SUBMITTED VIEW — calm confirmation + inline Calendly embed */
.fp-assess-view--submitted {
  align-items: stretch;
  max-width: 860px;
  width: 100%;
}

.fp-assess-submitted-head {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  max-width: 640px;
  margin: 0 auto 36px;
}

.fp-assess-view--submitted .fp-assess-headline {
  font-size: clamp(1.6rem, 3.2vw, 2.4rem);
}

.fp-assess-view--submitted .fp-assess-body {
  font-size: 1rem;
  line-height: 1.55;
}

.fp-assess-check {
  margin-bottom: 18px;
  animation: fp-assess-check-in 0.65s var(--fp-ease-out) both;
}

@keyframes fp-assess-check-in {
  0% { opacity: 0; transform: scale(0.7); }
  60% { opacity: 1; transform: scale(1.08); }
  100% { opacity: 1; transform: scale(1); }
}

/* Inline Calendly embed */
.fp-assess-calendly {
  width: 100%;
  background: var(--fp-paper);
  border: 1px solid var(--fp-border-on-paper);
  border-radius: var(--fp-radius-md);
  overflow: hidden;
  box-shadow: var(--fp-shadow-md);
  animation: fp-assess-calendly-in 0.6s var(--fp-ease-out) 0.3s both;
  margin: 0 auto;
  max-width: 860px;
}

.fp-assess-calendly .calendly-inline-widget {
  width: 100%;
  border-radius: var(--fp-radius-md);
}

@keyframes fp-assess-calendly-in {
  from { opacity: 0; transform: translateY(14px); }
  to { opacity: 1; transform: translateY(0); }
}

.fp-assess-submitted-actions {
  display: flex;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
  margin-top: 28px;
}

.fp-assess-submitted-actions--centered {
  justify-content: center;
}

@media (max-width: 760px) {
  .fp-assess-calendly .calendly-inline-widget { height: 700px !important; }
}

.fp-assess-stage.is-exiting {
  opacity: 0;
  transform: translateY(-8px);
}

.fp-assess-stage.is-entering {
  opacity: 0;
  transform: translateY(8px);
}

.fp-assess-view {
  width: 100%;
  max-width: 720px;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}

/* Close button */
.fp-assess-close {
  position: fixed;
  top: 22px;
  right: var(--fp-page-gutter);
  width: 40px;
  height: 40px;
  border: 1px solid var(--fp-border-on-paper);
  background: var(--fp-paper);
  border-radius: 50%;
  color: var(--fp-text-on-paper-muted);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 10;
  transition: background 0.25s var(--fp-ease), color 0.25s var(--fp-ease);
}
.fp-assess-close:hover { background: var(--fp-paper-2); color: var(--fp-ink); }

/* Progress bar (top of viewport) */
.fp-assess-progress {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  height: 2px;
  background: var(--fp-border-on-paper);
  z-index: 10;
}

.fp-assess-progress-bar {
  display: block;
  height: 100%;
  background: linear-gradient(90deg, var(--fp-accent) 0%, var(--fp-accent-light) 100%);
  transition: width 0.6s var(--fp-ease-out);
  box-shadow: 0 0 10px rgba(31, 77, 74, 0.3);
}

/* Eyebrow + headlines */
.fp-assess-eyebrow {
  font-family: var(--fp-body);
  font-size: 0.72rem;
  font-weight: 500;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--fp-text-on-paper-muted);
  margin-bottom: 22px;
}

.fp-assess-headline {
  font-family: var(--fp-display);
  font-weight: 500;
  font-size: clamp(1.85rem, 4.4vw, 2.8rem);
  line-height: 1.1;
  letter-spacing: -0.028em;
  color: var(--fp-ink);
  margin-bottom: 22px;
  max-width: 28ch;
}

.fp-assess-body {
  font-family: var(--fp-body);
  font-size: 1.04rem;
  line-height: 1.55;
  color: var(--fp-text-on-paper);
  margin-bottom: 28px;
  max-width: 56ch;
}

.fp-assess-meta {
  font-family: var(--fp-body);
  font-style: italic;
  font-size: 0.86rem;
  color: var(--fp-text-on-paper-muted);
  margin-bottom: 36px;
}

/* Question view specifics */
.fp-assess-meta-row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  width: 100%;
  margin-bottom: 18px;
  font-family: var(--fp-body);
  font-size: 0.72rem;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--fp-text-on-paper-muted);
}

.fp-assess-step {
  color: var(--fp-accent);
}
.fp-assess-step-of {
  color: var(--fp-text-on-paper-muted);
  font-weight: 400;
}

.fp-assess-archetype {
  font-weight: 500;
  color: var(--fp-text-on-paper-muted);
}

.fp-assess-ack {
  font-family: var(--fp-serif);
  font-style: italic;
  font-size: 1rem;
  line-height: 1.5;
  color: var(--fp-accent);
  margin-bottom: 14px;
  max-width: 56ch;
}

.fp-assess-context {
  font-family: var(--fp-body);
  font-size: 0.96rem;
  line-height: 1.5;
  color: var(--fp-text-on-paper-soft);
  margin-bottom: 18px;
  max-width: 60ch;
}

.fp-assess-question {
  font-family: var(--fp-display);
  font-weight: 500;
  font-size: clamp(1.55rem, 3.6vw, 2.2rem);
  line-height: 1.12;
  letter-spacing: -0.025em;
  color: var(--fp-ink);
  margin-bottom: 28px;
  max-width: 26ch;
}

/* Options list */
.fp-assess-options {
  list-style: none;
  margin: 0 0 24px;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0;
  border-top: 1px solid var(--fp-border-on-paper);
  width: 100%;
}

.fp-assess-option {
  width: 100%;
  display: grid;
  grid-template-columns: 26px 1fr;
  gap: 4px 18px;
  align-items: flex-start;
  background: transparent;
  border: 0;
  border-bottom: 1px solid var(--fp-border-on-paper);
  padding: 16px 6px;
  text-align: left;
  cursor: pointer;
  font-family: inherit;
  color: inherit;
  position: relative;
  overflow: hidden;
  transition: background 0.22s var(--fp-ease), padding 0.22s var(--fp-ease);
}

.fp-assess-option::after {
  content: '';
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 3px;
  height: 0;
  background: var(--fp-accent);
  transition: height 0.3s var(--fp-ease);
}

.fp-assess-option::before {
  content: '';
  position: absolute;
  top: 0;
  left: -60%;
  width: 50%;
  height: 100%;
  background: linear-gradient(90deg, transparent 0%, rgba(31, 77, 74, 0.06) 50%, transparent 100%);
  transform: skewX(-12deg);
  transition: left 0.7s var(--fp-ease-out);
  pointer-events: none;
}

.fp-assess-option:hover,
.fp-assess-option:focus-visible {
  background: var(--fp-paper-2);
  padding-left: 16px;
  outline: none;
}

.fp-assess-option:hover::after,
.fp-assess-option:focus-visible::after {
  height: 56%;
}

.fp-assess-option:hover::before {
  left: 130%;
}

.fp-assess-option.is-selected {
  background: rgba(31, 77, 74, 0.07);
  padding-left: 16px;
}
.fp-assess-option.is-selected::after { height: 72%; }

/* Letter prefix removed from markup; class kept hidden in case any old DOM still references it */
.fp-assess-option-letter { display: none; }

.fp-assess-option-text {
  font-family: var(--fp-body);
  font-size: 1rem;
  line-height: 1.5;
  color: var(--fp-ink);
  letter-spacing: 0.002em;
}

/* Checkbox-style indicator on the LEFT — matches modal-router exactly */
.fp-assess-option-check {
  width: 22px;
  height: 22px;
  border-radius: 5px;
  border: 1.5px solid var(--fp-border-on-paper-strong);
  background: var(--fp-paper);
  display: flex;
  align-items: center;
  justify-content: center;
  color: transparent;
  flex-shrink: 0;
  margin-top: 2px;
  position: relative;
  transition: background 0.22s var(--fp-ease), border-color 0.22s var(--fp-ease), color 0.22s var(--fp-ease), transform 0.22s var(--fp-ease-out);
}

.fp-assess-option:hover .fp-assess-option-check {
  border-color: var(--fp-accent);
}

.fp-assess-option.is-selected .fp-assess-option-check {
  background: var(--fp-accent);
  border-color: var(--fp-accent);
  color: var(--fp-paper);
}

.fp-assess-option-check svg {
  opacity: 0;
  transition: opacity 0.18s var(--fp-ease);
}

.fp-assess-option.is-selected .fp-assess-option-check svg {
  opacity: 1;
}

/* Selection ripple — same vocabulary as the modal-router */
.fp-assess-option.is-selected .fp-assess-option-check::before {
  content: '';
  position: absolute;
  inset: -2px;
  border-radius: 6px;
  border: 2px solid var(--fp-accent);
  opacity: 0;
  pointer-events: none;
  animation: fp-assess-check-ripple 0.85s var(--fp-ease-out);
}

@keyframes fp-assess-check-ripple {
  0% { transform: scale(1); opacity: 0.65; }
  100% { transform: scale(3); opacity: 0; }
}

.fp-assess-option-check svg { opacity: 0; transition: opacity 0.2s var(--fp-ease); }
.fp-assess-option.is-selected .fp-assess-option-check svg { opacity: 1; }

/* Back button */
.fp-assess-back {
  background: transparent;
  border: 0;
  font-family: var(--fp-body);
  font-size: 0.86rem;
  font-weight: 500;
  color: var(--fp-text-on-paper-muted);
  cursor: pointer;
  padding: 6px 0;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  transition: color 0.25s var(--fp-ease);
}
.fp-assess-back:hover { color: var(--fp-ink); }

/* Primary + secondary CTAs */
.fp-assess-primary {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: var(--fp-ink);
  color: var(--fp-paper);
  border: 0;
  border-radius: 999px;
  padding: 14px 28px;
  font-family: var(--fp-body);
  font-size: 0.96rem;
  font-weight: 500;
  letter-spacing: 0.01em;
  cursor: pointer;
  text-decoration: none;
  transition: background 0.25s var(--fp-ease), transform 0.2s var(--fp-ease), box-shadow 0.25s var(--fp-ease);
  box-shadow: 0 4px 14px -4px rgba(7, 8, 10, 0.18);
}
.fp-assess-primary:hover {
  background: var(--fp-ink-2);
  transform: translateY(-1px);
  box-shadow: 0 8px 24px -6px rgba(7, 8, 10, 0.28);
}
.fp-assess-primary svg { transition: transform 0.25s var(--fp-ease); }
.fp-assess-primary:hover svg { transform: translateX(3px); }

.fp-assess-secondary {
  background: transparent;
  border: 0;
  font-family: var(--fp-body);
  font-size: 0.9rem;
  font-weight: 500;
  color: var(--fp-text-on-paper-muted);
  cursor: pointer;
  padding: 12px 0;
  transition: color 0.25s var(--fp-ease);
}
.fp-assess-secondary:hover { color: var(--fp-ink); }

/* Summary view */
.fp-assess-summary-headline {
  font-family: var(--fp-display);
  font-weight: 500;
  font-size: clamp(1.7rem, 3.8vw, 2.4rem);
  line-height: 1.12;
  letter-spacing: -0.025em;
  color: var(--fp-ink);
  margin-bottom: 22px;
  max-width: 24ch;
}

.fp-assess-summary-body {
  font-family: var(--fp-body);
  font-size: 1.04rem;
  line-height: 1.6;
  color: var(--fp-text-on-paper);
  margin-bottom: 18px;
  max-width: 60ch;
}

.fp-assess-summary-close {
  font-family: var(--fp-serif);
  font-style: italic;
  font-size: 0.98rem;
  line-height: 1.55;
  color: var(--fp-text-on-paper-soft);
  margin-bottom: 28px;
  max-width: 60ch;
}

.fp-assess-form {
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 16px;
  margin-top: 24px;
  padding-top: 28px;
  border-top: 1px solid var(--fp-border-on-paper);
}

.fp-assess-form-eyebrow {
  font-family: var(--fp-body);
  font-size: 0.74rem;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--fp-text-on-paper-muted);
  margin: 0;
}

.fp-assess-form-row { display: flex; gap: 12px; }

.fp-assess-form-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px 16px;
}

.fp-assess-field {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.fp-assess-field--wide {
  grid-column: 1 / -1;
}

.fp-assess-label {
  font-family: var(--fp-body);
  font-size: 0.78rem;
  font-weight: 500;
  letter-spacing: 0.02em;
  color: var(--fp-text-on-paper-soft);
  display: flex;
  align-items: baseline;
  gap: 8px;
}

.fp-assess-label span[aria-hidden="true"] {
  color: var(--fp-accent);
}

.fp-assess-optional {
  font-size: 0.7rem;
  font-weight: 400;
  letter-spacing: 0.04em;
  color: var(--fp-text-on-paper-muted);
  text-transform: lowercase;
}

.fp-assess-input,
.fp-assess-textarea {
  width: 100%;
  background: var(--fp-paper);
  border: 1px solid var(--fp-border-on-paper-strong);
  border-radius: 8px;
  padding: 12px 14px;
  font-family: var(--fp-body);
  font-size: 0.94rem;
  color: var(--fp-ink);
  outline: none;
  transition: border-color 0.25s var(--fp-ease), background 0.25s var(--fp-ease);
}
.fp-assess-input:focus,
.fp-assess-textarea:focus {
  border-color: var(--fp-accent);
  background: var(--fp-paper);
}
.fp-assess-input::placeholder,
.fp-assess-textarea::placeholder {
  color: var(--fp-text-on-paper-muted);
}

.fp-assess-textarea {
  resize: vertical;
  min-height: 56px;
  font-family: var(--fp-body);
  line-height: 1.5;
}

.fp-assess-form-status {
  margin: 0;
  font-family: var(--fp-body);
  font-size: 0.86rem;
  color: var(--fp-text-on-paper-muted);
  min-height: 1em;
}
.fp-assess-form-status.is-error {
  color: #b8503a;
}

.fp-assess-form-actions {
  display: flex;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
  margin-top: 4px;
}

@media (max-width: 600px) {
  .fp-assess-form-grid { grid-template-columns: 1fr; gap: 12px; }
}

/* Assessment trigger styling — keep restrained */
[data-fp-assessment-trigger] {
  cursor: pointer;
}

/* Mid-page contextual CTA card */
.fp-assess-mid-cta {
  background: var(--fp-paper-2);
  border-top: 1px solid var(--fp-border-on-paper);
  border-bottom: 1px solid var(--fp-border-on-paper);
  padding: 64px 0;
}

.fp-assess-mid-cta-inner {
  max-width: 760px;
  margin: 0 auto;
  padding: 0 var(--fp-page-gutter);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 32px;
  flex-wrap: wrap;
}

.fp-assess-mid-cta-text {
  flex: 1 1 380px;
}

.fp-assess-mid-cta-eyebrow {
  font-family: var(--fp-body);
  font-size: 0.72rem;
  font-weight: 500;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--fp-accent);
  margin-bottom: 10px;
}

.fp-assess-mid-cta-title {
  font-family: var(--fp-display);
  font-weight: 500;
  font-size: clamp(1.32rem, 2.6vw, 1.7rem);
  line-height: 1.2;
  letter-spacing: -0.022em;
  color: var(--fp-ink);
  margin-bottom: 8px;
  max-width: 26ch;
}

.fp-assess-mid-cta-body {
  font-family: var(--fp-body);
  font-size: 0.96rem;
  line-height: 1.5;
  color: var(--fp-text-on-paper-soft);
  max-width: 48ch;
}

.fp-assess-mid-cta-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: var(--fp-ink);
  color: var(--fp-paper);
  border: 0;
  border-radius: 999px;
  padding: 14px 26px;
  font-family: var(--fp-body);
  font-size: 0.92rem;
  font-weight: 500;
  letter-spacing: 0.01em;
  cursor: pointer;
  white-space: nowrap;
  transition: background 0.25s var(--fp-ease), transform 0.2s var(--fp-ease), box-shadow 0.25s var(--fp-ease);
  box-shadow: 0 4px 14px -4px rgba(7, 8, 10, 0.18);
}
.fp-assess-mid-cta-btn:hover {
  background: var(--fp-ink-2);
  transform: translateY(-1px);
  box-shadow: 0 8px 24px -6px rgba(7, 8, 10, 0.28);
}
.fp-assess-mid-cta-btn svg { transition: transform 0.25s var(--fp-ease); }
.fp-assess-mid-cta-btn:hover svg { transform: translateX(3px); }

@media (max-width: 760px) {
  .fp-assess-stage { padding: 80px var(--fp-page-gutter) 40px; }
  .fp-assess-option { grid-template-columns: 32px 1fr 24px; gap: 10px 14px; padding: 14px 0; }
  .fp-assess-option-letter { width: 22px; height: 22px; font-size: 0.7rem; }
  .fp-assess-option-text { font-size: 0.94rem; }
  .fp-assess-option-check { width: 22px; height: 22px; }
  .fp-assess-meta-row { font-size: 0.66rem; }
  .fp-assess-form-actions { flex-direction: column; align-items: stretch; }
  .fp-assess-primary { width: 100%; justify-content: center; }
  .fp-assess-mid-cta-inner { flex-direction: column; align-items: flex-start; }
  /* In column direction flex-basis becomes height — reset so the text block
     hugs its content instead of stretching to 380px (caused a blank gap). */
  .fp-assess-mid-cta-text { flex: 0 0 auto; }
  .fp-assess-mid-cta-btn { width: 100%; justify-content: center; }
}

/* ============================================
   ADAPTIVE CONTENT — secondary-archetype sections
   Hidden by default; revealed by JS when ?with=archetype URL param matches.
   Subtle, executive, paper-2 background to differentiate without shouting.
   ============================================ */
.fp-adaptive {
  background: var(--fp-paper-2);
  border-top: 1px solid var(--fp-border-on-paper);
  border-bottom: 1px solid var(--fp-border-on-paper);
  padding: 88px 0;
  position: relative;
}

.fp-adaptive[hidden] { display: none !important; }

.fp-adaptive-inner {
  max-width: 760px;
  margin: 0 auto;
  padding: 0 var(--fp-page-gutter);
}

.fp-adaptive-eyebrow {
  font-family: var(--fp-body);
  font-size: 0.72rem;
  font-weight: 500;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--fp-accent);
  margin-bottom: 18px;
}

.fp-adaptive-title {
  font-family: var(--fp-display);
  font-weight: 500;
  font-size: clamp(1.5rem, 3.2vw, 2.1rem);
  line-height: 1.16;
  letter-spacing: -0.022em;
  color: var(--fp-ink);
  margin-bottom: 20px;
  max-width: 30ch;
}

.fp-adaptive-body {
  font-family: var(--fp-body);
  font-size: 1.02rem;
  line-height: 1.62;
  color: var(--fp-text-on-paper-soft);
  margin-bottom: 28px;
  max-width: 64ch;
}

.fp-adaptive-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--fp-body);
  font-size: 0.94rem;
  font-weight: 500;
  color: var(--fp-accent);
  border-bottom: 1px solid transparent;
  padding-bottom: 3px;
  transition: border-color 0.25s var(--fp-ease), gap 0.25s var(--fp-ease);
}

.fp-adaptive-link:hover {
  border-bottom-color: var(--fp-accent);
  gap: 10px;
}

/* Stack multiple adaptive sections cleanly — only one outer border between them */
.fp-adaptive + .fp-adaptive {
  border-top: 0;
}

@media (max-width: 760px) {
  .fp-adaptive { padding: 60px 0; }
}

/* ============================================
   NAV ACTIVE STATE — current archetype is marked in the nav
   (Replaces the previous audience-router strip — see commit history)
   ============================================ */
.desktop-nav a[aria-current="page"] {
  color: var(--fp-ink);
  font-weight: 600;
  border-bottom: 1px solid var(--fp-accent);
  padding-bottom: 3px;
}

.nav-links a[aria-current="page"] {
  color: var(--fp-ink);
  font-weight: 600;
}

/* ============================================
   LANDING HERO — text-only hero for archetype pages
   ============================================ */
.fp-landing-page {
  /* Same base as case study pages — paper background, generous top padding */
}

.fp-landing-hero {
  position: relative;
  padding: 180px 0 80px;
  background: var(--fp-paper);
  border-bottom: 1px solid var(--fp-border-on-paper);
  overflow: hidden;
}

.fp-landing-hero-inner {
  position: relative;
  z-index: 1;
}

.fp-landing-hero .fp-article-back {
  margin-bottom: 32px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--fp-body);
  font-size: 0.82rem;
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--fp-text-on-paper-muted);
  transition: color 0.25s var(--fp-ease);
}

.fp-landing-hero .fp-article-back:hover {
  color: var(--fp-ink);
}

.fp-landing-hero-headline {
  font-family: var(--fp-display);
  font-weight: 500;
  font-size: clamp(2.2rem, 5.8vw, 4.4rem);
  line-height: 1.04;
  letter-spacing: -0.03em;
  max-width: 22ch;
  margin-bottom: 28px;
  color: var(--fp-ink);
}

.fp-landing-hero-sub {
  font-family: var(--fp-body);
  font-size: clamp(1.04rem, 1.45vw, 1.18rem);
  line-height: 1.6;
  color: var(--fp-text-on-paper-soft);
  max-width: 62ch;
  margin-bottom: 40px;
}

.fp-landing-anchor {
  font-family: var(--fp-serif);
  font-style: italic;
  font-weight: 400;
  font-size: 0.92rem;
  letter-spacing: 0.01em;
  color: var(--fp-text-on-paper-muted);
  margin: -16px 0 32px;
  max-width: 50ch;
}

@media (max-width: 1100px) { .fp-landing-hero { padding: 150px 0 60px; } }
@media (max-width: 700px) { .fp-landing-hero { padding: 120px 0 48px; } }

/* ============================================
   ARCHITECTURE — what we actually build (light)
   ============================================ */
.fp-architecture-section { position: relative; }

.fp-architecture-grid {
  margin-top: 72px;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--fp-border-on-paper-strong);
  border: 1px solid var(--fp-border-on-paper-strong);
  border-radius: var(--fp-radius-lg);
  overflow: hidden;
}

.fp-arch-primitive {
  background: var(--fp-paper);
  padding: 36px 32px 32px;
  display: flex;
  flex-direction: column;
  transition: background 0.4s var(--fp-ease);
  position: relative;
}

.fp-arch-primitive:hover {
  background: linear-gradient(180deg, var(--fp-paper) 0%, var(--fp-paper-2) 100%);
}

.fp-arch-num {
  font-family: var(--fp-display);
  font-size: 0.78rem;
  font-weight: 500;
  letter-spacing: 0.06em;
  color: var(--fp-text-on-paper-muted);
  display: inline-block;
  margin-bottom: 14px;
  padding: 4px 10px;
  border: 1px solid var(--fp-border-on-paper-strong);
  border-radius: 4px;
  background: var(--fp-paper);
  align-self: flex-start;
}

/* Architecture primitive icon — sits between number and title */
.fp-arch-icon {
  width: 48px;
  height: 48px;
  color: var(--fp-accent);
  margin-bottom: 16px;
  opacity: 0;
  transform: translateY(6px) scale(0.92);
  transition: opacity 0.7s var(--fp-ease-out), transform 0.7s var(--fp-ease-out);
}
.fp-arch-icon svg { width: 100%; height: 100%; display: block; }
.fp-arch-primitive.fp-revealed .fp-arch-icon { opacity: 1; transform: translateY(0) scale(1); }
@media (prefers-reduced-motion: reduce) {
  .fp-arch-icon { opacity: 1; transform: none; transition: none; }
}

/* Composite Architecture overview diagram */
.fp-arch-overview {
  margin-top: 88px;
  padding-top: 64px;
  border-top: 1px solid var(--fp-border-on-paper);
  text-align: center;
}

.fp-arch-overview-eyebrow {
  font-family: var(--fp-body);
  font-size: 0.74rem;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--fp-text-on-paper-muted);
  margin-bottom: 14px;
}

.fp-arch-overview-title {
  font-family: var(--fp-display);
  font-weight: 500;
  font-size: clamp(1.4rem, 2.6vw, 1.85rem);
  letter-spacing: -0.022em;
  color: var(--fp-ink);
  margin-bottom: 40px;
  max-width: 32ch;
  margin-left: auto;
  margin-right: auto;
}

.fp-arch-overview-svg-wrap {
  max-width: 720px;
  margin: 0 auto;
}

.fp-arch-overview-svg-wrap svg {
  width: 100%;
  height: auto;
  display: block;
}

@media (max-width: 760px) {
  .fp-arch-overview { margin-top: 64px; padding-top: 48px; }
}

.fp-arch-title {
  font-family: var(--fp-display);
  font-weight: 500;
  font-size: 1.32rem;
  letter-spacing: -0.022em;
  line-height: 1.22;
  color: var(--fp-ink);
  margin-bottom: 14px;
}

.fp-arch-body {
  font-family: var(--fp-body);
  font-size: 0.96rem;
  line-height: 1.6;
  color: var(--fp-text-on-paper-soft);
}

@media (max-width: 980px) and (min-width: 761px) {
  .fp-architecture-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 760px) {
  .fp-architecture-grid {
    display: flex;
    grid-template-columns: none;
    gap: 14px;
    overflow-x: auto;
    overflow-y: visible;
    scroll-snap-type: x mandatory;
    scroll-padding-left: var(--fp-page-gutter);
    scroll-padding-right: var(--fp-page-gutter);
    margin: 48px calc(var(--fp-page-gutter) * -1) 0;
    padding: 8px var(--fp-page-gutter) 32px;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    scroll-behavior: smooth;
    background: transparent;
    border: 0;
    border-radius: 0;
  }
  .fp-architecture-grid::-webkit-scrollbar { display: none; }
  .fp-arch-primitive {
    flex: 0 0 80%;
    max-width: 340px;
    scroll-snap-align: start;
    border: 1px solid var(--fp-border-on-paper);
    border-radius: var(--fp-radius-lg);
    padding: 28px 24px 26px;
  }
  .fp-arch-primitive:last-child {
    scroll-snap-align: end;
    margin-right: var(--fp-page-gutter);
  }
}

/* ============================================
   WHAT WE BUILD — concrete product types (dark)
   ============================================ */
.fp-build { position: relative; }

.fp-build-grid {
  margin-top: 72px;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--fp-border-on-ink-strong);
  border: 1px solid var(--fp-border-on-ink-strong);
  border-radius: var(--fp-radius-lg);
  overflow: hidden;
  position: relative;
  z-index: 1;
}

.fp-build-item {
  background: var(--fp-ink);
  padding: 36px 32px 32px;
  display: flex;
  flex-direction: column;
  transition: background 0.4s var(--fp-ease);
  position: relative;
}

.fp-build-item:hover {
  background: linear-gradient(180deg, var(--fp-ink) 0%, var(--fp-ink-2) 100%);
}

.fp-build-num {
  font-family: var(--fp-display);
  font-size: 0.78rem;
  font-weight: 500;
  letter-spacing: 0.06em;
  color: var(--fp-text-on-ink-muted);
  display: inline-block;
  margin-bottom: 20px;
  padding: 4px 10px;
  border: 1px solid var(--fp-border-on-ink-strong);
  border-radius: 4px;
  background: transparent;
  align-self: flex-start;
}

.fp-build-title {
  font-family: var(--fp-display);
  font-weight: 500;
  font-size: 1.32rem;
  letter-spacing: -0.022em;
  line-height: 1.22;
  color: var(--fp-text-on-ink);
  margin-bottom: 14px;
}

.fp-build-body {
  font-family: var(--fp-body);
  font-size: 0.96rem;
  line-height: 1.6;
  color: var(--fp-text-on-ink-soft);
}

@media (max-width: 980px) and (min-width: 761px) {
  .fp-build-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 760px) {
  .fp-build-grid {
    display: flex;
    grid-template-columns: none;
    gap: 14px;
    overflow-x: auto;
    overflow-y: visible;
    scroll-snap-type: x mandatory;
    scroll-padding-left: var(--fp-page-gutter);
    scroll-padding-right: var(--fp-page-gutter);
    margin: 48px calc(var(--fp-page-gutter) * -1) 0;
    padding: 8px var(--fp-page-gutter) 32px;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    scroll-behavior: smooth;
    background: transparent;
    border: 0;
    border-radius: 0;
  }
  .fp-build-grid::-webkit-scrollbar { display: none; }
  .fp-build-item {
    flex: 0 0 80%;
    max-width: 340px;
    scroll-snap-align: start;
    border: 1px solid var(--fp-border-on-ink);
    border-radius: var(--fp-radius-lg);
    padding: 28px 24px 26px;
  }
  .fp-build-item:last-child {
    scroll-snap-align: end;
    margin-right: var(--fp-page-gutter);
  }
}

/* ============================================
   CRAFT SURFACE — Leadership 11.4 flowing line
   ============================================ */
.fp-craft-surface {
  margin-top: 96px;
  padding-top: 56px;
  border-top: 1px solid var(--fp-border-on-paper);
}

.fp-craft-surface > .fp-section-eyebrow {
  margin-bottom: 28px;
}

.fp-craft-intro {
  font-family: var(--fp-body);
  font-size: 1.02rem;
  line-height: 1.6;
  color: var(--fp-text-on-paper-soft);
  max-width: 56ch;
  margin-bottom: 28px;
}

.fp-craft-line {
  font-family: var(--fp-serif);
  font-weight: 400;
  font-size: clamp(1.18rem, 1.95vw, 1.5rem);
  line-height: 1.5;
  letter-spacing: -0.008em;
  color: var(--fp-ink);
  max-width: 72ch;
  margin-bottom: 24px;
}

.fp-craft-dot {
  display: inline-block;
  color: var(--fp-gold);
  opacity: 0.7;
  margin: 0 2px;
}

.fp-craft-coda {
  font-family: var(--fp-serif);
  font-weight: 400;
  font-style: italic;
  font-size: 0.96rem;
  line-height: 1.55;
  color: var(--fp-text-on-paper-muted);
  max-width: 56ch;
}

@media (max-width: 760px) {
  .fp-craft-surface { margin-top: 72px; padding-top: 44px; }
  .fp-craft-line { font-size: 1.12rem; }
}

/* ============================================
   CAPABILITIES
   ============================================ */
.fp-cap-head { margin-bottom: 72px; }

.fp-cap-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--fp-border-on-paper-strong);
  border: 1px solid var(--fp-border-on-paper-strong);
  border-radius: var(--fp-radius-xl);
  overflow: hidden;
  box-shadow: var(--fp-shadow-lg);
}

.fp-cap-tile {
  background: var(--fp-paper);
  padding: 40px 36px 44px;
  transition: background 0.4s var(--fp-ease);
  position: relative;
  overflow: hidden;
}

.fp-cap-tile::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 0% 0%, var(--fp-accent-soft) 0%, transparent 50%);
  opacity: 0;
  transition: opacity 0.4s var(--fp-ease);
  pointer-events: none;
}

.fp-cap-tile:hover::before { opacity: 1; }

.fp-cap-glyph {
  width: 48px;
  height: 48px;
  border-radius: 12px;
  background: var(--fp-paper-2);
  border: 1px solid var(--fp-border-on-paper);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 24px;
  color: var(--fp-accent);
  transition: background 0.3s var(--fp-ease), color 0.3s var(--fp-ease), border-color 0.3s var(--fp-ease);
  position: relative;
  z-index: 1;
}

.fp-cap-glyph svg { width: 26px; height: 26px; }

.fp-cap-tile:hover .fp-cap-glyph {
  background: var(--fp-accent);
  border-color: var(--fp-accent);
  color: var(--fp-paper);
}

.fp-cap-title {
  font-family: var(--fp-display);
  font-weight: 500;
  font-size: 1.2rem;
  letter-spacing: -0.015em;
  margin-bottom: 14px;
  color: var(--fp-ink);
  position: relative;
  z-index: 1;
}

.fp-cap-body {
  font-family: var(--fp-body);
  font-size: 0.97rem;
  line-height: 1.58;
  color: var(--fp-text-on-paper-soft);
  position: relative;
  z-index: 1;
}

@media (max-width: 900px) {
  .fp-cap-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 560px) {
  .fp-cap-grid { grid-template-columns: 1fr; border-radius: var(--fp-radius-lg); }
  .fp-cap-tile { padding: 32px 28px 36px; }
}

/* ============================================
   OFFERS
   ============================================ */
.fp-offers-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}

.fp-offer-card {
  background: var(--fp-paper);
  border: 1px solid var(--fp-border-on-paper);
  border-radius: var(--fp-radius-xl);
  padding: 40px 36px 36px;
  display: flex;
  flex-direction: column;
  position: relative;
  overflow: hidden;
  transition: border-color 0.4s var(--fp-ease), transform 0.4s var(--fp-ease), box-shadow 0.4s var(--fp-ease), background 0.4s var(--fp-ease);
  box-shadow: var(--fp-shadow-sm);
}

.fp-offer-card::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 0% 0%, var(--fp-accent-soft) 0%, transparent 55%);
  opacity: 0;
  transition: opacity 0.5s var(--fp-ease);
  pointer-events: none;
}

.fp-offer-card:hover {
  border-color: var(--fp-border-on-paper-strong);
  transform: translateY(-4px);
  box-shadow: var(--fp-shadow-lg);
}

.fp-offer-card:hover::before { opacity: 1; }

.fp-offer-card-featured {
  background:
    linear-gradient(180deg, var(--fp-paper-2) 0%, var(--fp-paper) 100%);
  border-color: var(--fp-border-on-paper-strong);
  position: relative;
}

.fp-offer-card-featured::after {
  content: 'Most engaged';
  position: absolute;
  top: 18px;
  right: 22px;
  font-family: var(--fp-body);
  font-size: 0.7rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--fp-accent);
  padding: 5px 10px;
  background: rgba(31, 77, 74, 0.08);
  border-radius: 999px;
  z-index: 1;
}

.fp-offer-meta {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 24px;
  position: relative;
  z-index: 1;
}

.fp-offer-num {
  font-family: var(--fp-display);
  font-size: 0.78rem;
  font-weight: 500;
  letter-spacing: 0.06em;
  color: var(--fp-text-on-paper-muted);
  padding: 5px 10px;
  border: 1px solid var(--fp-border-on-paper-strong);
  border-radius: 4px;
  background: var(--fp-paper);
}

.fp-offer-duration {
  font-family: var(--fp-body);
  font-size: 0.78rem;
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--fp-accent);
  padding: 5px 12px;
  background: rgba(31, 77, 74, 0.08);
  border-radius: 999px;
}

.fp-offer-name {
  font-family: var(--fp-display);
  font-weight: 500;
  font-size: clamp(1.32rem, 1.9vw, 1.55rem);
  letter-spacing: -0.02em;
  line-height: 1.18;
  color: var(--fp-ink);
  margin-bottom: 18px;
  position: relative;
  z-index: 1;
}

.fp-offer-body {
  font-family: var(--fp-body);
  font-size: 0.98rem;
  line-height: 1.6;
  color: var(--fp-text-on-paper-soft);
  margin-bottom: 24px;
  position: relative;
  z-index: 1;
}

.fp-offer-deliverables {
  list-style: none;
  padding: 0;
  margin: 0 0 28px;
  border-top: 1px solid var(--fp-border-on-paper);
  position: relative;
  z-index: 1;
  flex-grow: 1;
}

.fp-offer-deliverables li {
  font-family: var(--fp-body);
  font-size: 0.92rem;
  line-height: 1.55;
  color: var(--fp-text-on-paper);
  padding: 14px 0 14px 22px;
  border-bottom: 1px solid var(--fp-border-on-paper);
  position: relative;
}

.fp-offer-deliverables li::before {
  content: '';
  position: absolute;
  left: 0;
  top: calc(14px + 0.6em);
  width: 10px;
  height: 1px;
  background: var(--fp-accent);
}

.fp-offer-link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--fp-body);
  font-size: 0.94rem;
  font-weight: 500;
  color: var(--fp-accent);
  align-self: flex-start;
  position: relative;
  z-index: 1;
  transition: color 0.25s var(--fp-ease);
}

.fp-offer-link svg {
  transition: transform 0.3s var(--fp-ease);
}

.fp-offer-card:hover .fp-offer-link svg {
  transform: translateX(3px);
}

@media (max-width: 1100px) and (min-width: 761px) {
  .fp-offers-grid { grid-template-columns: 1fr; gap: 20px; max-width: 720px; margin-left: auto; margin-right: auto; }
  .fp-offer-card { padding: 32px 28px 32px; }
}

/* Mobile snap-carousel — Apple-style horizontal scroll */
@media (max-width: 760px) {
  .fp-offers-grid {
    display: flex;
    grid-template-columns: none;
    gap: 14px;
    overflow-x: auto;
    overflow-y: visible;
    scroll-snap-type: x mandatory;
    scroll-padding-left: var(--fp-page-gutter);
    scroll-padding-right: var(--fp-page-gutter);
    margin: 0 calc(var(--fp-page-gutter) * -1);
    padding: 8px var(--fp-page-gutter) 32px;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    scroll-behavior: smooth;
  }
  .fp-offers-grid::-webkit-scrollbar { display: none; }
  .fp-offer-card {
    flex: 0 0 86%;
    max-width: 380px;
    scroll-snap-align: start;
    padding: 30px 26px 28px;
  }
  .fp-offer-card:last-child {
    scroll-snap-align: end;
    margin-right: var(--fp-page-gutter);
  }
}

/* ============================================
   PHILOSOPHY
   ============================================ */
.fp-philosophy {
  padding: 200px 0;
  overflow: hidden;
}

@media (max-width: 900px) { .fp-philosophy { padding: 140px 0; } }

.fp-philosophy-bg {
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.fp-philosophy-glow {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 800px;
  height: 800px;
  transform: translate(-50%, -50%);
  background: radial-gradient(circle, rgba(31, 77, 74, 0.45) 0%, rgba(184, 155, 90, 0.12) 30%, transparent 65%);
  border-radius: 50%;
  filter: blur(40px);
  animation: fp-philo-glow 12s ease-in-out infinite alternate;
}

@keyframes fp-philo-glow {
  0% { transform: translate(-50%, -50%) scale(1); opacity: 0.6; }
  100% { transform: translate(-45%, -55%) scale(1.15); opacity: 0.8; }
}

.fp-philosophy-inner {
  text-align: center;
  position: relative;
  z-index: 2;
}

.fp-philosophy .fp-section-eyebrow { justify-content: center; }

.fp-philosophy-headline {
  font-family: var(--fp-serif);
  font-weight: 400;
  font-size: clamp(2.2rem, 5vw, 3.6rem);
  line-height: 1.16;
  letter-spacing: -0.018em;
  color: var(--fp-text-on-ink);
  margin: 0 auto 40px;
  max-width: 22ch;
}

.fp-philosophy-body {
  font-family: var(--fp-serif);
  font-weight: 300;
  font-size: clamp(1.18rem, 1.6vw, 1.36rem);
  line-height: 1.7;
  color: var(--fp-text-on-ink-soft);
  max-width: 56ch;
  margin: 0 auto;
}

.fp-philosophy-body-spaced {
  margin-top: 64px;
}

/* Contrast lockup */
.fp-thesis-contrast {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  margin: 80px auto 0;
  max-width: 760px;
  text-align: left;
  border-top: 1px solid var(--fp-border-on-ink);
  border-bottom: 1px solid var(--fp-border-on-ink);
}

.fp-thesis-col {
  padding: 32px 32px 36px;
}

.fp-thesis-col + .fp-thesis-col {
  border-left: 1px solid var(--fp-border-on-ink);
}

.fp-thesis-col-label {
  font-family: var(--fp-body);
  font-size: 0.78rem;
  font-weight: 500;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--fp-text-on-ink-muted);
  margin-bottom: 22px;
  line-height: 1.45;
}

.fp-thesis-col-accent .fp-thesis-col-label {
  color: var(--fp-accent-on-ink);
}

.fp-thesis-list {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.fp-thesis-list li {
  font-family: var(--fp-display);
  font-weight: 500;
  font-size: 1.04rem;
  letter-spacing: -0.01em;
  color: var(--fp-text-on-ink);
}

.fp-thesis-col:not(.fp-thesis-col-accent) .fp-thesis-list li {
  color: var(--fp-text-on-ink-soft);
}

.fp-thesis-col-accent .fp-thesis-list li {
  position: relative;
  padding-left: 16px;
}

.fp-thesis-col-accent .fp-thesis-list li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0.6em;
  width: 6px;
  height: 1px;
  background: var(--fp-accent-on-ink);
}

/* Light-context overrides — when thesis-contrast appears inside a fp-section-light */
.fp-section-light .fp-thesis-contrast {
  border-top-color: var(--fp-border-on-paper-strong);
  border-bottom-color: var(--fp-border-on-paper-strong);
}
.fp-section-light .fp-thesis-col + .fp-thesis-col {
  border-left-color: var(--fp-border-on-paper);
}
.fp-section-light .fp-thesis-col-label {
  color: var(--fp-text-on-paper-muted);
}
.fp-section-light .fp-thesis-list li {
  color: var(--fp-text-on-paper);
}
.fp-section-light .fp-thesis-col:not(.fp-thesis-col-accent) .fp-thesis-list li {
  color: var(--fp-text-on-paper-soft);
}

@media (max-width: 700px) {
  .fp-thesis-contrast {
    grid-template-columns: 1fr;
    margin-top: 40px;
  }
  .fp-thesis-col {
    padding: 24px 0;
  }
  .fp-thesis-col + .fp-thesis-col {
    border-left: none;
    border-top: 1px solid var(--fp-border-on-ink);
    padding-left: 0;
  }
}

/* Pull-quote callout */
.fp-thesis-callout {
  margin: 96px auto 0;
  max-width: 720px;
  text-align: center;
  padding-top: 36px;
  position: relative;
}

.fp-thesis-callout-rule {
  display: block;
  width: 60px;
  height: 1px;
  background: var(--fp-gold);
  opacity: 0.5;
  margin: 0 auto 36px;
}

.fp-thesis-callout blockquote {
  font-family: var(--fp-serif);
  font-weight: 400;
  font-style: italic;
  font-size: clamp(1.5rem, 3vw, 2.1rem);
  line-height: 1.32;
  letter-spacing: -0.015em;
  color: var(--fp-text-on-ink);
}

.fp-thesis-callout-emphasis {
  display: block;
  margin-top: 12px;
  font-style: normal;
  font-family: var(--fp-display);
  font-weight: 500;
  letter-spacing: -0.022em;
  background: linear-gradient(135deg, #A8C7C4 0%, #B89B5A 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
}

/* Friction lockup */
.fp-thesis-friction {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  margin: 56px auto 0;
  max-width: 760px;
  background: var(--fp-border-on-ink);
  border: 1px solid var(--fp-border-on-ink);
  border-radius: var(--fp-radius-md);
  overflow: hidden;
}

.fp-thesis-friction li {
  background: var(--fp-ink);
  padding: 22px 20px;
  text-align: center;
  font-family: var(--fp-body);
  font-size: 0.92rem;
  font-weight: 500;
  letter-spacing: 0.005em;
  color: var(--fp-text-on-ink-soft);
  transition: background 0.3s var(--fp-ease), color 0.3s var(--fp-ease);
}

.fp-thesis-friction li:hover {
  background: var(--fp-ink-2);
  color: var(--fp-text-on-ink);
}

@media (max-width: 700px) {
  .fp-thesis-friction {
    grid-template-columns: 1fr 1fr;
    margin-top: 40px;
  }
  .fp-thesis-friction li {
    padding: 18px 14px;
    font-size: 0.85rem;
  }
}

/* Final closing line */
.fp-thesis-final {
  font-family: var(--fp-serif);
  font-weight: 400;
  font-size: clamp(1.32rem, 2.2vw, 1.7rem);
  line-height: 1.4;
  letter-spacing: -0.012em;
  color: var(--fp-text-on-ink);
  max-width: 60ch;
  margin: 96px auto 0;
}

/* ============================================
   SELECTED WORK
   ============================================ */
.fp-work-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 28px;
}

.fp-work-card {
  background: var(--fp-paper);
  border: 1px solid var(--fp-border-on-paper);
  border-radius: var(--fp-radius-xl);
  padding: 40px 36px 36px;
  transition: border-color 0.4s var(--fp-ease), transform 0.4s var(--fp-ease), box-shadow 0.4s var(--fp-ease);
  position: relative;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  box-shadow: var(--fp-shadow-sm);
}

.fp-work-card::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 100% 0%, var(--fp-accent-soft) 0%, transparent 55%);
  opacity: 0;
  transition: opacity 0.5s var(--fp-ease);
  pointer-events: none;
}

.fp-work-card:hover {
  border-color: var(--fp-border-on-paper-strong);
  transform: translateY(-4px);
  box-shadow: var(--fp-shadow-lg);
}

.fp-work-card:hover::before { opacity: 1; }

.fp-work-card-featured {
  background: linear-gradient(135deg, var(--fp-paper) 0%, var(--fp-paper-2) 100%);
}

/* ============================================
   DEVICE-FRAME MOCKUPS — phone-shaped screenshot containers
   Used on Selected Work cards + case study pages.
   ============================================ */
.fp-work-mockup {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  gap: 14px;
  margin: -8px -8px 32px;
  height: 320px;
  perspective: 1200px;
}

.fp-device {
  position: relative;
  background: #0F2826;
  border-radius: 28px;
  padding: 6px;
  box-shadow:
    0 30px 60px -20px rgba(7, 8, 10, 0.4),
    0 14px 28px -10px rgba(7, 8, 10, 0.22),
    inset 0 0 0 1px rgba(255, 255, 255, 0.06);
  transform-origin: center bottom;
  transition: transform 0.6s var(--fp-ease-out), box-shadow 0.5s var(--fp-ease);
}

.fp-device-phone {
  width: 148px;
  aspect-ratio: 828 / 1792;
}

/* The back device is slightly smaller + rotated, sits behind */
.fp-device-back {
  width: 134px;
  transform: translate(-50%, 8%) rotate(-6deg);
  position: absolute;
  left: 50%;
  bottom: 0;
  z-index: 0;
  opacity: 0.92;
  filter: saturate(0.92);
}

.fp-device:not(.fp-device-back) {
  z-index: 1;
  transform: translateY(0);
}

.fp-work-card:hover .fp-device:not(.fp-device-back) {
  transform: translateY(-4px) rotate(0.5deg);
}
.fp-work-card:hover .fp-device-back {
  transform: translate(-50%, 6%) rotate(-9deg);
}

.fp-device-screen {
  width: 100%;
  height: 100%;
  display: block;
  border-radius: 22px;
  object-fit: cover;
}

@media (max-width: 760px) {
  .fp-work-mockup { height: 280px; gap: 10px; margin-bottom: 24px; }
  .fp-device-phone { width: 128px; }
  .fp-device-back { width: 116px; }
}

@media (prefers-reduced-motion: reduce) {
  .fp-device { transition: none; }
}

/* Case study gallery — horizontal row of 4 device frames */
.fp-case-gallery {
  padding: 32px 0 80px;
  background: var(--fp-paper);
}

.fp-case-gallery-row {
  display: flex;
  align-items: flex-end;
  justify-content: center;
  gap: 24px;
  flex-wrap: wrap;
  perspective: 1400px;
}

.fp-case-device {
  width: 200px;
  flex-shrink: 0;
  transition: transform 0.6s var(--fp-ease-out);
}

.fp-case-device:hover {
  transform: translateY(-6px);
}

/* Subtle alternating tilt to feel editorial, not catalog-y */
.fp-case-device-1 { transform: rotate(-3deg); }
.fp-case-device-2 { transform: rotate(2deg) translateY(-10px); }
.fp-case-device-3 { transform: rotate(-2deg) translateY(6px); }
.fp-case-device-4 { transform: rotate(3deg); }

.fp-case-device-1:hover { transform: rotate(-3deg) translateY(-6px); }
.fp-case-device-2:hover { transform: rotate(2deg) translateY(-16px); }
.fp-case-device-3:hover { transform: rotate(-2deg) translateY(0); }
.fp-case-device-4:hover { transform: rotate(3deg) translateY(-6px); }

@media (max-width: 900px) {
  .fp-case-gallery { padding: 24px 0 56px; }
  .fp-case-gallery-row { gap: 14px; }
  .fp-case-device { width: 160px; }
  .fp-case-device-1, .fp-case-device-2,
  .fp-case-device-3, .fp-case-device-4 { transform: none; }
}

@media (max-width: 600px) {
  .fp-case-gallery-row { gap: 10px; flex-wrap: nowrap; overflow-x: auto; padding: 16px var(--fp-page-gutter); scroll-snap-type: x mandatory; }
  .fp-case-gallery .container { padding: 0; }
  .fp-case-device { width: 200px; scroll-snap-align: center; }
}

.fp-work-header { position: relative; z-index: 1; }

.fp-work-meta {
  display: flex;
  align-items: center;
  gap: 18px;
  margin-bottom: 28px;
  font-family: var(--fp-body);
  font-size: 0.82rem;
  color: var(--fp-text-on-paper-muted);
  flex-wrap: wrap;
}

.fp-work-status {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-weight: 500;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  font-size: 0.72rem;
  padding: 5px 10px;
  border-radius: 999px;
  background: rgba(7, 8, 10, 0.04);
}

.fp-work-status-live { color: var(--fp-accent); background: rgba(31, 77, 74, 0.08); }
.fp-work-status-dev { color: var(--fp-text-on-paper-soft); background: rgba(7, 8, 10, 0.05); }

.fp-dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: currentColor;
  position: relative;
}

.fp-work-status-live .fp-dot::after {
  content: '';
  position: absolute;
  inset: -3px;
  border-radius: 50%;
  background: currentColor;
  opacity: 0.3;
  animation: fp-pulse-dot 2.4s ease-in-out infinite;
}

.fp-work-rating {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-weight: 500;
  color: var(--fp-text-on-paper);
}

.fp-rating-stars {
  color: var(--fp-gold);
  letter-spacing: 0.05em;
  font-size: 0.9rem;
}

.fp-work-title {
  font-family: var(--fp-display);
  font-weight: 500;
  font-size: 1.85rem;
  letter-spacing: -0.022em;
  margin-bottom: 8px;
  color: var(--fp-ink);
}

.fp-work-frame {
  font-family: var(--fp-body);
  font-size: 0.86rem;
  font-weight: 500;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--fp-accent);
  margin-bottom: 20px;
}

.fp-work-body {
  font-family: var(--fp-body);
  font-size: 0.99rem;
  line-height: 1.62;
  color: var(--fp-text-on-paper-soft);
  position: relative;
  z-index: 1;
  flex-grow: 1;
}

.fp-work-cta {
  display: flex;
  flex-direction: column;
  gap: 18px;
  margin-top: 28px;
  position: relative;
  z-index: 1;
}

.fp-work-link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--fp-body);
  font-size: 0.94rem;
  font-weight: 500;
  color: var(--fp-accent);
  text-decoration: none;
  align-self: flex-start;
  padding-bottom: 4px;
  border-bottom: 1px solid transparent;
  transition: border-color 0.25s var(--fp-ease);
}

.fp-work-link:hover {
  border-bottom-color: var(--fp-accent);
}

.fp-work-link svg {
  transition: transform 0.25s var(--fp-ease);
}

.fp-work-link:hover svg {
  transform: translateX(3px);
}

.fp-work-stores {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}

.fp-store-link {
  display: inline-block;
  transition: transform 0.3s var(--fp-ease);
}

.fp-store-link:hover { transform: translateY(-2px); }

.fp-store-badge {
  height: 42px;
  width: auto;
  border-radius: 6px;
}

@media (max-width: 800px) and (min-width: 761px) {
  .fp-work-grid { grid-template-columns: 1fr; }
  .fp-work-card { padding: 32px 28px; }
  .fp-work-title { font-size: 1.5rem; }
}

/* Mobile snap-carousel for Selected Work */
@media (max-width: 760px) {
  .fp-work-grid {
    display: flex;
    grid-template-columns: none;
    gap: 14px;
    overflow-x: auto;
    overflow-y: visible;
    scroll-snap-type: x mandatory;
    scroll-padding-left: var(--fp-page-gutter);
    scroll-padding-right: var(--fp-page-gutter);
    margin: 0 calc(var(--fp-page-gutter) * -1);
    padding: 8px var(--fp-page-gutter) 32px;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    scroll-behavior: smooth;
  }
  .fp-work-grid::-webkit-scrollbar { display: none; }
  .fp-work-card {
    flex: 0 0 88%;
    max-width: 400px;
    scroll-snap-align: start;
    padding: 30px 26px 28px;
  }
  .fp-work-card:last-child {
    scroll-snap-align: end;
    margin-right: var(--fp-page-gutter);
  }
  .fp-work-title { font-size: 1.5rem; }
}

/* ============================================
   PARTNER VOICES
   ============================================ */
.fp-pullquote {
  margin: 56px 0;
  max-width: 64ch;
  position: relative;
  padding-left: 60px;
}

.fp-pullquote:first-of-type { margin-top: 48px; }

.fp-quote-mark {
  position: absolute;
  left: -8px;
  top: -28px;
  font-family: var(--fp-serif);
  font-size: 6rem;
  line-height: 1;
  color: var(--fp-accent-on-ink);
  opacity: 0.35;
  font-weight: 400;
}

.fp-pullquote blockquote {
  font-family: var(--fp-serif);
  font-weight: 300;
  font-size: clamp(1.35rem, 2.4vw, 1.78rem);
  line-height: 1.4;
  letter-spacing: -0.01em;
  color: var(--fp-text-on-ink);
  margin-bottom: 24px;
  font-style: italic;
}

.fp-pullquote figcaption {
  font-family: var(--fp-body);
  font-size: 0.92rem;
  color: var(--fp-text-on-ink-muted);
  display: flex;
  flex-wrap: wrap;
  gap: 4px 16px;
}

.fp-pullquote-name {
  color: var(--fp-text-on-ink);
  font-weight: 500;
}

.fp-videos {
  margin-top: 88px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 32px;
}

.fp-video-frame {
  position: relative;
  width: 100%;
  padding-top: 56.25%;
  border-radius: var(--fp-radius-lg);
  overflow: hidden;
  background: var(--fp-ink-2);
  border: 1px solid var(--fp-border-on-ink-strong);
  box-shadow: var(--fp-shadow-xl);
}

.fp-video-frame iframe {
  position: absolute;
  inset: 0;
  width: 100%; height: 100%;
  border: 0;
}

.fp-video-poster {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  padding: 0;
  margin: 0;
  border: 0;
  background: var(--fp-ink-2);
  cursor: pointer;
  overflow: hidden;
}

.fp-video-thumb {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.6s var(--fp-ease-out), filter 0.4s var(--fp-ease);
  filter: brightness(0.92) saturate(1.05);
}

.fp-video-poster:hover .fp-video-thumb {
  transform: scale(1.04);
  filter: brightness(0.82) saturate(1.05);
}

.fp-video-play {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 76px;
  height: 76px;
  display: flex;
  align-items: center;
  justify-content: center;
  pointer-events: none;
  filter: drop-shadow(0 8px 24px rgba(7, 8, 10, 0.5));
  transition: transform 0.35s var(--fp-ease-out);
}

.fp-video-play svg {
  width: 100%;
  height: 100%;
  display: block;
}

.fp-video-poster:hover .fp-video-play {
  transform: translate(-50%, -50%) scale(1.08);
}

.fp-video-poster:focus-visible {
  outline: none;
}

.fp-video-poster:focus-visible .fp-video-play {
  transform: translate(-50%, -50%) scale(1.08);
  filter: drop-shadow(0 0 0 2px var(--fp-accent-on-ink)) drop-shadow(0 8px 24px rgba(7, 8, 10, 0.5));
}

.fp-video-close {
  position: absolute;
  top: 14px;
  right: 14px;
  width: 38px;
  height: 38px;
  padding: 0;
  border: 1px solid rgba(251, 250, 246, 0.18);
  border-radius: 50%;
  background: rgba(7, 8, 10, 0.65);
  backdrop-filter: blur(12px) saturate(140%);
  -webkit-backdrop-filter: blur(12px) saturate(140%);
  color: var(--fp-paper);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 2;
  transition: background 0.25s var(--fp-ease), transform 0.25s var(--fp-ease), border-color 0.25s var(--fp-ease);
}

.fp-video-close:hover {
  background: rgba(7, 8, 10, 0.92);
  border-color: rgba(251, 250, 246, 0.32);
  transform: scale(1.08);
}

.fp-video-close:focus-visible {
  outline: none;
  border-color: var(--fp-accent-on-ink);
  background: rgba(7, 8, 10, 0.92);
}

.fp-video-close svg {
  width: 14px;
  height: 14px;
  display: block;
}

.fp-video-caption {
  margin: 0 0 18px;
  font-family: var(--fp-body);
  font-size: 0.92rem;
  color: var(--fp-text-on-ink-muted);
  letter-spacing: 0.01em;
}

.fp-video-name { color: var(--fp-text-on-ink); font-weight: 500; }

@media (max-width: 800px) and (min-width: 761px) {
  .fp-videos { grid-template-columns: 1fr; }
}
@media (max-width: 800px) {
  .fp-pullquote { padding-left: 36px; }
  .fp-quote-mark { font-size: 4rem; top: -16px; left: -4px; }
}

/* Mobile snap-carousel for video testimonials */
@media (max-width: 760px) {
  .fp-videos {
    display: flex;
    grid-template-columns: none;
    gap: 14px;
    overflow-x: auto;
    overflow-y: visible;
    scroll-snap-type: x mandatory;
    scroll-padding-left: var(--fp-page-gutter);
    scroll-padding-right: var(--fp-page-gutter);
    margin: 32px calc(var(--fp-page-gutter) * -1) 0;
    padding: 8px var(--fp-page-gutter) 24px;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    scroll-behavior: smooth;
  }
  .fp-videos::-webkit-scrollbar { display: none; }
  .fp-video {
    flex: 0 0 86%;
    max-width: 400px;
    scroll-snap-align: start;
  }
  .fp-video:last-child {
    scroll-snap-align: end;
    margin-right: var(--fp-page-gutter);
  }
}

/* ============================================
   WRITINGS
   ============================================ */
.fp-writings-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 28px;
}

.fp-writings-more {
  display: contents;
}

.fp-writings-more[hidden] {
  display: none;
}

.fp-writing-card {
  background: var(--fp-paper);
  border: 1px solid var(--fp-border-on-paper);
  border-radius: var(--fp-radius-xl);
  padding: 36px 36px 32px;
  display: flex;
  flex-direction: column;
  transition: border-color 0.4s var(--fp-ease), transform 0.4s var(--fp-ease), box-shadow 0.4s var(--fp-ease), background 0.4s var(--fp-ease);
  position: relative;
  overflow: hidden;
  box-shadow: var(--fp-shadow-sm);
  text-decoration: none;
  color: inherit;
}

.fp-writing-card::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 100% 0%, var(--fp-accent-soft) 0%, transparent 55%);
  opacity: 0;
  transition: opacity 0.5s var(--fp-ease);
  pointer-events: none;
}

.fp-writing-card:hover {
  border-color: var(--fp-border-on-paper-strong);
  transform: translateY(-4px);
  box-shadow: var(--fp-shadow-lg);
}

.fp-writing-card:hover::before { opacity: 1; }

.fp-writing-meta {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-bottom: 22px;
  font-family: var(--fp-body);
  font-size: 0.82rem;
  color: var(--fp-text-on-paper-muted);
  position: relative;
  z-index: 1;
}

.fp-writing-tag {
  display: inline-flex;
  align-items: center;
  font-family: var(--fp-body);
  font-weight: 500;
  font-size: 0.72rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--fp-accent);
  padding: 5px 10px;
  border-radius: 999px;
  background: rgba(31, 77, 74, 0.08);
}

.fp-writing-date {
  font-weight: 500;
  letter-spacing: 0.01em;
}

.fp-writing-title {
  font-family: var(--fp-display);
  font-weight: 500;
  font-size: clamp(1.32rem, 1.9vw, 1.6rem);
  line-height: 1.22;
  letter-spacing: -0.02em;
  color: var(--fp-ink);
  margin-bottom: 16px;
  position: relative;
  z-index: 1;
}

.fp-writing-preview {
  font-family: var(--fp-body);
  font-size: 0.98rem;
  line-height: 1.6;
  color: var(--fp-text-on-paper-soft);
  margin-bottom: 24px;
  flex-grow: 1;
  position: relative;
  z-index: 1;
}

.fp-writing-link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--fp-body);
  font-size: 0.92rem;
  font-weight: 500;
  letter-spacing: -0.005em;
  color: var(--fp-accent);
  position: relative;
  z-index: 1;
  align-self: flex-start;
}

.fp-writing-link svg {
  transition: transform 0.3s var(--fp-ease);
}

.fp-writing-card:hover .fp-writing-link svg {
  transform: translateX(3px);
}

.fp-writings-toggle-row {
  display: flex;
  justify-content: center;
  margin-top: 48px;
}

.fp-writings-toggle {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  font-family: var(--fp-body);
  font-size: 0.95rem;
  font-weight: 500;
  letter-spacing: -0.005em;
  padding: 12px 22px;
  border: 1px solid var(--fp-border-on-paper-strong);
  background: var(--fp-paper);
  color: var(--fp-text-on-paper);
  border-radius: 999px;
  cursor: pointer;
  transition: background 0.25s var(--fp-ease), border-color 0.25s var(--fp-ease), transform 0.25s var(--fp-ease);
}

.fp-writings-toggle:hover {
  border-color: var(--fp-ink);
  background: var(--fp-paper-2);
  transform: translateY(-1px);
}

.fp-writings-toggle-count {
  font-size: 0.82rem;
  color: var(--fp-text-on-paper-muted);
  padding-left: 12px;
  border-left: 1px solid var(--fp-border-on-paper-strong);
}

.fp-writings-toggle-icon {
  transition: transform 0.3s var(--fp-ease);
}

.fp-writings-toggle[aria-expanded="true"] .fp-writings-toggle-icon {
  transform: rotate(180deg);
}

@media (max-width: 800px) and (min-width: 761px) {
  .fp-writings-grid { grid-template-columns: 1fr; }
  .fp-writing-card { padding: 28px 24px 24px; }
}

/* Mobile snap-carousel for Writings — show all 8, hide toggle */
@media (max-width: 760px) {
  .fp-writings-grid {
    display: flex;
    grid-template-columns: none;
    gap: 14px;
    overflow-x: auto;
    overflow-y: visible;
    scroll-snap-type: x mandatory;
    scroll-padding-left: var(--fp-page-gutter);
    scroll-padding-right: var(--fp-page-gutter);
    margin: 0 calc(var(--fp-page-gutter) * -1);
    padding: 8px var(--fp-page-gutter) 28px;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    scroll-behavior: smooth;
  }
  .fp-writings-grid::-webkit-scrollbar { display: none; }
  /* display:contents wrapper works inside flex — children become flex items */
  .fp-writings-more { display: contents !important; }
  .fp-writings-more[hidden] { display: contents !important; }
  .fp-writing-card {
    flex: 0 0 84%;
    max-width: 360px;
    scroll-snap-align: start;
    padding: 28px 24px 24px;
  }
  .fp-writing-card:last-child {
    scroll-snap-align: end;
    margin-right: var(--fp-page-gutter);
  }
  /* Hide the toggle row on mobile — carousel reveals all naturally */
  .fp-writings-toggle-row { display: none; }
}

/* ============================================
   LEADERSHIP
   ============================================ */
.fp-leadership-grid {
  display: grid;
  grid-template-columns: 340px 1fr;
  gap: 80px;
  align-items: center;
}

@media (max-width: 900px) {
  .fp-leadership-grid {
    grid-template-columns: 1fr;
    gap: 48px;
  }
}

.fp-leadership-monogram-col {
  display: flex;
  justify-content: center;
}

.fp-monogram {
  position: relative;
  width: 280px;
  height: 280px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.fp-monogram-inner {
  position: relative;
  width: 220px;
  height: 220px;
  border-radius: 50%;
  background:
    radial-gradient(circle at 30% 25%, rgba(255, 255, 255, 0.7) 0%, transparent 40%),
    linear-gradient(140deg, #2A6360 0%, #1F4D4A 50%, #143230 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow:
    0 30px 60px -20px rgba(31, 77, 74, 0.45),
    0 12px 24px -8px rgba(31, 77, 74, 0.2),
    inset 0 2px 4px rgba(255, 255, 255, 0.12);
  z-index: 3;
}

.fp-monogram-letters {
  font-family: var(--fp-serif);
  font-weight: 400;
  font-size: 5.4rem;
  color: var(--fp-paper);
  letter-spacing: -0.04em;
  line-height: 1;
}

.fp-monogram-portrait .fp-monogram-inner {
  overflow: hidden;
  background:
    linear-gradient(140deg, #2A6360 0%, #1F4D4A 50%, #143230 100%);
  padding: 0;
  position: relative;
}

.fp-monogram-portrait .fp-monogram-inner::after {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 50% 100%, rgba(31, 77, 74, 0.35) 0%, transparent 55%),
    linear-gradient(160deg, transparent 0%, transparent 55%, rgba(31, 77, 74, 0.25) 100%);
  pointer-events: none;
  mix-blend-mode: multiply;
}

.fp-portrait-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: 50% 30%;
  display: block;
  filter: saturate(0.55) contrast(1.05) brightness(0.98) hue-rotate(-8deg) sepia(0.08);
}

.fp-monogram-ring {
  position: absolute;
  border-radius: 50%;
  border: 1px solid var(--fp-border-on-paper-strong);
  pointer-events: none;
}

.fp-monogram-ring-1 {
  inset: -20px;
  z-index: 2;
  animation: fp-monogram-rotate 32s linear infinite;
}

.fp-monogram-ring-1::after {
  content: '';
  position: absolute;
  top: -3px;
  left: 50%;
  width: 6px; height: 6px;
  background: var(--fp-gold);
  border-radius: 50%;
  transform: translateX(-50%);
  box-shadow: 0 0 12px rgba(184, 155, 90, 0.5);
}

.fp-monogram-ring-2 {
  inset: -40px;
  z-index: 1;
  border-style: dashed;
  opacity: 0.5;
}

@keyframes fp-monogram-rotate {
  0% { transform: rotate(0deg); }
  100% { transform: rotate(360deg); }
}

.fp-leadership-body {
  font-family: var(--fp-serif);
  font-weight: 300;
  font-size: clamp(1.12rem, 1.55vw, 1.3rem);
  line-height: 1.66;
  color: var(--fp-text-on-paper-soft);
  max-width: 64ch;
  margin-bottom: 40px;
}

.fp-leadership-anchors {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 12px;
  padding-top: 28px;
  border-top: 1px solid var(--fp-border-on-paper);
}

.fp-leadership-anchors li {
  font-family: var(--fp-body);
  font-size: 0.86rem;
  font-weight: 500;
  color: var(--fp-text-on-paper);
  padding: 9px 16px;
  border: 1px solid var(--fp-border-on-paper-strong);
  border-radius: 999px;
  background: var(--fp-paper);
  transition: background 0.3s var(--fp-ease), border-color 0.3s var(--fp-ease), color 0.3s var(--fp-ease);
}

.fp-leadership-anchors li:hover {
  background: var(--fp-accent);
  border-color: var(--fp-accent);
  color: var(--fp-paper);
}

/* ============================================
   PRACTICE
   ============================================ */
.fp-practice {
  margin-top: 96px;
  padding-top: 56px;
  border-top: 1px solid var(--fp-border-on-paper);
  max-width: var(--fp-narrow);
  margin-left: auto;
  margin-right: auto;
}

.fp-practice-body {
  font-family: var(--fp-serif);
  font-weight: 400;
  font-size: clamp(1.15rem, 1.7vw, 1.4rem);
  line-height: 1.6;
  letter-spacing: -0.005em;
  color: var(--fp-text-on-paper);
  max-width: 64ch;
  margin-bottom: 48px;
}

.fp-practice-disciplines {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  margin-top: 32px;
  background: var(--fp-border-on-paper-strong);
  border: 1px solid var(--fp-border-on-paper-strong);
  border-radius: var(--fp-radius-md);
  overflow: hidden;
}

.fp-practice-disciplines li {
  background: var(--fp-paper);
  padding: 28px 24px;
  text-align: center;
  font-family: var(--fp-display);
  font-weight: 500;
  font-size: 1.05rem;
  letter-spacing: -0.01em;
  color: var(--fp-ink);
  transition: background 0.3s var(--fp-ease), color 0.3s var(--fp-ease);
}

.fp-practice-disciplines li:hover {
  background: var(--fp-accent);
  color: var(--fp-paper);
}

@media (max-width: 600px) {
  .fp-practice-disciplines { grid-template-columns: 1fr; }
}

/* Legacy split (kept for the article pages that may still reference it) */
.fp-practice-split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  margin-top: 24px;
  border-top: 1px solid var(--fp-border-on-paper-strong);
  border-bottom: 1px solid var(--fp-border-on-paper-strong);
}

.fp-practice-group {
  padding: 28px 32px 32px 0;
}

.fp-practice-group + .fp-practice-group {
  border-left: 1px solid var(--fp-border-on-paper);
  padding-left: 32px;
  padding-right: 0;
}

.fp-practice-group-label {
  font-family: var(--fp-body);
  font-size: 0.78rem;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--fp-accent);
  margin: 0 0 20px;
}

.fp-practice-list {
  display: flex;
  flex-direction: column;
}

.fp-practice-list li {
  font-family: var(--fp-body);
  font-size: 0.98rem;
  font-weight: 500;
  letter-spacing: -0.005em;
  color: var(--fp-text-on-paper);
  padding: 13px 0;
  border-bottom: 1px solid var(--fp-border-on-paper);
  display: flex;
  align-items: flex-start;
  gap: 12px;
}

.fp-practice-list li::before {
  content: '';
  display: block;
  width: 6px;
  height: 1px;
  background: var(--fp-accent);
  margin-top: 0.85em;
  flex-shrink: 0;
}

.fp-practice-list li:last-child {
  border-bottom: 0;
}

.fp-practice-coda {
  font-family: var(--fp-serif);
  font-weight: 400;
  font-style: italic;
  font-size: clamp(1.06rem, 1.4vw, 1.22rem);
  line-height: 1.62;
  letter-spacing: -0.005em;
  color: var(--fp-text-on-paper-soft);
  max-width: 64ch;
  margin-top: 44px;
}

@media (max-width: 760px) {
  .fp-practice-split {
    grid-template-columns: 1fr;
  }
  .fp-practice-group {
    padding: 24px 0 28px;
  }
  .fp-practice-group + .fp-practice-group {
    border-left: 0;
    border-top: 1px solid var(--fp-border-on-paper);
    padding-left: 0;
  }
}

/* ============================================
   CONVICTIONS
   ============================================ */
.fp-convictions {
  margin-top: 96px;
  padding-top: 56px;
  border-top: 1px solid var(--fp-border-on-paper);
  max-width: var(--fp-narrow);
  margin-left: auto;
  margin-right: auto;
}

.fp-convictions-list {
  display: flex;
  flex-direction: column;
  gap: 0;
  margin-top: 24px;
}

.fp-convictions-list li {
  display: grid;
  grid-template-columns: 60px 1fr;
  gap: 24px;
  align-items: baseline;
  padding: 28px 0;
  border-bottom: 1px solid var(--fp-border-on-paper);
}

.fp-convictions-list li:last-child {
  border-bottom: 0;
}

.fp-conviction-num {
  font-family: var(--fp-display);
  font-size: 0.82rem;
  font-weight: 500;
  letter-spacing: 0.08em;
  color: var(--fp-accent);
  padding-top: 4px;
}

.fp-conviction-text {
  font-family: var(--fp-serif);
  font-weight: 400;
  font-size: clamp(1.25rem, 2.2vw, 1.65rem);
  line-height: 1.34;
  letter-spacing: -0.012em;
  color: var(--fp-text-on-paper);
  max-width: 38ch;
}

@media (max-width: 600px) {
  .fp-convictions-list li {
    grid-template-columns: 1fr;
    gap: 8px;
    padding: 24px 0;
  }
  .fp-conviction-num { padding-top: 0; }
}

/* Dark-context overrides — when convictions appear inside a fp-section-dark */
.fp-section-dark .fp-convictions-list li {
  border-bottom-color: var(--fp-border-on-ink);
}
.fp-section-dark .fp-conviction-num {
  color: var(--fp-accent-on-ink);
}
.fp-section-dark .fp-conviction-text {
  color: var(--fp-text-on-ink);
}

/* ============================================
   LAURELS — irreverent credibility badges
   ============================================ */
.fp-laurels-block {
  margin-top: 96px;
  padding-top: 56px;
  border-top: 1px solid var(--fp-border-on-paper);
  max-width: var(--fp-container);
  margin-left: auto;
  margin-right: auto;
}

.fp-laurels {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 0;
  margin-top: 48px;
  align-items: center;
  justify-items: center;
}

.fp-laurel {
  position: relative;
  width: 190px;
  height: 175px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--fp-ink);
  transition: color 0.35s var(--fp-ease), transform 0.35s var(--fp-ease);
  cursor: default;
}

.fp-laurel:hover {
  color: var(--fp-accent);
  transform: translateY(-3px);
}

.fp-laurel-svg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  display: block;
}

.fp-laurel-text {
  position: relative;
  z-index: 1;
  font-family: var(--fp-display);
  font-weight: 600;
  font-size: 0.82rem;
  line-height: 1.2;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--fp-ink);
  text-align: center;
  padding: 0 8px;
  max-width: 130px;
  margin-top: 6px;
}

@media (max-width: 1100px) {
  .fp-laurels { grid-template-columns: repeat(3, 1fr); gap: 16px; }
}

@media (max-width: 560px) {
  .fp-laurels { grid-template-columns: repeat(2, 1fr); gap: 8px; }
  .fp-laurel { width: 160px; height: 150px; }
  .fp-laurel-text { font-size: 0.74rem; }
}

/* ============================================
   BRIDGE LINE
   ============================================ */
.fp-bridge {
  margin-top: 120px;
  text-align: center;
  max-width: var(--fp-narrow);
  margin-left: auto;
  margin-right: auto;
}

.fp-bridge-rule {
  display: block;
  width: 60px;
  height: 1px;
  background: var(--fp-gold);
  opacity: 0.55;
  margin: 0 auto 40px;
}

.fp-bridge-line {
  font-family: var(--fp-serif);
  font-weight: 400;
  font-style: italic;
  font-size: clamp(1.6rem, 3.4vw, 2.4rem);
  line-height: 1.3;
  letter-spacing: -0.018em;
  color: var(--fp-text-on-paper);
  max-width: 32ch;
  margin: 0 auto;
}

.fp-bridge-line::before {
  content: '';
  display: inline-block;
}

@media (max-width: 700px) {
  .fp-bridge { margin-top: 80px; }
}

/* ============================================
   FINAL CTA
   ============================================ */
.fp-cta {
  padding: 180px 0;
  overflow: hidden;
}

@media (max-width: 900px) { .fp-cta { padding: 120px 0; } }

.fp-cta-bg {
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.fp-cta-bg::before {
  content: '';
  position: absolute;
  top: 50%;
  right: -100px;
  width: 600px; height: 600px;
  background: radial-gradient(circle, rgba(31, 77, 74, 0.55) 0%, transparent 60%);
  border-radius: 50%;
  filter: blur(40px);
  transform: translateY(-50%);
}

.fp-cta-bg::after {
  content: '';
  position: absolute;
  bottom: -150px;
  left: 10%;
  width: 500px; height: 500px;
  background: radial-gradient(circle, rgba(184, 155, 90, 0.2) 0%, transparent 65%);
  border-radius: 50%;
  filter: blur(40px);
}

.fp-cta-inner { position: relative; z-index: 2; }

.fp-cta-headline {
  font-family: var(--fp-display);
  font-weight: 500;
  font-size: clamp(2.2rem, 4.8vw, 3.6rem);
  line-height: 1.06;
  letter-spacing: -0.028em;
  color: var(--fp-text-on-ink);
  margin-bottom: 28px;
  max-width: 22ch;
}

.fp-cta-body {
  font-family: var(--fp-body);
  font-size: clamp(1.08rem, 1.4vw, 1.22rem);
  line-height: 1.62;
  color: var(--fp-text-on-ink-soft);
  max-width: 56ch;
  margin-bottom: 48px;
}

.fp-cta-row {
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
}

/* ============================================
   FOOTER
   ============================================ */
.fp-footer {
  background: var(--fp-ink);
  color: var(--fp-text-on-ink-soft);
  padding: 100px 0 40px;
  position: relative;
  z-index: 1;
  border-top: 1px solid var(--fp-border-on-ink);
}

.fp-footer::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(to right, transparent, var(--fp-border-on-ink-strong), transparent);
}

.fp-footer-grid {
  display: grid;
  grid-template-columns: 1.8fr 1fr 1fr 1fr;
  gap: 56px;
  padding-bottom: 60px;
  border-bottom: 1px solid var(--fp-border-on-ink);
}

.fp-footer-brand { padding-right: 40px; }

.fp-footer-logo-row {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 22px;
}

.fp-footer-logo-row .fp-logo-mark {
  width: 40px;
  height: 40px;
}

.fp-footer-logo-row .fp-logo-word {
  font-size: 1.12rem;
}

.fp-footer-tagline {
  font-family: var(--fp-body);
  font-size: 0.96rem;
  line-height: 1.58;
  color: var(--fp-text-on-ink-soft);
  max-width: 34ch;
}

.fp-footer-col h5 {
  font-family: var(--fp-body);
  font-size: 0.78rem;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--fp-text-on-ink-muted);
  margin-bottom: 20px;
}

.fp-footer-col a {
  display: block;
  font-family: var(--fp-body);
  font-size: 0.96rem;
  color: var(--fp-text-on-ink-soft);
  margin-bottom: 12px;
  transition: color 0.25s var(--fp-ease);
}

.fp-footer-col a:hover { color: var(--fp-text-on-ink); }

.fp-footer-col a.fp-footer-muted {
  color: var(--fp-text-on-ink-muted);
  font-size: 0.86rem;
}

.fp-footer-bottom {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: 32px;
  font-family: var(--fp-body);
  font-size: 0.84rem;
  color: var(--fp-text-on-ink-muted);
}

.fp-social { display: flex; gap: 12px; }

.fp-social a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px; height: 36px;
  border-radius: 50%;
  border: 1px solid var(--fp-border-on-ink-strong);
  color: var(--fp-text-on-ink-muted);
  transition: color 0.25s var(--fp-ease), border-color 0.25s var(--fp-ease), background 0.25s var(--fp-ease);
}

.fp-social a:hover {
  color: var(--fp-ink);
  border-color: var(--fp-paper);
  background: var(--fp-paper);
}

@media (max-width: 900px) {
  .fp-footer-grid { grid-template-columns: 1fr 1fr; gap: 36px; }
  .fp-footer-brand { grid-column: 1 / -1; padding-right: 0; }
  .fp-footer-bottom { flex-direction: column; align-items: flex-start; gap: 16px; }
}

@media (max-width: 520px) {
  .fp-footer-grid { grid-template-columns: 1fr; }
}

/* ============================================
   ARTICLE PAGES
   ============================================ */
.fp-article-page {
  background: var(--fp-paper);
}

.fp-article-hero {
  padding: 180px 0 72px;
  border-bottom: 1px solid var(--fp-border-on-paper);
  position: relative;
  z-index: 1;
}

@media (max-width: 700px) {
  .fp-article-hero { padding: 130px 0 56px; }
}

.fp-article-back {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--fp-body);
  font-size: 0.88rem;
  font-weight: 500;
  color: var(--fp-text-on-paper-muted);
  margin-bottom: 36px;
  transition: color 0.25s var(--fp-ease);
}

.fp-article-back:hover { color: var(--fp-ink); }

.fp-article-back svg { transition: transform 0.25s var(--fp-ease); }
.fp-article-back:hover svg { transform: translateX(-3px); }

.fp-article-meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px 16px;
  font-family: var(--fp-body);
  font-size: 0.86rem;
  color: var(--fp-text-on-paper-muted);
  margin-bottom: 28px;
}

@media (max-width: 520px) {
  .fp-article-meta { gap: 8px 12px; font-size: 0.82rem; }
  .fp-article-meta span[aria-hidden="true"] { display: none; }
}

.fp-article-title {
  font-family: var(--fp-display);
  font-weight: 500;
  font-size: clamp(2rem, 4.8vw, 3.4rem);
  line-height: 1.08;
  letter-spacing: -0.028em;
  color: var(--fp-ink);
  margin-bottom: 24px;
  max-width: 22ch;
}

.fp-article-lede {
  font-family: var(--fp-serif);
  font-weight: 400;
  font-size: clamp(1.2rem, 1.8vw, 1.42rem);
  line-height: 1.5;
  color: var(--fp-text-on-paper-soft);
  max-width: 56ch;
}

.fp-article-body {
  padding: 72px 0 96px;
}

.fp-article-body p {
  font-family: var(--fp-body);
  font-size: 1.08rem;
  line-height: 1.72;
  color: var(--fp-text-on-paper);
  margin-bottom: 22px;
  max-width: 64ch;
}

.fp-article-body p strong {
  font-weight: 600;
  color: var(--fp-ink);
}

.fp-article-body h2 {
  font-family: var(--fp-display);
  font-weight: 500;
  font-size: clamp(1.4rem, 2.4vw, 1.85rem);
  line-height: 1.18;
  letter-spacing: -0.022em;
  margin: 64px 0 24px;
  color: var(--fp-ink);
  max-width: 32ch;
}

.fp-article-body h3 {
  font-family: var(--fp-display);
  font-weight: 500;
  font-size: 1.18rem;
  letter-spacing: -0.012em;
  margin: 40px 0 14px;
  color: var(--fp-ink);
}

.fp-article-body blockquote {
  font-family: var(--fp-serif);
  font-style: italic;
  font-weight: 400;
  font-size: clamp(1.3rem, 2.2vw, 1.6rem);
  line-height: 1.42;
  letter-spacing: -0.012em;
  border-left: 2px solid var(--fp-accent);
  padding: 4px 0 4px 28px;
  margin: 40px 0 40px;
  color: var(--fp-text-on-paper);
  max-width: 56ch;
}

.fp-article-body ul {
  margin: 0 0 24px;
  padding-left: 0;
  max-width: 64ch;
}

.fp-article-body ul li {
  font-family: var(--fp-body);
  font-size: 1.06rem;
  line-height: 1.68;
  padding-left: 22px;
  position: relative;
  margin-bottom: 10px;
  color: var(--fp-text-on-paper);
}

.fp-article-body ul li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0.78em;
  width: 10px;
  height: 1px;
  background: var(--fp-accent);
}

/* ============================================
   FOOTER NEWSLETTER SIGNUP
   ============================================ */
.fp-sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  border: 0;
}

.fp-footer-newsletter {
  margin-top: 64px;
  padding: 48px 0 32px;
  border-top: 1px solid var(--fp-border-on-ink);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 40px;
  align-items: center;
}

.fp-footer-newsletter-eyebrow {
  font-family: var(--fp-body);
  font-size: 0.72rem;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--fp-text-on-ink-muted);
  margin-bottom: 12px;
}

.fp-footer-newsletter-title {
  font-family: var(--fp-display);
  font-weight: 500;
  font-size: 1.15rem;
  line-height: 1.32;
  letter-spacing: -0.012em;
  color: var(--fp-text-on-ink);
  margin-bottom: 10px;
}

.fp-footer-newsletter-body {
  font-family: var(--fp-body);
  font-size: 0.88rem;
  line-height: 1.55;
  color: var(--fp-text-on-ink-muted);
}

.fp-footer-newsletter-form {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  position: relative;
}

.fp-footer-newsletter-input {
  flex: 1 1 220px;
  min-width: 0;
  background: rgba(251, 250, 246, 0.06);
  border: 1px solid var(--fp-border-on-ink-strong);
  border-radius: 999px;
  padding: 12px 18px;
  font-family: var(--fp-body);
  font-size: 0.95rem;
  color: var(--fp-text-on-ink);
  transition: border-color 0.25s var(--fp-ease), background 0.25s var(--fp-ease);
}
.fp-footer-newsletter-input::placeholder { color: var(--fp-text-on-ink-muted); }
.fp-footer-newsletter-input:focus {
  outline: none;
  border-color: var(--fp-accent-on-ink);
  background: rgba(251, 250, 246, 0.1);
}

.fp-footer-newsletter-button {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: var(--fp-paper);
  color: var(--fp-ink);
  border: 0;
  border-radius: 999px;
  padding: 12px 22px;
  font-family: var(--fp-body);
  font-size: 0.92rem;
  font-weight: 500;
  cursor: pointer;
  transition: background 0.25s var(--fp-ease), color 0.25s var(--fp-ease), gap 0.25s var(--fp-ease);
}
.fp-footer-newsletter-button:hover {
  background: var(--fp-accent-on-ink);
  color: var(--fp-ink);
  gap: 10px;
}
.fp-footer-newsletter-button[disabled] { opacity: 0.6; cursor: default; }

.fp-footer-newsletter-status {
  flex: 1 1 100%;
  font-family: var(--fp-body);
  font-size: 0.84rem;
  color: var(--fp-accent-on-ink);
  margin: 4px 0 0;
  min-height: 1em;
}

@media (max-width: 760px) {
  .fp-footer-newsletter { grid-template-columns: 1fr; gap: 24px; padding: 36px 0 24px; }
}

/* ============================================
   404 PAGE — branded "where you are now"
   ============================================ */
.fp-404 {
  min-height: 100vh;
  display: flex;
  align-items: center;
  padding: 140px 0 80px;
}

.fp-404-eyebrow {
  font-family: var(--fp-body);
  font-size: 0.78rem;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--fp-text-on-paper-muted);
  margin-bottom: 24px;
}

.fp-404-headline {
  font-family: var(--fp-display);
  font-weight: 500;
  font-size: clamp(2.2rem, 5vw, 3.6rem);
  letter-spacing: -0.03em;
  line-height: 1.08;
  color: var(--fp-ink);
  margin-bottom: 24px;
  max-width: 24ch;
}

.fp-404-body {
  font-family: var(--fp-body);
  font-size: 1.05rem;
  line-height: 1.6;
  color: var(--fp-text-on-paper-soft);
  max-width: 56ch;
  margin-bottom: 48px;
}

.fp-404-options {
  display: flex;
  flex-direction: column;
  gap: 0;
  margin-bottom: 40px;
  border-top: 1px solid var(--fp-border-on-paper);
}

.fp-404-option {
  display: grid;
  grid-template-columns: 56px 1fr auto;
  gap: 24px;
  align-items: center;
  padding: 24px 4px;
  border-bottom: 1px solid var(--fp-border-on-paper);
  text-decoration: none;
  transition: background 0.2s var(--fp-ease), padding 0.2s var(--fp-ease);
  position: relative;
}

.fp-404-option::after {
  content: '';
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 3px;
  height: 0;
  background: var(--fp-accent);
  transition: height 0.3s var(--fp-ease);
}

.fp-404-option:hover {
  background: var(--fp-paper-2);
  padding-left: 16px;
}
.fp-404-option:hover::after {
  height: 60%;
}

.fp-404-num {
  font-family: var(--fp-display);
  font-size: 0.78rem;
  font-weight: 500;
  letter-spacing: 0.08em;
  color: var(--fp-text-on-paper-muted);
  transition: color 0.2s var(--fp-ease);
}

.fp-404-option:hover .fp-404-num { color: var(--fp-accent); }

.fp-404-body-block {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.fp-404-title {
  font-family: var(--fp-display);
  font-weight: 500;
  font-size: 1.08rem;
  letter-spacing: -0.018em;
  color: var(--fp-ink);
  line-height: 1.25;
}

.fp-404-sub {
  font-family: var(--fp-body);
  font-size: 0.88rem;
  line-height: 1.45;
  color: var(--fp-text-on-paper-soft);
}

.fp-404-arrow {
  font-family: var(--fp-body);
  font-size: 1.4rem;
  color: var(--fp-accent);
  transition: transform 0.25s var(--fp-ease);
}
.fp-404-option:hover .fp-404-arrow { transform: translateX(3px); }

.fp-404-footnote {
  font-family: var(--fp-body);
  font-size: 0.92rem;
  color: var(--fp-text-on-paper-muted);
}
.fp-404-footnote a {
  color: var(--fp-accent);
  text-decoration: underline;
  text-decoration-color: rgba(31, 77, 74, 0.3);
  text-underline-offset: 3px;
}
.fp-404-footnote a:hover { text-decoration-color: var(--fp-accent); }

@media (max-width: 600px) {
  .fp-404 { padding: 100px 0 60px; }
  .fp-404-option { grid-template-columns: 40px 1fr auto; gap: 14px; padding: 20px 4px; }
  .fp-404-num { font-size: 0.7rem; }
  .fp-404-title { font-size: 1rem; }
  .fp-404-sub { font-size: 0.82rem; }
}

/* ============================================
   ARTICLE RELATED + SHARE — bottom-of-post
   ============================================ */
.fp-article-related {
  border-top: 1px solid var(--fp-border-on-paper);
  padding: 72px 0 24px;
  background: var(--fp-paper);
}

.fp-article-share {
  display: flex;
  align-items: center;
  gap: 18px;
  flex-wrap: wrap;
  margin-bottom: 56px;
  padding-bottom: 28px;
  border-bottom: 1px solid var(--fp-border-on-paper);
}

.fp-article-share-label {
  font-family: var(--fp-body);
  font-size: 0.78rem;
  font-weight: 500;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--fp-text-on-paper-muted);
}

.fp-article-share-link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--fp-body);
  font-size: 0.88rem;
  font-weight: 500;
  color: var(--fp-text-on-paper-soft);
  padding: 8px 14px;
  border: 1px solid var(--fp-border-on-paper);
  border-radius: 999px;
  transition: color 0.25s var(--fp-ease), border-color 0.25s var(--fp-ease), background 0.25s var(--fp-ease);
}
.fp-article-share-link:hover {
  color: var(--fp-ink);
  border-color: var(--fp-accent);
  background: var(--fp-paper-2);
}

.fp-article-related-eyebrow {
  font-family: var(--fp-body);
  font-size: 0.78rem;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--fp-text-on-paper-muted);
  margin-bottom: 16px;
}

.fp-article-related-title {
  font-family: var(--fp-display);
  font-weight: 500;
  font-size: clamp(1.6rem, 3vw, 2.1rem);
  letter-spacing: -0.025em;
  color: var(--fp-ink);
  margin-bottom: 36px;
}

.fp-article-related-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
  margin-bottom: 48px;
}

.fp-related-card {
  display: flex;
  flex-direction: column;
  gap: 14px;
  padding: 26px 24px 22px;
  background: var(--fp-paper);
  border: 1px solid var(--fp-border-on-paper);
  border-radius: var(--fp-radius-md);
  text-decoration: none;
  transition: border-color 0.25s var(--fp-ease), background 0.25s var(--fp-ease), transform 0.25s var(--fp-ease), box-shadow 0.25s var(--fp-ease);
}
.fp-related-card:hover {
  border-color: var(--fp-border-on-paper-strong);
  background: linear-gradient(180deg, var(--fp-paper) 0%, var(--fp-paper-2) 100%);
  transform: translateY(-2px);
  box-shadow: var(--fp-shadow-md);
}

.fp-related-tag {
  font-family: var(--fp-body);
  font-size: 0.7rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--fp-accent);
  padding: 4px 10px;
  background: rgba(31, 77, 74, 0.08);
  border-radius: 999px;
  align-self: flex-start;
}

.fp-related-title {
  font-family: var(--fp-display);
  font-weight: 500;
  font-size: 1.04rem;
  letter-spacing: -0.018em;
  line-height: 1.3;
  color: var(--fp-ink);
  flex-grow: 1;
}

.fp-related-cta {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--fp-body);
  font-size: 0.86rem;
  font-weight: 500;
  color: var(--fp-accent);
}
.fp-related-card:hover .fp-related-cta svg { transform: translateX(2px); }
.fp-related-cta svg { transition: transform 0.25s var(--fp-ease); }

@media (max-width: 900px) {
  .fp-article-related-grid { grid-template-columns: 1fr; }
}

.fp-article-cta {
  border-top: 1px solid var(--fp-border-on-paper);
  padding: 88px 0 96px;
  text-align: center;
  background: var(--fp-paper-2);
}

.fp-article-cta-eyebrow {
  font-family: var(--fp-body);
  font-size: 0.78rem;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--fp-text-on-paper-muted);
  margin-bottom: 18px;
}

.fp-article-cta-title {
  font-family: var(--fp-display);
  font-weight: 500;
  font-size: clamp(1.6rem, 3vw, 2.2rem);
  line-height: 1.12;
  letter-spacing: -0.022em;
  color: var(--fp-ink);
  margin-bottom: 24px;
  max-width: 24ch;
  margin-left: auto;
  margin-right: auto;
}

.fp-article-cta-row {
  display: inline-flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 14px;
  margin-top: 8px;
}

/* ============================================
   CASE STUDY PAGES
   ============================================ */
.fp-case-page .fp-article-title {
  max-width: 24ch;
}

.fp-case-stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  margin-top: 56px;
  padding-top: 32px;
  border-top: 1px solid var(--fp-border-on-paper);
}

.fp-case-stat {
  padding: 0 24px 0 0;
  border-right: 1px solid var(--fp-border-on-paper);
}

.fp-case-stat:last-child {
  border-right: 0;
}

.fp-case-stat + .fp-case-stat {
  padding-left: 24px;
}

.fp-case-stat-value {
  font-family: var(--fp-display);
  font-weight: 500;
  font-size: clamp(1.6rem, 2.6vw, 2.2rem);
  line-height: 1;
  letter-spacing: -0.025em;
  color: var(--fp-ink);
  display: block;
  margin-bottom: 10px;
}

.fp-case-stat-star {
  color: var(--fp-gold);
  margin-left: 4px;
  font-size: 0.85em;
}

.fp-case-stat-plus {
  color: var(--fp-accent);
  margin-left: 1px;
}

.fp-case-stat-sub {
  display: block;
  font-size: 0.62em;
  font-weight: 500;
  letter-spacing: -0.018em;
  color: var(--fp-text-on-paper-soft);
  margin-top: 2px;
}

.fp-case-stat-label {
  font-family: var(--fp-body);
  font-size: 0.85rem;
  line-height: 1.45;
  color: var(--fp-text-on-paper-muted);
  letter-spacing: 0.005em;
}

@media (max-width: 800px) {
  .fp-case-stats { grid-template-columns: repeat(2, 1fr); gap: 24px 0; }
  .fp-case-stat:nth-child(2) { border-right: 0; }
  .fp-case-stat:nth-child(3) { padding-left: 0; }
}

@media (max-width: 460px) {
  .fp-case-stats { grid-template-columns: 1fr; }
  .fp-case-stat { border-right: 0; border-bottom: 1px solid var(--fp-border-on-paper); padding: 0 0 16px; }
  .fp-case-stat + .fp-case-stat { padding-left: 0; padding-top: 16px; }
  .fp-case-stat:last-child { border-bottom: 0; }
}

.fp-case-pullquote {
  margin: 64px auto;
  padding: 32px 0 0 60px;
  position: relative;
}

.fp-case-pullquote .fp-quote-mark {
  color: var(--fp-accent);
  opacity: 0.4;
  top: -16px;
  left: 0;
}

.fp-case-pullquote blockquote {
  color: var(--fp-text-on-paper);
  font-family: var(--fp-serif);
  font-style: italic;
  font-weight: 400;
  font-size: clamp(1.32rem, 2.4vw, 1.7rem);
  line-height: 1.4;
  letter-spacing: -0.012em;
  margin-bottom: 20px;
}

.fp-case-pullquote figcaption {
  color: var(--fp-text-on-paper-muted);
  font-family: var(--fp-body);
  font-size: 0.92rem;
}

.fp-case-pullquote .fp-pullquote-name {
  color: var(--fp-text-on-paper);
  font-weight: 500;
}

.fp-case-actions {
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
  margin: 48px 0 16px;
  padding-top: 32px;
  border-top: 1px solid var(--fp-border-on-paper);
}

.fp-case-recognition {
  margin: 56px 0 8px;
  padding: 32px 0;
  border-top: 1px solid var(--fp-border-on-paper);
  border-bottom: 1px solid var(--fp-border-on-paper);
}

.fp-case-recognition-label {
  font-family: var(--fp-body);
  font-size: 0.78rem;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--fp-text-on-paper-muted);
  margin: 0 0 22px;
}

.fp-case-recognition-item {
  display: flex;
  align-items: center;
  gap: 24px;
}

.fp-case-recognition-img {
  width: 92px;
  height: auto;
  flex-shrink: 0;
  border-radius: 8px;
}

.fp-case-recognition-title {
  font-family: var(--fp-display);
  font-weight: 500;
  font-size: 1.15rem;
  letter-spacing: -0.015em;
  color: var(--fp-ink);
  margin: 0 0 4px;
}

.fp-case-recognition-detail {
  font-family: var(--fp-body);
  font-size: 0.95rem;
  line-height: 1.5;
  color: var(--fp-text-on-paper-soft);
  margin: 0;
}

@media (max-width: 520px) {
  .fp-case-recognition-item { gap: 16px; }
  .fp-case-recognition-img { width: 72px; }
}

/* ============================================
   MOBILE VISUAL DENSITY BUMPS
   Scale up key visual moments on mobile so they read clearly
   ============================================ */

@media (max-width: 760px) {
  /* Architecture overview composite diagram — full-bleed on mobile */
  .fp-arch-overview-svg-wrap {
    max-width: none;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    width: 100vw;
    padding: 0 8px;
    box-sizing: border-box;
  }

  /* Hero ecosystem viz — push labels bigger still */
  .fp-eco-label-lg { font-size: 28px; }
  .fp-eco-center-label { font-size: 24px; }
  .fp-hero-eco-stage { padding: 0; }

  /* Trusted-by marquee logos — bigger on mobile */
  .fp-marquee-logo { height: 52px !important; max-width: 220px !important; }

  /* Press strip logos — bigger on mobile */
  .fp-press-item img { max-width: 200px !important; }
  .fp-press-item:nth-child(1) { height: 32px !important; }
  .fp-press-item:nth-child(2) { height: 44px !important; }
  .fp-press-item:nth-child(3) { height: 48px !important; }
  .fp-press-item:nth-child(4) { height: 58px !important; }
  .fp-press-item:nth-child(5) { height: 48px !important; }
  .fp-press-item:nth-child(6) { height: 54px !important; }
}

@media (max-width: 480px) {
  .fp-eco-label-lg { font-size: 32px; }
  .fp-eco-center-label { font-size: 26px; }
  .fp-marquee-logo { height: 58px !important; max-width: 240px !important; }
}

/* ============================================
   MOBILE PERFORMANCE
   - backdrop-filter is one of the most expensive properties on mobile
     GPUs. Strip it on small viewports; sections still read fine with
     solid background colors.
   - content-visibility tells the browser to skip rendering work for
     off-screen sections until they're scrolled near. Cheap LCP/INP win.
   - Reduce drop-shadow filters on small screens.
   ============================================ */
@media (max-width: 760px) {
  /* Cut every backdrop-filter that's not strictly required for legibility */
  .fp-header,
  .fp-card,
  .fp-pill,
  .fp-glass,
  .fp-modal-router-dialog,
  .fp-modal-router-option,
  .fp-assess-dialog,
  .fp-assess-stage,
  .fp-work-card,
  .fp-case-card {
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
  }

  /* Skip render work for sections that aren't on screen yet.
     Using generic selectors keeps this resilient to section renames. */
  section.fp-press,
  section.fp-philosophy,
  section.fp-framework,
  section.fp-architecture,
  section.fp-work,
  section.fp-leader,
  section.fp-testimonials,
  section.fp-faq,
  section.fp-cta-final,
  footer {
    content-visibility: auto;
    contain-intrinsic-size: 1px 1200px;
  }
}
