/* ============================================
   MYLES THEME — Premium Strategy & Innovation
   ============================================
   Brand Styleguide v1.0 (Mai 2026)
   Colors:
     Navy Teal #002D37  primary, dark backgrounds, titles
     Dark Teal #235764  secondary, borders, subheads
     Mid Teal  #5096A0  accents, charts, captions
     Coral Red #D75555  CTAs, key facts — sparingly
     Warm Gold #D2A064  quotes, warm decorative accents
   Font: Helvetica Neue
   ============================================ */

/* ============================================
   1. CSS Custom Properties
   ============================================ */

:root {
  /* Brand Colors — Navy Teal palette */
  --color-primary: #002D37;
  --color-primary-light: #003d4a;
  --color-primary-dark: #001e25;
  --color-teal-dark: #235764;
  --color-teal-mid: #5096A0;
  --color-coral: #D75555;
  --color-coral-light: #e07878;
  --color-coral-dark: #b04545;
  --color-gold: #D2A064;
  --color-gold-light: #dcb480;
  --color-gold-dark: #b08552;
  /* Legacy accent aliases mapped to new palette.
     --color-accent drives CTAs and link hover (coral).
     --color-accent-warm drives quote marks, decorative
     icons, and soft warm backgrounds (warm gold). */
  --color-accent: var(--color-coral);
  --color-accent-light: var(--color-coral-light);
  --color-accent-dark: var(--color-coral-dark);
  --color-accent-subtle: rgba(215, 85, 85, 0.1);
  --color-accent-warm: var(--color-gold);

  /* Neutrals */
  --color-white: #ffffff;
  --color-off-white: #FAFAF8;
  --color-warm-gray-50: #F5F4F1;
  --color-warm-gray-100: #EDECEA;
  --color-warm-gray-200: #D8D6D2;
  --color-warm-gray-300: #B8B5AE;
  --color-warm-gray-400: #918D84;
  --color-warm-gray-500: #6E6A62;
  --color-warm-gray-600: #504D47;
  --color-warm-gray-700: #3A3833;
  --color-warm-gray-800: #252420;
  --color-warm-gray-900: #1a1a18;

  /* Semantic Colors */
  --bg: var(--color-off-white);
  --bg-alt: var(--color-warm-gray-50);
  --bg-surface: var(--color-white);
  --bg-dark: var(--color-primary);
  --bg-dark-alt: var(--color-primary-light);

  --text: var(--color-warm-gray-900);
  --text-secondary: var(--color-warm-gray-600);
  --text-muted: var(--color-warm-gray-400);
  --text-on-dark: var(--color-off-white);
  --text-on-dark-muted: rgba(250, 250, 248, 0.6);

  --border: var(--color-warm-gray-200);
  --border-light: var(--color-warm-gray-100);
  --border-dark: var(--color-warm-gray-300);

  /* Callout Colors */
  --callout-info: #2563eb;
  --callout-tip: #059669;
  --callout-warning: #d97706;
  --callout-success: #059669;

  /* Typography — Helvetica Neue is the MYLES house font.
     Cross-platform fallback: Helvetica (macOS), Arial (Windows),
     then generic sans-serif. */
  --font-sans: 'Helvetica Neue', Helvetica, Arial, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --font-display: 'Helvetica Neue', Helvetica, Arial, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --font-mono: 'JetBrains Mono', 'Fira Code', 'Consolas', monospace;

  --text-xs: 0.75rem;
  --text-sm: 0.875rem;
  --text-base: 1.0625rem;
  --text-lg: 1.125rem;
  --text-xl: 1.25rem;
  --text-2xl: 1.5rem;
  --text-3xl: 1.875rem;
  --text-4xl: 2.25rem;
  --text-5xl: 3rem;
  --text-6xl: 3.75rem;

  --leading-tight: 1.15;
  --leading-snug: 1.3;
  --leading-normal: 1.6;
  --leading-relaxed: 1.75;

  --tracking-tight: -0.02em;
  --tracking-normal: 0;
  --tracking-wide: 0.02em;
  --tracking-wider: 0.05em;
  --tracking-widest: 0.1em;

  /* Spacing */
  --space-xs: 0.25rem;
  --space-sm: 0.5rem;
  --space-md: 1rem;
  --space-lg: 1.5rem;
  --space-xl: 2rem;
  --space-2xl: 3rem;
  --space-3xl: 4rem;
  --space-4xl: 6rem;
  --space-5xl: 8rem;

  /* Layout */
  --container-max: 1200px;
  --container-narrow: 720px;
  --container-wide: 1400px;
  --header-height: 72px;
  --sidebar-width: 260px;

  /* Borders & Radius */
  --radius-sm: 4px;
  --radius-md: 8px;
  --radius-lg: 12px;
  --radius-xl: 16px;
  --radius-full: 9999px;

  /* Shadows */
  --shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.04);
  --shadow-md: 0 4px 12px rgba(0, 0, 0, 0.06);
  --shadow-lg: 0 8px 24px rgba(0, 0, 0, 0.08);
  --shadow-xl: 0 16px 48px rgba(0, 0, 0, 0.1);

  /* Transitions */
  --transition-fast: 150ms ease;
  --transition: 250ms ease;
  --transition-slow: 400ms ease;
  --transition-spring: 500ms cubic-bezier(0.34, 1.56, 0.64, 1);
}

/* Dark Mode */
@media (prefers-color-scheme: dark) {
  :root {
    --bg: var(--color-primary-dark);
    --bg-alt: var(--color-primary);
    --bg-surface: var(--color-primary-light);
    --bg-dark: var(--color-warm-gray-900);

    --text: var(--color-off-white);
    --text-secondary: var(--color-warm-gray-300);
    --text-muted: var(--color-warm-gray-400);

    --border: rgba(255, 255, 255, 0.1);
    --border-light: rgba(255, 255, 255, 0.06);
    --border-dark: rgba(255, 255, 255, 0.15);

    --shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.2);
    --shadow-md: 0 4px 12px rgba(0, 0, 0, 0.3);
    --shadow-lg: 0 8px 24px rgba(0, 0, 0, 0.4);
    --shadow-xl: 0 16px 48px rgba(0, 0, 0, 0.5);
  }
}

/* ============================================
   2. Reset & Base
   ============================================ */

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

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

body {
  font-family: var(--font-sans);
  font-size: var(--text-base);
  line-height: var(--leading-normal);
  color: var(--text);
  background-color: var(--bg);
  overflow-x: hidden;
}

body.no-scroll {
  overflow: hidden;
}

img, video {
  max-width: 100%;
  height: auto;
  display: block;
}

a {
  color: var(--color-teal-dark);
  text-decoration: none;
  transition: color var(--transition-fast);
}

a:hover {
  color: var(--color-coral);
}

/* ============================================
   3. Layout & Container
   ============================================ */

.container {
  width: 100%;
  max-width: var(--container-max);
  margin: 0 auto;
  padding: 0 var(--space-lg);
}

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

.container--wide {
  max-width: var(--container-wide);
}

/* ============================================
   4. Typography — Prose
   ============================================ */

.prose {
  font-size: var(--text-lg);
  line-height: var(--leading-relaxed);
  color: var(--text);
}

.prose > * + * {
  margin-top: 1.5em;
}

.prose h2 {
  font-size: var(--text-3xl);
  font-weight: 700;
  line-height: var(--leading-tight);
  letter-spacing: var(--tracking-tight);
  margin-top: 2.5em;
  margin-bottom: 0.75em;
  color: var(--text);
  padding-bottom: 0.5em;
  border-bottom: 1px solid var(--border-light);
}

.prose h3 {
  font-size: var(--text-2xl);
  font-weight: 600;
  line-height: var(--leading-snug);
  letter-spacing: var(--tracking-tight);
  margin-top: 2em;
  margin-bottom: 0.5em;
  color: var(--text);
}

.prose h4 {
  font-size: var(--text-xl);
  font-weight: 600;
  line-height: var(--leading-snug);
  margin-top: 1.75em;
  margin-bottom: 0.5em;
  color: var(--text);
}

.prose p {
  margin-bottom: 1.25em;
}

.prose strong {
  font-weight: 600;
  color: var(--text);
}

.prose em {
  font-style: italic;
}

.prose a {
  color: var(--color-accent-dark);
  text-decoration: underline;
  text-decoration-color: var(--color-accent-light);
  text-underline-offset: 3px;
  text-decoration-thickness: 1px;
  transition: all var(--transition-fast);
}

.prose a:hover {
  color: var(--color-accent);
  text-decoration-color: var(--color-accent);
}

.prose ul, .prose ol {
  padding-left: 1.5em;
  margin-bottom: 1.25em;
}

.prose li {
  margin-bottom: 0.5em;
}

.prose li::marker {
  color: var(--color-accent);
}

.prose blockquote {
  border-left: 3px solid var(--color-accent);
  padding: var(--space-lg) var(--space-xl);
  margin: var(--space-2xl) 0;
  background: var(--bg-alt);
  border-radius: 0 var(--radius-md) var(--radius-md) 0;
  font-size: var(--text-xl);
  font-style: italic;
  line-height: var(--leading-normal);
  color: var(--text-secondary);
}

.prose blockquote p {
  margin-bottom: 0;
}

.prose blockquote cite {
  display: block;
  font-size: var(--text-sm);
  font-style: normal;
  font-weight: 500;
  margin-top: var(--space-md);
  color: var(--text-muted);
}

.prose hr {
  border: none;
  height: 1px;
  background: var(--border);
  margin: var(--space-3xl) 0;
}

.prose img {
  border-radius: var(--radius-md);
  margin: var(--space-2xl) 0;
}

.prose figure {
  margin: var(--space-2xl) 0;
}

.prose figcaption {
  font-size: var(--text-sm);
  color: var(--text-muted);
  text-align: center;
  margin-top: var(--space-sm);
}

/* Code */
.prose code {
  font-family: var(--font-mono);
  font-size: 0.875em;
  padding: 0.15em 0.4em;
  background: var(--bg-alt);
  border: 1px solid var(--border-light);
  border-radius: var(--radius-sm);
  color: var(--color-primary);
}

.prose pre {
  background: var(--color-primary);
  color: var(--text-on-dark);
  padding: var(--space-xl);
  border-radius: var(--radius-md);
  overflow-x: auto;
  margin: var(--space-2xl) 0;
  font-size: var(--text-sm);
  line-height: 1.7;
}

.prose pre code {
  background: none;
  border: none;
  padding: 0;
  color: inherit;
  font-size: inherit;
}

/* Tables */
.prose table {
  width: 100%;
  border-collapse: collapse;
  margin: var(--space-2xl) 0;
  font-size: var(--text-base);
}

.prose thead {
  background: var(--bg-alt);
}

.prose th {
  font-weight: 600;
  text-align: left;
  padding: var(--space-md) var(--space-lg);
  border-bottom: 2px solid var(--border);
  font-size: var(--text-sm);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wider);
  color: var(--text-secondary);
}

.prose td {
  padding: var(--space-md) var(--space-lg);
  border-bottom: 1px solid var(--border-light);
  vertical-align: top;
}

.prose tbody tr:hover {
  background: var(--bg-alt);
}

/* Footnotes */
.prose .footnotes {
  font-size: var(--text-sm);
  color: var(--text-secondary);
  border-top: 1px solid var(--border);
  margin-top: var(--space-3xl);
  padding-top: var(--space-xl);
}

/* Definition lists */
.prose dl {
  margin-bottom: 1.25em;
}

.prose dt {
  font-weight: 600;
  margin-top: 1em;
}

.prose dd {
  padding-left: 1.5em;
  margin-bottom: 0.5em;
  color: var(--text-secondary);
}

/* ============================================
   5. Buttons
   ============================================ */

.btn {
  display: inline-flex;
  align-items: center;
  gap: var(--space-sm);
  padding: 0.75rem 1.5rem;
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  font-weight: 600;
  letter-spacing: var(--tracking-wide);
  text-decoration: none;
  border: none;
  border-radius: var(--radius-sm);
  cursor: pointer;
  transition: all var(--transition);
  white-space: nowrap;
}

.btn-accent {
  background: var(--color-accent);
  color: var(--color-primary-dark);
}

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

.btn-primary {
  background: var(--color-primary);
  color: var(--color-white);
}

.btn-primary:hover {
  background: var(--color-primary-light);
  transform: translateY(-1px);
  box-shadow: var(--shadow-md);
}

.btn-outline {
  background: transparent;
  color: var(--text);
  border: 1.5px solid var(--border-dark);
}

.btn-outline:hover {
  border-color: var(--color-accent);
  color: var(--color-accent-dark);
}

.btn-lg {
  padding: 1rem 2rem;
  font-size: var(--text-base);
}

.btn-full {
  width: 100%;
  justify-content: center;
}

/* ============================================
   6. Header / Navigation
   ============================================ */

.site-header {
  position: sticky;
  top: 0;
  z-index: 1000;
  background: var(--bg);
  border-bottom: 1px solid transparent;
  transition: all var(--transition);
}

.site-header.is-scrolled {
  border-bottom-color: var(--border-light);
  box-shadow: var(--shadow-sm);
  background: rgba(250, 250, 248, 0.95);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}

@media (prefers-color-scheme: dark) {
  .site-header.is-scrolled {
    background: rgba(0, 30, 37, 0.95);
  }
}

.header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: var(--header-height);
  max-width: var(--container-max);
  margin: 0 auto;
  padding: 0 var(--space-lg);
}

/* Logo */
.header-logo {
  flex-shrink: 0;
}

.logo-link {
  display: flex;
  align-items: center;
  text-decoration: none;
}

.logo-img {
  height: 28px;
  width: auto;
}

/* Header logo — single-line MYLES wordmark, thin weight, wide tracking.
   Matches the MYLES_Logo_WHITE_RGB asset (open, light, generous spacing).
   Color follows CSS variables so dark-hero pages render white and light
   pages render in navy teal. Full MYLES AHEAD masthead is in the footer. */
.logo-text {
  display: inline-flex;
  align-items: center;
  line-height: 1;
}

.logo-word-primary {
  font-size: 1.5rem;
  font-weight: 300;          /* Light, like the asset */
  letter-spacing: 0.22em;    /* generous tracking */
  color: var(--color-primary);
  line-height: 1;
  /* compensate for the wide letter-spacing: trim the trailing space
     after the last letter so the wordmark stays optically centered */
  padding-right: 0;
  text-indent: 0.11em;
}

.logo-word-secondary {
  /* Reserved for the footer masthead; not rendered in the header. */
  display: none;
}

@media (prefers-color-scheme: dark) {
  .logo-word-primary {
    color: var(--color-off-white);
  }
}

/* Desktop Nav */
.main-nav {
  display: none;
}

@media (min-width: 1024px) {
  .main-nav {
    display: flex;
    align-items: center;
  }
}

.nav-list {
  display: flex;
  align-items: center;
  gap: var(--space-xs);
  list-style: none;
}

.nav-link {
  display: block;
  padding: 0.5rem 0.875rem;
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--text-secondary);
  text-decoration: none;
  letter-spacing: var(--tracking-wide);
  border-radius: var(--radius-sm);
  transition: all var(--transition-fast);
}

.nav-link:hover {
  color: var(--text);
  background: var(--bg-alt);
}

.nav-item.is-active .nav-link {
  color: var(--text);
  font-weight: 600;
}

/* Header Actions */
.header-actions {
  display: flex;
  align-items: center;
  gap: var(--space-md);
}

/* Language Switcher */
.lang-switcher {
  position: relative;
  display: none;
}

@media (min-width: 1024px) {
  .lang-switcher {
    display: block;
  }
}

.lang-toggle {
  display: flex;
  align-items: center;
  gap: var(--space-xs);
  padding: 0.4rem 0.6rem;
  background: none;
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  font-weight: 600;
  color: var(--text-secondary);
  cursor: pointer;
  transition: all var(--transition-fast);
  letter-spacing: var(--tracking-wider);
}

.lang-toggle:hover {
  border-color: var(--border-dark);
  color: var(--text);
}

.lang-menu {
  position: absolute;
  top: 100%;
  right: 0;
  margin-top: var(--space-xs);
  min-width: 140px;
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-lg);
  list-style: none;
  padding: var(--space-xs);
  display: none;
  z-index: 100;
}

.lang-menu.is-open {
  display: block;
}

.lang-link {
  display: block;
  padding: 0.5rem 0.75rem;
  font-size: var(--text-sm);
  color: var(--text-secondary);
  text-decoration: none;
  border-radius: var(--radius-sm);
  transition: all var(--transition-fast);
}

.lang-link:hover,
.lang-link.is-active {
  background: var(--bg-alt);
  color: var(--text);
}

/* Header CTA */
.header-cta {
  display: none;
  padding: 0.5rem 1.25rem;
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--color-primary-dark);
  background: var(--color-accent);
  border-radius: var(--radius-sm);
  text-decoration: none;
  letter-spacing: var(--tracking-wide);
  transition: all var(--transition);
}

@media (min-width: 1024px) {
  .header-cta {
    display: inline-flex;
  }
}

.header-cta:hover {
  background: var(--color-accent-dark);
  color: var(--color-white);
  transform: translateY(-1px);
}

/* Mobile Toggle */
.mobile-toggle {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  background: none;
  border: none;
  cursor: pointer;
  padding: 0;
  z-index: 1001;
}

@media (min-width: 1024px) {
  .mobile-toggle {
    display: none;
  }
}

.hamburger {
  display: flex;
  flex-direction: column;
  gap: 5px;
  width: 22px;
}

.hamburger-line {
  display: block;
  width: 100%;
  height: 2px;
  background: var(--text);
  border-radius: 1px;
  transition: all var(--transition);
  transform-origin: center;
}

.mobile-toggle.is-active .hamburger-line:nth-child(1) {
  transform: translateY(7px) rotate(45deg);
}

.mobile-toggle.is-active .hamburger-line:nth-child(2) {
  opacity: 0;
}

.mobile-toggle.is-active .hamburger-line:nth-child(3) {
  transform: translateY(-7px) rotate(-45deg);
}

/* Mobile Menu */
.mobile-menu {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: var(--bg);
  z-index: 999;
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: var(--space-3xl) var(--space-xl);
  opacity: 0;
  visibility: hidden;
  transition: all var(--transition-slow);
}

.mobile-menu.is-open {
  opacity: 1;
  visibility: visible;
}

.mobile-nav-list {
  list-style: none;
  margin-bottom: var(--space-3xl);
}

.mobile-nav-item {
  border-bottom: 1px solid var(--border-light);
}

.mobile-nav-link {
  display: block;
  padding: var(--space-lg) 0;
  font-size: var(--text-3xl);
  font-weight: 600;
  color: var(--text);
  text-decoration: none;
  letter-spacing: var(--tracking-tight);
  transition: color var(--transition-fast);
}

.mobile-nav-link:hover,
.mobile-nav-link.is-active {
  color: var(--color-accent);
}

.mobile-nav-footer {
  display: flex;
  flex-direction: column;
  gap: var(--space-lg);
}

.mobile-lang {
  display: flex;
  gap: var(--space-md);
}

.mobile-lang-link {
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--text-muted);
  text-decoration: none;
  padding: 0.4rem 0.75rem;
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  transition: all var(--transition-fast);
}

.mobile-lang-link.is-active,
.mobile-lang-link:hover {
  color: var(--text);
  border-color: var(--text);
}

/* ============================================
   7. Reading Progress Bar
   ============================================ */

.reading-progress-container {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  z-index: 1100;
  background: transparent;
}

.reading-progress-bar {
  height: 100%;
  width: 0;
  background: linear-gradient(90deg, var(--color-accent), var(--color-accent-light));
  transition: width 100ms linear;
}

/* Pillar Progress */
.pillar-progress {
  position: fixed;
  top: var(--header-height);
  left: 0;
  right: 0;
  height: 3px;
  z-index: 1050;
  background: var(--border-light);
}

.pillar-progress-bar {
  height: 100%;
  width: 0;
  background: var(--color-accent);
  transition: width 100ms linear;
}

/* ============================================
   8. Hero Section
   ============================================ */

.hero {
  position: relative;
  padding: var(--space-5xl) 0;
  overflow: hidden;
  background: var(--bg);
  min-height: 70vh;
  display: flex;
  align-items: center;
}

.hero-content {
  position: relative;
  z-index: 2;
  max-width: 760px;
}

.hero-eyebrow {
  display: inline-block;
  font-size: var(--text-xs);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: var(--tracking-widest);
  color: var(--color-accent);
  margin-bottom: var(--space-lg);
  padding: 0.4rem 1rem;
  border: 1px solid var(--color-accent);
  border-radius: var(--radius-full);
}

.hero-title {
  font-size: clamp(2.5rem, 5.5vw, var(--text-6xl));
  font-weight: 800;
  line-height: var(--leading-tight);
  letter-spacing: var(--tracking-tight);
  color: var(--text);
  margin-bottom: var(--space-xl);
}

.hero-subtitle {
  font-size: var(--text-xl);
  line-height: var(--leading-normal);
  color: var(--text-secondary);
  margin-bottom: var(--space-2xl);
  max-width: 560px;
}

.hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-md);
}

/* Hero Decorative Lines */
.hero-decoration {
  position: absolute;
  top: 0;
  right: -5%;
  bottom: 0;
  width: 50%;
  pointer-events: none;
}

.hero-line {
  position: absolute;
  background: var(--border-light);
  transform-origin: top right;
}

.hero-line--1 {
  width: 1px;
  height: 100%;
  right: 30%;
  top: 0;
}

.hero-line--2 {
  width: 1px;
  height: 70%;
  right: 55%;
  top: 15%;
  opacity: 0.5;
}

.hero-line--3 {
  width: 200px;
  height: 1px;
  right: 10%;
  top: 40%;
  opacity: 0.3;
}

@media (max-width: 768px) {
  .hero {
    padding: var(--space-3xl) 0;
    min-height: auto;
  }
  .hero-decoration {
    display: none;
  }
}

/* ============================================
   9. Section Headers
   ============================================ */

.hp-section {
  padding: var(--space-4xl) 0;
}

.section-header {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  margin-bottom: var(--space-2xl);
  padding-bottom: var(--space-lg);
  border-bottom: 1px solid var(--border);
}

.section-eyebrow {
  display: block;
  font-size: var(--text-xs);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: var(--tracking-widest);
  color: var(--color-accent);
  margin-bottom: var(--space-sm);
}

.section-title {
  font-size: var(--text-3xl);
  font-weight: 700;
  letter-spacing: var(--tracking-tight);
  color: var(--text);
  margin: 0;
}

.section-link {
  display: inline-flex;
  align-items: center;
  gap: var(--space-xs);
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--color-accent-dark);
  text-decoration: none;
  transition: all var(--transition-fast);
  white-space: nowrap;
}

.section-link:hover {
  color: var(--color-accent);
  gap: var(--space-sm);
}

/* ============================================
   10. Article Cards
   ============================================ */

.articles-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-xl);
  margin-top: var(--space-xl);
}

.articles-grid--home {
  margin-top: var(--space-2xl);
}

@media (max-width: 900px) {
  .articles-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

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

.article-card {
  background: var(--bg-surface);
  border: 1px solid var(--border-light);
  border-radius: var(--radius-md);
  overflow: hidden;
  transition: all var(--transition);
}

.article-card:hover {
  border-color: var(--border);
  box-shadow: var(--shadow-md);
  transform: translateY(-2px);
}

.card-link {
  display: flex;
  flex-direction: column;
  text-decoration: none;
  color: inherit;
  height: 100%;
}

.card-image {
  position: relative;
  height: 200px;
  overflow: hidden;
}

.card-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--transition-slow);
}

.article-card:hover .card-image img {
  transform: scale(1.03);
}

.card-image--placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--bg-alt);
  height: 120px;
}

.card-placeholder-icon {
  color: var(--text-muted);
  opacity: 0.4;
}

.card-category {
  position: absolute;
  top: var(--space-md);
  left: var(--space-md);
  font-size: var(--text-xs);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: var(--tracking-wider);
  color: var(--color-white);
  background: var(--color-primary);
  padding: 0.25rem 0.625rem;
  border-radius: var(--radius-sm);
}

.card-body {
  padding: var(--space-lg);
  display: flex;
  flex-direction: column;
  flex-grow: 1;
}

.card-title {
  font-size: var(--text-xl);
  font-weight: 700;
  line-height: var(--leading-snug);
  color: var(--text);
  margin: 0 0 var(--space-sm);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.card-excerpt {
  font-size: var(--text-sm);
  color: var(--text-secondary);
  line-height: var(--leading-normal);
  margin-bottom: var(--space-md);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.card-meta {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--space-xs);
  font-size: var(--text-xs);
  color: var(--text-muted);
  margin-top: auto;
}

.card-meta-sep {
  color: var(--border-dark);
}

.card-author {
  font-weight: 500;
  color: var(--text-secondary);
}

/* Featured Card */
.featured-card {
  border: 1px solid var(--border-light);
  border-radius: var(--radius-md);
  overflow: hidden;
  transition: all var(--transition);
  background: var(--bg-surface);
}

.featured-card:hover {
  border-color: var(--border);
  box-shadow: var(--shadow-md);
}

.featured-card-link {
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  text-decoration: none;
  color: inherit;
}

@media (max-width: 768px) {
  .featured-card-link {
    grid-template-columns: 1fr;
  }
}

.featured-card-image {
  height: 100%;
  min-height: 300px;
  overflow: hidden;
}

.featured-card-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--transition-slow);
}

.featured-card:hover .featured-card-image img {
  transform: scale(1.03);
}

.featured-card-body {
  padding: var(--space-2xl);
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.featured-card-category {
  font-size: var(--text-xs);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: var(--tracking-widest);
  color: var(--color-accent);
  margin-bottom: var(--space-md);
}

.featured-card-title {
  font-size: var(--text-3xl);
  font-weight: 700;
  line-height: var(--leading-tight);
  letter-spacing: var(--tracking-tight);
  color: var(--text);
  margin: 0 0 var(--space-md);
}

.featured-card-excerpt {
  font-size: var(--text-base);
  color: var(--text-secondary);
  line-height: var(--leading-normal);
  margin-bottom: var(--space-lg);
}

/* ============================================
   11. Pillar Cards (Homepage)
   ============================================ */

.pillars-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-lg);
}

@media (max-width: 768px) {
  .pillars-grid {
    grid-template-columns: 1fr;
  }
}

.pillar-card {
  display: flex;
  flex-direction: column;
  padding: var(--space-2xl);
  background: var(--color-primary);
  color: var(--text-on-dark);
  text-decoration: none;
  border-radius: var(--radius-md);
  transition: all var(--transition);
  position: relative;
  overflow: hidden;
}

.pillar-card:hover {
  transform: translateY(-3px);
  box-shadow: var(--shadow-xl);
  color: var(--text-on-dark);
}

.pillar-card-number {
  font-size: var(--text-5xl);
  font-weight: 800;
  color: rgba(210, 160, 100, 0.2);
  line-height: 1;
  margin-bottom: var(--space-lg);
}

.pillar-card-title {
  font-size: var(--text-2xl);
  font-weight: 700;
  line-height: var(--leading-snug);
  margin: 0 0 var(--space-md);
}

.pillar-card-desc {
  font-size: var(--text-sm);
  color: var(--text-on-dark-muted);
  line-height: var(--leading-normal);
  margin-bottom: var(--space-xl);
  flex-grow: 1;
}

.pillar-card-link {
  display: inline-flex;
  align-items: center;
  gap: var(--space-sm);
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--color-accent);
  transition: gap var(--transition-fast);
}

.pillar-card:hover .pillar-card-link {
  gap: var(--space-md);
}

/* ============================================
   12. Breadcrumbs
   ============================================ */

.breadcrumbs {
  padding: var(--space-lg) 0;
  border-bottom: 1px solid var(--border-light);
}

.breadcrumb-list {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-xs);
  list-style: none;
  font-size: var(--text-sm);
}

.breadcrumb-item + .breadcrumb-item::before {
  content: "/";
  margin-right: var(--space-xs);
  color: var(--text-muted);
}

.breadcrumb-item a {
  color: var(--text-muted);
  text-decoration: none;
  transition: color var(--transition-fast);
}

.breadcrumb-item a:hover {
  color: var(--text);
}

.breadcrumb-item.is-current span {
  color: var(--text-secondary);
  font-weight: 500;
}

/* ============================================
   13. Article Layout
   ============================================ */

.article-header {
  padding: var(--space-3xl) 0 var(--space-2xl);
  text-align: center;
}

.article-categories {
  margin-bottom: var(--space-lg);
}

.article-category {
  display: inline-block;
  font-size: var(--text-xs);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: var(--tracking-widest);
  color: var(--color-accent);
  text-decoration: none;
  padding: 0.3rem 0.875rem;
  border: 1px solid var(--color-accent);
  border-radius: var(--radius-full);
  transition: all var(--transition-fast);
  margin: 0 var(--space-xs);
}

.article-category:hover {
  background: var(--color-accent);
  color: var(--color-primary-dark);
}

.article-title {
  font-size: clamp(var(--text-3xl), 4.5vw, var(--text-5xl));
  font-weight: 800;
  line-height: var(--leading-tight);
  letter-spacing: var(--tracking-tight);
  color: var(--text);
  margin-bottom: var(--space-lg);
  max-width: var(--container-narrow);
  margin-left: auto;
  margin-right: auto;
}

.article-subtitle {
  font-size: var(--text-xl);
  line-height: var(--leading-normal);
  color: var(--text-secondary);
  max-width: 580px;
  margin: 0 auto var(--space-xl);
}

.article-meta {
  display: flex;
  justify-content: center;
  margin-bottom: var(--space-md);
}

.article-author {
  display: flex;
  align-items: center;
  gap: var(--space-md);
}

.author-avatar {
  width: 44px;
  height: 44px;
  border-radius: var(--radius-full);
  object-fit: cover;
}

.author-avatar--placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--bg-alt);
  color: var(--text-muted);
}

.author-details {
  text-align: left;
}

.author-name {
  font-weight: 600;
  font-size: var(--text-sm);
  color: var(--text);
}

.article-meta-row {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  font-size: var(--text-xs);
  color: var(--text-muted);
}

.meta-sep {
  color: var(--border-dark);
}

.article-tags {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--space-sm);
}

.article-tag {
  font-size: var(--text-xs);
  font-weight: 500;
  color: var(--text-muted);
  text-decoration: none;
  padding: 0.25rem 0.5rem;
  border-radius: var(--radius-sm);
  transition: all var(--transition-fast);
}

.article-tag:hover {
  color: var(--color-accent-dark);
  background: var(--color-accent-subtle);
}

/* Article Hero Image */
.article-hero {
  margin-bottom: var(--space-3xl);
}

.article-hero-figure {
  border-radius: var(--radius-lg);
  overflow: hidden;
}

.article-hero-img {
  width: 100%;
  max-height: 480px;
  object-fit: cover;
}

.article-hero-caption {
  font-size: var(--text-sm);
  color: var(--text-muted);
  text-align: center;
  padding: var(--space-sm) 0;
}

/* Article Layout — Sidebar + Content */
.article-body {
  padding-bottom: var(--space-4xl);
}

.article-layout {
  display: grid;
  grid-template-columns: var(--sidebar-width) 1fr;
  gap: var(--space-3xl);
  align-items: start;
}

@media (max-width: 1024px) {
  .article-layout {
    grid-template-columns: 1fr;
  }
}

.article-sidebar {
  display: none;
}

@media (min-width: 1025px) {
  .article-sidebar {
    display: block;
  }
}

.toc-sticky {
  position: sticky;
  top: calc(var(--header-height) + var(--space-xl));
}

.toc-mobile {
  display: block;
  margin-bottom: var(--space-2xl);
}

@media (min-width: 1025px) {
  .toc-mobile {
    display: none;
  }
}

/* Table of Contents */
.toc {
  border: 1px solid var(--border-light);
  border-radius: var(--radius-md);
  padding: var(--space-lg);
  background: var(--bg-surface);
}

.toc-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: var(--space-md);
  padding-bottom: var(--space-md);
  border-bottom: 1px solid var(--border-light);
}

.toc-label {
  font-size: var(--text-xs);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: var(--tracking-widest);
  color: var(--text-muted);
}

.toc-toggle {
  background: none;
  border: none;
  cursor: pointer;
  color: var(--text-muted);
  padding: var(--space-xs);
  border-radius: var(--radius-sm);
  transition: all var(--transition-fast);
  display: block;
}

@media (min-width: 1025px) {
  .toc-toggle {
    display: none;
  }
}

.toc-toggle:hover {
  color: var(--text);
  background: var(--bg-alt);
}

.toc-toggle svg {
  transition: transform var(--transition);
}

.toc-toggle[aria-expanded="false"] svg {
  transform: rotate(-90deg);
}

.toc-nav {
  max-height: 400px;
  overflow-y: auto;
}

.toc-nav.is-collapsed {
  display: none;
}

.toc-nav ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

.toc-nav li {
  margin: 0;
}

.toc-nav a {
  display: block;
  font-size: var(--text-sm);
  line-height: var(--leading-normal);
  color: var(--text-muted);
  text-decoration: none;
  padding: 0.35rem 0 0.35rem 0.875rem;
  border-left: 2px solid transparent;
  transition: all var(--transition-fast);
}

.toc-nav a:hover {
  color: var(--text);
  border-left-color: var(--border);
}

.toc-nav a.is-active {
  color: var(--color-accent-dark);
  border-left-color: var(--color-accent);
  font-weight: 500;
}

.toc-nav ul ul a {
  padding-left: 1.75rem;
  font-size: var(--text-xs);
}

.toc-nav::-webkit-scrollbar {
  width: 3px;
}

.toc-nav::-webkit-scrollbar-track {
  background: transparent;
}

.toc-nav::-webkit-scrollbar-thumb {
  background: var(--border);
  border-radius: 2px;
}

/* ============================================
   14. Author Box
   ============================================ */

.author-box {
  margin-top: var(--space-3xl);
  padding-top: var(--space-2xl);
  border-top: 1px solid var(--border-light);
}

.author-box-inner {
  display: flex;
  align-items: flex-start;
  gap: var(--space-lg);
  padding: var(--space-xl);
  background: var(--bg-alt);
  border-radius: var(--radius-md);
}

.author-box-avatar img {
  width: 64px;
  height: 64px;
  border-radius: var(--radius-full);
  object-fit: cover;
  flex-shrink: 0;
}

.author-box-label {
  font-size: var(--text-xs);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: var(--tracking-widest);
  color: var(--text-muted);
}

.author-box-name {
  font-size: var(--text-xl);
  font-weight: 700;
  margin: var(--space-xs) 0 var(--space-sm);
  color: var(--text);
}

.author-box-bio {
  font-size: var(--text-sm);
  line-height: var(--leading-normal);
  color: var(--text-secondary);
  margin: 0;
}

@media (max-width: 600px) {
  .author-box-inner {
    flex-direction: column;
    text-align: center;
    align-items: center;
  }
}

/* ============================================
   15. Article CTA
   ============================================ */

.article-cta {
  margin-top: var(--space-3xl);
}

.article-cta-inner {
  text-align: center;
  padding: var(--space-3xl) var(--space-2xl);
  background: var(--color-primary);
  border-radius: var(--radius-lg);
  color: var(--text-on-dark);
}

.article-cta-title {
  font-size: var(--text-2xl);
  font-weight: 700;
  margin-bottom: var(--space-md);
  color: var(--text-on-dark);
}

.article-cta-text {
  font-size: var(--text-base);
  color: var(--text-on-dark-muted);
  margin-bottom: var(--space-xl);
  max-width: 480px;
  margin-left: auto;
  margin-right: auto;
}

/* ============================================
   16. Related Posts
   ============================================ */

.related-posts {
  margin-top: var(--space-3xl);
  padding-top: var(--space-2xl);
  border-top: 1px solid var(--border-light);
}

.related-posts-title {
  font-size: var(--text-2xl);
  font-weight: 700;
  color: var(--text);
  margin-bottom: var(--space-xs);
}

.related-posts-subtitle {
  font-size: var(--text-sm);
  color: var(--text-muted);
  margin-bottom: var(--space-xl);
}

.related-posts-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-lg);
}

@media (max-width: 768px) {
  .related-posts-grid {
    grid-template-columns: 1fr;
    gap: var(--space-md);
  }
}

.related-card {
  display: flex;
  flex-direction: column;
  text-decoration: none;
  color: inherit;
  border: 1px solid var(--border-light);
  border-radius: var(--radius-md);
  overflow: hidden;
  transition: all var(--transition);
}

.related-card:hover {
  border-color: var(--border);
  box-shadow: var(--shadow-sm);
  transform: translateY(-2px);
}

.related-card-image {
  height: 140px;
  overflow: hidden;
}

.related-card-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--transition-slow);
}

.related-card:hover .related-card-image img {
  transform: scale(1.03);
}

.related-card-body {
  padding: var(--space-md);
}

.related-card-category {
  font-size: var(--text-xs);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: var(--tracking-wider);
  color: var(--color-accent);
  margin-bottom: var(--space-xs);
  display: block;
}

.related-card-title {
  font-size: var(--text-base);
  font-weight: 600;
  line-height: var(--leading-snug);
  color: var(--text);
  margin: 0 0 var(--space-sm);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.related-card-meta {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  font-size: var(--text-xs);
  color: var(--text-muted);
}

/* ============================================
   17. Article Navigation
   ============================================ */

.article-nav {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-lg);
  margin-top: var(--space-3xl);
  padding-top: var(--space-2xl);
  border-top: 1px solid var(--border-light);
}

@media (max-width: 600px) {
  .article-nav {
    grid-template-columns: 1fr;
  }
}

.article-nav-link {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
  padding: var(--space-lg);
  border: 1px solid var(--border-light);
  border-radius: var(--radius-md);
  text-decoration: none;
  transition: all var(--transition);
}

.article-nav-link:hover {
  border-color: var(--border);
  box-shadow: var(--shadow-sm);
  background: var(--bg-alt);
}

.article-nav-next {
  text-align: right;
  grid-column: 2;
}

@media (max-width: 600px) {
  .article-nav-next {
    grid-column: 1;
  }
}

.article-nav-label {
  display: flex;
  align-items: center;
  gap: var(--space-xs);
  font-size: var(--text-xs);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: var(--tracking-wider);
  color: var(--color-accent);
}

.article-nav-next .article-nav-label {
  justify-content: flex-end;
}

.article-nav-title {
  font-size: var(--text-base);
  font-weight: 600;
  color: var(--text);
  line-height: var(--leading-snug);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* ============================================
   18. CTA Banner
   ============================================ */

.cta-banner {
  padding: var(--space-4xl) 0;
  background: var(--color-primary);
  color: var(--text-on-dark);
}

.cta-banner-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3xl);
}

@media (max-width: 768px) {
  .cta-banner-inner {
    flex-direction: column;
    text-align: center;
  }
}

.cta-banner-eyebrow {
  font-size: var(--text-xs);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: var(--tracking-widest);
  color: var(--color-accent);
  margin-bottom: var(--space-md);
  display: block;
}

.cta-banner-title {
  font-size: var(--text-3xl);
  font-weight: 700;
  line-height: var(--leading-tight);
  letter-spacing: var(--tracking-tight);
  color: var(--text-on-dark);
  margin-bottom: var(--space-md);
}

.cta-banner-text {
  font-size: var(--text-base);
  color: var(--text-on-dark-muted);
  line-height: var(--leading-normal);
  max-width: 480px;
}

@media (max-width: 768px) {
  .cta-banner-text {
    margin: 0 auto;
  }
}

.cta-banner-actions {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-md);
  flex-shrink: 0;
}

.cta-banner-note {
  font-size: var(--text-xs);
  color: var(--text-on-dark-muted);
}

/* ============================================
   19. List Page
   ============================================ */

.list-header {
  padding: var(--space-3xl) 0 var(--space-2xl);
  border-bottom: 1px solid var(--border);
}

.list-header-content {
  max-width: var(--container-narrow);
}

.list-eyebrow {
  font-size: var(--text-xs);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: var(--tracking-widest);
  color: var(--color-accent);
  margin-bottom: var(--space-md);
}

.list-title {
  font-size: clamp(var(--text-3xl), 4vw, var(--text-5xl));
  font-weight: 800;
  line-height: var(--leading-tight);
  letter-spacing: var(--tracking-tight);
  color: var(--text);
  margin-bottom: var(--space-md);
}

.list-description {
  font-size: var(--text-lg);
  color: var(--text-secondary);
  line-height: var(--leading-normal);
}

/* Category Filter */
.category-filter {
  padding: var(--space-lg) 0;
  border-bottom: 1px solid var(--border-light);
  position: sticky;
  top: var(--header-height);
  background: var(--bg);
  z-index: 50;
}

.filter-nav {
  display: flex;
  gap: var(--space-xs);
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  padding-bottom: var(--space-xs);
}

.filter-nav::-webkit-scrollbar {
  display: none;
}

.filter-link {
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--text-muted);
  text-decoration: none;
  padding: 0.4rem 1rem;
  border-radius: var(--radius-full);
  white-space: nowrap;
  border: 1px solid transparent;
  transition: all var(--transition-fast);
}

.filter-link:hover {
  color: var(--text);
  background: var(--bg-alt);
}

.filter-link.is-active {
  color: var(--color-primary-dark);
  background: var(--color-accent-subtle);
  border-color: var(--color-accent);
  font-weight: 600;
}

.list-content {
  padding: var(--space-2xl) 0 var(--space-4xl);
}

/* Empty State */
.empty-state {
  text-align: center;
  padding: var(--space-5xl) var(--space-xl);
  color: var(--text-muted);
}

.empty-state h2 {
  font-size: var(--text-2xl);
  font-weight: 600;
  color: var(--text-secondary);
  margin-bottom: var(--space-md);
}

/* ============================================
   20. Pagination
   ============================================ */

.pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-md);
  margin-top: var(--space-3xl);
  padding-top: var(--space-2xl);
  border-top: 1px solid var(--border-light);
}

.pagination-link {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--text-secondary);
  text-decoration: none;
  padding: 0.5rem 1rem;
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  transition: all var(--transition-fast);
}

.pagination-link:hover {
  border-color: var(--color-accent);
  color: var(--color-accent-dark);
}

.pagination-numbers {
  display: flex;
  gap: var(--space-xs);
}

.pagination-number {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--text-secondary);
  text-decoration: none;
  border-radius: var(--radius-sm);
  transition: all var(--transition-fast);
}

.pagination-number:hover {
  background: var(--bg-alt);
  color: var(--text);
}

.pagination-number.is-current {
  background: var(--color-primary);
  color: var(--text-on-dark);
  font-weight: 600;
}

/* ============================================
   21. Pillar Page
   ============================================ */

.pillar-badge {
  display: inline-block;
  font-size: var(--text-xs);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: var(--tracking-widest);
  color: var(--color-primary-dark);
  background: var(--color-accent);
  padding: 0.35rem 1rem;
  border-radius: var(--radius-sm);
  margin-bottom: var(--space-lg);
}

.pillar-header {
  padding: var(--space-3xl) 0 var(--space-2xl);
  text-align: center;
}

.pillar-title {
  font-size: clamp(var(--text-3xl), 5vw, var(--text-5xl));
  font-weight: 800;
  line-height: var(--leading-tight);
  letter-spacing: var(--tracking-tight);
  color: var(--text);
  margin-bottom: var(--space-lg);
}

.pillar-subtitle {
  font-size: var(--text-xl);
  color: var(--text-secondary);
  line-height: var(--leading-normal);
  max-width: 600px;
  margin: 0 auto var(--space-2xl);
}

.pillar-meta {
  display: flex;
  justify-content: center;
}

.pillar-author {
  display: flex;
  align-items: center;
  gap: var(--space-md);
}

/* Pillar Hero Image */
.pillar-hero {
  margin-bottom: var(--space-3xl);
}

.pillar-hero-img {
  width: 100%;
  max-height: 400px;
  object-fit: cover;
  border-radius: var(--radius-lg);
}

/* Pillar Layout */
.pillar-body {
  padding-bottom: var(--space-4xl);
}

.pillar-layout {
  display: grid;
  grid-template-columns: 280px 1fr;
  gap: var(--space-3xl);
  align-items: start;
}

@media (max-width: 1024px) {
  .pillar-layout {
    grid-template-columns: 1fr;
  }
}

.pillar-sidebar {
  display: none;
}

@media (min-width: 1025px) {
  .pillar-sidebar {
    display: block;
  }
}

.pillar-toc-sticky {
  position: sticky;
  top: calc(var(--header-height) + var(--space-xl));
}

.pillar-toc {
  border: 1px solid var(--border-light);
  border-radius: var(--radius-md);
  padding: var(--space-lg);
  background: var(--bg-surface);
  margin-bottom: var(--space-xl);
}

/* Cluster Articles in Sidebar */
.pillar-cluster {
  border: 1px solid var(--border-light);
  border-radius: var(--radius-md);
  padding: var(--space-lg);
  background: var(--bg-surface);
}

.pillar-cluster-title {
  font-size: var(--text-xs);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: var(--tracking-widest);
  color: var(--text-muted);
  margin-bottom: var(--space-md);
  padding-bottom: var(--space-md);
  border-bottom: 1px solid var(--border-light);
}

.pillar-cluster-list {
  list-style: none;
}

.pillar-cluster-link {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-sm);
  padding: var(--space-sm) 0;
  font-size: var(--text-sm);
  color: var(--text-secondary);
  text-decoration: none;
  border-bottom: 1px solid var(--border-light);
  transition: all var(--transition-fast);
}

.pillar-cluster-link:hover {
  color: var(--color-accent-dark);
}

.pillar-cluster-link:last-child {
  border-bottom: none;
}

.pillar-cluster-link-title {
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* Pillar CTA */
.pillar-cta {
  margin-top: var(--space-3xl);
}

.pillar-cta-inner {
  padding: var(--space-3xl);
  background: var(--color-primary);
  border-radius: var(--radius-lg);
  text-align: center;
  color: var(--text-on-dark);
}

.pillar-cta-eyebrow {
  display: block;
  font-size: var(--text-xs);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: var(--tracking-widest);
  color: var(--color-accent);
  margin-bottom: var(--space-md);
}

.pillar-cta-title {
  font-size: var(--text-3xl);
  font-weight: 700;
  line-height: var(--leading-tight);
  color: var(--text-on-dark);
  margin-bottom: var(--space-md);
}

.pillar-cta-text {
  font-size: var(--text-base);
  color: var(--text-on-dark-muted);
  max-width: 480px;
  margin: 0 auto var(--space-xl);
}

/* ============================================
   22. Callout Shortcode
   ============================================ */

.callout {
  display: flex;
  gap: var(--space-md);
  padding: var(--space-lg) var(--space-xl);
  margin: var(--space-2xl) 0;
  border-radius: var(--radius-md);
  border-left: 4px solid var(--callout-info);
  background: var(--bg-alt);
}

.callout-icon {
  flex-shrink: 0;
  margin-top: 2px;
}

.callout--info { border-left-color: var(--callout-info); }
.callout--info .callout-icon { color: var(--callout-info); }

.callout--tip { border-left-color: var(--callout-tip); }
.callout--tip .callout-icon { color: var(--callout-tip); }

.callout--warning { border-left-color: var(--callout-warning); }
.callout--warning .callout-icon { color: var(--callout-warning); }

.callout--success { border-left-color: var(--callout-success); }
.callout--success .callout-icon { color: var(--callout-success); }

.callout-title {
  font-size: var(--text-sm);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: var(--tracking-wider);
  color: var(--text);
  margin: 0 0 var(--space-sm);
}

.callout-text {
  font-size: var(--text-base);
  line-height: var(--leading-normal);
  color: var(--text-secondary);
}

.callout-text p {
  margin: 0;
}

.callout-text p + p {
  margin-top: var(--space-sm);
}

/* ============================================
   23. Expert Quote Shortcode
   ============================================ */

.expert-quote {
  margin: var(--space-2xl) 0;
  padding: var(--space-2xl);
  background: var(--bg-alt);
  border-radius: var(--radius-md);
  border: 1px solid var(--border-light);
  position: relative;
}

.expert-quote-mark {
  color: var(--color-accent);
  opacity: 0.4;
  margin-bottom: var(--space-md);
}

.expert-quote-text {
  font-size: var(--text-xl);
  font-style: italic;
  line-height: var(--leading-normal);
  color: var(--text);
  margin: 0;
}

.expert-quote-text p {
  margin: 0;
}

.expert-quote-footer {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  margin-top: var(--space-lg);
  padding-top: var(--space-lg);
  border-top: 1px solid var(--border-light);
}

.expert-quote-avatar {
  width: 48px;
  height: 48px;
  border-radius: var(--radius-full);
  object-fit: cover;
}

.expert-quote-name {
  display: block;
  font-style: normal;
  font-weight: 600;
  font-size: var(--text-sm);
  color: var(--text);
}

.expert-quote-title {
  display: block;
  font-size: var(--text-xs);
  color: var(--text-muted);
  margin-top: 2px;
}

/* ============================================
   24. FAQ Shortcode
   ============================================ */

.faq-item {
  border-bottom: 1px solid var(--border-light);
  margin-bottom: 0;
}

.faq-question {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  padding: var(--space-lg) 0;
  background: none;
  border: none;
  font-family: var(--font-sans);
  font-size: var(--text-lg);
  font-weight: 600;
  color: var(--text);
  cursor: pointer;
  text-align: left;
  line-height: var(--leading-snug);
  transition: color var(--transition-fast);
}

.faq-question:hover {
  color: var(--color-accent-dark);
}

.faq-icon {
  flex-shrink: 0;
  color: var(--text-muted);
  transition: transform var(--transition);
}

.faq-item.is-open .faq-icon {
  transform: rotate(45deg);
}

.faq-answer {
  max-height: 0;
  overflow: hidden;
  transition: max-height var(--transition-slow);
}

.faq-item.is-open .faq-answer {
  max-height: 1000px;
}

.faq-answer-inner {
  padding-bottom: var(--space-xl);
  font-size: var(--text-base);
  color: var(--text-secondary);
  line-height: var(--leading-relaxed);
}

.faq-answer-inner p {
  margin: 0;
}

.faq-answer-inner p + p {
  margin-top: var(--space-md);
}

/* ============================================
   25. Inline CTA Shortcode
   ============================================ */

.cta-inline {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-xl);
  padding: var(--space-xl) var(--space-2xl);
  margin: var(--space-2xl) 0;
  background: var(--color-accent-subtle);
  border: 1px solid var(--color-accent-light);
  border-radius: var(--radius-md);
}

@media (max-width: 600px) {
  .cta-inline {
    flex-direction: column;
    text-align: center;
    padding: var(--space-xl);
  }
}

.cta-inline-title {
  font-size: var(--text-lg);
  font-weight: 700;
  color: var(--text);
  margin: 0 0 var(--space-xs);
}

.cta-inline-text {
  font-size: var(--text-sm);
  color: var(--text-secondary);
  margin: 0;
}

/* ============================================
   26. Podcast Embed Shortcode
   ============================================ */

.podcast-embed {
  margin: var(--space-2xl) 0;
  padding: var(--space-xl);
  background: var(--bg-alt);
  border-radius: var(--radius-md);
  border: 1px solid var(--border-light);
}

.podcast-embed-header {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  margin-bottom: var(--space-md);
  color: var(--text);
}

.podcast-embed-title {
  font-size: var(--text-base);
  font-weight: 600;
  margin: 0;
}

.podcast-embed-desc {
  font-size: var(--text-sm);
  color: var(--text-secondary);
  margin-bottom: var(--space-lg);
}

.podcast-embed-player {
  border-radius: var(--radius-md);
  overflow: hidden;
}

/* ============================================
   27. Framework Diagram Shortcode
   ============================================ */

.framework-diagram {
  margin: var(--space-2xl) 0;
  border: 2px solid var(--color-primary);
  border-radius: var(--radius-md);
  overflow: hidden;
}

.framework-diagram-header {
  padding: var(--space-md) var(--space-xl);
  background: var(--color-primary);
}

.framework-diagram-title {
  font-size: var(--text-sm);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: var(--tracking-wider);
  color: var(--color-accent);
  margin: 0;
}

.framework-diagram-body {
  padding: var(--space-xl);
  font-size: var(--text-base);
  line-height: var(--leading-relaxed);
}

.framework-diagram-body ul,
.framework-diagram-body ol {
  padding-left: 1.5em;
}

.framework-diagram-body li + li {
  margin-top: var(--space-sm);
}

.framework-diagram-caption {
  padding: var(--space-sm) var(--space-xl);
  font-size: var(--text-sm);
  color: var(--text-muted);
  text-align: center;
  border-top: 1px solid var(--border-light);
  background: var(--bg-alt);
}

/* Accent variant */
.framework-diagram--accent {
  border-color: var(--color-accent);
}

.framework-diagram--accent .framework-diagram-header {
  background: var(--color-accent);
}

.framework-diagram--accent .framework-diagram-title {
  color: var(--color-primary-dark);
}

/* ============================================
   28. Footer
   ============================================ */

.site-footer {
  background: var(--color-primary);
  color: var(--text-on-dark);
  padding: var(--space-4xl) 0 var(--space-xl);
}

.footer-grid {
  display: grid;
  grid-template-columns: 1.5fr 1fr 1fr 1fr;
  gap: var(--space-3xl);
  margin-bottom: var(--space-3xl);
}

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

@media (max-width: 600px) {
  .footer-grid {
    grid-template-columns: 1fr;
    gap: var(--space-2xl);
  }
}

.footer-brand .logo-word-primary {
  color: var(--text-on-dark);
}

.footer-logo {
  text-decoration: none;
  display: inline-block;
  margin-bottom: var(--space-lg);
}

.footer-tagline {
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--color-accent);
  margin-bottom: var(--space-md);
}

.footer-about {
  font-size: var(--text-sm);
  color: var(--text-on-dark-muted);
  line-height: var(--leading-normal);
}

.footer-heading {
  font-size: var(--text-xs);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: var(--tracking-widest);
  color: var(--text-on-dark-muted);
  margin-bottom: var(--space-lg);
}

.footer-nav {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
}

.footer-link {
  font-size: var(--text-sm);
  color: var(--text-on-dark-muted);
  text-decoration: none;
  transition: color var(--transition-fast);
  display: block;
  padding: 2px 0;
}

.footer-link:hover {
  color: var(--color-accent);
}

/* Footer Bottom */
.footer-bottom {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-top: var(--space-xl);
  border-top: 1px solid rgba(255, 255, 255, 0.1);
}

@media (max-width: 768px) {
  .footer-bottom {
    flex-direction: column;
    gap: var(--space-lg);
    text-align: center;
  }
}

.footer-copyright {
  font-size: var(--text-xs);
  color: var(--text-on-dark-muted);
}

.footer-copyright a {
  color: var(--text-on-dark-muted);
  text-decoration: none;
}

.footer-legal-nav {
  display: flex;
  gap: var(--space-lg);
  margin-top: var(--space-sm);
}

.footer-legal-nav a {
  font-size: var(--text-xs);
  color: var(--text-on-dark-muted);
  text-decoration: none;
  transition: color var(--transition-fast);
}

.footer-legal-nav a:hover {
  color: var(--color-accent);
}

.footer-social {
  display: flex;
  gap: var(--space-md);
}

.social-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: var(--radius-full);
  color: var(--text-on-dark-muted);
  text-decoration: none;
  transition: all var(--transition-fast);
  border: 1px solid rgba(255, 255, 255, 0.1);
}

.social-icon:hover {
  color: var(--color-accent);
  border-color: var(--color-accent);
  background: rgba(210, 160, 100, 0.1);
}

/* ============================================
   29. Back to Top Button
   ============================================ */

.back-to-top {
  position: fixed;
  bottom: var(--space-xl);
  right: var(--space-xl);
  width: 44px;
  height: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--color-primary);
  color: var(--text-on-dark);
  border: none;
  border-radius: var(--radius-full);
  cursor: pointer;
  z-index: 500;
  opacity: 0;
  visibility: hidden;
  transform: translateY(12px);
  transition: all var(--transition);
  box-shadow: var(--shadow-lg);
}

.back-to-top.is-visible {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.back-to-top:hover {
  background: var(--color-accent);
  color: var(--color-primary-dark);
}

/* ============================================
   30. Scroll Reveal Animations
   ============================================ */

.js .hp-section,
.js .cta-banner,
.js .article-card,
.js .related-card {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.6s ease, transform 0.6s ease;
}

.js .hp-section.is-visible,
.js .cta-banner.is-visible,
.js .article-card.is-visible,
.js .related-card.is-visible {
  opacity: 1;
  transform: translateY(0);
}

/* Disable animations for reduced motion preference */
@media (prefers-reduced-motion: reduce) {
  .hp-section,
  .cta-banner,
  .article-card,
  .related-card {
    opacity: 1;
    transform: none;
    transition: none;
  }
}

/* ============================================
   31. Print Stylesheet
   ============================================ */

@media print {
  .site-header,
  .site-footer,
  .back-to-top,
  .reading-progress-container,
  .pillar-progress,
  .article-sidebar,
  .toc-mobile,
  .article-cta,
  .cta-banner,
  .article-nav,
  .related-posts,
  .category-filter,
  .breadcrumbs,
  .header-cta,
  .mobile-toggle,
  .article-tags {
    display: none !important;
  }

  body {
    font-size: 12pt;
    color: #000;
    background: #fff;
    line-height: 1.6;
  }

  .container {
    max-width: 100%;
    padding: 0;
  }

  .article-layout {
    grid-template-columns: 1fr;
  }

  .article-title {
    font-size: 24pt;
  }

  .prose h2 {
    font-size: 18pt;
    page-break-after: avoid;
  }

  .prose h3 {
    font-size: 14pt;
    page-break-after: avoid;
  }

  .prose img {
    max-width: 100%;
    page-break-inside: avoid;
  }

  .prose a {
    color: #000;
    text-decoration: underline;
  }

  .prose a[href^="http"]::after {
    content: " (" attr(href) ")";
    font-size: 0.8em;
    color: #666;
  }

  .prose pre {
    border: 1px solid #ccc;
    page-break-inside: avoid;
    white-space: pre-wrap;
  }

  .prose blockquote {
    border-left: 3px solid #ccc;
    background: none;
  }
}

/* ============================================
   32. Selection
   ============================================ */

::selection {
  background: var(--color-accent);
  color: var(--color-primary-dark);
}

::-moz-selection {
  background: var(--color-accent);
  color: var(--color-primary-dark);
}

/* ============================================
   33. Focus States (Accessibility)
   ============================================ */

:focus-visible {
  outline: 2px solid var(--color-accent);
  outline-offset: 2px;
}

a:focus:not(:focus-visible),
button:focus:not(:focus-visible) {
  outline: none;
}

/* ============================================
   34. Skip to Content
   ============================================ */

.skip-to-content {
  position: absolute;
  top: -100%;
  left: var(--space-md);
  padding: var(--space-sm) var(--space-lg);
  background: var(--color-primary);
  color: var(--text-on-dark);
  font-weight: 600;
  z-index: 9999;
  border-radius: 0 0 var(--radius-sm) var(--radius-sm);
  transition: top var(--transition-fast);
}

.skip-to-content:focus {
  top: 0;
}

/* ============================================
   35. Homepage Hero — Full Viewport Dark
   ============================================ */

/* Scroll reveal animations */
@keyframes hp-fadeUp {
  from { opacity: 0; transform: translateY(32px); }
  to { opacity: 1; transform: translateY(0); }
}

@keyframes hp-fadeIn {
  from { opacity: 0; }
  to { opacity: 1; }
}

@keyframes hp-scaleIn {
  from { opacity: 0; transform: scale(0.85); }
  to { opacity: 1; transform: scale(1); }
}

@keyframes hp-slideRight {
  from { opacity: 0; transform: translateX(-24px); }
  to { opacity: 1; transform: translateX(0); }
}

@keyframes hp-patternDrift {
  0% { transform: translate(0, 0) rotate(0deg); }
  50% { transform: translate(8px, -6px) rotate(0.5deg); }
  100% { transform: translate(0, 0) rotate(0deg); }
}

.js .hp-reveal {
  opacity: 0;
  transform: translateY(32px);
  transition: opacity 0.7s cubic-bezier(0.22, 1, 0.36, 1),
              transform 0.7s cubic-bezier(0.22, 1, 0.36, 1);
}

.js .hp-reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.hp-hero {
  position: relative;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  justify-content: center;
  background: var(--color-primary);
  color: var(--text-on-dark);
  overflow: hidden;
  padding-top: var(--space-5xl);
}

.hp-hero__bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
}

.hp-hero__pattern {
  width: 100%;
  height: 100%;
  opacity: 1;
  animation: hp-patternDrift 25s ease-in-out infinite;
}

.hp-hero__content {
  position: relative;
  z-index: 2;
  max-width: 820px;
}

.hp-hero__title {
  font-family: var(--font-display);
  font-size: clamp(3rem, 7vw, 5.5rem);
  font-weight: 400;
  line-height: 1.05;
  letter-spacing: -0.02em;
  color: var(--color-white);
  margin-bottom: var(--space-xl);
  animation: hp-fadeUp 0.9s cubic-bezier(0.22, 1, 0.36, 1) 0.1s both;
}

.hp-hero__subtitle {
  font-size: clamp(1.0625rem, 1.5vw, 1.25rem);
  line-height: 1.7;
  color: rgba(250, 250, 248, 0.7);
  margin-bottom: var(--space-2xl);
  max-width: 580px;
  animation: hp-fadeUp 0.9s cubic-bezier(0.22, 1, 0.36, 1) 0.25s both;
}

.hp-hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-md);
  margin-bottom: var(--space-3xl);
  animation: hp-fadeUp 0.9s cubic-bezier(0.22, 1, 0.36, 1) 0.4s both;
}

.btn-outline-light {
  background: transparent;
  color: var(--color-white);
  border: 1.5px solid rgba(255, 255, 255, 0.25);
  display: inline-flex;
  align-items: center;
  gap: var(--space-sm);
  padding: 1rem 2rem;
  font-family: var(--font-sans);
  font-size: var(--text-base);
  font-weight: 600;
  letter-spacing: var(--tracking-wide);
  text-decoration: none;
  border-radius: var(--radius-sm);
  cursor: pointer;
  transition: all 0.4s cubic-bezier(0.22, 1, 0.36, 1);
  white-space: nowrap;
}

.btn-outline-light:hover {
  border-color: var(--color-accent);
  color: var(--color-accent);
  background: rgba(210, 160, 100, 0.08);
  transform: translateY(-1px);
}

/* Hero Stats Bar */
.hp-hero__stats {
  position: relative;
  z-index: 2;
  margin-top: auto;
  padding-bottom: var(--space-3xl);
  animation: hp-fadeIn 1s cubic-bezier(0.22, 1, 0.36, 1) 0.7s both;
}

.hp-hero__stats-bar {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 0;
  padding: var(--space-2xl) 0;
  border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.hp-hero__stat {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 0 var(--space-2xl);
}

.hp-hero__stat:first-child {
  padding-left: 0;
  align-items: flex-start;
}

.hp-hero__stat-divider {
  width: 1px;
  height: 48px;
  background: rgba(255, 255, 255, 0.08);
  flex-shrink: 0;
}

.hp-hero__stat-number {
  font-family: var(--font-display);
  font-size: var(--text-4xl);
  font-weight: 400;
  color: var(--color-accent);
  line-height: 1;
  margin-bottom: var(--space-sm);
  letter-spacing: -0.01em;
}

.hp-hero__stat-label {
  font-size: 0.6875rem;
  font-weight: 600;
  color: rgba(250, 250, 248, 0.4);
  text-transform: uppercase;
  letter-spacing: var(--tracking-widest);
  white-space: nowrap;
}

@media (max-width: 768px) {
  .hp-hero {
    min-height: auto;
    padding: var(--space-4xl) 0 var(--space-2xl);
  }

  .hp-hero__title {
    font-size: 2.5rem;
  }

  .hp-hero__stats-bar {
    flex-wrap: wrap;
    gap: var(--space-xl);
  }

  .hp-hero__stat {
    padding: 0;
    width: calc(50% - var(--space-md));
    align-items: flex-start;
  }

  .hp-hero__stat-divider {
    display: none;
  }
}

/* ============================================
   36. Client Logos Bar
   ============================================ */

.hp-logos {
  background: var(--bg);
  padding: var(--space-3xl) 0;
  border-bottom: 1px solid var(--border-light);
}

.hp-logos__heading {
  font-size: 0.6875rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  color: var(--text-muted);
  text-align: center;
  margin-bottom: var(--space-xl);
}

.hp-logos__row {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-3xl);
  flex-wrap: wrap;
}

.hp-logos__item {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 40px;
  transition: all 0.5s cubic-bezier(0.22, 1, 0.36, 1);
  user-select: none;
  opacity: 0.45;
  filter: grayscale(100%);
}

.hp-logos__item img {
  max-height: 36px;
  max-width: 120px;
  width: auto;
  height: auto;
  object-fit: contain;
}

.hp-logos__item:hover {
  opacity: 1;
  filter: grayscale(0%);
  transform: scale(1.08);
}

@media (max-width: 768px) {
  .hp-logos__row {
    justify-content: center;
    gap: var(--space-xl);
  }

  .hp-logos__item {
    height: 32px;
  }

  .hp-logos__item img {
    max-height: 28px;
    max-width: 100px;
  }
}

/* ============================================
   37. Problem / Solution Section
   ============================================ */

.hp-problem {
  padding: var(--space-5xl) 0;
  background: var(--bg);
}

.hp-problem__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-4xl);
  margin-bottom: var(--space-2xl);
}

.hp-problem__eyebrow {
  display: inline-block;
  font-size: 0.6875rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  color: var(--color-accent);
  margin-bottom: var(--space-lg);
}

.hp-problem__title {
  font-family: var(--font-display);
  font-size: clamp(var(--text-2xl), 3vw, var(--text-4xl));
  font-weight: 400;
  line-height: 1.15;
  letter-spacing: -0.01em;
  color: var(--text);
  margin-bottom: var(--space-lg);
}

.hp-problem__text {
  font-size: var(--text-lg);
  line-height: var(--leading-relaxed);
  color: var(--text-secondary);
}

.hp-problem__col--solution {
  padding-left: var(--space-2xl);
  border-left: 3px solid var(--color-accent);
}

.hp-problem__cta {
  text-align: center;
  padding-top: var(--space-xl);
}

.hp-problem__link {
  display: inline-flex;
  align-items: center;
  gap: var(--space-sm);
  font-size: var(--text-lg);
  font-weight: 600;
  color: var(--color-accent-dark);
  text-decoration: none;
  transition: all 0.4s cubic-bezier(0.22, 1, 0.36, 1);
}

.hp-problem__link:hover {
  color: var(--color-accent);
  gap: var(--space-md);
}

@media (max-width: 768px) {
  .hp-problem {
    padding: var(--space-3xl) 0;
  }

  .hp-problem__grid {
    grid-template-columns: 1fr;
    gap: var(--space-2xl);
  }

  .hp-problem__col--solution {
    padding-left: 0;
    border-left: none;
    padding-top: var(--space-2xl);
    border-top: 3px solid var(--color-accent);
  }
}

/* ============================================
   38. Services Cards (Dark Background)
   ============================================ */

.hp-services {
  padding: var(--space-5xl) 0;
  background: var(--color-primary);
  color: var(--text-on-dark);
  position: relative;
}

.hp-services__header {
  text-align: center;
  margin-bottom: var(--space-4xl);
}

.hp-services__eyebrow {
  display: block;
  font-size: 0.6875rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  color: var(--color-accent);
  margin-bottom: var(--space-md);
}

.hp-services__title {
  font-family: var(--font-display);
  font-size: clamp(var(--text-3xl), 3.5vw, var(--text-4xl));
  font-weight: 400;
  letter-spacing: -0.01em;
  color: var(--color-white);
}

.hp-services__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-xl);
  margin-bottom: var(--space-3xl);
}

.hp-services__card {
  position: relative;
  padding: var(--space-2xl) var(--space-2xl) var(--space-2xl);
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(255, 255, 255, 0.06);
  border-radius: var(--radius-lg);
  transition: all 0.5s cubic-bezier(0.22, 1, 0.36, 1);
  overflow: hidden;
}

.hp-services__card::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: var(--color-accent);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.5s cubic-bezier(0.22, 1, 0.36, 1);
}

.hp-services__card:hover {
  background: rgba(255, 255, 255, 0.07);
  border-color: rgba(255, 255, 255, 0.12);
  transform: translateY(-4px);
  box-shadow: 0 24px 64px rgba(0, 0, 0, 0.35);
}

.hp-services__card:hover::after {
  transform: scaleX(1);
}

.hp-services__icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 52px;
  height: 52px;
  border-radius: var(--radius-full);
  background: rgba(210, 160, 100, 0.1);
  color: var(--color-accent);
  margin-bottom: var(--space-xl);
  transition: all 0.5s cubic-bezier(0.22, 1, 0.36, 1);
}

.hp-services__card:hover .hp-services__icon {
  background: rgba(210, 160, 100, 0.18);
  transform: scale(1.08);
}

.hp-services__card-title {
  font-size: var(--text-xl);
  font-weight: 700;
  color: var(--color-white);
  margin-bottom: var(--space-md);
}

.hp-services__card-text {
  font-size: var(--text-base);
  line-height: 1.7;
  color: rgba(250, 250, 248, 0.55);
  margin-bottom: var(--space-lg);
}

.hp-services__card-link {
  display: inline-flex;
  align-items: center;
  gap: var(--space-sm);
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--color-accent);
  text-decoration: none;
  transition: all 0.4s cubic-bezier(0.22, 1, 0.36, 1);
}

.hp-services__card-link svg {
  transition: transform 0.4s cubic-bezier(0.22, 1, 0.36, 1);
}

.hp-services__card-link:hover {
  color: var(--color-accent-light);
}

.hp-services__card-link:hover svg {
  transform: translateX(4px);
}

.hp-services__footer {
  text-align: center;
}

@media (max-width: 768px) {
  .hp-services {
    padding: var(--space-3xl) 0;
  }

  .hp-services__grid {
    grid-template-columns: 1fr;
    gap: var(--space-lg);
  }
}

/* ============================================
   39. Methodology — ODI 6-Step Flow
   ============================================ */

.hp-method {
  padding: var(--space-5xl) 0;
  background: var(--bg);
}

.hp-method__header {
  text-align: center;
  max-width: 720px;
  margin: 0 auto var(--space-4xl);
}

.hp-method__eyebrow {
  display: block;
  font-size: 0.6875rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  color: var(--color-accent);
  margin-bottom: var(--space-md);
}

.hp-method__title {
  font-family: var(--font-display);
  font-size: clamp(var(--text-2xl), 3vw, var(--text-3xl));
  font-weight: 400;
  letter-spacing: -0.01em;
  color: var(--text);
  margin-bottom: var(--space-lg);
}

.hp-method__subtitle {
  font-size: var(--text-lg);
  line-height: var(--leading-normal);
  color: var(--text-secondary);
}

.hp-method__flow {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-xl) var(--space-2xl);
  max-width: 1000px;
  margin: 0 auto;
}

.hp-method__step {
  display: flex;
  align-items: flex-start;
  gap: var(--space-lg);
  padding: var(--space-xl);
  border-left: 3px solid var(--color-accent);
  transition: all 0.5s cubic-bezier(0.22, 1, 0.36, 1);
}

.hp-method__step:hover {
  background: var(--color-warm-gray-50);
  border-left-color: var(--color-primary);
}

.hp-method__step-num {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  border-radius: var(--radius-full);
  background: var(--color-primary);
  color: var(--color-accent);
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-weight: 400;
  flex-shrink: 0;
}

.hp-method__step-content {
  flex: 1;
}

.hp-method__connector {
  display: none;
}

.hp-method__step-title {
  font-size: var(--text-base);
  font-weight: 700;
  color: var(--text);
  margin-bottom: var(--space-xs);
}

.hp-method__step-text {
  font-size: var(--text-sm);
  color: var(--text-secondary);
  line-height: 1.6;
}

.hp-method__cta {
  text-align: center;
  margin-top: var(--space-3xl);
}

@media (max-width: 900px) {
  .hp-method__flow {
    grid-template-columns: 1fr;
    gap: 0;
    max-width: 500px;
  }

  .hp-method__step {
    padding: var(--space-lg) var(--space-md) var(--space-lg) var(--space-lg);
  }
}

/* ============================================
   40. Testimonials Section
   ============================================ */

.hp-testimonials {
  padding: var(--space-5xl) 0;
  background: var(--color-warm-gray-50);
}

.hp-testimonials__header {
  text-align: center;
  margin-bottom: var(--space-3xl);
}

.hp-testimonials__eyebrow {
  display: block;
  font-size: var(--text-xs);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: var(--tracking-widest);
  color: var(--color-accent);
  margin-bottom: var(--space-md);
}

.hp-testimonials__title {
  font-family: var(--font-display);
  font-size: clamp(var(--text-2xl), 3vw, var(--text-3xl));
  font-weight: 400;
  letter-spacing: -0.01em;
  color: var(--text);
}

.hp-testimonials__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-xl);
}

.hp-testimonials__card {
  background: var(--bg-surface);
  border: 1px solid var(--border-light);
  border-left: 3px solid var(--color-accent);
  border-radius: var(--radius-lg);
  padding: var(--space-2xl) var(--space-2xl) var(--space-2xl) calc(var(--space-2xl) - 2px);
  display: flex;
  flex-direction: column;
  transition: all 0.5s cubic-bezier(0.22, 1, 0.36, 1);
  position: relative;
}

.hp-testimonials__card:hover {
  border-color: var(--border);
  border-left-color: var(--color-primary);
  box-shadow: 0 12px 40px rgba(0, 45, 55, 0.08);
  transform: translateY(-4px);
}

.hp-testimonials__quote-mark {
  color: var(--color-accent);
  opacity: 0.25;
  margin-bottom: var(--space-md);
}

.hp-testimonials__text {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  line-height: 1.7;
  color: var(--text);
  font-style: italic;
  font-weight: 400;
  margin: 0 0 var(--space-xl);
  flex-grow: 1;
  border: none;
  padding: 0;
}

.hp-testimonials__author {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  padding-top: var(--space-lg);
  border-top: 1px solid var(--border-light);
}

.hp-testimonials__avatar {
  width: 52px;
  height: 52px;
  border-radius: var(--radius-full);
  background: var(--color-primary);
  color: var(--color-accent);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: var(--text-sm);
  font-weight: 700;
  flex-shrink: 0;
  letter-spacing: 0.05em;
  border: 2px solid rgba(210, 160, 100, 0.3);
}

.hp-testimonials__author-info {
  display: flex;
  flex-direction: column;
}

.hp-testimonials__name {
  font-size: var(--text-sm);
  font-weight: 700;
  color: var(--text);
}

.hp-testimonials__role {
  font-size: var(--text-xs);
  color: var(--text-muted);
  margin-top: 2px;
}

@media (max-width: 900px) {
  .hp-testimonials__grid {
    grid-template-columns: 1fr;
    max-width: 560px;
    margin: 0 auto;
  }
}

@media (max-width: 768px) {
  .hp-testimonials {
    padding: var(--space-3xl) 0;
  }
}

/* ============================================
   41. Podcast Section
   ============================================ */

.hp-podcast {
  padding: var(--space-5xl) 0;
  background: var(--color-primary);
  color: var(--text-on-dark);
}

.hp-podcast__grid {
  display: grid;
  grid-template-columns: 1.2fr 0.8fr;
  gap: var(--space-4xl);
  align-items: center;
}

.hp-podcast__eyebrow {
  display: block;
  font-size: var(--text-xs);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: var(--tracking-widest);
  color: var(--color-accent);
  margin-bottom: var(--space-md);
}

.hp-podcast__title {
  font-family: var(--font-display);
  font-size: clamp(var(--text-3xl), 3.5vw, var(--text-4xl));
  font-weight: 400;
  letter-spacing: -0.01em;
  color: var(--color-white);
  margin-bottom: var(--space-lg);
}

.hp-podcast__text {
  font-size: var(--text-lg);
  line-height: var(--leading-normal);
  color: rgba(250, 250, 248, 0.65);
  margin-bottom: var(--space-2xl);
}

.hp-podcast__episodes {
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
  margin-bottom: var(--space-2xl);
}

.hp-podcast__episode {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  padding: var(--space-md) var(--space-lg);
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.06);
  border-radius: var(--radius-md);
  transition: all 0.5s cubic-bezier(0.22, 1, 0.36, 1);
}

.hp-podcast__episode:hover {
  background: rgba(255, 255, 255, 0.08);
  border-color: rgba(210, 160, 100, 0.3);
  transform: translateX(4px);
}

.hp-podcast__episode-num {
  font-size: var(--text-xs);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: var(--tracking-wider);
  color: var(--color-accent);
  flex-shrink: 0;
  min-width: 64px;
}

.hp-podcast__episode-title {
  font-size: var(--text-sm);
  color: rgba(250, 250, 248, 0.8);
  font-weight: 500;
}

.hp-podcast__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-md);
}

/* Podcast Artwork */
.hp-podcast__visual {
  display: flex;
  justify-content: center;
}

.hp-podcast__artwork {
  width: 280px;
  height: 280px;
  border-radius: var(--radius-xl);
  background: linear-gradient(135deg, rgba(210, 160, 100, 0.15), rgba(210, 160, 100, 0.05));
  border: 1px solid rgba(210, 160, 100, 0.2);
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  overflow: hidden;
}

.hp-podcast__artwork::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 30% 30%, rgba(210, 160, 100, 0.1), transparent 60%);
}

.hp-podcast__artwork-inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-lg);
  position: relative;
  z-index: 1;
  color: var(--color-accent);
}

.hp-podcast__artwork-title {
  font-size: var(--text-sm);
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: var(--tracking-widest);
  text-align: center;
  line-height: 1.5;
  color: var(--color-accent);
}

.hp-podcast__artwork-sub {
  font-size: var(--text-xs);
  color: rgba(250, 250, 248, 0.5);
  letter-spacing: var(--tracking-wider);
}

@media (max-width: 768px) {
  .hp-podcast {
    padding: var(--space-3xl) 0;
  }

  .hp-podcast__grid {
    grid-template-columns: 1fr;
    gap: var(--space-2xl);
  }

  .hp-podcast__visual {
    order: -1;
  }

  .hp-podcast__artwork {
    width: 200px;
    height: 200px;
  }
}

/* ============================================
   42. Final CTA Section
   ============================================ */

.hp-final-cta {
  padding: var(--space-5xl) 0;
  background: var(--color-primary-dark);
  color: var(--text-on-dark);
}

.hp-final-cta__inner {
  text-align: center;
  max-width: 640px;
  margin: 0 auto;
}

.hp-final-cta__title {
  font-family: var(--font-display);
  font-size: clamp(var(--text-3xl), 4vw, var(--text-4xl));
  font-weight: 400;
  letter-spacing: -0.01em;
  color: var(--color-white);
  margin-bottom: var(--space-lg);
}

.hp-final-cta__text {
  font-size: var(--text-lg);
  line-height: var(--leading-normal);
  color: rgba(250, 250, 248, 0.6);
  margin-bottom: var(--space-2xl);
}

.hp-final-cta__actions {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-lg);
}

.hp-final-cta__secondary {
  font-size: var(--text-sm);
  color: rgba(250, 250, 248, 0.5);
  text-decoration: none;
  font-weight: 500;
  transition: color var(--transition-fast);
}

.hp-final-cta__secondary:hover {
  color: var(--color-accent);
}

@media (max-width: 768px) {
  .hp-final-cta {
    padding: var(--space-3xl) 0;
  }
}

/* ============================================
   43. Page Hero (Services, About, Contact)
   ============================================ */

.page-hero {
  position: relative;
  padding: clamp(5rem, 10vw, 8rem) 0 clamp(3rem, 6vw, 5rem);
  background: var(--color-primary);
  color: var(--text-on-dark);
  overflow: hidden;
}

.page-hero__pattern {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
}

.page-hero__pattern svg {
  width: 100%;
  height: 100%;
}

.page-hero__content {
  position: relative;
  z-index: 1;
  max-width: 720px;
}

.page-hero__eyebrow {
  display: inline-block;
  font-size: var(--text-xs);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: var(--tracking-widest);
  color: var(--color-accent);
  margin-bottom: var(--space-lg);
}

.page-hero__title {
  font-family: var(--font-display);
  font-size: clamp(var(--text-3xl), 5vw, var(--text-5xl));
  font-weight: 400;
  line-height: var(--leading-tight);
  letter-spacing: -0.01em;
  color: var(--color-white);
  margin-bottom: var(--space-lg);
}

.page-hero__subtitle {
  font-size: var(--text-lg);
  line-height: var(--leading-normal);
  color: rgba(250, 250, 248, 0.6);
}

/* ============================================
   44. Services Page — Overview Strip
   ============================================ */

.svc-overview {
  padding: var(--space-3xl) 0;
  background: var(--bg);
  border-bottom: 1px solid var(--border-light);
}

.svc-overview__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-lg);
}

.svc-overview__card {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  padding: var(--space-xl);
  background: var(--bg-surface);
  border: 1px solid var(--border-light);
  border-radius: var(--radius-lg);
  text-decoration: none;
  position: relative;
  overflow: hidden;
  transition: all 0.5s cubic-bezier(0.22, 1, 0.36, 1);
}

.svc-overview__card::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: var(--color-accent);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.5s cubic-bezier(0.22, 1, 0.36, 1);
}

.svc-overview__card:hover {
  border-color: var(--border);
  box-shadow: 0 12px 40px rgba(0, 45, 55, 0.06);
  transform: translateY(-3px);
}

.svc-overview__card:hover::after {
  transform: scaleX(1);
}

.svc-overview__icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 48px;
  height: 48px;
  border-radius: var(--radius-full);
  background: rgba(0, 45, 55, 0.04);
  color: var(--color-accent);
  margin-bottom: var(--space-md);
  transition: all 0.5s cubic-bezier(0.22, 1, 0.36, 1);
}

.svc-overview__card:hover .svc-overview__icon {
  background: var(--color-primary);
  color: var(--color-accent);
}

.svc-overview__title {
  font-size: var(--text-base);
  font-weight: 700;
  color: var(--text);
  margin-bottom: var(--space-xs);
  line-height: 1.3;
}

.svc-overview__text {
  font-size: var(--text-sm);
  color: var(--text-secondary);
  line-height: 1.5;
  flex-grow: 1;
}

.svc-overview__arrow {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  border-radius: var(--radius-full);
  color: var(--color-accent);
  margin-top: var(--space-md);
  opacity: 0;
  transform: translateY(-4px);
  transition: all 0.4s ease;
}

.svc-overview__card:hover .svc-overview__arrow {
  opacity: 1;
  transform: translateY(0);
}

@media (max-width: 900px) {
  .svc-overview__grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

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

/* ============================================
   44b. Services Page — Detail Sections
   ============================================ */

.svc-detail {
  padding: var(--space-5xl) 0;
  border-bottom: 1px solid var(--border-light);
}

.svc-detail--alt {
  background: var(--color-warm-gray-50);
}

.svc-detail__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-4xl);
  align-items: start;
}

.svc-detail__grid--reverse {
  direction: rtl;
}

.svc-detail__grid--reverse > * {
  direction: ltr;
}

.svc-detail__num {
  display: inline-block;
  font-family: var(--font-display);
  font-size: clamp(var(--text-4xl), 5vw, var(--text-5xl));
  font-weight: 400;
  color: var(--color-accent);
  opacity: 0.3;
  line-height: 1;
  margin-bottom: var(--space-md);
}

.svc-detail__title {
  font-family: var(--font-display);
  font-size: clamp(var(--text-2xl), 3vw, var(--text-3xl));
  font-weight: 400;
  letter-spacing: -0.01em;
  color: var(--text);
  margin-bottom: var(--space-md);
  line-height: var(--leading-tight);
}

.svc-detail__tagline {
  font-size: var(--text-lg);
  font-weight: 600;
  color: var(--color-primary);
  margin-bottom: var(--space-lg);
  padding-left: var(--space-md);
  border-left: 3px solid var(--color-accent);
  line-height: 1.5;
}

.svc-detail__desc {
  font-size: var(--text-base);
  line-height: 1.8;
  color: var(--text-secondary);
}

/* Detail Cards */
.svc-detail__info {
  display: flex;
  flex-direction: column;
  gap: var(--space-lg);
}

.svc-detail__card {
  padding: var(--space-xl);
  background: var(--bg-surface);
  border: 1px solid var(--border-light);
  border-radius: var(--radius-lg);
  transition: all 0.5s cubic-bezier(0.22, 1, 0.36, 1);
}

.svc-detail--alt .svc-detail__card {
  background: var(--color-white, #fff);
}

.svc-detail__card:hover {
  border-color: var(--border);
  box-shadow: 0 8px 32px rgba(0, 45, 55, 0.05);
}

.svc-detail__card--highlight {
  border-left: 3px solid var(--color-accent);
  background: linear-gradient(135deg, rgba(210, 160, 100, 0.03), transparent);
}

.svc-detail__card-label {
  font-size: var(--text-xs);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: var(--tracking-widest);
  color: var(--color-accent);
  margin-bottom: var(--space-md);
  padding-bottom: var(--space-sm);
  border-bottom: 1px solid var(--border-light);
}

.svc-detail__list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.svc-detail__list li {
  position: relative;
  padding-left: var(--space-lg);
  padding-bottom: var(--space-sm);
  margin-bottom: var(--space-sm);
  font-size: var(--text-sm);
  line-height: 1.6;
  color: var(--text-secondary);
  border-bottom: 1px solid rgba(0, 0, 0, 0.03);
}

.svc-detail__list li:last-child {
  border-bottom: none;
  margin-bottom: 0;
  padding-bottom: 0;
}

.svc-detail__list li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 8px;
  width: 6px;
  height: 6px;
  border-radius: var(--radius-full);
  background: var(--color-accent);
}

/* Services Responsive */
@media (max-width: 900px) {
  .svc-detail {
    padding: var(--space-3xl) 0;
  }

  .svc-detail__grid,
  .svc-detail__grid--reverse {
    grid-template-columns: 1fr;
    gap: var(--space-2xl);
    direction: ltr;
  }
}

/* ============================================
   45. About Page Content
   ============================================ */

.about-content {
  padding: var(--space-4xl) 0;
}

.about-content .prose h3 {
  font-size: var(--text-2xl);
  color: var(--text);
  border-bottom: none;
  padding-bottom: 0;
  padding-left: var(--space-md);
  border-left: 3px solid var(--color-accent);
}

/* ============================================
   46. Contact Page
   ============================================ */

.page-hero--contact {
  position: relative;
  overflow: hidden;
}

.contact-hero__pattern {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
}

.contact-hero__pattern svg {
  width: 100%;
  height: 100%;
}

.page-hero--contact .page-hero__title {
  font-family: var(--font-display);
  font-weight: 400;
  letter-spacing: -0.01em;
}

.contact-content {
  padding: var(--space-4xl) 0;
}

.contact-grid {
  display: grid;
  grid-template-columns: 1.5fr 1fr;
  gap: var(--space-4xl);
  align-items: start;
}

.contact-main {
  display: flex;
  flex-direction: column;
  gap: var(--space-2xl);
}

.contact-form-block,
.contact-calendly {
  padding: var(--space-3xl);
  background: var(--bg-alt);
  border-radius: var(--radius-lg);
  border: 1px solid var(--border-light);
  border-left: 3px solid var(--color-accent);
  position: relative;
}

.contact-hubspot {
  margin-top: var(--space-lg);
}

/* HubSpot embed: nudge it to inherit MYLES typography & spacing.
   HubSpot wraps its form in a shadow-DOM container, so deep theming
   isn't possible without their style API — we only style the wrapper
   and the visible fallback. */
.contact-hubspot .hs-form-frame {
  min-height: 480px;
}

.contact-form-fallback {
  padding: var(--space-md) var(--space-lg);
  background: var(--bg-surface);
  border: 1px dashed var(--border);
  border-radius: var(--radius-md);
  color: var(--text-secondary);
  font-size: var(--text-sm);
}

.contact-form-fallback a {
  color: var(--color-coral);
  font-weight: 600;
}

.contact-section-title {
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  font-weight: 400;
  letter-spacing: -0.01em;
  color: var(--text);
  margin-bottom: var(--space-md);
}

.contact-section-text {
  font-size: var(--text-base);
  color: var(--text-secondary);
  line-height: var(--leading-normal);
  margin-bottom: var(--space-xl);
}

.contact-sidebar {
  display: flex;
  flex-direction: column;
  gap: var(--space-xl);
}

.contact-info-card {
  padding: var(--space-xl);
  background: var(--bg-surface);
  border: 1px solid var(--border-light);
  border-radius: var(--radius-md);
  transition: all 0.5s cubic-bezier(0.22, 1, 0.36, 1);
}

.contact-info-card:hover {
  border-color: var(--color-accent);
  box-shadow: 0 8px 32px rgba(0, 45, 55, 0.06);
  transform: translateY(-2px);
}

.contact-info-title {
  font-size: var(--text-xs);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: var(--tracking-widest);
  color: var(--color-accent);
  margin-bottom: var(--space-lg);
  padding-bottom: var(--space-md);
  border-bottom: 2px solid var(--color-accent);
}

.contact-info-item {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  margin-bottom: var(--space-md);
  color: var(--text-secondary);
}

.contact-info-item:last-child {
  margin-bottom: 0;
}

.contact-info-item svg {
  color: var(--color-accent);
  flex-shrink: 0;
}

.contact-info-item a {
  font-size: var(--text-sm);
  color: var(--text-secondary);
  text-decoration: none;
  transition: color var(--transition-fast);
}

.contact-info-item a:hover {
  color: var(--color-accent-dark);
}

.contact-address {
  font-style: normal;
  font-size: var(--text-sm);
  line-height: var(--leading-relaxed);
  color: var(--text-secondary);
}

.contact-social {
  display: flex;
  gap: var(--space-md);
}

.contact-social-link {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: var(--radius-full);
  border: 1px solid var(--border);
  color: var(--text-secondary);
  text-decoration: none;
  transition: all var(--transition-fast);
}

.contact-social-link:hover {
  border-color: var(--color-accent);
  color: var(--color-accent-dark);
  background: var(--color-accent-subtle);
}

@media (max-width: 768px) {
  .contact-grid {
    grid-template-columns: 1fr;
    gap: var(--space-2xl);
  }
}

/* ============================================
   47a. About — Team Section
   ============================================ */

.about-team {
  padding: var(--space-4xl) 0;
}

.about-team__eyebrow {
  display: block;
  font-size: var(--text-xs);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: var(--tracking-widest);
  color: var(--color-accent);
  margin-bottom: var(--space-2xl);
}

.about-team__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-2xl);
}

.about-team__card {
  display: flex;
  gap: var(--space-xl);
  padding: var(--space-xl);
  background: var(--bg-surface);
  border: 1px solid var(--border-light);
  border-radius: var(--radius-md);
  transition: all 0.5s cubic-bezier(0.22, 1, 0.36, 1);
  position: relative;
  overflow: hidden;
}

.about-team__card::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 3px;
  background: var(--color-accent);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.5s cubic-bezier(0.22, 1, 0.36, 1);
}

.about-team__card:hover {
  border-color: var(--color-accent);
  box-shadow: 0 12px 40px rgba(0, 45, 55, 0.08);
  transform: translateY(-4px);
}

.about-team__card:hover::after {
  transform: scaleX(1);
}

.about-team__photo {
  flex-shrink: 0;
  width: 120px;
  height: 120px;
  border-radius: var(--radius-full);
  overflow: hidden;
  border: 3px solid var(--color-accent);
  box-shadow: 0 4px 16px rgba(210, 160, 100, 0.2);
}

.about-team__photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.5s cubic-bezier(0.22, 1, 0.36, 1);
}

.about-team__card:hover .about-team__photo img {
  transform: scale(1.05);
}

.about-team__info {
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.about-team__name {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-weight: 400;
  color: var(--text);
  margin-bottom: var(--space-xs);
}

.about-team__role {
  font-size: var(--text-sm);
  color: var(--text-secondary);
  margin-bottom: var(--space-md);
}

.about-team__linkedin {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: var(--radius-full);
  border: 1px solid var(--border);
  color: var(--text-secondary);
  text-decoration: none;
  transition: all 0.3s ease;
}

.about-team__linkedin:hover {
  border-color: var(--color-accent);
  color: var(--color-accent-dark);
  background: var(--color-accent-subtle);
}

@media (max-width: 768px) {
  .about-team__grid {
    grid-template-columns: 1fr;
  }

  .about-team__card {
    flex-direction: column;
    align-items: center;
    text-align: center;
  }

  .about-team__info {
    align-items: center;
  }
}

/* ============================================
   47. Scroll Reveal — New Sections
   ============================================ */

.js .hp-problem,
.js .hp-services,
.js .hp-method,
.js .hp-testimonials,
.js .hp-podcast,
.js .hp-final-cta,
.js .hp-logos {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 0.7s ease, transform 0.7s ease;
}

.js .hp-problem.is-visible,
.js .hp-services.is-visible,
.js .hp-method.is-visible,
.js .hp-testimonials.is-visible,
.js .hp-podcast.is-visible,
.js .hp-final-cta.is-visible,
.js .hp-logos.is-visible {
  opacity: 1;
  transform: translateY(0);
}

@media (prefers-reduced-motion: reduce) {
  .hp-problem,
  .hp-services,
  .hp-method,
  .hp-testimonials,
  .hp-podcast,
  .hp-final-cta,
  .hp-logos {
    opacity: 1;
    transform: none;
    transition: none;
  }
}

/* ============================================
   48. Staggered Card Animations
   ============================================ */

.js .hp-testimonials__card,
.js .hp-method__step {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.6s cubic-bezier(0.22, 1, 0.36, 1),
              transform 0.6s cubic-bezier(0.22, 1, 0.36, 1);
}

.js .hp-testimonials__card.is-visible,
.js .hp-method__step.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.js .hp-services__card {
  opacity: 0;
  transform: translateY(20px);
}

.js .hp-services__card.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.hp-services__card:nth-child(2),
.hp-testimonials__card:nth-child(2),
.hp-method__step:nth-child(2) {
  transition-delay: 0.1s;
}

.hp-services__card:nth-child(3),
.hp-testimonials__card:nth-child(3),
.hp-method__step:nth-child(3) {
  transition-delay: 0.2s;
}

.hp-services__card:nth-child(4),
.hp-method__step:nth-child(4) {
  transition-delay: 0.3s;
}

.hp-method__step:nth-child(5) {
  transition-delay: 0.4s;
}

.hp-method__step:nth-child(6) {
  transition-delay: 0.5s;
}

@media (prefers-reduced-motion: reduce) {
  .hp-services__card,
  .hp-testimonials__card,
  .hp-method__step {
    opacity: 1;
    transform: none;
    transition: none;
  }
}

/* ============================================
   49. Legal Page Layout
   ============================================ */

.legal-page {
  background: var(--bg);
}

/* Legal Hero */
.legal-hero {
  position: relative;
  padding: clamp(5rem, 10vw, 8rem) 0 clamp(3rem, 6vw, 5rem);
  background: var(--color-primary);
  color: var(--text-on-dark);
  overflow: hidden;
}

.legal-hero__pattern {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
}

.legal-hero__pattern svg {
  width: 100%;
  height: 100%;
}

.legal-hero__content {
  position: relative;
  z-index: 1;
  max-width: 640px;
}

.legal-hero__eyebrow {
  display: inline-block;
  font-size: var(--text-xs);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: var(--tracking-widest);
  color: var(--color-accent);
  margin-bottom: var(--space-lg);
}

.legal-hero__title {
  font-family: var(--font-display);
  font-size: clamp(var(--text-3xl), 5vw, var(--text-5xl));
  font-weight: 400;
  letter-spacing: -0.01em;
  line-height: var(--leading-tight);
  color: var(--color-white);
  margin-bottom: var(--space-md);
}

.legal-hero__subtitle {
  font-size: var(--text-lg);
  line-height: var(--leading-normal);
  color: rgba(250, 250, 248, 0.6);
}

.legal-hero__border {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: linear-gradient(90deg,
    var(--color-accent) 0%,
    var(--color-accent) 30%,
    transparent 30%,
    transparent 33%,
    var(--color-accent) 33%,
    var(--color-accent) 38%,
    transparent 38%
  );
}

/* Legal Content Layout */
.legal-content {
  padding: var(--space-4xl) 0 var(--space-5xl);
}

.legal-layout {
  display: grid;
  grid-template-columns: 240px 1fr;
  gap: var(--space-4xl);
  align-items: start;
}

/* Legal Sidebar */
.legal-sidebar {
  position: sticky;
  top: 100px;
}

.legal-nav {
  margin-bottom: var(--space-2xl);
}

.legal-nav__label {
  display: block;
  font-size: var(--text-xs);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: var(--tracking-widest);
  color: var(--color-accent);
  margin-bottom: var(--space-md);
  padding-bottom: var(--space-sm);
  border-bottom: 2px solid var(--color-accent);
}

.legal-nav #TableOfContents {
  font-size: var(--text-sm);
}

.legal-nav #TableOfContents ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

.legal-nav #TableOfContents > ul > li {
  margin-bottom: 0;
}

.legal-nav #TableOfContents li {
  margin-bottom: var(--space-xs);
}

.legal-nav #TableOfContents a {
  display: block;
  padding: var(--space-xs) var(--space-sm);
  color: var(--text-secondary);
  text-decoration: none;
  border-left: 2px solid transparent;
  transition: all 0.3s ease;
  line-height: 1.4;
}

.legal-nav #TableOfContents a:hover {
  color: var(--color-primary);
  border-left-color: var(--color-accent);
  background: var(--color-warm-gray-50);
}

.legal-nav #TableOfContents ul ul {
  padding-left: var(--space-md);
}

.legal-nav #TableOfContents ul ul a {
  font-size: var(--text-xs);
  padding: 2px var(--space-sm);
}

/* Legal Contact Card */
.legal-contact-card {
  padding: var(--space-xl);
  background: var(--color-warm-gray-50);
  border-radius: var(--radius-lg);
  border-left: 3px solid var(--color-accent);
}

.legal-contact-card__title {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  font-weight: 400;
  color: var(--text);
  margin-bottom: var(--space-xs);
}

.legal-contact-card__text {
  font-size: var(--text-sm);
  color: var(--text-secondary);
  line-height: 1.5;
  margin-bottom: var(--space-md);
}

.legal-contact-card__link {
  display: inline-flex;
  align-items: center;
  gap: var(--space-xs);
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--color-primary);
  text-decoration: none;
  transition: color 0.3s ease;
}

.legal-contact-card__link:hover {
  color: var(--color-accent);
}

/* Legal Main Content */
.legal-main {
  max-width: 720px;
}

.legal-prose h2 {
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  font-weight: 400;
  letter-spacing: -0.01em;
  color: var(--text);
  margin-top: 0;
  margin-bottom: var(--space-xl);
  padding-bottom: var(--space-md);
  border-bottom: 2px solid var(--color-accent);
}

.legal-prose h3 {
  font-size: var(--text-lg);
  font-weight: 700;
  color: var(--text);
  margin-top: var(--space-2xl);
  margin-bottom: var(--space-md);
  padding-left: var(--space-md);
  border-left: 3px solid var(--color-accent);
}

.legal-prose p {
  font-size: var(--text-base);
  line-height: 1.8;
  color: var(--text-secondary);
  margin-bottom: var(--space-lg);
}

.legal-prose strong {
  color: var(--text);
  font-weight: 600;
}

.legal-prose ul,
.legal-prose ol {
  margin-bottom: var(--space-lg);
  padding-left: var(--space-xl);
}

.legal-prose li {
  font-size: var(--text-base);
  line-height: 1.8;
  color: var(--text-secondary);
  margin-bottom: var(--space-xs);
}

.legal-prose li::marker {
  color: var(--color-accent);
}

.legal-prose a {
  color: var(--color-primary);
  text-decoration: underline;
  text-underline-offset: 2px;
  transition: color 0.3s ease;
}

.legal-prose a:hover {
  color: var(--color-accent);
}

/* Legal Footer Meta */
.legal-footer-meta {
  margin-top: var(--space-4xl);
}

.legal-footer-meta__divider {
  height: 1px;
  background: linear-gradient(90deg,
    var(--color-accent),
    var(--border-light) 40%,
    transparent
  );
  margin-bottom: var(--space-xl);
}

.legal-footer-meta__text {
  font-size: var(--text-sm);
  color: var(--text-muted);
}

/* Legal Page Responsive */
@media (max-width: 900px) {
  .legal-layout {
    grid-template-columns: 1fr;
    gap: var(--space-2xl);
  }

  .legal-sidebar {
    position: static;
    display: flex;
    flex-direction: column;
    gap: var(--space-xl);
  }

  .legal-nav {
    margin-bottom: 0;
    padding: var(--space-lg);
    background: var(--color-warm-gray-50);
    border-radius: var(--radius-lg);
  }
}

@media (max-width: 768px) {
  .legal-hero {
    padding: var(--space-3xl) 0 var(--space-2xl);
  }

  .legal-content {
    padding: var(--space-2xl) 0 var(--space-3xl);
  }
}

/* ============================================
   Brand updates — Martin feedback 2026-05-04
   ============================================ */

:root {
  --color-headline: #235764;
}

/* Headlines on light backgrounds in #235764
   (NOTE: hp-services__title intentionally excluded — that section is on dark petrol) */
.hp-problem__title,
.hp-method__title,
.hp-testimonials__title,
.svc-detail__title,
.article-title,
.list-title,
.section-title,
.start-here-content .prose h2,
.start-here-content .prose h3,
.article-content h2,
.article-content h3,
.legal-content h2,
.legal-content h3 {
  color: var(--color-headline);
}

/* Body text on light surfaces in pure black */
.article-content,
.start-here-content,
.legal-content,
.hp-problem__text,
.svc-detail__desc {
  color: #000;
}

/* Hero stats bar: center the row (was left-aligned) */
.hp-hero__stats-bar {
  justify-content: center;
}

.hp-hero__stat:first-child {
  padding-left: var(--space-2xl);
  align-items: center;
}

@media (max-width: 768px) {
  .hp-hero__stats-bar {
    justify-content: center;
  }
  .hp-hero__stat:first-child {
    padding: 0;
    align-items: center;
  }
  .hp-hero__stat {
    align-items: center;
  }
}

/* Services page: make 01-04 numbers prominent */
.svc-detail__num {
  opacity: 1;
  color: var(--color-headline);
  font-weight: 700;
  font-size: clamp(3rem, 6vw, 5rem);
  letter-spacing: -0.02em;
}

/* Homepage methodology step numbers: stronger contrast */
.hp-method__step-num {
  opacity: 1;
  font-weight: 700;
}

/* Hero pledge — "We keep our promises." */
.hp-hero__pledge {
  margin-top: var(--space-lg);
  margin-bottom: var(--space-xl);
  font-family: var(--font-display);
  font-size: clamp(1.25rem, 2vw, 1.625rem);
  font-weight: 600;
  letter-spacing: 0.005em;
  color: var(--color-accent);
}

/* Podcast artwork — petrol gradient, removes greenish tint */
.hp-podcast__artwork {
  background: linear-gradient(135deg, #235764 0%, var(--color-primary) 100%);
  border: 1px solid rgba(210, 160, 100, 0.35);
}

.hp-podcast__artwork::before {
  background: radial-gradient(circle at 30% 30%, rgba(210, 160, 100, 0.18), transparent 60%);
}

/* ============================================
   Approach page (/approach, /ansatz)
   ============================================ */

.approach-intro {
  padding: var(--space-4xl) 0;
  background: var(--bg-surface);
}

.approach-partnership {
  padding: var(--space-4xl) 0;
  background: var(--color-primary);
  color: var(--text-on-dark);
}

.approach-partnership__inner {
  max-width: 760px;
  margin: 0 auto;
  text-align: center;
}

.approach-partnership__eyebrow {
  display: inline-block;
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: var(--tracking-widest);
  text-transform: uppercase;
  color: var(--color-gold);
  margin-bottom: var(--space-md);
}

.approach-partnership__title {
  font-family: var(--font-display);
  font-size: clamp(1.75rem, 3vw, 2.5rem);
  font-weight: 700;
  line-height: var(--leading-tight);
  letter-spacing: var(--tracking-tight);
  margin-bottom: var(--space-lg);
  color: var(--text-on-dark);
}

.approach-partnership__text {
  font-size: var(--text-lg);
  line-height: var(--leading-relaxed);
  color: rgba(250, 250, 248, 0.85);
  margin-bottom: var(--space-xl);
}

.approach-partnership__link {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  color: var(--color-gold);
  font-weight: 600;
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  font-size: var(--text-sm);
  border-bottom: 1px solid rgba(210, 160, 100, 0.4);
  padding-bottom: 4px;
  transition: color var(--transition), border-color var(--transition);
}

.approach-partnership__link:hover {
  color: var(--color-coral);
  border-color: var(--color-coral);
}

.approach-whitepapers {
  padding: var(--space-4xl) 0;
  background: var(--bg-alt);
}

.approach-whitepapers__header {
  max-width: 760px;
  margin: 0 auto var(--space-3xl);
  text-align: center;
}

.approach-whitepapers__eyebrow {
  display: inline-block;
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: var(--tracking-widest);
  text-transform: uppercase;
  color: var(--color-teal-mid);
  margin-bottom: var(--space-md);
}

.approach-whitepapers__title {
  font-family: var(--font-display);
  font-size: clamp(1.75rem, 3vw, 2.5rem);
  font-weight: 700;
  line-height: var(--leading-tight);
  letter-spacing: var(--tracking-tight);
  margin-bottom: var(--space-md);
  color: var(--color-primary);
}

.approach-whitepapers__lede {
  font-size: var(--text-lg);
  line-height: var(--leading-relaxed);
  color: var(--text-secondary);
}

.approach-whitepapers__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: var(--space-xl);
}

.wp-card {
  background: var(--bg-surface);
  border: 1px solid var(--border-light);
  border-radius: var(--radius-lg);
  padding: var(--space-2xl);
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
  transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition);
}

.wp-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-lg);
  border-color: var(--color-gold);
}

.wp-card__type {
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: var(--tracking-widest);
  text-transform: uppercase;
  color: var(--color-teal-mid);
}

.wp-card__title {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-weight: 700;
  line-height: var(--leading-snug);
  color: var(--color-primary);
}

.wp-card__text {
  font-size: var(--text-base);
  line-height: var(--leading-normal);
  color: var(--text-secondary);
  flex: 1;
}

.wp-card__cta {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  align-self: flex-start;
  color: var(--color-coral);
  font-weight: 600;
  font-size: var(--text-sm);
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  margin-top: var(--space-md);
}

.wp-card__cta:hover {
  color: var(--color-coral-dark);
}

.wp-card__cta[data-coming-soon] {
  cursor: not-allowed;
  opacity: 0.7;
}

.approach-fit {
  padding: var(--space-4xl) 0;
  background: var(--bg-surface);
}

.approach-fit__inner {
  text-align: center;
}

.approach-fit__eyebrow {
  display: inline-block;
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: var(--tracking-widest);
  text-transform: uppercase;
  color: var(--color-coral);
  margin-bottom: var(--space-md);
}

.approach-fit__title {
  font-family: var(--font-display);
  font-size: clamp(1.5rem, 3vw, 2.25rem);
  font-weight: 700;
  line-height: var(--leading-snug);
  letter-spacing: var(--tracking-tight);
  margin-bottom: var(--space-lg);
  color: var(--color-primary);
}

.approach-fit__text {
  font-size: var(--text-lg);
  line-height: var(--leading-relaxed);
  color: var(--text-secondary);
  max-width: 640px;
  margin: 0 auto;
}

/* ============================================
   ODI deep-dive page (/odi)
   ============================================ */

.odi-quote {
  padding: var(--space-4xl) 0;
  background: var(--bg-surface);
}

.odi-quote__inner {
  text-align: left;
  border-left: 4px solid var(--color-gold);
  padding: var(--space-lg) var(--space-2xl);
  font-style: italic;
}

.odi-quote__text {
  font-family: var(--font-display);
  font-size: clamp(1.25rem, 2.2vw, 1.625rem);
  font-weight: 400;
  line-height: var(--leading-relaxed);
  color: var(--color-primary);
  margin-bottom: var(--space-md);
}

.odi-quote__cite {
  display: block;
  font-style: normal;
  font-size: var(--text-sm);
  font-weight: 600;
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  color: var(--text-secondary);
}

.odi-quote__cite span {
  font-weight: 400;
  text-transform: none;
  letter-spacing: 0;
  color: var(--text-muted);
}

.odi-foundation {
  padding: var(--space-4xl) 0;
  background: var(--bg-alt);
}

.odi-foundation__header {
  max-width: 780px;
  margin: 0 auto var(--space-3xl);
  text-align: center;
}

.odi-foundation__eyebrow {
  display: inline-block;
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: var(--tracking-widest);
  text-transform: uppercase;
  color: var(--color-teal-mid);
  margin-bottom: var(--space-md);
}

.odi-foundation__title {
  font-family: var(--font-display);
  font-size: clamp(1.75rem, 3vw, 2.5rem);
  font-weight: 700;
  line-height: var(--leading-tight);
  letter-spacing: var(--tracking-tight);
  margin-bottom: var(--space-md);
  color: var(--color-primary);
}

.odi-foundation__lede {
  font-size: var(--text-lg);
  color: var(--text-secondary);
  line-height: var(--leading-relaxed);
}

.odi-foundation__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: var(--space-xl);
}

.odi-foundation__card {
  background: var(--bg-surface);
  border: 1px solid var(--border-light);
  border-radius: var(--radius-lg);
  padding: var(--space-2xl);
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
}

.odi-foundation__num {
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  font-weight: 700;
  color: var(--color-coral);
  letter-spacing: var(--tracking-tight);
}

.odi-foundation__heading {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-weight: 700;
  line-height: var(--leading-snug);
  color: var(--color-primary);
}

.odi-foundation__text {
  font-size: var(--text-base);
  line-height: var(--leading-relaxed);
  color: var(--text-secondary);
}

.odi-process {
  padding: var(--space-4xl) 0;
  background: var(--bg-surface);
}

.odi-process__header {
  max-width: 780px;
  margin: 0 auto var(--space-3xl);
  text-align: center;
}

.odi-process__eyebrow {
  display: inline-block;
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: var(--tracking-widest);
  text-transform: uppercase;
  color: var(--color-teal-mid);
  margin-bottom: var(--space-md);
}

.odi-process__title {
  font-family: var(--font-display);
  font-size: clamp(1.75rem, 3vw, 2.5rem);
  font-weight: 700;
  line-height: var(--leading-tight);
  letter-spacing: var(--tracking-tight);
  margin-bottom: var(--space-md);
  color: var(--color-primary);
}

.odi-process__lede {
  font-size: var(--text-lg);
  color: var(--text-secondary);
  line-height: var(--leading-relaxed);
}

.odi-process__steps {
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
}

.odi-step {
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  background: var(--bg-surface);
  overflow: hidden;
  transition: border-color var(--transition), box-shadow var(--transition);
}

.odi-step[open] {
  border-color: var(--color-teal-mid);
  box-shadow: var(--shadow-md);
}

.odi-step__summary {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: var(--space-lg);
  padding: var(--space-lg) var(--space-xl);
  cursor: pointer;
  list-style: none;
  user-select: none;
  transition: background-color var(--transition);
}

.odi-step__summary::-webkit-details-marker {
  display: none;
}

.odi-step__summary:hover {
  background-color: var(--bg-alt);
}

.odi-step__num {
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  font-weight: 700;
  color: var(--color-coral);
  min-width: 2.5em;
  letter-spacing: var(--tracking-tight);
}

.odi-step__title {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  font-weight: 700;
  color: var(--color-primary);
  line-height: var(--leading-snug);
}

.odi-step__chev {
  color: var(--color-teal-mid);
  transition: transform var(--transition);
}

.odi-step[open] .odi-step__chev {
  transform: rotate(180deg);
}

.odi-step__body {
  padding: 0 var(--space-xl) var(--space-xl) calc(var(--space-xl) + 2.5em + var(--space-lg));
  color: var(--text-secondary);
  font-size: var(--text-base);
  line-height: var(--leading-relaxed);
  border-top: 1px solid var(--border-light);
  padding-top: var(--space-lg);
}

@media (max-width: 640px) {
  .odi-step__summary {
    grid-template-columns: auto 1fr;
    grid-template-rows: auto auto;
    gap: var(--space-sm) var(--space-md);
    padding: var(--space-md) var(--space-lg);
  }
  .odi-step__num { grid-row: 1; grid-column: 1; font-size: var(--text-xl); }
  .odi-step__title { grid-row: 1; grid-column: 2; font-size: var(--text-base); }
  .odi-step__chev { grid-row: 1; grid-column: 2; justify-self: end; }
  .odi-step__body {
    padding: var(--space-md) var(--space-lg) var(--space-lg);
  }
}

/* Page-hero variants for new pages */
.page-hero--approach,
.page-hero--odi {
  background: linear-gradient(140deg, var(--color-primary) 0%, var(--color-teal-dark) 100%);
}

/* ============================================================================
   DESIGN SYSTEM v2 — Editorial / McKinsey-grade
   ============================================================================
   Philosophy:
   - Helvetica Neue treated as the protagonist, not invisible utility
   - Generous editorial scale (clamp-based, fluid)
   - Hairline rules instead of zebra section flips
   - Statistic moments as full-width design
   - Photography as atmosphere
   - Coral as inline typographic accent (not just buttons)
   - Warm gold for citation / quotation only
   ============================================================================ */

:root {
  /* Editorial type scale (fluid clamp) */
  --display-1: clamp(3rem, 7vw + 1rem, 8rem);       /* Hero H1 */
  --display-2: clamp(2.25rem, 4vw + 0.5rem, 4.5rem); /* Section title */
  --display-3: clamp(1.75rem, 2.5vw + 0.5rem, 3rem); /* Sub-section */
  --stat-display: clamp(5rem, 14vw, 16rem);          /* Statistic moments */
  --lede: clamp(1.125rem, 1.5vw + 0.4rem, 1.5rem);   /* Editorial lede */
  --caption: 0.75rem;                                /* Small-caps captions */

  --rule-width: 1px;
  --rule-color: rgba(0, 45, 55, 0.12);
  --rule-color-dark: rgba(255, 255, 255, 0.14);

  --paper-noise: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><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.04 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
}

body {
  /* Subtle paper grain to fight the digital flatness */
  background-image: var(--paper-noise);
  background-attachment: fixed;
}

/* Tabular figures for all numbers — required for statistic blocks */
.tabular,
.ed-stat__num,
.ed-stat-row__num,
.ed-section-no,
.ed-step__no {
  font-variant-numeric: tabular-nums lining-nums;
  font-feature-settings: "tnum", "lnum";
}

/* ----------------------------------------------------------------------------
   ED-HERO — editorial hero (replaces page-hero + hp-hero pattern)
   ---------------------------------------------------------------------------- */

.ed-hero {
  position: relative;
  min-height: 92vh;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: clamp(7rem, 12vw, 11rem) 0 clamp(4rem, 7vw, 6rem);
  background: var(--color-primary);
  color: var(--text-on-dark);
  overflow: hidden;
  isolation: isolate;
}

/* Photo + veil cover the entire hero (top to bottom). The stats bar at the
   bottom is translucent so the photo shows through it — no separate opaque
   navy band. The photo's lower edge therefore matches the stats bar's lower
   edge (both at hero bottom). */
.ed-hero__photo {
  position: absolute;
  inset: 0;
  z-index: -2;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  background-size: cover;
  background-position: center;
  opacity: 0.55;
  filter: grayscale(0.3) contrast(1.05);
}

.ed-hero__veil {
  position: absolute;
  inset: 0;
  z-index: -1;
  background:
    linear-gradient(180deg,
      rgba(0,45,55,0.30) 0%,
      rgba(0,45,55,0.45) 60%,
      rgba(0,45,55,0.65) 100%),
    linear-gradient(120deg,
      rgba(0,45,55,0.78) 0%,
      rgba(35,87,100,0.15) 100%);
}

.ed-hero__meta {
  display: flex;
  align-items: center;
  gap: 1rem;
  font-size: var(--caption);
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-gold);
  margin-bottom: clamp(2rem, 4vw, 3rem);
}

.ed-hero__meta::before {
  content: '';
  width: 2.5rem;
  height: 1px;
  background: var(--color-coral);
}

.ed-hero__title {
  font-family: var(--font-display);
  font-size: var(--display-1);
  line-height: 0.96;
  letter-spacing: -0.035em;
  font-weight: 700;
  color: var(--color-off-white);
  margin: 0;
  max-width: 18ch;
}

.ed-hero__title em {
  font-style: normal;
  color: var(--color-coral);
}

.ed-hero__lede {
  font-size: var(--lede);
  line-height: 1.45;
  max-width: 48ch;
  margin-top: clamp(1.5rem, 3vw, 2.5rem);
  color: rgba(250, 250, 248, 0.82);
  font-weight: 300;
}

.ed-hero__rule {
  width: 100%;
  height: 1px;
  background: var(--rule-color-dark);
  margin: clamp(2rem, 4vw, 3rem) 0 clamp(1.25rem, 2vw, 2rem);
}

.ed-hero__actions {
  display: flex;
  gap: 1.25rem;
  align-items: center;
  flex-wrap: wrap;
}

.ed-hero__stats {
  /* Now a standalone section sitting BETWEEN .ed-hero and .ed-clients.
     Its top border touches the hero's bottom edge, and its bottom border
     touches the clients section's top edge (the shared border the user
     wants). Solid navy background reads as a clean band. */
  display: block;
  margin: 0;
  padding: 1.75rem 0;
  background: var(--color-primary-dark);
  border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.ed-hero__stats-inner {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
}

.ed-hero__stat {
  padding: 0 clamp(1rem, 2vw, 2rem);
  border-right: 1px solid var(--rule-color-dark);
}

.ed-hero__stat:last-child { border-right: none; }

.ed-hero__stat-num {
  font-family: var(--font-display);
  font-size: clamp(1.75rem, 3vw, 2.75rem);
  font-weight: 700;
  letter-spacing: -0.02em;
  line-height: 1;
  color: var(--color-off-white);
  font-variant-numeric: tabular-nums lining-nums;
}

.ed-hero__stat-num em {
  font-style: normal;
  color: var(--color-coral);
}

.ed-hero__stat-label {
  display: block;
  font-size: 0.7rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: rgba(250, 250, 248, 0.55);
  margin-top: 0.5rem;
  font-weight: 500;
}

@media (max-width: 720px) {
  .ed-hero__stats-inner {
    grid-template-columns: repeat(2, 1fr);
    gap: 1rem;
  }
  .ed-hero__stat {
    padding: 0.75rem 1rem;
    border-right: none;
  }
}

/* ----------------------------------------------------------------------------
   ED-CHAPTER — numbered section header, magazine-style
   ---------------------------------------------------------------------------- */

.ed-chapter {
  padding: clamp(5rem, 10vw, 9rem) 0 clamp(3rem, 6vw, 5rem);
  position: relative;
}

.ed-chapter--dark {
  background: var(--color-primary);
  color: var(--text-on-dark);
}

.ed-chapter__inner {
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(2rem, 5vw, 4rem);
}

@media (min-width: 1024px) {
  .ed-chapter__inner {
    grid-template-columns: 200px 1fr;
    align-items: start;
  }
}

.ed-chapter__meta {
  font-size: var(--caption);
  letter-spacing: 0.2em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--color-teal-mid);
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

/* Sticky only when used as a sidebar meta inside a two-column chapter layout.
   Inline (<div>) usages on contact + whitepaper-download must stay in flow. */
aside.ed-chapter__meta {
  position: sticky;
  top: calc(var(--header-height) + 1.5rem);
}

.ed-chapter__no {
  font-family: var(--font-display);
  font-size: 1rem;
  font-weight: 700;
  color: var(--color-coral);
  letter-spacing: -0.02em;
  font-variant-numeric: tabular-nums lining-nums;
}

.ed-chapter__title {
  font-family: var(--font-display);
  font-size: var(--display-2);
  line-height: 1.02;
  letter-spacing: -0.03em;
  font-weight: 700;
  color: var(--color-primary);
  margin: 0 0 clamp(1.25rem, 2.5vw, 2rem);
  max-width: 22ch;
}

.ed-chapter--dark .ed-chapter__title {
  color: var(--color-off-white);
}

.ed-chapter__title em {
  font-style: normal;
  color: var(--color-coral);
}

.ed-chapter__lede {
  font-size: var(--lede);
  line-height: 1.5;
  max-width: 56ch;
  color: var(--text-secondary);
  font-weight: 300;
}

.ed-chapter--dark .ed-chapter__lede {
  color: rgba(250, 250, 248, 0.78);
}

.ed-chapter__body {
  margin-top: clamp(2rem, 4vw, 3rem);
  font-size: 1.0625rem;
  line-height: 1.7;
  color: var(--text-secondary);
  max-width: 64ch;
}

.ed-chapter--dark .ed-chapter__body {
  color: rgba(250, 250, 248, 0.75);
}

.ed-chapter__body p + p { margin-top: 1.25rem; }

.ed-chapter__body em {
  font-style: normal;
  color: var(--color-coral);
  font-weight: 500;
}

.ed-chapter--dark .ed-chapter__body em {
  color: var(--color-coral-light);
}

/* ----------------------------------------------------------------------------
   ED-STAT — full-width statistic moment (signature element)
   ---------------------------------------------------------------------------- */

.ed-stat {
  padding: clamp(5rem, 10vw, 8rem) 0;
  background: var(--bg);
  border-top: 1px solid var(--rule-color);
  border-bottom: 1px solid var(--rule-color);
  text-align: left;
}

.ed-stat--dark {
  background: var(--color-primary);
  color: var(--text-on-dark);
  border-color: var(--rule-color-dark);
}

.ed-stat__layout {
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(2rem, 5vw, 4rem);
  align-items: center;
}

@media (min-width: 768px) {
  .ed-stat__layout { grid-template-columns: 1.2fr 1fr; }
}

.ed-stat__num {
  font-family: var(--font-display);
  font-size: var(--stat-display);
  font-weight: 700;
  line-height: 0.85;
  letter-spacing: -0.05em;
  color: var(--color-primary);
  margin: 0;
  font-variant-numeric: tabular-nums lining-nums;
}

.ed-stat--dark .ed-stat__num {
  color: var(--color-off-white);
}

.ed-stat__num sup {
  font-size: 0.4em;
  vertical-align: super;
  margin-left: 0.1em;
  color: var(--color-coral);
  font-weight: 700;
}

.ed-stat__copy {
  border-left: 1px solid var(--rule-color);
  padding-left: clamp(1.5rem, 3vw, 2.5rem);
}

.ed-stat--dark .ed-stat__copy {
  border-color: var(--rule-color-dark);
}

.ed-stat__label {
  display: block;
  font-size: var(--caption);
  letter-spacing: 0.2em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--color-teal-mid);
  margin-bottom: 1rem;
}

.ed-stat__title {
  font-family: var(--font-display);
  font-size: clamp(1.25rem, 2vw + 0.3rem, 1.75rem);
  font-weight: 700;
  line-height: 1.15;
  letter-spacing: -0.02em;
  color: var(--color-primary);
  margin: 0 0 1rem;
  max-width: 24ch;
}

.ed-stat--dark .ed-stat__title {
  color: var(--color-off-white);
}

.ed-stat__text {
  font-size: 1rem;
  line-height: 1.6;
  color: var(--text-secondary);
  max-width: 42ch;
}

.ed-stat--dark .ed-stat__text {
  color: rgba(250, 250, 248, 0.7);
}

/* ----------------------------------------------------------------------------
   ED-PULL — editorial pull quote (full-width break)
   ---------------------------------------------------------------------------- */

.ed-pull {
  padding: clamp(5rem, 10vw, 8rem) 0;
  background: var(--bg);
  border-top: 1px solid var(--rule-color);
  border-bottom: 1px solid var(--rule-color);
}

.ed-pull__inner {
  max-width: 900px;
  margin: 0 auto;
  text-align: left;
  position: relative;
}

.ed-pull__mark {
  font-family: var(--font-display);
  font-size: clamp(6rem, 12vw, 12rem);
  line-height: 0.6;
  color: var(--color-gold);
  font-weight: 700;
  position: absolute;
  top: -0.2em;
  left: -0.1em;
  z-index: 0;
  user-select: none;
}

.ed-pull__text {
  position: relative;
  z-index: 1;
  font-family: var(--font-display);
  font-size: clamp(1.5rem, 2.5vw + 0.4rem, 2.5rem);
  font-weight: 400;
  line-height: 1.25;
  letter-spacing: -0.015em;
  color: var(--color-primary);
  margin: 0;
  padding-left: clamp(2rem, 5vw, 4rem);
}

.ed-pull__text em {
  font-style: normal;
  color: var(--color-coral);
}

.ed-pull__cite {
  display: block;
  margin-top: 2rem;
  padding-left: clamp(2rem, 5vw, 4rem);
  font-size: var(--caption);
  letter-spacing: 0.2em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--color-teal-mid);
  font-style: normal;
}

.ed-pull__cite span {
  font-weight: 400;
  text-transform: none;
  letter-spacing: 0;
  color: var(--text-muted);
  display: block;
  margin-top: 0.25rem;
  font-size: 0.85rem;
}

/* ----------------------------------------------------------------------------
   ED-INSIGHTS — editorial card grid (replaces whitepaper boxes / blog teasers)
   ---------------------------------------------------------------------------- */

.ed-insights {
  padding: clamp(5rem, 10vw, 8rem) 0;
}

.ed-insights__head {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  padding-bottom: 2rem;
  margin-bottom: clamp(2rem, 4vw, 3rem);
  border-bottom: 1px solid var(--rule-color);
  flex-wrap: wrap;
  gap: 1.5rem;
}

.ed-insights__eyebrow {
  font-size: var(--caption);
  letter-spacing: 0.2em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--color-coral);
  display: block;
  margin-bottom: 0.75rem;
}

.ed-insights__title {
  font-family: var(--font-display);
  font-size: clamp(2rem, 3.5vw, 3rem);
  font-weight: 700;
  letter-spacing: -0.025em;
  line-height: 1.05;
  color: var(--color-primary);
  margin: 0;
  max-width: 18ch;
}

.ed-insights__all {
  font-size: var(--caption);
  letter-spacing: 0.2em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--color-primary);
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  border-bottom: 1px solid var(--color-primary);
  padding-bottom: 4px;
  transition: color var(--transition), border-color var(--transition);
}

.ed-insights__all:hover {
  color: var(--color-coral);
  border-color: var(--color-coral);
}

.ed-insights__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 0;
  border-top: 1px solid var(--rule-color);
}

.ed-card {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
  padding: 2rem 2rem 2.5rem;
  border-right: 1px solid var(--rule-color);
  border-bottom: 1px solid var(--rule-color);
  background: var(--bg);
  text-decoration: none;
  transition: background-color var(--transition);
  overflow: hidden;
}

.ed-card:last-child { border-right: none; }

@media (max-width: 900px) {
  .ed-card { border-right: none; }
}

.ed-card:hover {
  background: var(--bg-alt);
}

.ed-card__image {
  aspect-ratio: 16 / 10;
  background-size: cover;
  background-position: center;
  background-color: var(--color-primary);
  margin: -2rem -2rem 0;
  filter: grayscale(0.15) contrast(1.05);
  transition: filter var(--transition);
}

.ed-card:hover .ed-card__image {
  filter: grayscale(0) contrast(1.1);
}

.ed-card__meta {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  font-size: 0.7rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--color-coral);
}

.ed-card__meta-dot {
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background: var(--color-coral);
}

.ed-card__date {
  color: var(--text-muted);
  font-size: 0.7rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-weight: 400;
}

.ed-card__title {
  font-family: var(--font-display);
  font-size: clamp(1.125rem, 1.5vw + 0.4rem, 1.5rem);
  font-weight: 700;
  line-height: 1.2;
  letter-spacing: -0.02em;
  color: var(--color-primary);
  margin: 0;
}

.ed-card:hover .ed-card__title { color: var(--color-coral-dark); }

.ed-card__excerpt {
  font-size: 0.9375rem;
  line-height: 1.55;
  color: var(--text-secondary);
  margin-top: auto;
}

.ed-card__readmore {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  margin-top: 0.5rem;
  font-size: var(--caption);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--color-primary);
}

/* ----------------------------------------------------------------------------
   ED-PROCESS — custom ODI 6-step diagram (replaces accordion)
   Editorial chapter style: massive number + title + body
   ---------------------------------------------------------------------------- */

.ed-process {
  padding: clamp(4rem, 8vw, 7rem) 0;
}

.ed-step {
  padding: clamp(3rem, 5vw, 5rem) 0;
  border-top: 1px solid var(--rule-color);
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(1.5rem, 3vw, 2.5rem);
  position: relative;
}

@media (min-width: 900px) {
  .ed-step {
    grid-template-columns: minmax(180px, 240px) 1fr;
    gap: clamp(2rem, 5vw, 5rem);
  }
}

.ed-step:last-child { border-bottom: 1px solid var(--rule-color); }

.ed-step__no {
  font-family: var(--font-display);
  font-size: clamp(3.5rem, 7vw, 6rem);
  font-weight: 700;
  letter-spacing: -0.04em;
  line-height: 0.85;
  color: var(--color-coral);
  font-variant-numeric: tabular-nums lining-nums;
}

.ed-step__title {
  font-family: var(--font-display);
  font-size: clamp(1.375rem, 2vw + 0.3rem, 2rem);
  font-weight: 700;
  letter-spacing: -0.02em;
  line-height: 1.1;
  color: var(--color-primary);
  margin: 0 0 1rem;
  max-width: 28ch;
}

.ed-step__body {
  font-size: 1rem;
  line-height: 1.65;
  color: var(--text-secondary);
  max-width: 64ch;
}

.ed-step__body em {
  font-style: normal;
  color: var(--color-coral);
  font-weight: 500;
}

/* ----------------------------------------------------------------------------
   ED-CTA — full-width call-to-action band
   ---------------------------------------------------------------------------- */

.ed-cta {
  padding: clamp(5rem, 10vw, 8rem) 0;
  background: var(--color-primary);
  color: var(--text-on-dark);
  position: relative;
  overflow: hidden;
}

.ed-cta::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--color-coral) 35%, var(--color-coral) 65%, transparent);
  opacity: 0.6;
}

.ed-cta__layout {
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(2rem, 4vw, 3rem);
  align-items: end;
}

@media (min-width: 900px) {
  .ed-cta__layout { grid-template-columns: 1.4fr 1fr; }
}

.ed-cta__eyebrow {
  font-size: var(--caption);
  letter-spacing: 0.2em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--color-coral);
  display: block;
  margin-bottom: 1.25rem;
}

.ed-cta__title {
  font-family: var(--font-display);
  font-size: clamp(2rem, 4vw, 3.5rem);
  font-weight: 700;
  letter-spacing: -0.03em;
  line-height: 1.05;
  color: var(--color-off-white);
  margin: 0;
  max-width: 18ch;
}

.ed-cta__title em {
  font-style: normal;
  color: var(--color-coral);
}

.ed-cta__actions {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  align-items: flex-start;
}

@media (min-width: 900px) {
  .ed-cta__actions { align-items: flex-end; }
}

/* ----------------------------------------------------------------------------
   FOOTER MASTHEAD — full-bleed dark, oversized wordmark
   ---------------------------------------------------------------------------- */

.ed-footer {
  background: var(--color-primary);
  color: var(--text-on-dark);
  padding: clamp(4rem, 8vw, 6rem) 0 2rem;
  position: relative;
}

.ed-footer::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 1px;
  background: var(--rule-color-dark);
}

/* Stacked footer masthead — MYLES large, AHEAD smaller under it. */
.ed-footer__masthead {
  display: inline-flex;
  flex-direction: column;
  align-items: flex-start;
  font-family: var(--font-display);
  color: var(--color-off-white);
  margin-bottom: clamp(2rem, 5vw, 4rem);
  text-decoration: none;
  line-height: 0.92;
  gap: 0.18em;
}

.ed-footer__masthead-primary {
  font-size: clamp(4rem, 14vw, 11rem);
  font-weight: 500;
  letter-spacing: 0.04em;
  line-height: 0.9;
  color: var(--color-off-white);
}

.ed-footer__masthead-secondary {
  font-size: clamp(1.25rem, 4vw, 3rem);
  font-weight: 400;
  letter-spacing: 0.32em;
  line-height: 1;
  color: var(--color-off-white);
  /* match the optical alignment under the MYLES word */
  padding-left: 0.32em;
}

.ed-footer__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: clamp(2rem, 4vw, 3rem);
  padding: clamp(2.5rem, 5vw, 4rem) 0;
  border-top: 1px solid var(--rule-color-dark);
}

.ed-footer__col-label {
  font-size: var(--caption);
  letter-spacing: 0.2em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--color-coral);
  margin-bottom: 1.25rem;
}

.ed-footer__col ul {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

.ed-footer__col a {
  color: rgba(250, 250, 248, 0.75);
  font-size: 0.9375rem;
  transition: color var(--transition);
}

.ed-footer__col a:hover { color: var(--color-off-white); }

.ed-footer__address {
  font-style: normal;
  font-size: 0.9375rem;
  line-height: 1.6;
  color: rgba(250, 250, 248, 0.75);
}

.ed-footer__colophon {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-top: 2rem;
  border-top: 1px solid var(--rule-color-dark);
  font-size: 0.75rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(250, 250, 248, 0.45);
  flex-wrap: wrap;
  gap: 1rem;
}

.ed-footer__legal {
  display: flex;
  gap: 1.5rem;
  flex-wrap: wrap;
}

.ed-footer__legal a {
  color: inherit;
  transition: color var(--transition);
}

.ed-footer__legal a:hover { color: var(--color-coral); }

/* ----------------------------------------------------------------------------
   BUTTON SYSTEM v2 — editorial, hairline-bordered
   ---------------------------------------------------------------------------- */

.ed-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.75rem;
  padding: 1.1rem 1.75rem;
  border: 1px solid currentColor;
  background: transparent;
  color: var(--color-off-white);
  font-family: var(--font-sans);
  font-size: 0.85rem;
  font-weight: 600;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  text-decoration: none;
  cursor: pointer;
  transition: background-color var(--transition), color var(--transition), border-color var(--transition);
  position: relative;
  overflow: hidden;
}

.ed-btn--coral {
  background: var(--color-coral);
  border-color: var(--color-coral);
  color: var(--color-off-white);
}

.ed-btn--coral:hover {
  background: var(--color-coral-dark);
  border-color: var(--color-coral-dark);
  color: var(--color-off-white);
}

.ed-btn--ghost {
  background: transparent;
  border-color: rgba(255,255,255,0.4);
}

.ed-btn--ghost:hover {
  background: rgba(255,255,255,0.06);
  border-color: var(--color-off-white);
}

.ed-btn--dark {
  background: var(--color-primary);
  border-color: var(--color-primary);
  color: var(--color-off-white);
}

.ed-btn--dark:hover {
  background: transparent;
  color: var(--color-primary);
  border-color: var(--color-primary);
}

.ed-btn__arrow {
  display: inline-block;
  transition: transform var(--transition);
}

.ed-btn:hover .ed-btn__arrow {
  transform: translateX(4px);
}

/* ----------------------------------------------------------------------------
   ED-RULE — hairline section divider with optional centered label
   ---------------------------------------------------------------------------- */

.ed-rule {
  height: 1px;
  background: var(--rule-color);
  border: 0;
  margin: 0;
}

.ed-rule--dark { background: var(--rule-color-dark); }

/* ----------------------------------------------------------------------------
   ED-IN — inline accent for body text. Use as <em class="ed-in"> or <span>
   ---------------------------------------------------------------------------- */

.ed-in {
  font-style: normal;
  color: var(--color-coral);
  font-weight: 500;
}

.ed-in--gold { color: var(--color-gold-dark); }

/* ----------------------------------------------------------------------------
   STAGGER REVEAL — refined motion (extends existing .hp-reveal)
   ---------------------------------------------------------------------------- */

.js .ed-reveal > * {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 0.8s cubic-bezier(0.22, 1, 0.36, 1),
              transform 0.8s cubic-bezier(0.22, 1, 0.36, 1);
}

/* Decorative hero backgrounds must NOT participate in the reveal animation —
   they're absolutely positioned with `z-index: -2` to sit behind the hero copy.
   `.ed-reveal > *` applies a transform, which establishes a new stacking
   context and traps the negative z-index, causing the photo to render on top
   of the title. Exempt them so they render immediately at their intended
   opacity (0.55 / 0.32). Doubled class joiners bump specificity above the
   `.js .ed-reveal.is-visible > *` rule below that would otherwise win. */
.js .ed-reveal > .ed-hero__photo.ed-hero__photo,
.js .ed-reveal > .ed-hero__veil.ed-hero__veil,
.js .ed-reveal > .ed-list-hero__photo.ed-list-hero__photo,
.js .ed-reveal > .ed-list-hero__veil.ed-list-hero__veil,
.js .ed-reveal.is-visible > .ed-hero__photo.ed-hero__photo,
.js .ed-reveal.is-visible > .ed-hero__veil.ed-hero__veil,
.js .ed-reveal.is-visible > .ed-list-hero__photo.ed-list-hero__photo,
.js .ed-reveal.is-visible > .ed-list-hero__veil.ed-list-hero__veil {
  opacity: var(--hero-bg-opacity, 1);
  transform: none;
  transition: none;
}
.ed-hero__photo  { --hero-bg-opacity: 0.55; }
.ed-list-hero__photo { --hero-bg-opacity: 0.32; }
.ed-hero__veil, .ed-list-hero__veil { --hero-bg-opacity: 1; }

.js .ed-reveal.is-visible > *:nth-child(1) { transition-delay: 0ms; }
.js .ed-reveal.is-visible > *:nth-child(2) { transition-delay: 90ms; }
.js .ed-reveal.is-visible > *:nth-child(3) { transition-delay: 180ms; }
.js .ed-reveal.is-visible > *:nth-child(4) { transition-delay: 270ms; }
.js .ed-reveal.is-visible > *:nth-child(5) { transition-delay: 360ms; }
.js .ed-reveal.is-visible > *:nth-child(6) { transition-delay: 450ms; }

.js .ed-reveal.is-visible > * {
  opacity: 1;
  transform: translateY(0);
}

/* Count-up animation gets a single fade plus a numeric tween via JS */
.js .ed-stat__num[data-count] {
  opacity: 0;
  transform: translateY(16px);
  transition: opacity 0.8s ease, transform 0.8s ease;
}

.js .ed-stat.is-visible .ed-stat__num[data-count] {
  opacity: 1;
  transform: translateY(0);
}

/* Hide back-to-top default; we'll restyle on editorial pages */
.ed-page .back-to-top {
  background: var(--color-primary);
  color: var(--color-off-white);
  border: 1px solid var(--color-coral);
  border-radius: 0;
}

.ed-page .back-to-top:hover {
  background: var(--color-coral);
}

/* ----------------------------------------------------------------------------
   ED-CLIENTS — minimal logo strip
   ---------------------------------------------------------------------------- */

.ed-clients {
  padding: clamp(3rem, 5vw, 4.5rem) 0;
  background: var(--bg);
  border-top: 1px solid var(--rule-color);
  border-bottom: 1px solid var(--rule-color);
}

.ed-clients__heading {
  text-align: center;
  font-size: var(--caption);
  letter-spacing: 0.2em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--text-muted);
  margin: 0 0 2.5rem;
}

.ed-clients__row {
  display: flex;
  flex-wrap: wrap;
  gap: clamp(1.5rem, 3vw, 3rem) clamp(2rem, 4vw, 4rem);
  align-items: center;
  justify-content: center;
}

.ed-clients__item img {
  height: clamp(20px, 2.2vw, 28px);
  width: auto;
  filter: grayscale(1) opacity(0.55);
  transition: filter var(--transition);
}

.ed-clients__item img:hover {
  filter: grayscale(0) opacity(1);
}

/* ----------------------------------------------------------------------------
   ED-SVC — service cards (grid of 4)
   ---------------------------------------------------------------------------- */

.ed-svc-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  border-top: 1px solid var(--rule-color);
  border-left: 1px solid var(--rule-color);
}

.ed-svc {
  padding: clamp(2rem, 3vw, 2.5rem);
  border-right: 1px solid var(--rule-color);
  border-bottom: 1px solid var(--rule-color);
  background: var(--bg);
  display: flex;
  flex-direction: column;
  gap: 1rem;
  text-decoration: none;
  transition: background-color var(--transition);
  min-height: 320px;
  position: relative;
}

.ed-svc:hover { background: var(--bg-alt); }

.ed-svc__no {
  font-family: var(--font-display);
  font-size: 0.85rem;
  font-weight: 600;
  letter-spacing: 0.2em;
  color: var(--color-coral);
  font-variant-numeric: tabular-nums lining-nums;
}

.ed-svc__title {
  font-family: var(--font-display);
  font-size: clamp(1.125rem, 1.5vw + 0.3rem, 1.5rem);
  font-weight: 700;
  letter-spacing: -0.02em;
  line-height: 1.15;
  color: var(--color-primary);
  margin: 0;
}

.ed-svc__text {
  font-size: 0.95rem;
  line-height: 1.55;
  color: var(--text-secondary);
  flex: 1;
}

.ed-svc__cta {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-size: var(--caption);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--color-primary);
  margin-top: auto;
}

.ed-svc:hover .ed-svc__cta { color: var(--color-coral); }
.ed-svc:hover .ed-svc__cta .ed-btn__arrow { transform: translateX(4px); }
.ed-svc__cta .ed-btn__arrow { transition: transform var(--transition); }

/* ----------------------------------------------------------------------------
   ED-FLOW — 6-step process diagram (homepage methodology)
   ---------------------------------------------------------------------------- */

.ed-flow {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 0;
  border-top: 1px solid var(--rule-color-dark);
  border-left: 1px solid var(--rule-color-dark);
}

.ed-flow__item {
  padding: 2rem 1.5rem;
  border-right: 1px solid var(--rule-color-dark);
  border-bottom: 1px solid var(--rule-color-dark);
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  position: relative;
  transition: background-color var(--transition);
}

.ed-flow__item:hover {
  background: rgba(255, 255, 255, 0.04);
}

.ed-flow__no {
  font-family: var(--font-display);
  font-size: 2.5rem;
  font-weight: 700;
  letter-spacing: -0.04em;
  line-height: 1;
  color: var(--color-coral);
  font-variant-numeric: tabular-nums lining-nums;
}

.ed-flow__title {
  font-family: var(--font-display);
  font-size: 1.125rem;
  font-weight: 700;
  letter-spacing: -0.01em;
  line-height: 1.15;
  color: var(--color-off-white);
  margin: 0;
}

.ed-flow__text {
  font-size: 0.875rem;
  line-height: 1.4;
  color: rgba(250, 250, 248, 0.65);
}

/* ----------------------------------------------------------------------------
   ED-TM — testimonial cards (editorial, no chrome)
   ---------------------------------------------------------------------------- */

.ed-testimonials {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 0;
  border-top: 1px solid var(--rule-color);
  border-left: 1px solid var(--rule-color);
}

.ed-tm {
  padding: clamp(2rem, 3vw, 2.5rem);
  margin: 0;
  border-right: 1px solid var(--rule-color);
  border-bottom: 1px solid var(--rule-color);
  background: var(--bg);
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}

.ed-tm__quote {
  margin: 0;
  font-family: var(--font-display);
  font-size: 1.0625rem;
  line-height: 1.5;
  letter-spacing: -0.005em;
  color: var(--color-primary);
  position: relative;
  padding-left: 0;
}

.ed-tm__quote::before {
  content: '"';
  display: inline;
  color: var(--color-gold);
  font-weight: 700;
  font-size: 1.4em;
  margin-right: 0.05em;
  line-height: 0;
  vertical-align: -0.1em;
}

.ed-tm__cite {
  font-style: normal;
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
  padding-top: 1rem;
  border-top: 1px solid var(--rule-color);
  margin-top: auto;
}

.ed-tm__cite strong {
  font-weight: 700;
  font-size: 0.9375rem;
  letter-spacing: 0.01em;
  color: var(--color-primary);
}

.ed-tm__cite span {
  font-size: var(--caption);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--text-muted);
  font-weight: 500;
}


/* ----------------------------------------------------------------------------
   ED-HERO --page variant: shorter than homepage hero
   ---------------------------------------------------------------------------- */

.ed-hero--page {
  min-height: clamp(560px, 78vh, 780px);
  padding-bottom: clamp(3rem, 6vw, 5rem);
}

/* Constrain the homepage hero so it never grows beyond a reasonable height
   even on tall viewports / QA screenshots. */
.ed-hero:not(.ed-hero--page) {
  min-height: clamp(680px, 92vh, 980px);
}

/* ----------------------------------------------------------------------------
   ED-ARCHIVE — editorial list (used for whitepapers, downloads)
   Replaces the boxy whitepaper cards with a magazine-style row layout
   ---------------------------------------------------------------------------- */

.ed-archive {
  list-style: none;
  padding: 0;
  margin: 0;
  border-top: 1px solid var(--rule-color);
}

.ed-archive__item {
  border-bottom: 1px solid var(--rule-color);
}

.ed-archive__link {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: clamp(1.25rem, 3vw, 2.5rem);
  align-items: center;
  padding: clamp(1.75rem, 3vw, 2.5rem) 0;
  text-decoration: none;
  transition: background-color var(--transition);
  position: relative;
}

@media (max-width: 640px) {
  .ed-archive__link {
    grid-template-columns: auto 1fr;
    grid-template-areas:
      "no body"
      "no action";
    align-items: start;
    gap: 1rem;
  }
  .ed-archive__no { grid-area: no; }
  .ed-archive__body { grid-area: body; }
  .ed-archive__action { grid-area: action; justify-self: end; }
}

.ed-archive__no {
  font-family: var(--font-display);
  font-size: clamp(2rem, 4vw, 3rem);
  font-weight: 700;
  letter-spacing: -0.03em;
  color: var(--color-coral);
  font-variant-numeric: tabular-nums lining-nums;
  line-height: 1;
  min-width: 3ch;
}

.ed-archive__body {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  max-width: 60ch;
}

.ed-archive__type {
  font-size: var(--caption);
  letter-spacing: 0.2em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--color-teal-mid);
}

.ed-archive__title {
  font-family: var(--font-display);
  font-size: clamp(1.25rem, 1.8vw + 0.3rem, 1.75rem);
  font-weight: 700;
  line-height: 1.15;
  letter-spacing: -0.02em;
  color: var(--color-primary);
  margin: 0;
  transition: color var(--transition);
}

.ed-archive__link:hover .ed-archive__title { color: var(--color-coral); }

.ed-archive__desc {
  font-size: 0.95rem;
  line-height: 1.55;
  color: var(--text-secondary);
}

.ed-archive__action {
  font-size: var(--caption);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--color-primary);
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  white-space: nowrap;
}

.ed-archive__link:hover .ed-archive__action { color: var(--color-coral); }
.ed-archive__link:hover .ed-archive__action .ed-btn__arrow { transform: translateX(4px); }
.ed-archive__action .ed-btn__arrow { transition: transform var(--transition); }

.ed-archive__link[data-coming-soon] {
  cursor: not-allowed;
}

.ed-archive__link[data-coming-soon] .ed-archive__action {
  opacity: 0.7;
}

/* ----------------------------------------------------------------------------
   HEADER POLISH on editorial pages
   Make the existing header darker / more refined when paired with ed-pages
   ---------------------------------------------------------------------------- */

body.has-dark-hero .site-header {
  /* At top of page: fully transparent so the photographic hero shows through.
     On scroll, the .is-scrolled rule below adds a dark translucent backdrop. */
  background: transparent;
  border-bottom-color: transparent;
}

/* The hero slides UP underneath the transparent header so the photo extends
   to the very top of the viewport (McKinsey/BCG style edge-to-edge image). */
body.has-dark-hero main {
  margin-top: calc(-1 * var(--header-height));
}

body.has-dark-hero .site-header.is-scrolled {
  background: rgba(0, 45, 55, 0.94);
}

body.has-dark-hero .nav-link,
body.has-dark-hero .lang-current,
body.has-dark-hero .logo-word-primary,
body.has-dark-hero .logo-word-secondary {
  color: var(--color-off-white);
}

body.has-dark-hero .logo-img {
  filter: invert(1) brightness(2);
}

body.has-dark-hero .nav-link:hover {
  color: var(--color-coral);
}

body.has-dark-hero .nav-item.is-active .nav-link {
  color: var(--color-coral);
}

body.has-dark-hero .header-cta {
  background: var(--color-coral);
  color: var(--color-off-white);
  border-color: var(--color-coral);
}

body.has-dark-hero .header-cta:hover {
  background: var(--color-coral-dark);
}

body.has-dark-hero .lang-toggle {
  color: var(--color-off-white);
}

body.has-dark-hero .hamburger-line {
  background: var(--color-off-white);
}

body.has-dark-hero .lang-toggle {
  border-color: rgba(255, 255, 255, 0.3);
}

body.has-dark-hero .lang-toggle svg {
  stroke: var(--color-off-white);
}


/* ----------------------------------------------------------------------------
   ED-FOUNDATIONS — 3-column foundations grid (ODI page)
   ---------------------------------------------------------------------------- */

.ed-foundations {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 0;
  border-top: 1px solid var(--rule-color);
  border-left: 1px solid var(--rule-color);
}

.ed-foundation {
  padding: clamp(2rem, 3vw, 2.5rem);
  border-right: 1px solid var(--rule-color);
  border-bottom: 1px solid var(--rule-color);
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.ed-foundation__no {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 1.125rem;
  font-weight: 500;
  letter-spacing: 0.05em;
  color: var(--color-coral);
  font-variant-numeric: tabular-nums lining-nums;
}

.ed-foundation__title {
  font-family: var(--font-display);
  font-size: clamp(1.125rem, 1.5vw + 0.3rem, 1.4rem);
  font-weight: 700;
  letter-spacing: -0.015em;
  line-height: 1.2;
  color: var(--color-primary);
  margin: 0;
}

.ed-foundation__text {
  font-size: 0.95rem;
  line-height: 1.55;
  color: var(--text-secondary);
}


/* ----------------------------------------------------------------------------
   ED-TEAM — team cards, editorial layout
   ---------------------------------------------------------------------------- */

.ed-team {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  gap: 0;
  border-top: 1px solid var(--rule-color);
  border-left: 1px solid var(--rule-color);
}

.ed-team__card {
  padding: clamp(2rem, 3vw, 2.5rem);
  border-right: 1px solid var(--rule-color);
  border-bottom: 1px solid var(--rule-color);
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}

.ed-team__photo {
  aspect-ratio: 4 / 5;
  overflow: hidden;
  background: var(--color-primary);
  margin: 0;
}

.ed-team__photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: grayscale(0.2) contrast(1.05);
  transition: filter var(--transition);
}

.ed-team__card:hover .ed-team__photo img {
  filter: grayscale(0) contrast(1.1);
}

.ed-team__info {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.ed-team__name {
  font-family: var(--font-display);
  font-size: clamp(1.5rem, 2vw + 0.3rem, 2rem);
  font-weight: 700;
  letter-spacing: -0.02em;
  line-height: 1.1;
  color: var(--color-primary);
  margin: 0;
}

.ed-team__role {
  font-size: var(--caption);
  letter-spacing: 0.2em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--color-coral);
  margin: 0 0 0.5rem;
}

.ed-team__bio {
  font-size: 0.95rem;
  line-height: 1.55;
  color: var(--text-secondary);
  margin: 0;
}

.ed-team__bio em {
  font-style: italic;
  color: var(--color-primary);
}

.ed-team__link {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-size: var(--caption);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--color-primary);
  margin-top: 0.5rem;
  width: fit-content;
  transition: color var(--transition);
}

.ed-team__link:hover { color: var(--color-coral); }
.ed-team__link:hover .ed-btn__arrow { transform: translateX(4px); }
.ed-team__link .ed-btn__arrow { transition: transform var(--transition); }

/* ----------------------------------------------------------------------------
   ED-PROSE — long-form markdown content treatment
   ---------------------------------------------------------------------------- */

.ed-prose {
  max-width: 68ch;
  color: var(--text-secondary);
  font-size: 1.0625rem;
  line-height: 1.7;
}

.ed-prose h2 {
  font-family: var(--font-display);
  font-size: clamp(1.5rem, 2.5vw, 2rem);
  font-weight: 700;
  letter-spacing: -0.02em;
  line-height: 1.15;
  color: var(--color-primary);
  margin: 2.5rem 0 1rem;
}

.ed-prose h3 {
  font-family: var(--font-display);
  font-size: clamp(1.25rem, 2vw, 1.5rem);
  font-weight: 700;
  letter-spacing: -0.015em;
  line-height: 1.2;
  color: var(--color-primary);
  margin: 2rem 0 0.75rem;
}

.ed-prose p { margin: 0 0 1.25rem; }
.ed-prose p:last-child { margin-bottom: 0; }

.ed-prose ul, .ed-prose ol {
  margin: 0 0 1.5rem 1.25rem;
  padding: 0;
}

.ed-prose li { margin-bottom: 0.5rem; }

.ed-prose strong {
  color: var(--color-primary);
  font-weight: 600;
}

.ed-prose em {
  font-style: italic;
  color: var(--color-primary);
}

.ed-prose hr {
  border: none;
  border-top: 1px solid var(--rule-color);
  margin: 2.5rem 0;
}

.ed-prose a {
  color: var(--color-teal-dark);
  border-bottom: 1px solid currentColor;
  transition: color var(--transition);
}

.ed-prose a:hover { color: var(--color-coral); }

/* ----------------------------------------------------------------------------
   ED-SVC-DETAIL — services page individual service blocks
   ---------------------------------------------------------------------------- */

.ed-svc-detail {
  padding: clamp(4rem, 8vw, 7rem) 0;
  border-top: 1px solid var(--rule-color);
}

.ed-svc-detail--alt {
  background: var(--bg-alt);
}

.ed-svc-detail__layout {
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(2rem, 5vw, 4rem);
  align-items: center;
}

@media (min-width: 900px) {
  .ed-svc-detail__layout {
    grid-template-columns: 1fr 1fr;
  }
  .ed-svc-detail__layout--reverse {
    direction: rtl;
  }
  .ed-svc-detail__layout--reverse > * {
    direction: ltr;
  }
}

.ed-svc-detail__copy {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  max-width: 56ch;
}

.ed-svc-detail__no {
  font-family: var(--font-display);
  font-size: 0.85rem;
  font-weight: 600;
  letter-spacing: 0.2em;
  color: var(--color-coral);
  font-variant-numeric: tabular-nums lining-nums;
}

.ed-svc-detail__title {
  font-family: var(--font-display);
  font-size: clamp(1.75rem, 3vw, 2.75rem);
  font-weight: 700;
  letter-spacing: -0.025em;
  line-height: 1.05;
  color: var(--color-primary);
  margin: 0;
}

.ed-svc-detail__tag {
  font-family: var(--font-display);
  font-style: italic;
  font-size: clamp(1.0625rem, 1.4vw + 0.3rem, 1.25rem);
  line-height: 1.4;
  color: var(--color-teal-dark);
  margin: 0;
}

.ed-svc-detail__desc {
  font-size: 1rem;
  line-height: 1.65;
  color: var(--text-secondary);
  margin: 0.5rem 0 0;
}

.ed-svc-detail__image {
  aspect-ratio: 4 / 3;
  background-size: cover;
  background-position: center;
  filter: grayscale(0.2) contrast(1.05);
  background-color: var(--color-primary);
}

/* ----------------------------------------------------------------------------
   ED-CONTACT — contact page layout + cards
   ---------------------------------------------------------------------------- */

.ed-contact {
  padding: clamp(4rem, 8vw, 7rem) 0;
}

.ed-contact__layout {
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(2.5rem, 5vw, 5rem);
}

@media (min-width: 900px) {
  .ed-contact__layout { grid-template-columns: 1.6fr 1fr; }
}

.ed-contact__title {
  font-family: var(--font-display);
  font-size: clamp(1.5rem, 2.5vw + 0.3rem, 2.25rem);
  font-weight: 700;
  letter-spacing: -0.025em;
  line-height: 1.1;
  color: var(--color-primary);
  margin: 0 0 0.75rem;
  max-width: 22ch;
}

.ed-contact__lede {
  font-size: 1.0625rem;
  line-height: 1.55;
  color: var(--text-secondary);
  margin: 0 0 2rem;
  max-width: 50ch;
}

.ed-contact__form {
  border-top: 1px solid var(--rule-color);
  border-bottom: 1px solid var(--rule-color);
  padding: clamp(1.5rem, 3vw, 2.5rem) 0;
  min-height: 480px;
}

.ed-contact__form .hs-form-frame { min-height: 480px; }

.ed-contact__fallback {
  padding: var(--space-md);
  background: var(--bg-alt);
  border: 1px dashed var(--rule-color);
  color: var(--text-secondary);
  font-size: var(--text-sm);
}

.ed-contact__fallback a { color: var(--color-coral); font-weight: 600; }

.ed-contact__sidebar {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
  position: sticky;
  top: calc(var(--header-height) + 2rem);
  align-self: start;
}

.ed-contact__card {
  padding: 1.75rem;
  background: var(--bg-alt);
  border: 1px solid var(--rule-color);
  border-left: 3px solid var(--color-coral);
}

.ed-contact__card-label {
  font-size: var(--caption);
  letter-spacing: 0.2em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--color-teal-mid);
  margin: 0 0 1rem;
}

.ed-contact__list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.ed-contact__list a {
  color: var(--color-primary);
  font-size: 0.95rem;
  font-weight: 500;
  transition: color var(--transition);
}

.ed-contact__list a:hover { color: var(--color-coral); }

.ed-contact__address {
  font-style: normal;
  font-size: 0.95rem;
  line-height: 1.6;
  color: var(--text-secondary);
}


/* ============================================================================
   DESIGN SYSTEM v2 — Long-form article + list + pillar + legal
   ============================================================================ */

/* ----------------------------------------------------------------------------
   ED-LIST-HERO — shorter editorial hero for list/legal pages
   ---------------------------------------------------------------------------- */

.ed-list-hero {
  position: relative;
  padding: clamp(8rem, 14vw, 11rem) 0 clamp(3rem, 5vw, 4.5rem);
  background: var(--color-primary);
  color: var(--text-on-dark);
  overflow: hidden;
  isolation: isolate;
}

.ed-list-hero__photo {
  position: absolute;
  inset: 0;
  z-index: -2;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  background-size: cover;
  background-position: center;
  opacity: 0.32;
  filter: grayscale(0.4) contrast(1.05);
}

.ed-list-hero__veil {
  position: absolute;
  inset: 0;
  z-index: -1;
  background: linear-gradient(180deg, rgba(0,45,55,0.55) 0%, rgba(0,45,55,0.92) 100%);
}

.ed-list-hero__eyebrow {
  display: inline-block;
  font-size: var(--caption);
  letter-spacing: 0.2em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--color-gold);
  margin-bottom: clamp(1rem, 2vw, 1.5rem);
}

.ed-list-hero__title {
  font-family: var(--font-display);
  font-size: var(--display-2);
  font-weight: 700;
  line-height: 1.02;
  letter-spacing: -0.03em;
  color: var(--color-off-white);
  margin: 0;
  max-width: 22ch;
}

.ed-list-hero__lede {
  font-size: var(--lede);
  line-height: 1.45;
  color: rgba(250, 250, 248, 0.82);
  margin-top: clamp(1.25rem, 2.5vw, 2rem);
  max-width: 56ch;
  font-weight: 300;
}

.ed-list-hero--legal {
  background: var(--color-primary-dark);
  padding-bottom: clamp(2rem, 4vw, 3rem);
}

/* ----------------------------------------------------------------------------
   ED-FILTER — category filter for blog list
   ---------------------------------------------------------------------------- */

.ed-filter {
  border-bottom: 1px solid var(--rule-color);
  background: var(--bg);
}

.ed-filter__row {
  display: flex;
  gap: 2rem;
  padding: 1.25rem 0;
  overflow-x: auto;
  scrollbar-width: none;
}

.ed-filter__row::-webkit-scrollbar { display: none; }

.ed-filter__link {
  font-size: var(--caption);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--text-muted);
  white-space: nowrap;
  transition: color var(--transition);
  padding-bottom: 0.25rem;
  border-bottom: 2px solid transparent;
}

.ed-filter__link:hover { color: var(--color-primary); }

.ed-filter__link.is-active {
  color: var(--color-coral);
  border-bottom-color: var(--color-coral);
}

/* ----------------------------------------------------------------------------
   ED-LIST — list section (blog index)
   ---------------------------------------------------------------------------- */

.ed-list {
  padding: clamp(3rem, 6vw, 5rem) 0;
}

/* ----------------------------------------------------------------------------
   ED-FEATURE — featured (lead) story card on blog index
   ---------------------------------------------------------------------------- */

.ed-feature {
  margin-bottom: clamp(2rem, 4vw, 3rem);
  border-top: 1px solid var(--rule-color);
  border-bottom: 1px solid var(--rule-color);
}

.ed-feature__link {
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(1.5rem, 3vw, 2.5rem);
  padding: clamp(1.5rem, 3vw, 2.5rem) 0;
  text-decoration: none;
}

@media (min-width: 900px) {
  .ed-feature__link {
    grid-template-columns: 1.2fr 1fr;
    align-items: center;
  }
}

.ed-feature__image {
  aspect-ratio: 16 / 10;
  background-size: cover;
  background-position: center;
  background-color: var(--color-primary);
  filter: grayscale(0.15) contrast(1.05);
  transition: filter var(--transition);
}

.ed-feature__link:hover .ed-feature__image { filter: grayscale(0) contrast(1.1); }

.ed-feature__meta {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  font-size: var(--caption);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--color-coral);
  margin-bottom: 1rem;
  flex-wrap: wrap;
}

.ed-feature__meta time, .ed-feature__meta span:not(.ed-card__meta-dot) {
  color: var(--text-muted);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-weight: 400;
}

.ed-feature__meta > span:first-child {
  color: var(--color-coral);
  letter-spacing: 0.2em;
  font-weight: 600;
}

.ed-feature__title {
  font-family: var(--font-display);
  font-size: clamp(1.5rem, 2.8vw, 2.5rem);
  font-weight: 700;
  letter-spacing: -0.025em;
  line-height: 1.05;
  color: var(--color-primary);
  margin: 0 0 1rem;
  transition: color var(--transition);
}

.ed-feature__link:hover .ed-feature__title { color: var(--color-coral-dark); }

.ed-feature__excerpt {
  font-size: 1.0625rem;
  line-height: 1.55;
  color: var(--text-secondary);
  margin: 0 0 1.5rem;
}

.ed-feature__footer {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-top: 1rem;
  border-top: 1px solid var(--rule-color);
  font-size: var(--caption);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  font-weight: 600;
}

.ed-feature__readtime { color: var(--text-muted); letter-spacing: 0.1em; }
.ed-feature__readmore { color: var(--color-primary); display: inline-flex; gap: 0.5rem; align-items: center; }
.ed-feature__link:hover .ed-feature__readmore { color: var(--color-coral); }
.ed-feature__link:hover .ed-feature__readmore .ed-btn__arrow { transform: translateX(4px); }
.ed-feature__readmore .ed-btn__arrow { transition: transform var(--transition); }

/* ----------------------------------------------------------------------------
   ED-PAGINATION
   ---------------------------------------------------------------------------- */

.ed-pagination {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: 2rem;
  margin-top: clamp(3rem, 5vw, 4rem);
  padding-top: 2rem;
  border-top: 1px solid var(--rule-color);
}

.ed-pagination__link {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-size: var(--caption);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--color-primary);
}

.ed-pagination__link:last-child { justify-self: end; }

.ed-pagination__link:hover { color: var(--color-coral); }

.ed-pagination__numbers {
  display: flex;
  gap: 0.5rem;
  justify-content: center;
}

.ed-pagination__num {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.5rem;
  height: 2.5rem;
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--text-secondary);
  font-variant-numeric: tabular-nums;
  transition: color var(--transition), background-color var(--transition);
}

.ed-pagination__num:hover { color: var(--color-primary); background: var(--bg-alt); }

.ed-pagination__num.is-current {
  color: var(--color-off-white);
  background: var(--color-coral);
}

/* ----------------------------------------------------------------------------
   ED-EMPTY
   ---------------------------------------------------------------------------- */

.ed-empty {
  text-align: center;
  padding: clamp(4rem, 8vw, 6rem) 0;
}

.ed-empty__title {
  font-family: var(--font-display);
  font-size: clamp(1.5rem, 2.5vw, 2rem);
  font-weight: 700;
  letter-spacing: -0.02em;
  color: var(--color-primary);
  margin: 0 0 0.75rem;
}

.ed-empty__text {
  color: var(--text-secondary);
}

/* ============================================================================
   ED-ARTICLE — long-form single article
   ============================================================================ */

.ed-article__crumbs {
  padding: clamp(5.5rem, 9vw, 7rem) 0 0;
  background: var(--bg);
  border-bottom: 1px solid var(--rule-color);
}

.ed-article__crumbs .breadcrumbs {
  padding: 1rem 0;
  font-size: var(--caption);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--text-muted);
}

.ed-article__head {
  background: var(--bg);
  padding: clamp(2.5rem, 5vw, 4rem) 0 clamp(2rem, 4vw, 3rem);
}

.ed-article__cats {
  display: flex;
  gap: 0.75rem;
  flex-wrap: wrap;
  margin-bottom: 1.5rem;
}

.ed-article__cat {
  font-size: var(--caption);
  letter-spacing: 0.2em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--color-coral);
  transition: color var(--transition);
}

.ed-article__cat:hover { color: var(--color-coral-dark); }

.ed-article__title {
  font-family: var(--font-display);
  font-size: clamp(2rem, 4vw + 0.3rem, 4rem);
  font-weight: 700;
  letter-spacing: -0.035em;
  line-height: 1;
  color: var(--color-primary);
  margin: 0 0 1.25rem;
}

.ed-article__deck {
  font-family: var(--font-display);
  font-style: italic;
  font-size: clamp(1.125rem, 1.5vw + 0.3rem, 1.5rem);
  font-weight: 300;
  line-height: 1.4;
  color: var(--text-secondary);
  margin: 0 0 2rem;
  max-width: 56ch;
}

.ed-article__byline {
  display: flex;
  gap: 1.5rem;
  align-items: center;
  padding-top: 1.5rem;
  border-top: 1px solid var(--rule-color);
}

.ed-article__author {
  display: flex;
  gap: 1rem;
  align-items: center;
}

.ed-article__avatar {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  object-fit: cover;
  border: 1px solid var(--rule-color);
}

.ed-article__author-info {
  display: flex;
  flex-direction: column;
  gap: 0.125rem;
}

.ed-article__author-name {
  font-weight: 700;
  font-size: 0.9375rem;
  color: var(--color-primary);
}

.ed-article__date {
  font-size: var(--caption);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text-muted);
}

/* ----------------------------------------------------------------------------
   ED-ARTICLE hero image (full-bleed)
   ---------------------------------------------------------------------------- */

.ed-article__hero {
  margin: 0;
  padding: 0;
  width: 100%;
}

.ed-article__hero img {
  width: 100%;
  height: auto;
  display: block;
  max-height: 60vh;
  object-fit: cover;
  filter: grayscale(0.1) contrast(1.05);
}

.ed-article__hero figcaption {
  padding: 0.75rem var(--space-md);
  font-size: var(--caption);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text-muted);
  text-align: center;
}

/* ----------------------------------------------------------------------------
   ED-ARTICLE body layout
   ---------------------------------------------------------------------------- */

.ed-article__body {
  padding: clamp(3rem, 6vw, 5rem) 0;
}

.ed-article__layout {
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(2rem, 5vw, 4rem);
}

@media (min-width: 1024px) {
  .ed-article__layout {
    grid-template-columns: 240px 1fr;
  }
}

.ed-article__sidebar {
  position: relative;
}

.ed-article__toc-sticky {
  position: sticky;
  top: calc(var(--header-height) + 2rem);
  padding-right: 1rem;
  max-height: calc(100vh - var(--header-height) - 4rem);
  overflow-y: auto;
}

.ed-article__toc-mobile {
  display: block;
  padding: 1.5rem;
  background: var(--bg-alt);
  border-left: 3px solid var(--color-coral);
  margin-bottom: 2rem;
}

@media (min-width: 1024px) {
  .ed-article__toc-mobile { display: none; }
}

.ed-article__toc-label {
  font-size: var(--caption);
  letter-spacing: 0.2em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--color-coral);
  margin: 0 0 1rem;
}

.ed-article__toc-nav ul,
.ed-article__toc-mobile ul {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.ed-article__toc-nav li,
.ed-article__toc-mobile li {
  font-size: 0.875rem;
  line-height: 1.4;
}

.ed-article__toc-nav a,
.ed-article__toc-mobile a {
  color: var(--text-secondary);
  border-left: 2px solid transparent;
  padding-left: 0.75rem;
  margin-left: -0.75rem;
  display: block;
  padding-top: 0.25rem;
  padding-bottom: 0.25rem;
  transition: color var(--transition), border-color var(--transition);
}

.ed-article__toc-nav a:hover,
.ed-article__toc-mobile a:hover {
  color: var(--color-primary);
  border-color: var(--color-coral);
}

.ed-article__toc-nav a.is-active {
  color: var(--color-primary);
  border-color: var(--color-coral);
  font-weight: 600;
}

.ed-article__toc-nav ul ul,
.ed-article__toc-mobile ul ul {
  margin-left: 1rem;
  margin-top: 0.25rem;
  padding-left: 0.5rem;
  border-left: 1px solid var(--rule-color);
}

.ed-article__main {
  max-width: 760px;
}

/* The prose styles already exist (.ed-prose) — extend for article context */
.ed-article__content {
  font-size: 1.125rem;
  line-height: 1.75;
  color: var(--text);
}

.ed-article__content h2 {
  font-family: var(--font-display);
  font-size: clamp(1.625rem, 2.5vw, 2.25rem);
  font-weight: 700;
  letter-spacing: -0.025em;
  line-height: 1.15;
  color: var(--color-primary);
  margin: 3rem 0 1rem;
  padding-top: 1.5rem;
  border-top: 1px solid var(--rule-color);
}

.ed-article__content h3 {
  font-family: var(--font-display);
  font-size: clamp(1.25rem, 2vw, 1.625rem);
  font-weight: 700;
  letter-spacing: -0.015em;
  line-height: 1.2;
  color: var(--color-primary);
  margin: 2.25rem 0 0.75rem;
}

.ed-article__content p { margin: 0 0 1.25rem; }

.ed-article__content ul,
.ed-article__content ol {
  margin: 0 0 1.5rem 1.25rem;
  padding: 0;
}

.ed-article__content li { margin-bottom: 0.5rem; }

.ed-article__content blockquote {
  border-left: 3px solid var(--color-coral);
  margin: 2rem 0;
  padding: 0.5rem 0 0.5rem 1.5rem;
  font-family: var(--font-display);
  font-size: 1.25rem;
  font-style: italic;
  line-height: 1.5;
  color: var(--color-primary);
}

.ed-article__content strong { color: var(--color-primary); font-weight: 600; }
.ed-article__content a {
  color: var(--color-teal-dark);
  border-bottom: 1px solid currentColor;
  transition: color var(--transition);
}
.ed-article__content a:hover { color: var(--color-coral); }

.ed-article__content hr {
  border: none;
  border-top: 1px solid var(--rule-color);
  margin: 2.5rem 0;
}

.ed-article__content img {
  margin: 2rem 0;
  border-radius: 0;
  max-width: 100%;
}

.ed-article__content pre {
  background: var(--color-primary);
  color: var(--text-on-dark);
  padding: 1.25rem;
  overflow-x: auto;
  font-size: 0.875rem;
  margin: 1.5rem 0;
}

.ed-article__content code {
  background: var(--bg-alt);
  padding: 0.1em 0.4em;
  font-size: 0.9em;
}

.ed-article__content pre code { background: none; padding: 0; }

/* Tags */
.ed-article__tags {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin: 3rem 0 0;
  padding-top: 1.5rem;
  border-top: 1px solid var(--rule-color);
}

.ed-article__tag {
  font-size: 0.75rem;
  letter-spacing: 0.05em;
  color: var(--text-muted);
  padding: 0.25rem 0.6rem;
  background: var(--bg-alt);
  transition: color var(--transition), background-color var(--transition);
}

.ed-article__tag:hover {
  color: var(--color-coral);
  background: var(--bg);
}

/* Author box */
.ed-author-box {
  margin-top: 3rem;
  padding-top: 2rem;
  border-top: 1px solid var(--rule-color);
  display: grid;
  grid-template-columns: 80px 1fr;
  gap: 1.5rem;
  align-items: start;
}

@media (max-width: 540px) {
  .ed-author-box { grid-template-columns: 60px 1fr; gap: 1rem; }
}

.ed-author-box__photo img {
  width: 80px;
  height: 80px;
  border-radius: 50%;
  object-fit: cover;
  border: 1px solid var(--rule-color);
}

@media (max-width: 540px) {
  .ed-author-box__photo img { width: 60px; height: 60px; }
}

.ed-author-box__label {
  font-size: var(--caption);
  letter-spacing: 0.2em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--color-coral);
  display: block;
  margin-bottom: 0.5rem;
}

.ed-author-box__name {
  font-family: var(--font-display);
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--color-primary);
  margin: 0 0 0.5rem;
}

.ed-author-box__bio {
  font-size: 0.9375rem;
  line-height: 1.55;
  color: var(--text-secondary);
  margin: 0;
}

/* Inline CTA */
.ed-inline-cta {
  margin: 3rem 0;
  padding: clamp(2rem, 3vw, 2.5rem);
  background: var(--color-primary);
  color: var(--text-on-dark);
  border-left: 3px solid var(--color-coral);
}

.ed-inline-cta__eyebrow {
  display: block;
  font-size: var(--caption);
  letter-spacing: 0.2em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--color-coral);
  margin-bottom: 0.75rem;
}

.ed-inline-cta__title {
  font-family: var(--font-display);
  font-size: clamp(1.5rem, 2.5vw, 2rem);
  font-weight: 700;
  letter-spacing: -0.025em;
  line-height: 1.1;
  color: var(--color-off-white);
  margin: 0 0 1rem;
}

.ed-inline-cta__title em {
  font-style: normal;
  color: var(--color-coral);
}

.ed-inline-cta__text {
  font-size: 1rem;
  line-height: 1.55;
  color: rgba(250, 250, 248, 0.78);
  margin: 0 0 1.5rem;
  max-width: 56ch;
}

/* Prev / Next nav */
.ed-article__nav {
  margin-top: 3rem;
  padding-top: 2rem;
  border-top: 1px solid var(--rule-color);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
}

.ed-article__nav-link {
  padding: 1.25rem;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  transition: background-color var(--transition);
}

.ed-article__nav-link:hover { background: var(--bg-alt); }

.ed-article__nav-link--next { text-align: right; }

.ed-article__nav-label {
  font-size: var(--caption);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--color-coral);
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
}

.ed-article__nav-link--next .ed-article__nav-label { justify-content: flex-end; }

.ed-article__nav-title {
  font-family: var(--font-display);
  font-size: 1rem;
  font-weight: 700;
  color: var(--color-primary);
  line-height: 1.3;
}

.ed-article__footer-meta {
  margin-top: 3rem;
  padding-top: 2rem;
  border-top: 1px solid var(--rule-color);
  font-size: var(--caption);
  letter-spacing: 0.08em;
  color: var(--text-muted);
}

/* ============================================================================
   ED-PILLAR — long-form pillar page (extends ED-ARTICLE)
   ============================================================================ */

.ed-pillar__progress {
  position: fixed;
  top: var(--header-height);
  left: 0;
  right: 0;
  height: 3px;
  background: var(--rule-color);
  z-index: 50;
}

.ed-pillar__progress-bar {
  height: 100%;
  background: var(--color-coral);
  width: 0;
  transition: width 80ms linear;
}

.ed-pillar__head {
  background: var(--bg);
  padding: clamp(2.5rem, 5vw, 4rem) 0 clamp(2rem, 4vw, 3rem);
}

.ed-pillar__badge {
  display: inline-block;
  font-size: var(--caption);
  letter-spacing: 0.2em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--color-off-white);
  background: var(--color-coral);
  padding: 0.4rem 0.85rem;
  margin-bottom: 1.5rem;
}

.ed-pillar__title {
  font-family: var(--font-display);
  font-size: clamp(2.25rem, 5vw, 4.5rem);
  font-weight: 700;
  letter-spacing: -0.035em;
  line-height: 1;
  color: var(--color-primary);
  margin: 0 0 1.5rem;
}

.ed-pillar__deck {
  font-family: var(--font-display);
  font-style: italic;
  font-size: clamp(1.25rem, 1.8vw + 0.3rem, 1.625rem);
  font-weight: 300;
  line-height: 1.4;
  color: var(--text-secondary);
  margin: 0 0 2rem;
  max-width: 56ch;
}

.ed-pillar__cluster {
  margin-top: 2.5rem;
  padding-top: 2rem;
  border-top: 1px solid var(--rule-color);
}

.ed-pillar__cluster ul {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

.ed-pillar__cluster a {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.875rem;
  color: var(--color-primary);
  font-weight: 500;
  transition: color var(--transition);
}

.ed-pillar__cluster a:hover { color: var(--color-coral); }
.ed-pillar__cluster a:hover .ed-btn__arrow { transform: translateX(3px); }
.ed-pillar__cluster a .ed-btn__arrow { transition: transform var(--transition); }


/* ============================================================================
   ED-MODULE — services page module block (6 modules)
   ============================================================================ */

.ed-module {
  padding: clamp(4rem, 8vw, 7rem) 0;
  border-top: 1px solid var(--rule-color);
}

.ed-module--alt {
  background: var(--bg-alt);
}

.ed-module__layout {
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(2rem, 5vw, 4rem);
  align-items: start;
}

@media (min-width: 900px) {
  .ed-module__layout {
    grid-template-columns: 1.3fr 1fr;
  }
  .ed-module__layout--reverse {
    direction: rtl;
  }
  .ed-module__layout--reverse > * {
    direction: ltr;
  }
}

.ed-module__copy {
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
  max-width: 64ch;
}

.ed-module__head {
  display: flex;
  gap: 1.5rem;
  align-items: baseline;
  padding-bottom: 0.5rem;
  border-bottom: 1px solid var(--rule-color);
}

.ed-module__no {
  font-family: var(--font-display);
  font-size: clamp(2rem, 4vw, 3.5rem);
  font-weight: 700;
  letter-spacing: -0.04em;
  line-height: 1;
  color: var(--color-coral);
  font-variant-numeric: tabular-nums lining-nums;
}

.ed-module__duration {
  font-size: var(--caption);
  letter-spacing: 0.2em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--text-muted);
}

.ed-module__title {
  font-family: var(--font-display);
  font-size: clamp(1.75rem, 3vw, 2.5rem);
  font-weight: 700;
  letter-spacing: -0.025em;
  line-height: 1.05;
  color: var(--color-primary);
  margin: 0;
}

.ed-module__odi-step {
  font-size: var(--caption);
  letter-spacing: 0.2em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--color-teal-mid);
  margin: 0;
}

.ed-module__lede {
  font-size: 1.0625rem;
  line-height: 1.55;
  color: var(--text-secondary);
  margin: 0 0 0.5rem;
}

.ed-module__block {
  padding-top: 1rem;
  border-top: 1px solid var(--rule-color);
}

.ed-module__block-label {
  font-size: var(--caption);
  letter-spacing: 0.2em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--color-coral);
  margin: 0 0 0.75rem;
}

.ed-module__list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.ed-module__list li {
  font-size: 0.95rem;
  line-height: 1.5;
  color: var(--text-secondary);
  padding-left: 1.25rem;
  position: relative;
}

.ed-module__list li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0.7em;
  width: 6px;
  height: 1px;
  background: var(--color-coral);
}

.ed-module__ideal {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 1.0625rem;
  line-height: 1.5;
  color: var(--color-primary);
  margin: 0;
}

.ed-module__image {
  aspect-ratio: 4 / 3;
  background-size: cover;
  background-position: center;
  filter: grayscale(0.2) contrast(1.05);
  background-color: var(--color-primary);
  position: sticky;
  top: calc(var(--header-height) + 2rem);
}

@media (max-width: 899px) {
  .ed-module__image { position: static; }
}

.ed-companions {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 0;
  border-top: 1px solid var(--rule-color-dark);
  border-left: 1px solid var(--rule-color-dark);
}

.ed-companion {
  padding: clamp(1.75rem, 3vw, 2.5rem);
  border-right: 1px solid var(--rule-color-dark);
  border-bottom: 1px solid var(--rule-color-dark);
}

.ed-companion__title {
  font-family: var(--font-display);
  font-size: clamp(1.125rem, 1.5vw + 0.3rem, 1.4rem);
  font-weight: 700;
  letter-spacing: -0.015em;
  line-height: 1.2;
  color: var(--color-off-white);
  margin: 0 0 0.75rem;
}

.ed-companion__text {
  font-size: 0.95rem;
  line-height: 1.55;
  color: rgba(250, 250, 248, 0.7);
  margin: 0;
}

.ed-usecases {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 0;
  border-top: 1px solid var(--rule-color);
  border-left: 1px solid var(--rule-color);
}

.ed-usecase {
  padding: clamp(1.75rem, 3vw, 2.5rem);
  border-right: 1px solid var(--rule-color);
  border-bottom: 1px solid var(--rule-color);
  background: var(--bg);
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

.ed-usecase__label {
  font-size: var(--caption);
  letter-spacing: 0.2em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--color-teal-mid);
}

.ed-usecase__title {
  font-family: var(--font-display);
  font-size: clamp(1.125rem, 1.5vw + 0.3rem, 1.4rem);
  font-weight: 700;
  letter-spacing: -0.015em;
  line-height: 1.2;
  color: var(--color-primary);
  margin: 0;
}

.ed-usecase__text {
  font-size: 0.95rem;
  line-height: 1.5;
  color: var(--text-secondary);
  margin: 0 0 0.75rem;
}

.ed-usecase__modules {
  margin-top: auto;
  padding-top: 1rem;
  border-top: 1px solid var(--rule-color);
  font-size: var(--caption);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--text-muted);
}

.ed-usecase__modules em {
  font-style: normal;
  color: var(--color-coral);
  font-weight: 700;
  margin-left: 0.5em;
  letter-spacing: 0.12em;
}


/* ============================================================================
   ED-FORM — custom contact form (replaces HubSpot embed)
   ============================================================================ */

.ed-form {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
  padding-top: 0.5rem;
}

.ed-form__row {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.25rem;
}

@media (min-width: 640px) {
  .ed-form__row--two { grid-template-columns: 1fr 1fr; }
}

.ed-form__field {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.ed-form__label {
  font-size: var(--caption);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--color-primary);
}

.ed-form__req {
  color: var(--color-coral);
  margin-left: 0.15em;
}

.ed-form__input,
.ed-form__textarea {
  font-family: var(--font-sans);
  font-size: 1rem;
  line-height: 1.5;
  color: var(--color-primary);
  background: var(--bg-surface);
  border: 1px solid var(--rule-color);
  border-radius: 0;
  padding: 0.85rem 1rem;
  width: 100%;
  transition: border-color var(--transition), background-color var(--transition);
  -webkit-appearance: none;
  appearance: none;
}

.ed-form__input:focus,
.ed-form__textarea:focus {
  outline: none;
  border-color: var(--color-coral);
  border-width: 1px;
  background: var(--bg);
}

.ed-form__input:invalid:not(:placeholder-shown) {
  border-color: var(--color-coral-dark);
}

.ed-form__textarea {
  min-height: 140px;
  resize: vertical;
  font-family: var(--font-sans);
}

/* Radio group — chip style */
.ed-form__radios {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}

.ed-form__radio {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  cursor: pointer;
  padding: 0.6rem 1rem;
  border: 1px solid var(--rule-color);
  background: var(--bg-surface);
  font-size: 0.875rem;
  color: var(--color-primary);
  transition: border-color var(--transition), background-color var(--transition);
}

.ed-form__radio:hover {
  border-color: var(--color-teal-mid);
}

.ed-form__radio input[type="radio"] {
  margin: 0;
  accent-color: var(--color-coral);
  width: 14px;
  height: 14px;
}

.ed-form__radio:has(input:checked) {
  border-color: var(--color-coral);
  background: var(--color-accent-subtle);
  color: var(--color-coral-dark);
  font-weight: 600;
}

/* Honeypot — hide from real users */
.ed-form__honeypot {
  position: absolute;
  left: -9999px;
  width: 1px;
  height: 1px;
  overflow: hidden;
}

/* Cloudflare Turnstile widget wrapper */
.ed-form__captcha {
  margin-top: 0.5rem;
}

.ed-form__captcha iframe {
  border: none !important;
}

.ed-form__actions {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  align-items: flex-start;
  padding-top: 0.5rem;
}

@media (min-width: 640px) {
  .ed-form__actions {
    flex-direction: row;
    align-items: center;
    gap: 1.5rem;
  }
}

.ed-form__small {
  font-size: var(--caption);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-muted);
  margin: 0;
}

#cfSubmit:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}

.ed-form__status {
  font-size: 0.95rem;
  line-height: 1.5;
  padding: 0.85rem 1rem;
  border-left: 3px solid transparent;
  background: transparent;
  color: var(--text-secondary);
  display: none;
}

.ed-form__status.is-success,
.ed-form__status.is-error {
  display: block;
}

.ed-form__status.is-success {
  border-left-color: #2d8a4d;
  background: rgba(45, 138, 77, 0.08);
  color: #1c5b32;
}

.ed-form__status.is-error {
  border-left-color: var(--color-coral);
  background: var(--color-accent-subtle);
  color: var(--color-coral-dark);
}


/* ============================================================================
   ED-SOI — State of Innovation (podcast + speaker) two-column block
   ============================================================================ */

.ed-soi {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0;
  border-top: 1px solid var(--rule-color-dark);
  border-left: 1px solid var(--rule-color-dark);
}

@media (min-width: 900px) {
  .ed-soi { grid-template-columns: 1fr 1fr; }
}

.ed-soi__col {
  padding: clamp(1.75rem, 3vw, 2.5rem);
  border-right: 1px solid var(--rule-color-dark);
  border-bottom: 1px solid var(--rule-color-dark);
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.ed-soi__label {
  font-size: var(--caption);
  letter-spacing: 0.2em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--color-gold);
  margin: 0;
}

.ed-soi__text {
  font-size: 0.95rem;
  line-height: 1.6;
  color: rgba(250, 250, 248, 0.78);
  margin: 0;
  flex: 1;
}

.ed-soi__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  margin-top: 0.5rem;
}


/* ============================================================================
   ED-SYNTAX — outcome statement structure callout (ODI page)
   ============================================================================ */

.ed-syntax {
  border: 1px solid var(--rule-color);
  background: var(--bg);
  padding: clamp(1.75rem, 3vw, 2.5rem);
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}

.ed-syntax__formula {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5rem;
  padding-bottom: 1.25rem;
  border-bottom: 1px solid var(--rule-color);
  font-size: var(--caption);
  letter-spacing: 0.15em;
  text-transform: uppercase;
  font-weight: 600;
}

.ed-syntax__plus {
  color: var(--color-coral);
  font-weight: 700;
  font-size: 1rem;
  padding: 0 0.25em;
}

.ed-syntax__tok {
  display: inline-block;
  padding: 0.4em 0.7em;
  border-radius: 2px;
  font-size: var(--caption);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-weight: 600;
  white-space: nowrap;
  border: 1px solid transparent;
}

.ed-syntax__tok--dir {
  background: var(--color-accent-subtle);
  color: var(--color-coral-dark);
  border-color: var(--color-coral);
}

.ed-syntax__tok--metric {
  background: rgba(80, 150, 160, 0.1);
  color: var(--color-teal-dark);
  border-color: var(--color-teal-mid);
}

.ed-syntax__tok--obj {
  background: rgba(210, 160, 100, 0.1);
  color: var(--color-gold-dark);
  border-color: var(--color-gold);
}

.ed-syntax__tok--ctx {
  background: var(--bg-alt);
  color: var(--text-secondary);
  border-color: var(--border);
}

.ed-syntax__example {
  font-family: var(--font-display);
  font-size: clamp(1.125rem, 1.5vw + 0.4rem, 1.5rem);
  line-height: 1.5;
  font-weight: 400;
  color: var(--color-primary);
  margin: 0;
  display: inline;
}

.ed-syntax__example .ed-syntax__tok {
  font-family: var(--font-sans);
  font-size: 0.7em;
  letter-spacing: 0.08em;
  margin-right: 0.3em;
  vertical-align: baseline;
  display: inline-block;
}

.ed-syntax__rules {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  padding-top: 1.25rem;
  border-top: 1px solid var(--rule-color);
}

.ed-syntax__rules li {
  font-size: 0.95rem;
  line-height: 1.55;
  color: var(--text-secondary);
  padding-left: 1.25rem;
  position: relative;
}

.ed-syntax__rules li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0.7em;
  width: 6px;
  height: 1px;
  background: var(--color-coral);
}

.ed-syntax__rules li strong {
  color: var(--color-primary);
  font-weight: 600;
}

.ed-syntax__cite {
  font-size: var(--caption);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--text-muted);
  margin: 0;
}


/* ============================================================================
   MOBILE HARDENING — body fonts ≥16px, touch targets ≥44px, hover hygiene
   ============================================================================
   Added 2026-05-20. Applies the iOS-safe ≥16px rule to body copy that was
   shrinking too aggressively on small screens, and gives interactive elements
   the Apple HIG minimum 44×44 tap area.
   ============================================================================ */

@media (max-width: 600px) {
  /* Body text — bump to 16px so iOS doesn't zoom on focus and small-screen
     reading stays comfortable. Eyebrow/label styles intentionally stay small. */
  .ed-flow__text     { font-size: 1rem; line-height: 1.5; }    /* was 0.875rem (14px) */
  .ed-card__excerpt  { font-size: 1rem; line-height: 1.55; }   /* was 0.9375rem (15px) */
  .ed-svc__text      { font-size: 1rem; line-height: 1.55; }   /* was 0.95rem (15.2px) */
  .ed-soi__text      { font-size: 1rem; line-height: 1.6; }    /* was 0.95rem (15.2px) */
  .ed-feature__excerpt { font-size: 1rem; line-height: 1.55; }
  .ed-footer__col a  { font-size: 1rem; }                      /* was 0.9375rem */
  .ed-footer__address { font-size: 1rem; }
}

/* ---- Touch targets ≥44×44 on all pointer types
   These rules apply globally because tap-friendly padding doesn't hurt
   desktop users and avoids a media-query maze. Inline-flex + min-height
   keeps the label visually inline but the click target expands vertically. */

.ed-card__readmore,
.ed-feature__readmore,
.ed-insights__all,
.ed-team__link {
  min-height: 44px;
  padding: 0.5rem 0;
  align-items: center;
}

.ed-footer__col a,
.ed-footer__address a {
  display: inline-block;
  padding: 0.375rem 0;       /* ~6px top/bottom — gives ~30px tap height on label */
  min-height: 32px;
  line-height: 1.5;
}

.logo-link {
  padding: 0.625rem 0;       /* lifts the 24px wordmark to a 44px tap target */
  min-height: 44px;
}

/* ---- Hover hygiene: don't apply hover-only visual states on pure-touch
   devices (phones/tablets without a mouse). Prevents "sticky" hover states
   left behind after a tap on Safari iOS. */

@media (hover: none) {
  .ed-card:hover .ed-card__image,
  .ed-feature__link:hover .ed-feature__image,
  .ed-card:hover .ed-card__title,
  .ed-feature__link:hover .ed-feature__title,
  .ed-insights__all:hover,
  .ed-team__link:hover,
  .ed-team__link:hover .ed-btn__arrow,
  .ed-feature__link:hover .ed-feature__readmore,
  .ed-feature__link:hover .ed-feature__readmore .ed-btn__arrow,
  .ed-btn:hover,
  .ed-btn:hover .ed-btn__arrow,
  .nav-link:hover,
  .footer-link:hover {
    /* Disable hover-derived transforms/colors — the tap event itself will
       trigger any actual navigation; visual feedback comes from :active. */
    transform: none !important;
    color: inherit;
    border-color: inherit;
  }
  /* Keep button hover backgrounds since they're the primary visual affordance,
     but neutralize the lift/translate effects above. */
  .ed-btn--coral:hover { background: var(--color-coral); color: var(--text-on-dark); }
  .ed-btn--dark:hover  { background: var(--color-primary); color: var(--text-on-dark); }
}
