    @import url('https://fonts.googleapis.com/css2?family=IBM+Plex+Mono:wght@400;500&family=Inter:wght@400;500;600;700&display=swap');

    :root {
      --font-sans: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
      --font-mono: 'IBM Plex Mono', 'SFMono-Regular', ui-monospace, 'Cascadia Code', 'Source Code Pro', monospace;
      --font-ui-weight: 500;
      --font-display-weight: 400;
      --tracking-ui: -0.02em;
      --tracking-ui-tight: -0.024em;
      --tracking-display: -0.04em;
      --tracking-display-tight: -0.055em;
      --tracking-label: 0.06em;
      --line-display: 1;
      --line-display-relaxed: 1.04;
    }

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

    html {
      scroll-behavior: smooth;
    }

    body {
      font-family: var(--font-sans);
      font-optical-sizing: auto;
      background: #f2f4f8;
      min-height: 100vh;
      -webkit-font-smoothing: antialiased;
      text-rendering: optimizeLegibility;
      color: #1a2533;
    }

    button,
    input,
    textarea,
    select {
      font: inherit;
    }

    code,
    kbd,
    pre,
    samp,
    .language-toggle-code {
      font-family: var(--font-mono);
    }

    .site-page-shell {
      min-height: 100vh;
      display: flex;
      flex-direction: column;
    }

    .site-page-main {
      flex: 1 0 auto;
    }

    .breadcrumb {
      --breadcrumb-ink: rgba(26, 37, 51, 0.72);
      --breadcrumb-current: #152132;
      --breadcrumb-surface: rgba(255, 255, 255, 0.74);
      --breadcrumb-surface-hover: rgba(255, 255, 255, 0.94);
      --breadcrumb-border: rgba(26, 37, 51, 0.1);
      --breadcrumb-ring: rgba(59, 125, 219, 0.34);
      --breadcrumb-shadow: 0 16px 36px rgba(26, 37, 51, 0.08);
      margin-bottom: 22px;
      max-width: 100%;
    }

    .breadcrumb ol {
      display: flex;
      align-items: center;
      flex-wrap: nowrap;
      gap: 2px;
      width: max-content;
      max-width: 100%;
      list-style: none;
      margin: 0;
      padding: 4px;
      border: 1px solid var(--breadcrumb-border);
      border-radius: 999px;
      background: var(--breadcrumb-surface);
      box-shadow: var(--breadcrumb-shadow);
      backdrop-filter: blur(18px) saturate(1.25);
      -webkit-backdrop-filter: blur(18px) saturate(1.25);
      overflow-x: auto;
      scrollbar-width: none;
      font-size: 12.5px;
      font-weight: 600;
      line-height: 1.2;
      letter-spacing: 0;
      text-transform: none;
      white-space: nowrap;
    }

    .breadcrumb ol::-webkit-scrollbar {
      display: none;
    }

    .breadcrumb li {
      display: inline-flex;
      align-items: center;
      min-width: 0;
      color: var(--breadcrumb-ink);
    }

    .breadcrumb a,
    .breadcrumb span[aria-current],
    .breadcrumb li > span:not([aria-current]) {
      display: inline-flex;
      align-items: center;
      gap: 6px;
      max-width: min(34ch, 42vw);
      min-height: 34px;
      padding: 0 12px;
      border-radius: 999px;
      color: inherit;
      text-decoration: none;
    }

    .breadcrumb a {
      transition: background 0.18s ease, color 0.18s ease, transform 0.18s ease;
    }

    .breadcrumb a:hover {
      background: var(--breadcrumb-surface-hover);
      color: #204f8f;
      transform: translateY(-1px);
    }

    .breadcrumb a:focus-visible {
      outline: 3px solid var(--breadcrumb-ring);
      outline-offset: 2px;
    }

    .breadcrumb a span,
    .breadcrumb span[aria-current] span,
    .breadcrumb li > span:not([aria-current]) span {
      min-width: 0;
      overflow: hidden;
      text-overflow: ellipsis;
    }

    .breadcrumb [aria-current="page"] {
      color: var(--breadcrumb-current);
      background: rgba(26, 37, 51, 0.06);
      box-shadow: inset 0 0 0 1px rgba(26, 37, 51, 0.05);
    }

    .breadcrumb-home-icon {
      width: 14px;
      height: 14px;
      flex: 0 0 auto;
      fill: none;
      stroke: currentColor;
      stroke-width: 1.65;
      stroke-linecap: round;
      stroke-linejoin: round;
    }

    .breadcrumb-separator {
      width: 15px;
      height: 15px;
      flex: 0 0 auto;
      margin: 0 1px;
      fill: none;
      stroke: currentColor;
      stroke-width: 1.75;
      stroke-linecap: round;
      stroke-linejoin: round;
      opacity: 0.36;
    }

    .procurement-hero .breadcrumb,
    .workshop-hero .breadcrumb,
    .workshop-detail-hero .breadcrumb {
      --breadcrumb-ink: rgba(255, 255, 255, 0.72);
      --breadcrumb-current: #fff;
      --breadcrumb-surface: rgba(255, 255, 255, 0.1);
      --breadcrumb-surface-hover: rgba(255, 255, 255, 0.18);
      --breadcrumb-border: rgba(255, 255, 255, 0.18);
      --breadcrumb-ring: rgba(255, 255, 255, 0.28);
      --breadcrumb-shadow: 0 18px 38px rgba(0, 0, 0, 0.16);
    }

    .procurement-hero .breadcrumb ol {
      justify-content: center;
      margin: 0 auto;
    }

    .procurement-hero .breadcrumb [aria-current="page"],
    .workshop-hero .breadcrumb [aria-current="page"],
    .workshop-detail-hero .breadcrumb [aria-current="page"] {
      background: rgba(255, 255, 255, 0.14);
      box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.08);
    }

    .procurement-hero .breadcrumb [aria-current="page"] {
      color: #fff;
    }

    .procurement-hero .breadcrumb a:hover,
    .workshop-hero .breadcrumb a:hover,
    .workshop-detail-hero .breadcrumb a:hover {
      color: #fff;
    }

    @media (max-width: 640px) {
      .breadcrumb {
        margin-bottom: 18px;
      }

      .breadcrumb ol {
        width: 100%;
        padding: 3px;
        font-size: 12px;
      }

      .breadcrumb a,
      .breadcrumb span[aria-current],
      .breadcrumb li > span:not([aria-current]) {
        max-width: min(48vw, 22ch);
        min-height: 32px;
        padding: 0 10px;
      }

      .breadcrumb-current-item {
        flex: 1 1 auto;
      }

      .breadcrumb-current-item span[aria-current] {
        max-width: 100%;
      }
    }

.services-index-hero {
  padding: clamp(112px, 16vw, 168px) var(--page-pad) clamp(40px, 8vw, 84px);
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.94), rgba(247, 249, 246, 0.96)),
    radial-gradient(circle at 14% 20%, rgba(119, 178, 85, 0.18), transparent 34%),
    radial-gradient(circle at 86% 16%, rgba(36, 68, 64, 0.12), transparent 30%);
}

.services-index-heading {
  width: min(980px, 100%);
  margin: 0 auto;
  text-align: center;
}

.services-index-label {
  margin: 0 0 18px;
  color: rgba(18, 27, 25, 0.62);
  font-size: 0.74rem;
  font-weight: 760;
  letter-spacing: 0;
  text-transform: uppercase;
}

.services-index-heading h1 {
  margin: 0;
  color: var(--ink);
  font-size: clamp(2.55rem, 5.8vw, 5.9rem);
  line-height: 0.95;
  letter-spacing: 0;
}

.services-index-sub {
  width: min(760px, 100%);
  margin: 24px auto 0;
  color: var(--muted);
  font-size: clamp(1.05rem, 1.6vw, 1.28rem);
  line-height: 1.62;
}

.services-index-links {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
  width: min(1180px, calc(100% - (var(--page-pad) * 2)));
  margin: clamp(36px, 7vw, 72px) auto clamp(72px, 10vw, 120px);
}

.services-index-link {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 18px;
  min-height: 178px;
  padding: 26px;
  border: 1px solid rgba(18, 27, 25, 0.1);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.86);
  color: var(--ink);
  text-decoration: none;
  box-shadow: 0 18px 44px rgba(18, 27, 25, 0.07);
  transition: transform 180ms ease, border-color 180ms ease, box-shadow 180ms ease;
}

.services-index-link:hover,
.services-index-link:focus-visible {
  transform: translateY(-3px);
  border-color: rgba(119, 178, 85, 0.46);
  box-shadow: 0 24px 58px rgba(18, 27, 25, 0.1);
}

.services-index-link strong {
  display: block;
  font-size: 1.08rem;
  line-height: 1.2;
}

.services-index-link small {
  display: block;
  margin-top: 12px;
  color: var(--muted);
  font-size: 0.95rem;
  line-height: 1.55;
}

.services-index-link svg {
  flex: 0 0 auto;
  width: 22px;
  margin-top: 2px;
}

@media (max-width: 820px) {
  .services-index-links {
    grid-template-columns: 1fr;
  }

  .services-index-link {
    min-height: auto;
  }
}

    h1, h2, h3, h4, h5, h6 {
      font-family: var(--font-sans);
      font-weight: var(--font-display-weight);
      letter-spacing: var(--tracking-display);
      line-height: var(--line-display-relaxed);
    }

    /* ── Header ── */
    header {
      position: sticky;
      top: 0;
      z-index: 1000;
    }

    header::before {
      content: "";
      position: absolute;
      inset: 0;
      background:
        linear-gradient(180deg, rgba(252, 253, 255, 0.6) 0%, rgba(240, 245, 251, 0.5) 100%);
      backdrop-filter: blur(28px) saturate(1.02);
      -webkit-backdrop-filter: blur(28px) saturate(1.02);
      box-shadow:
        0 12px 32px rgba(24, 44, 72, 0.04),
        inset 0 1px 0 rgba(255, 255, 255, 0.34);
      pointer-events: none;
      z-index: 0;
      opacity: 1;
      transition: opacity 0.4s ease;
    }

    header::after {
      content: "";
      position: absolute;
      inset: 0;
      background:
        linear-gradient(180deg, rgba(14, 25, 45, 0.42) 0%, rgba(10, 20, 38, 0.3) 100%);
      backdrop-filter: blur(30px) saturate(1.02);
      -webkit-backdrop-filter: blur(30px) saturate(1.02);
      box-shadow:
        0 14px 34px rgba(0, 0, 0, 0.12),
        inset 0 1px 0 rgba(255, 255, 255, 0.08);
      pointer-events: none;
      z-index: 0;
      opacity: 0;
      transition: opacity 0.4s ease;
    }

    nav {
      position: relative;
      max-width: 1280px;
      margin: 0 auto;
      display: grid;
      grid-template-columns: 1fr auto 1fr;
      align-items: center;
      padding: 6px 32px;
      height: 52px;
      z-index: 1;
    }

    nav > * {
      position: relative;
      z-index: 1;
    }

    /* Logo */
    .nav-logo {
      display: flex;
      align-items: center;
      gap: 8px;
      text-decoration: none;
      justify-self: start;
      isolation: isolate;
    }

    .logo-mark {
      display: inline-flex;
      position: relative;
      align-items: center;
      justify-content: center;
      width: 26px;
      height: 26px;
      perspective: 400px;
      transition: transform 0.2s ease;
    }

    .logo-mark::before {
      content: "";
      position: absolute;
      inset: -6px;
      border-radius: 50%;
      background:
        radial-gradient(circle, rgba(91, 163, 217, 0.28) 0%, rgba(91, 163, 217, 0) 68%);
      opacity: 0;
      transform: scale(0.72);
      transition: opacity 0.2s ease, transform 0.2s ease;
      z-index: -1;
    }

    .logo-mark-svg {
      width: 100%;
      height: 100%;
      transform-origin: 50% 50%;
      transition: transform 0.2s ease, filter 0.2s ease;
    }

    .nav-logo:hover .logo-mark {
      transform: translateY(-1px) scale(1.04);
    }

    .nav-logo:hover .logo-mark::before {
      opacity: 1;
      transform: scale(1);
    }

    .nav-logo:hover .logo-mark-svg {
      transform: rotate(18deg);
      filter: drop-shadow(0 8px 14px rgba(59, 125, 219, 0.24));
    }

    @keyframes hixton-tumble {
      0%   { transform: rotate3d(0, 0, 0, 0deg); }
      50%  { transform: rotate3d(1, 0, 0, -45deg); }
      100% { transform: rotate3d(0, 0, 0, 0deg); }
    }

    @keyframes hixton-spin {
      0%   { transform: rotateZ(0deg); }
      100% { transform: rotateZ(360deg); }
    }

    @media (prefers-reduced-motion: reduce) {
      .nav-logo:hover .logo-mark,
      .nav-logo:hover .logo-mark-svg {
        transform: none;
      }
    }

    .logo-mark-svg {
      transition: transform 0.2s ease, filter 0.2s ease;
    }

    .logo-wordmark {
      height: 18px;
      width: auto;
      object-fit: contain;
      transition: opacity 0.2s ease, transform 0.2s ease, filter 0.2s ease;
    }

    .nav-logo {
      position: relative;
    }

    .nav-logo .logo-dark {
      opacity: 1;
    }

    .nav-logo:hover .logo-dark {
      transform: translateX(2px);
      filter: drop-shadow(0 6px 16px rgba(26, 37, 51, 0.08));
    }

    .nav-logo .logo-light {
      opacity: 0;
      position: absolute;
      left: 34px;
      top: 50%;
      transform: translateY(-50%);
      pointer-events: none;
    }

    .nav-logo:hover .logo-light {
      transform: translateY(-50%) translateX(2px);
    }

    /* Over-hero: crossfade mark and wordmark to white */
    .over-hero .logo-mark-svg {
      filter: brightness(0) invert(1);
    }

    .over-hero .nav-logo .logo-dark {
      opacity: 0;
    }

    .over-hero .nav-logo .logo-light {
      opacity: 1;
    }

    /* Center links */
    .nav-center {
      display: flex;
      align-items: center;
      gap: 2px;
      padding: 3px;
      border-radius: 980px;
      list-style: none;
      background: transparent;
    }

    .nav-center a {
      display: block;
      text-decoration: none;
      font-size: 13.5px;
      font-weight: var(--font-ui-weight);
      letter-spacing: var(--tracking-ui);
      color: #5a6270;
      padding: 6px 16px;
      border-radius: 980px;
      transition: all 0.2s ease;
      white-space: nowrap;
      background: transparent;
    }

    .nav-center a:hover {
      color: #3b7ddb;
    }

    .nav-center a.active {
      color: #3b7ddb;
      background: transparent;
    }

    /* Dropdown */
    .nav-dropdown {
      position: relative;
    }

    .nav-dropdown-toggle {
      display: inline-flex;
      align-items: center;
      gap: 4px;
      font-family: inherit;
      font-size: 13.5px;
      font-weight: var(--font-ui-weight);
      letter-spacing: var(--tracking-ui);
      color: #5a6270;
      padding: 6px 16px;
      border-radius: 980px;
      border: none;
      background: transparent;
      cursor: pointer;
      transition: all 0.2s ease;
      white-space: nowrap;
    }

    .nav-dropdown-toggle:hover {
      color: #3b7ddb;
    }

    .nav-dropdown-toggle.active {
      color: #3b7ddb;
    }

    .nav-chevron {
      width: 10px;
      height: 10px;
      transition: transform 0.2s ease;
    }

    .nav-dropdown:hover .nav-chevron {
      transform: rotate(180deg);
    }

    .nav-dropdown-menu {
      position: absolute;
      top: calc(100% + 18px);
      left: 50%;
      transform: translateX(-50%);
      min-width: 224px;
      background:
        linear-gradient(180deg, rgba(249, 251, 254, 0.82) 0%, rgba(236, 242, 249, 0.72) 100%);
      backdrop-filter: blur(28px) saturate(1.08);
      -webkit-backdrop-filter: blur(28px) saturate(1.08);
      will-change: transform, opacity;
      overflow: visible;
      border-radius: 13px;
      border: 1px solid rgba(255, 255, 255, 0.62);
      box-shadow:
        0 18px 42px rgba(28, 52, 82, 0.12),
        inset 0 1px 0 rgba(255, 255, 255, 0.54);
      padding: 6px;
      opacity: 0;
      visibility: hidden;
      transition: opacity 0.2s ease, visibility 0.2s ease;
      z-index: 2000;
    }

    .nav-dropdown:hover .nav-dropdown-menu {
      opacity: 1;
      visibility: visible;
    }

    .nav-dropdown-item {
      position: relative;
    }

    .nav-dropdown-item + .nav-dropdown-item {
      margin-top: 2px;
    }

    .nav-dropdown-menu a {
      display: flex;
      align-items: center;
      gap: 11px;
      text-decoration: none;
      padding: 9px 11px;
      border-radius: 10px;
      transition: background 0.15s ease;
    }

    .nav-dropdown-menu a:hover {
      background: rgba(255, 255, 255, 0.48);
    }

    .dropdown-icon {
      width: 38px;
      height: 38px;
      border-radius: 10px;
      background: rgba(255, 255, 255, 0.5);
      display: flex;
      align-items: center;
      justify-content: center;
      flex-shrink: 0;
    }

    .dropdown-icon svg {
      width: 17px;
      height: 17px;
      color: #5a6270;
    }

    .dropdown-text {
      flex: 1;
      min-width: 0;
    }

    .dropdown-title {
      display: block;
      font-size: 13.5px;
      font-weight: var(--font-ui-weight);
      letter-spacing: var(--tracking-ui-tight);
      color: #1a2533;
    }

    .dropdown-desc {
      display: block;
      font-size: 12px;
      color: #0000005c;
      margin-top: 2px;
    }

    .dropdown-arrow {
      width: 13px;
      height: 13px;
      color: #0000005c;
      flex-shrink: 0;
      opacity: 0;
      transform: translateX(-4px);
      transition: opacity 0.15s ease, transform 0.15s ease;
    }

    .nav-dropdown-menu a:hover .dropdown-arrow {
      opacity: 1;
      transform: translateX(0);
    }

    .dropdown-submenu-chevron {
      width: 14px;
      height: 14px;
      color: #00000074;
      flex-shrink: 0;
      transition: transform 0.18s ease;
    }

    .nav-dropdown-item-has-children:hover > .nav-dropdown-link .dropdown-submenu-chevron,
    .nav-dropdown-item-has-children:focus-within > .nav-dropdown-link .dropdown-submenu-chevron {
      transform: translateX(2px);
    }

    .nav-submenu {
      position: absolute;
      top: 0;
      left: calc(100% - 6px);
      min-width: 280px;
      max-width: 340px;
      padding: 8px;
      border-radius: 16px;
      border: 1px solid rgba(255, 255, 255, 0.68);
      background: rgba(255, 255, 255, 0.96);
      backdrop-filter: blur(34px) saturate(1.08);
      -webkit-backdrop-filter: blur(34px) saturate(1.08);
      box-shadow:
        0 18px 42px rgba(28, 52, 82, 0.12),
        inset 0 1px 0 rgba(255, 255, 255, 0.54);
      opacity: 0;
      visibility: hidden;
      pointer-events: none;
      transform: translateX(8px);
      transition: opacity 0.18s ease, visibility 0.18s ease, transform 0.18s ease;
      z-index: 2200;
    }

    .nav-dropdown-item-has-children:hover > .nav-submenu,
    .nav-dropdown-item-has-children:focus-within > .nav-submenu,
    .nav-dropdown-item-has-children > .nav-dropdown-link:focus + .nav-submenu,
    .nav-dropdown-item-has-children > .nav-submenu:focus-within {
      opacity: 1;
      visibility: visible;
      pointer-events: auto;
      transform: translateX(0);
    }

    .nav-submenu .nav-submenu-link {
      display: flex;
      align-items: center;
      gap: 12px;
      padding: 10px 12px;
      border-radius: 12px;
      white-space: normal;
    }

    .nav-submenu .nav-submenu-link:hover,
    .nav-submenu .nav-submenu-link:focus-visible {
      background: rgba(255, 255, 255, 0.62);
      outline: none;
    }

    .nav-submenu-icon {
      width: 38px;
      height: 38px;
      border-radius: 10px;
      background: rgba(255, 255, 255, 0.56);
      display: inline-flex;
      align-items: center;
      justify-content: center;
      flex-shrink: 0;
    }

    .nav-submenu-icon svg {
      width: 19px;
      height: 19px;
      color: #5a6270;
    }

    .nav-submenu-text {
      flex: 1;
      min-width: 0;
    }

    .nav-submenu-title {
      display: block;
      font-size: 15.5px;
      font-weight: var(--font-ui-weight);
      letter-spacing: var(--tracking-ui-tight);
      color: #1a2533;
    }

    .nav-submenu-desc {
      display: block;
      margin-top: 2px;
      font-size: 14.5px;
      line-height: 1.35;
      color: #0000005c;
    }

    .nav-submenu-arrow {
      width: 14px;
      height: 14px;
      color: #0000005c;
      flex-shrink: 0;
      opacity: 0;
      transform: translateX(-4px);
      transition: opacity 0.15s ease, transform 0.15s ease;
    }

    .nav-submenu .nav-submenu-link:hover .nav-submenu-arrow,
    .nav-submenu .nav-submenu-link:focus-visible .nav-submenu-arrow {
      opacity: 1;
      transform: translateX(0);
    }

    /* Over-hero dropdown styles */
    .over-hero .nav-dropdown-toggle {
      color: rgba(255, 255, 255, 0.8);
    }

    .over-hero .nav-dropdown-toggle:hover,
    .over-hero .nav-dropdown-toggle.active {
      color: #fff;
    }

    .over-hero .nav-dropdown-menu {
      background:
        linear-gradient(180deg, rgba(16, 30, 53, 0.72) 0%, rgba(10, 23, 43, 0.64) 100%);
      backdrop-filter: blur(34px) saturate(1.06);
      -webkit-backdrop-filter: blur(34px) saturate(1.06);
      border-color: rgba(255, 255, 255, 0.16);
    }

    .over-hero .nav-dropdown-menu a:hover {
      background: rgba(255, 255, 255, 0.1);
    }

    .over-hero .dropdown-title {
      color: #fff;
    }

    .over-hero .dropdown-desc {
      color: rgba(255, 255, 255, 0.6);
    }

    .over-hero .dropdown-icon {
      background: rgba(255, 255, 255, 0.12);
    }

    .over-hero .dropdown-icon svg {
      color: rgba(255, 255, 255, 0.8);
    }

    .over-hero .dropdown-arrow {
      color: rgba(255, 255, 255, 0.6);
    }

    .over-hero .dropdown-submenu-chevron {
      color: rgba(255, 255, 255, 0.68);
    }

    .over-hero .nav-submenu {
      background: rgba(15, 30, 55, 0.86);
      border-color: rgba(255, 255, 255, 0.12);
    }

    .over-hero .nav-submenu .nav-submenu-link:hover,
    .over-hero .nav-submenu .nav-submenu-link:focus-visible {
      background: rgba(255, 255, 255, 0.1);
    }

    .over-hero .nav-submenu-title {
      color: #fff;
    }

    .over-hero .nav-submenu-desc,
    .over-hero .nav-submenu-arrow {
      color: rgba(255, 255, 255, 0.62);
    }

    .over-hero .nav-submenu-icon {
      background: rgba(255, 255, 255, 0.12);
    }

    .over-hero .nav-submenu-icon svg {
      color: rgba(255, 255, 255, 0.82);
    }

    /* Right side — CTA */
    .nav-right {
      display: flex;
      align-items: center;
      gap: 12px;
      justify-self: end;
    }

    .nav-cta {
      display: inline-flex;
      align-items: center;
      gap: 6px;
      text-decoration: none;
      font-size: 13px;
      font-weight: var(--font-ui-weight);
      letter-spacing: var(--tracking-ui-tight);
      color: #fff;
      padding: 7px 18px;
      border-radius: 980px;
      background: #0e0f19;
      box-shadow: 0 2px 8px rgba(0, 0, 0, 0.12);
      transition: background 0.4s ease, color 0.4s ease,
                  box-shadow 0.22s ease,
                  transform 0.18s cubic-bezier(0.34, 1.56, 0.64, 1);
    }

    .nav-cta:hover {
      transform: translateY(-2px);
      box-shadow: 0 6px 18px rgba(0, 0, 0, 0.22);
    }

    .nav-cta:active {
      transform: scale(0.97);
      box-shadow: 0 1px 4px rgba(0, 0, 0, 0.1);
      transition-duration: 0.06s;
    }

    .nav-cta svg {
      width: 11px;
      height: 11px;
      transition: transform 0.2s cubic-bezier(0.34, 1.56, 0.64, 1);
    }

    .nav-cta:hover svg {
      transform: translateX(3px);
    }

    /* Language toggle */
    .language-toggle {
      display: inline-flex;
      align-items: center;
      gap: 5px;
      background: none;
      border: 0;
      padding: 5px 6px;
      border-radius: 8px;
      font-size: 11px;
      font-weight: var(--font-ui-weight);
      letter-spacing: var(--tracking-ui);
      color: rgba(26, 37, 51, 0.55);
      cursor: pointer;
      transition: color 0.2s ease, background 0.2s ease;
    }

    .language-toggle:hover {
      color: #1a2533;
      background: rgba(26, 37, 51, 0.06);
    }

    .language-toggle svg {
      flex-shrink: 0;
    }

    .language-toggle-code {
      line-height: 1;
    }

    /* Header over hero — subtle glass blur */
    .over-hero::before {
      opacity: 0;
    }

    .over-hero::after {
      opacity: 1;
      background:
        linear-gradient(180deg, rgba(14, 25, 45, 0.34) 0%, rgba(10, 20, 38, 0.22) 100%);
      backdrop-filter: blur(26px) saturate(1.03);
      -webkit-backdrop-filter: blur(26px) saturate(1.03);
      box-shadow:
        0 8px 24px rgba(0, 0, 0, 0.08),
        inset 0 1px 0 rgba(255, 255, 255, 0.08);
    }

    header.home-nav-at-top::before,
    header.home-nav-at-top::after {
      opacity: 0;
      box-shadow: none;
    }

    .over-hero .nav-center a {
      color: rgba(255, 255, 255, 0.8);
    }

    .over-hero .nav-center a:hover,
    .over-hero .nav-center a.active {
      color: #fff;
    }

    .over-hero .nav-cta {
      background: #fff;
      color: #1a2533;
      box-shadow: 0 4px 14px rgba(0, 0, 0, 0.15);
    }

    .over-hero .nav-cta:hover {
      box-shadow: 0 6px 20px rgba(0, 0, 0, 0.2);
    }

    .over-hero .nav-toggle span {
      background: #fff;
    }

    .over-hero .language-toggle {
      color: rgba(255, 255, 255, 0.6);
    }

    .over-hero .language-toggle:hover {
      color: #fff;
      background: rgba(255, 255, 255, 0.1);
    }

    /* Mobile */
    .nav-toggle {
      display: none;
      flex-direction: column;
      gap: 5px;
      cursor: pointer;
      padding: 6px;
      background: none;
      border: none;
    }

    .nav-toggle span {
      display: block;
      width: 22px;
      height: 2px;
      border-radius: 2px;
      background: #5a6270;
      transition: all 0.3s ease;
    }

    /* ── Hero (legacy dark — kept for subpages) ── */
    .hero-shell {
      margin: -64px 0 0;
    }

    .hero {
      position: relative;
      overflow: hidden;
      margin: 0;
      border-radius: 0;
      min-height: clamp(520px, 78vh, 820px);
      display: flex;
      align-items: stretch;
      justify-content: center;
      background: #2a2031;
      isolation: isolate;
    }

    .hero-bg-wrap {
      position: absolute;
      inset: 0;
      overflow: hidden;
      z-index: 0;
    }

    .hero-bg {
      position: absolute;
      inset: 0;
      background: #2a2031;
      transform: scale(1.02);
    }

    .hero-blob {
      display: none;
    }

    .hero-blob-1 {
      width: 60%;
      height: 60%;
      top: -5%;
      left: 0%;
      background: radial-gradient(circle, #3b7ddb 0%, transparent 70%);
      animation: blob-appear 1.2s ease-out 0.2s both, blob-1 18s ease-in-out 1.4s infinite;
    }

    .hero-blob-2 {
      width: 55%;
      height: 55%;
      bottom: -5%;
      right: 0%;
      background: radial-gradient(circle, #5ba3d9 0%, transparent 70%);
      animation: blob-appear 1.2s ease-out 0.4s both, blob-2 15s ease-in-out 1.6s infinite;
    }

    .hero-blob-3 {
      width: 45%;
      height: 45%;
      top: 15%;
      right: 15%;
      background: radial-gradient(circle, #6db3e8 0%, transparent 70%);
      animation: blob-appear 1.2s ease-out 0.6s both, blob-3 20s ease-in-out 1.8s infinite;
    }

    .hero-blob-4 {
      width: 40%;
      height: 40%;
      bottom: 15%;
      left: 20%;
      background: radial-gradient(circle, rgba(255, 255, 255, 0.15) 0%, transparent 70%);
      animation: blob-appear 1.2s ease-out 0.8s both, blob-4 24s ease-in-out 2s infinite;
    }

    @keyframes blob-appear {
      from {
        opacity: 0;
        transform: scale(0.6);
      }
      to {
        opacity: 1;
        transform: scale(1);
      }
    }

    @keyframes blob-1 {
      0%, 100% { transform: translate(0%, 0%) scale(1); }
      20% { transform: translate(22%, 18%) scale(1.2); }
      40% { transform: translate(-15%, 24%) scale(0.85); }
      60% { transform: translate(18%, -14%) scale(1.15); }
      80% { transform: translate(-10%, -20%) scale(0.9); }
    }

    @keyframes blob-2 {
      0%, 100% { transform: translate(0%, 0%) scale(1); }
      20% { transform: translate(-20%, -16%) scale(1.18); }
      40% { transform: translate(18%, -22%) scale(0.85); }
      60% { transform: translate(-24%, 14%) scale(1.12); }
      80% { transform: translate(14%, 20%) scale(0.88); }
    }

    @keyframes blob-3 {
      0%, 100% { transform: translate(0%, 0%) scale(1); }
      20% { transform: translate(-18%, 22%) scale(0.85); }
      40% { transform: translate(22%, 12%) scale(1.2); }
      60% { transform: translate(8%, -20%) scale(0.88); }
      80% { transform: translate(-22%, -8%) scale(1.15); }
    }

    @keyframes blob-4 {
      0%, 100% { transform: translate(0%, 0%) scale(1); }
      20% { transform: translate(20%, -18%) scale(1.15); }
      40% { transform: translate(-18%, 16%) scale(0.85); }
      60% { transform: translate(-14%, -22%) scale(1.18); }
      80% { transform: translate(16%, 18%) scale(0.88); }
    }

    .hero-content {
      position: relative;
      z-index: 1;
      width: 100%;
      min-height: inherit;
      padding: 0;
      display: flex;
      flex-direction: column;
      animation: hero-fade-in 1s ease-out both;
    }

    .hero-copy {
      text-align: left;
      max-width: 640px;
    }

    .hero-step-label {
      font-size: 13px;
      font-weight: var(--font-ui-weight);
      letter-spacing: var(--tracking-label);
      text-transform: uppercase;
      color: rgba(255, 255, 255, 0.72);
      margin-bottom: 18px;
    }

    @keyframes hero-fade-in {
      from {
        opacity: 0;
        transform: translateY(24px);
      }
      to {
        opacity: 1;
        transform: translateY(0);
      }
    }

    .hero-content h1 {
      font-size: clamp(3.15rem, 5.4vw, 5.4rem);
      font-weight: var(--font-display-weight);
      letter-spacing: var(--tracking-display-tight);
      line-height: var(--line-display);
      color: #fff;
      margin: 0;
    }

    .hero-description {
      font-size: 19px;
      line-height: 1.72;
      color: rgba(255, 255, 255, 0.8);
      max-width: 590px;
      margin: 0 0 30px;
      animation: hero-fade-in 0.9s ease-out 0.3s both;
    }

    .hero-point-list {
      list-style: none;
      display: grid;
      gap: 12px;
      margin: 0 0 34px;
      padding: 0;
      max-width: 560px;
      animation: hero-fade-in 0.9s ease-out 0.36s both;
    }

    .hero-point-list li {
      position: relative;
      padding-left: 18px;
      color: rgba(255, 255, 255, 0.78);
      font-size: 15px;
      line-height: 1.5;
    }

    .hero-point-list li::before {
      content: '';
      position: absolute;
      left: 0;
      top: 0.75em;
      width: 6px;
      height: 6px;
      border-radius: 999px;
      background: rgba(255, 255, 255, 0.72);
      transform: translateY(-50%);
    }

    .hero-actions {
      display: flex;
      align-items: center;
      gap: 18px;
      flex-wrap: wrap;
      animation: hero-fade-in 0.9s ease-out 0.45s both;
    }

    .hero-rotator {
      position: relative;
      min-height: inherit;
      flex: 1;
      animation: hero-fade-in 0.9s ease-out 0.32s both;
    }

    .hero-rotator-stage {
      position: relative;
      min-height: inherit;
      height: 100%;
      isolation: isolate;
      flex: 1;
    }

    .hero-rotator-stage::before {
      content: '';
      position: absolute;
      inset: 0;
      background:
        linear-gradient(180deg, rgba(7, 15, 28, 0.08) 0%, rgba(7, 15, 28, 0.1) 40%, rgba(7, 15, 28, 0.2) 100%),
        radial-gradient(circle at 76% 22%, rgba(255, 255, 255, 0.08) 0%, rgba(255, 255, 255, 0) 38%),
        radial-gradient(circle at 18% 72%, rgba(91, 163, 217, 0.1) 0%, rgba(91, 163, 217, 0) 34%);
      z-index: 0;
      pointer-events: none;
    }

    .hero-rotator-card {
      position: absolute;
      inset: 0;
      overflow: hidden;
      border-radius: 0;
      transition:
        transform 1s cubic-bezier(0.22, 1, 0.36, 1),
        opacity 1s ease,
        filter 1s ease;
      will-change: opacity, transform;
      z-index: 1;
    }

    .hero-rotator-card::after {
      content: '';
      position: absolute;
      inset: 0;
      background:
        linear-gradient(180deg, rgba(6, 14, 28, 0.12) 0%, rgba(6, 14, 28, 0.08) 40%, rgba(6, 14, 28, 0.28) 80%, rgba(6, 14, 28, 0.38) 100%);
      pointer-events: none;
    }

    .hero-rotator-card.is-active {
      opacity: 1;
      transform: scale(1);
      z-index: 3;
    }

    .hero-rotator-card.is-hidden {
      opacity: 0;
      transform: scale(1.03);
      pointer-events: none;
    }

    .hero-rotator-card-image {
      width: 100%;
      height: 100%;
      object-fit: cover;
      display: block;
      opacity: 1;
      filter: saturate(0.94) contrast(1.03);
    }

    .hero-rotator-overlay {
      position: absolute;
      left: max(24px, calc((100% - 1320px) / 2 + 24px));
      bottom: clamp(38px, 10vh, 108px);
      z-index: 4;
      display: grid;
      gap: 22px;
      max-width: min(620px, calc(100% - 56px));
    }

    .hero-rotator-title {
      max-width: 10ch;
      text-shadow: 0 18px 36px rgba(4, 11, 25, 0.34);
    }

    .hero-rotator-description {
      font-size: clamp(1rem, 1.35vw, 1.18rem);
      line-height: 1.72;
      color: rgba(255, 255, 255, 0.8);
      max-width: 44ch;
      margin: 0;
      text-shadow: 0 12px 28px rgba(4, 11, 25, 0.24);
    }

    .hero-rotator-link {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      min-height: 44px;
      width: fit-content;
      padding: 0 18px;
      border-radius: 999px;
      text-decoration: none;
      color: #0f1728;
      background: rgba(255, 255, 255, 0.98);
      border: 1px solid rgba(255, 255, 255, 0.24);
      box-shadow: 0 8px 24px rgba(6, 14, 28, 0.14);
      font-size: 0.92rem;
      font-weight: 600;
      transition: transform 0.18s ease, box-shadow 0.18s ease, background 0.18s ease;
    }

    .hero-rotator-link svg {
      width: 14px;
      height: 14px;
      transition: transform 0.18s ease;
    }

    .hero-rotator-link:hover {
      transform: translateY(-1px);
      box-shadow: 0 12px 28px rgba(6, 14, 28, 0.18);
      background: #ffffff;
    }

    .hero-rotator-link:hover svg {
      transform: translateX(2px);
    }

    .journey-sections {
      max-width: 1320px;
      margin: 104px auto 0;
      padding: 0 24px;
    }

    .journey-sections-heading {
      text-align: center;
      margin: 0 auto 28px;
    }

    .journey-sections-sub {
      max-width: 720px;
      margin: 0 auto;
    }

    .process-showcase {
      --process-visual-width: clamp(460px, 42vw, 620px);
      --process-visual-height: clamp(470px, 43vw, 590px);
      --process-glass-width: clamp(390px, 80%, 500px);
      --process-glass-height: clamp(340px, 31vw, 430px);
      --process-graphic-shell-height: var(--process-glass-height);
      max-width: 1320px;
      margin: 120px 24px 0;
      margin-left: max(24px, calc((100% - 1320px) / 2));
      margin-right: max(24px, calc((100% - 1320px) / 2));
      padding: 0;
    }

    .process-showcase-label {
      width: fit-content;
      max-width: 900px;
      margin: 0 auto 40px;
      text-align: center;
      font-size: clamp(2.25rem, 4vw, 4.25rem);
      font-weight: 500;
      letter-spacing: -0.06em;
      line-height: 0.98;
      text-transform: none;
      color: #05070c;
    }

    .process-showcase-stack {
      display: grid;
      gap: 72px;
    }

    .process-showcase-section {
      display: grid;
      gap: 0;
      padding: 18px 0 0;
    }

    .process-showcase-section:hover {
      box-shadow: none;
    }

    .process-showcase-heading {
      display: grid;
      grid-template-columns: auto minmax(0, 1fr);
      gap: 20px;
      align-items: start;
      margin-bottom: 34px;
    }

    .process-showcase-step-number {
      font-size: clamp(2.75rem, 5vw, 4.5rem);
      font-weight: 500;
      letter-spacing: -0.06em;
      line-height: 0.9;
      color: rgba(17, 24, 39, 0.12);
    }

    .process-showcase-heading h2 {
      font-size: clamp(2.2rem, 3.35vw, 3.25rem);
      font-weight: var(--font-display-weight);
      letter-spacing: var(--tracking-display-tight);
      line-height: var(--line-display);
      color: #111827;
      margin: 0;
      max-width: none;
      white-space: nowrap;
    }

    .process-showcase-body {
      display: grid;
      grid-template-columns: minmax(0, var(--process-visual-width)) minmax(380px, 1fr);
      grid-template-areas:
        "visual stages"
        "visual detail";
      gap: clamp(36px, 4vw, 72px);
      align-items: start;
    }

    .process-showcase-section.is-reversed .process-showcase-body {
      grid-template-columns: minmax(380px, 1fr) minmax(0, var(--process-visual-width));
      grid-template-areas:
        "stages visual"
        "detail visual";
    }

    .process-showcase-visual {
      grid-area: visual;
      width: min(100%, var(--process-visual-width));
      min-width: 0;
      min-height: var(--process-visual-height);
      justify-self: center;
    }

    .process-showcase-stage-list {
      grid-area: stages;
      display: grid;
      gap: 22px;
      max-width: 48ch;
      padding-top: 22px;
      position: relative;
      z-index: 2;
    }

    .process-showcase-stage {
      position: relative;
      display: grid;
      gap: 10px;
      width: 100%;
      padding: 20px 0 0;
      border: 0;
      border-top: 1px solid rgba(17, 24, 39, 0.12);
      background: none;
      text-align: left;
      cursor: pointer;
      appearance: none;
      pointer-events: auto;
      touch-action: manipulation;
      transition: opacity 0.2s ease, transform 0.2s ease;
    }

    .process-showcase-stage::before {
      content: "";
      position: absolute;
      left: 0;
      top: -1px;
      width: 0;
      height: 2px;
      border-radius: 999px;
      background: rgba(17, 24, 39, 0.45);
      transition: width 0.24s ease;
    }

    .process-showcase-stage:hover {
      transform: translateX(2px);
    }

    .process-showcase-stage.is-active::before {
      width: min(160px, 42%);
    }

    .process-showcase-stage-title {
      display: block;
      font-size: clamp(1.16rem, 1.3vw, 1.58rem);
      font-weight: 500;
      letter-spacing: -0.03em;
      line-height: 1.08;
      color: rgba(17, 24, 39, 0.36);
      transition: color 0.2s ease;
    }

    .process-showcase-stage-summary {
      display: block;
      max-width: none;
      font-size: 0.92rem;
      line-height: 1.58;
      color: rgba(17, 24, 39, 0.42);
      transition: color 0.2s ease;
    }

    .process-showcase-stage.is-active .process-showcase-stage-title {
      color: #111827;
    }

    .process-showcase-stage.is-active .process-showcase-stage-summary {
      color: rgba(17, 24, 39, 0.74);
    }

    .process-showcase-stage:focus-visible {
      outline: none;
    }

    .process-showcase-stage:focus-visible .process-showcase-stage-title,
    .process-showcase-stage:focus-visible .process-showcase-stage-summary {
      color: #111827;
    }

    .process-showcase-stage:focus-visible::before {
      width: min(160px, 42%);
      background: #111827;
    }

    .process-showcase-detail {
      grid-area: detail;
      max-width: 52ch;
      margin-top: 18px;
      min-height: 120px;
      position: relative;
      z-index: 2;
    }

    .process-showcase-detail-panel[hidden] {
      display: none;
    }

    .process-showcase-cta {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      text-decoration: none;
      min-height: 42px;
      padding: 0 18px;
      border-radius: 999px;
      background: #f2f4f8;
      border: 1px solid rgba(17, 24, 39, 0.12);
      color: #111827;
      font-size: 0.92rem;
      font-weight: 600;
      letter-spacing: -0.01em;
      box-shadow: 0 2px 8px rgba(17, 24, 39, 0.04);
      transition: background 0.18s ease, border-color 0.18s ease, transform 0.18s ease, box-shadow 0.18s ease;
    }

    .process-showcase-cta svg {
      width: 14px;
      height: 14px;
      transition: transform 0.18s ease;
    }

    .process-showcase-cta:hover {
      background: #eef1f6;
      border-color: rgba(17, 24, 39, 0.16);
      box-shadow: 0 6px 18px rgba(17, 24, 39, 0.08);
      transform: translateY(-1px);
    }

    .process-showcase-cta:hover svg {
      transform: translateX(3px);
    }

    .process-showcase-build-lane {
      display: grid;
      grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: 12px;
      width: min(100%, 74%);
      margin: 14px auto 0;
    }

    .process-showcase-build-node {
      display: flex;
      align-items: center;
      justify-content: center;
      min-height: 40px;
      padding: 0 12px;
      border-radius: 14px;
      background: rgba(255, 255, 255, 0.08);
      border: 1px solid rgba(255, 255, 255, 0.08);
      color: rgba(255, 255, 255, 0.86);
      font-size: 0.76rem;
      font-weight: 600;
      letter-spacing: -0.01em;
      box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.04);
    }

    .journey-sections-stack {
      display: grid;
      gap: 96px;
    }

    .journey-panel {
      display: grid;
      gap: 50px;
      padding: 36px 0 22px;
    }

    .process-showcase-section.journey-panel {
      gap: 0;
      padding: 18px 0 0;
    }

    .journey-panel-overview {
      display: grid;
      grid-template-columns: minmax(0, 1fr) auto;
      gap: 40px;
      align-items: start;
      width: 100%;
    }

    .journey-panel-copy {
      padding: 6px 0 0;
      max-width: none;
    }

    .journey-panel-visual {
      position: relative;
      display: flex;
      align-items: stretch;
      justify-content: center;
      min-width: 0;
      width: 100%;
      min-height: var(--process-visual-height);
      padding: 26px 22px;
      border-radius: 34px;
      overflow: hidden;
    }

    .journey-panel-visual::before,
    .journey-panel-visual::after {
      content: '';
      position: absolute;
      border-radius: 26px;
      pointer-events: none;
      z-index: 0;
      opacity: 0.24;
    }

    .journey-panel-visual::before {
      left: 26px;
      top: 26px;
      width: 30%;
      height: 18%;
      background: linear-gradient(145deg, rgba(255, 255, 255, 0.12) 0%, rgba(255, 255, 255, 0.02) 100%);
      opacity: 0.12;
    }

    .journey-panel-visual::after {
      right: 28px;
      bottom: 28px;
      width: 26%;
      height: 16%;
      background: linear-gradient(145deg, rgba(175, 222, 255, 0.12) 0%, rgba(175, 222, 255, 0.02) 100%);
      opacity: 0.1;
    }

    .journey-panel-visual-strategy {
      background:
        radial-gradient(circle at 10% 14%, rgba(59, 125, 219, 0.3) 0%, rgba(59, 125, 219, 0) 32%),
        radial-gradient(circle at 42% 18%, rgba(123, 188, 241, 0.28) 0%, rgba(123, 188, 241, 0) 32%),
        radial-gradient(circle at 88% 10%, rgba(206, 226, 255, 0.82) 0%, rgba(206, 226, 255, 0) 38%),
        radial-gradient(circle at 16% 90%, rgba(191, 215, 255, 0.3) 0%, rgba(191, 215, 255, 0) 28%),
        linear-gradient(145deg, #eef5ff 0%, #dbeaff 38%, #c3dbf8 72%, #d8e7ff 100%);
    }

    .journey-panel-visual-build,
    .journey-panel-visual-implementation {
      background:
        radial-gradient(circle at 12% 16%, rgba(59, 125, 219, 0.28) 0%, rgba(59, 125, 219, 0) 32%),
        radial-gradient(circle at 46% 18%, rgba(123, 188, 241, 0.3) 0%, rgba(123, 188, 241, 0) 32%),
        radial-gradient(circle at 88% 12%, rgba(206, 226, 255, 0.84) 0%, rgba(206, 226, 255, 0) 38%),
        radial-gradient(circle at 22% 86%, rgba(191, 215, 255, 0.28) 0%, rgba(191, 215, 255, 0) 28%),
        linear-gradient(145deg, #edf5ff 0%, #d8e9ff 38%, #bfd9f8 72%, #d5e6ff 100%);
    }

    .journey-panel-visual-adoption {
      background:
        radial-gradient(circle at 10% 16%, rgba(59, 125, 219, 0.26) 0%, rgba(59, 125, 219, 0) 32%),
        radial-gradient(circle at 40% 18%, rgba(123, 188, 241, 0.26) 0%, rgba(123, 188, 241, 0) 32%),
        radial-gradient(circle at 86% 12%, rgba(206, 226, 255, 0.84) 0%, rgba(206, 226, 255, 0) 38%),
        radial-gradient(circle at 20% 88%, rgba(191, 215, 255, 0.3) 0%, rgba(191, 215, 255, 0) 28%),
        linear-gradient(145deg, #eef5ff 0%, #d9eaff 38%, #c1daf8 72%, #d7e7ff 100%);
    }

    .journey-panel-label {
      font-size: 11px;
      font-weight: 700;
      letter-spacing: 0.16em;
      text-transform: uppercase;
      color: rgba(17, 24, 39, 0.48);
      margin-bottom: 22px;
    }

    .journey-panel-copy h3 {
      font-size: clamp(2.7rem, 3.8vw, 4rem);
      font-weight: 500;
      letter-spacing: -0.065em;
      line-height: 0.92;
      color: #111827;
      margin-bottom: 0;
      max-width: 10.5ch;
    }

    .journey-panel-link {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      gap: 8px;
      align-self: start;
      margin-top: 12px;
      text-decoration: none;
      min-height: 42px;
      padding: 0 18px;
      border-radius: 999px;
      background: #f2f4f8;
      border: 1px solid rgba(17, 24, 39, 0.12);
      font-size: 0.92rem;
      font-weight: 600;
      color: #111827;
      letter-spacing: -0.01em;
      box-shadow: 0 2px 8px rgba(17, 24, 39, 0.04);
      transition: background 0.18s ease, border-color 0.18s ease, transform 0.18s ease, box-shadow 0.18s ease;
    }

    .journey-panel-link svg {
      width: 14px;
      height: 14px;
      transition: transform 0.18s ease;
    }

    .journey-panel-link:hover {
      background: #eef1f6;
      border-color: rgba(17, 24, 39, 0.16);
      box-shadow: 0 6px 18px rgba(17, 24, 39, 0.08);
      transform: translateY(-1px);
    }

    .journey-panel-link:hover svg {
      transform: translateX(3px);
    }

    .journey-panel-body {
      display: grid;
      grid-template-columns: minmax(360px, 0.98fr) minmax(300px, 0.82fr);
      gap: 84px;
      align-items: start;
    }

    .journey-panel-body.is-reversed {
      grid-template-columns: minmax(300px, 0.82fr) minmax(360px, 0.98fr);
    }

    .journey-panel-body.is-reversed .journey-panel-visual {
      order: 2;
    }

    .journey-panel-body.is-reversed .journey-panel-aside {
      order: 1;
    }

    .journey-panel-aside {
      padding-top: 8px;
      max-width: 430px;
    }

    .journey-panel-description {
      font-size: 0.98rem;
      line-height: 1.76;
      color: rgba(17, 24, 39, 0.62);
      max-width: 34ch;
      margin: 0 0 28px;
    }

    .journey-panel-visual {
      padding: 26px 22px;
      border-radius: 32px;
    }

    .journey-panel-visual::before {
      left: 18px;
      top: 18px;
      width: 26%;
      height: 15%;
      opacity: 0.07;
      border-radius: 20px;
    }

    .journey-panel-visual::after {
      right: 18px;
      bottom: 18px;
      width: 23%;
      height: 13%;
      opacity: 0.07;
      border-radius: 20px;
    }

    .journey-panel-points {
      list-style: none;
      padding: 0;
      margin: 0;
      display: grid;
      gap: 0;
      max-width: 420px;
    }

    .journey-panel-points li {
      position: relative;
      padding: 18px 0;
      border-top: 1px solid rgba(17, 24, 39, 0.08);
      font-size: 1rem;
      line-height: 1.56;
      color: rgba(17, 24, 39, 0.88);
    }

    .journey-panel-points li:last-child {
      border-bottom: 1px solid rgba(17, 24, 39, 0.08);
    }

    .journey-panel-visual .hero-visual {
      position: relative;
      width: min(100%, var(--process-glass-width));
      min-height: var(--process-graphic-shell-height);
      height: var(--process-graphic-shell-height);
      margin: auto;
      border-radius: 28px;
      padding: 14px;
      background:
        radial-gradient(circle at 18% 14%, rgba(255, 255, 255, 0.78) 0%, rgba(255, 255, 255, 0) 26%),
        radial-gradient(circle at 82% 16%, rgba(191, 218, 255, 0.24) 0%, rgba(191, 218, 255, 0) 30%),
        linear-gradient(180deg, rgba(255, 255, 255, 0.54) 0%, rgba(234, 243, 255, 0.44) 100%);
      border: 1px solid rgba(255, 255, 255, 0.5);
      box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.72),
        0 24px 44px rgba(80, 112, 171, 0.12);
      animation: none;
    }

    .journey-panel-visual .hero-visual::before {
      opacity: 0.05;
      background-size: 20% 20%;
    }

    .journey-panel-visual .hero-visual::after {
      content: '';
      position: absolute;
      inset: -18px;
      border-radius: 34px;
      border: 1px solid rgba(255, 255, 255, 0.24);
      box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.1);
      pointer-events: none;
      opacity: 0.85;
    }

    .journey-panel-visual .hero-visual-card {
      position: relative;
      inset: auto;
      display: flex;
      flex-direction: column;
      min-height: 100%;
      border-radius: 0;
      padding: 0;
      background: none;
      border: 0;
      box-shadow: none;
      backdrop-filter: none;
      -webkit-backdrop-filter: none;
    }

    .journey-panel-visual .hero-visual-mapping .hero-visual-card {
      display: grid;
      grid-template-rows: auto minmax(210px, 1fr) auto;
      gap: 24px;
    }

    .journey-panel-visual .hero-visual-adoption .hero-visual-card {
      top: auto;
      bottom: auto;
      min-height: 0;
      width: 100%;
      margin: 0 auto;
    }

    .journey-panel-visual .hero-visual-card-top {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 12px;
      min-height: 42px;
      padding: 0;
      border-radius: 0;
      background: none;
      border: 0;
      margin-bottom: 22px;
      box-shadow: none;
      backdrop-filter: none;
      -webkit-backdrop-filter: none;
    }

    .journey-panel-visual .hero-visual-card-top span {
      font-size: 10px;
      letter-spacing: 0.14em;
      color: rgba(17, 24, 39, 0.44);
    }

    .journey-panel-visual .hero-visual-card-top strong {
      font-size: 13px;
      color: rgba(17, 24, 39, 0.84);
    }

    .process-graphic-frame-head {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 12px;
      margin-bottom: 16px;
    }

    .process-graphic-frame-head span,
    .process-graphic-callout span,
    .process-graphic-score-row span,
    .process-graphic-feature-card span,
    .process-graphic-stat-card span,
    .process-graphic-layer-row > span,
    .process-graphic-governance-card span,
    .process-graphic-execution-step span {
      font-size: 10px;
      font-weight: 700;
      letter-spacing: 0.12em;
      text-transform: uppercase;
      color: rgba(17, 24, 39, 0.44);
    }

    .process-graphic-frame-head strong,
    .process-graphic-callout strong,
    .process-graphic-feature-card strong,
    .process-graphic-stat-card strong,
    .process-graphic-governance-card strong,
    .process-graphic-response-card strong,
    .process-graphic-result-card strong,
    .process-graphic-guide-card strong,
    .process-graphic-guide-step strong,
    .process-graphic-exception-card strong,
    .process-graphic-note-strip strong,
    .process-graphic-literacy-row strong {
      color: rgba(17, 24, 39, 0.9);
    }

    .process-graphic-panel,
    .process-graphic-note-strip,
    .process-graphic-chip-card,
    .process-graphic-layer-row,
    .process-graphic-search-prompt,
    .process-graphic-response-card,
    .process-graphic-result-card,
    .process-graphic-guide-step,
    .process-graphic-guide-card,
    .process-graphic-execution-step,
    .process-graphic-exception-card,
    .process-graphic-stat-card,
    .process-graphic-governance-card,
    .process-graphic-literacy-row {
      border-radius: 20px;
      background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.78) 0%, rgba(223, 236, 255, 0.66) 100%);
      border: 1px solid rgba(255, 255, 255, 0.7);
      box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.8),
        0 12px 28px rgba(71, 95, 153, 0.08);
      backdrop-filter: blur(18px);
      -webkit-backdrop-filter: blur(18px);
    }

    .process-graphic-panel {
      display: grid;
      gap: 18px;
      padding: 18px;
    }

    .process-graphic-focus-grid,
    .process-graphic-foundation-grid {
      display: grid;
      gap: 14px;
    }

    .process-graphic-focus-grid {
      grid-template-columns: minmax(0, 0.95fr) minmax(0, 1fr);
      align-items: stretch;
    }

    .process-graphic-callout,
    .process-graphic-feature-card,
    .process-graphic-response-card,
    .process-graphic-exception-card {
      padding: 18px;
    }

    .process-graphic-callout strong,
    .process-graphic-feature-card strong {
      display: block;
      margin-top: 8px;
      font-size: 1.55rem;
      line-height: 1.03;
      letter-spacing: -0.04em;
    }

    .process-graphic-callout p,
    .process-graphic-feature-card p,
    .process-graphic-response-card p,
    .process-graphic-exception-card p,
    .process-graphic-note-strip span {
      margin: 10px 0 0;
      font-size: 0.88rem;
      line-height: 1.52;
      color: rgba(17, 24, 39, 0.6);
    }

    .process-graphic-score-stack,
    .process-graphic-search-results,
    .process-graphic-progress-list {
      display: grid;
      gap: 10px;
    }

    .process-graphic-score-row,
    .process-graphic-progress-row {
      display: grid;
      gap: 8px;
      padding: 12px 14px;
      border-radius: 16px;
      background: linear-gradient(180deg, rgba(255, 255, 255, 0.68) 0%, rgba(225, 238, 255, 0.54) 100%);
      border: 1px solid rgba(121, 154, 216, 0.14);
    }

    .process-graphic-score-row div,
    .process-graphic-progress-row div {
      display: flex;
      align-items: baseline;
      justify-content: space-between;
      gap: 12px;
    }

    .process-graphic-score-row strong,
    .process-graphic-progress-row strong {
      font-size: 12px;
      font-weight: 700;
    }

    .process-graphic-score-row i,
    .process-graphic-progress-row i,
    .process-graphic-roi-track {
      display: block;
      height: 8px;
      border-radius: 999px;
      background: rgba(115, 142, 196, 0.14);
      overflow: hidden;
    }

    .process-graphic-score-row i::before,
    .process-graphic-progress-row i::before,
    .process-graphic-roi-track span {
      content: "";
      display: block;
      width: var(--score, var(--progress, 72%));
      height: 100%;
      border-radius: inherit;
      background: linear-gradient(90deg, rgba(108, 142, 235, 0.9), rgba(142, 216, 255, 0.96));
      transform-origin: left center;
      box-shadow: 0 0 12px rgba(120, 165, 241, 0.18);
    }

    .process-graphic-chip-grid,
    .process-graphic-pill-row,
    .process-graphic-rhythm-row {
      display: flex;
      flex-wrap: wrap;
      gap: 10px;
    }

    .process-graphic-chip-card,
    .process-graphic-pill-row i,
    .process-graphic-rhythm-row i {
      display: inline-flex;
      align-items: center;
      gap: 10px;
      min-height: 42px;
      padding: 0 14px;
      border-radius: 999px;
      font-style: normal;
    }

    .process-graphic-chip-card span {
      font-size: 10px;
      font-weight: 700;
      letter-spacing: 0.08em;
      text-transform: uppercase;
      color: rgba(17, 24, 39, 0.38);
    }

    .process-graphic-chip-card strong {
      font-size: 0.9rem;
      color: rgba(17, 24, 39, 0.8);
    }

    .process-graphic-chip-card.is-emphasis {
      background: linear-gradient(180deg, rgba(248, 251, 255, 0.94) 0%, rgba(220, 234, 255, 0.86) 100%);
      border-color: rgba(138, 173, 236, 0.2);
    }

    .process-graphic-mini-grid,
    .process-graphic-training-grid,
    .process-graphic-governance-grid {
      display: grid;
      gap: 10px;
    }

    .process-graphic-mini-grid,
    .process-graphic-training-grid {
      grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .process-graphic-stat-card {
      padding: 14px;
    }

    .process-graphic-stat-card strong {
      display: block;
      margin-top: 6px;
      font-size: 1.15rem;
      letter-spacing: -0.03em;
    }

    .process-graphic-layer-stack {
      display: grid;
      gap: 10px;
    }

    .process-graphic-layer-row {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 16px;
      padding: 14px 16px;
    }

    .process-graphic-layer-row div {
      display: flex;
      flex-wrap: wrap;
      justify-content: flex-end;
      gap: 8px;
    }

    .process-graphic-layer-row i,
    .process-graphic-pill-row i,
    .process-graphic-rhythm-row i {
      font-style: normal;
      font-size: 0.8rem;
      color: rgba(17, 24, 39, 0.72);
      background: linear-gradient(180deg, rgba(255, 255, 255, 0.72) 0%, rgba(230, 240, 255, 0.62) 100%);
      border: 1px solid rgba(132, 163, 224, 0.16);
      padding: 0 12px;
    }

    .process-graphic-governance-grid {
      grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .process-graphic-governance-card {
      padding: 16px;
    }

    .process-graphic-governance-card strong {
      display: block;
      margin-top: 8px;
      font-size: 0.98rem;
      line-height: 1.3;
    }

    .process-graphic-governance-callout,
    .process-graphic-note-strip {
      padding: 16px 18px;
    }

    .process-graphic-note-strip {
      display: grid;
      gap: 2px;
      background: linear-gradient(180deg, rgba(255, 255, 255, 0.72) 0%, rgba(226, 238, 255, 0.62) 100%);
    }

    .process-graphic-search-prompt {
      padding: 14px 18px;
      font-size: 0.92rem;
      line-height: 1.45;
      color: rgba(17, 24, 39, 0.84);
      background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.76) 0%, rgba(229, 240, 255, 0.66) 100%);
    }

    .process-graphic-response-card {
      display: grid;
      gap: 6px;
      padding: 16px 18px;
    }

    .process-graphic-search-results {
      grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .process-graphic-result-card {
      display: grid;
      gap: 5px;
      padding: 14px;
    }

    .process-graphic-result-card strong,
    .process-graphic-guide-card strong,
    .process-graphic-guide-step strong {
      font-size: 0.92rem;
      line-height: 1.28;
    }

    .process-graphic-result-card span,
    .process-graphic-guide-card span {
      font-size: 0.78rem;
      line-height: 1.45;
      color: rgba(17, 24, 39, 0.52);
      letter-spacing: 0;
      text-transform: none;
      font-weight: 500;
    }

    .process-graphic-note-strip strong {
      display: block;
      font-size: 0.88rem;
      line-height: 1.35;
      letter-spacing: -0.01em;
    }

    .process-graphic-guide-grid {
      display: grid;
      grid-template-columns: minmax(0, 0.92fr) minmax(0, 1.08fr);
      gap: 12px;
    }

    .process-graphic-guide-route,
    .process-graphic-guide-cards {
      display: grid;
      gap: 10px;
    }

    .process-graphic-guide-step,
    .process-graphic-guide-card {
      padding: 14px;
    }

    .process-graphic-execution-lane {
      display: grid;
      grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: 12px;
    }

    .process-graphic-execution-step {
      position: relative;
      display: grid;
      gap: 8px;
      padding: 14px;
    }

    .process-graphic-execution-step b {
      position: absolute;
      top: 50%;
      right: -13px;
      width: 14px;
      height: 1px;
      background: rgba(17, 24, 39, 0.18);
    }

    .process-graphic-exception-card {
      margin-top: 12px;
    }

    .process-graphic-literacy-matrix {
      display: grid;
      gap: 10px;
    }

    .process-graphic-literacy-row {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 12px;
      padding: 14px 16px;
    }

    .process-graphic-literacy-row span {
      display: inline-flex;
      align-items: center;
      min-height: 28px;
      padding: 0 10px;
      border-radius: 999px;
      background: linear-gradient(180deg, rgba(245, 249, 255, 0.96) 0%, rgba(219, 233, 255, 0.86) 100%);
      color: rgba(42, 63, 111, 0.74);
      font-size: 0.76rem;
      font-weight: 600;
    }

    .process-graphic-growth-chart {
      position: relative;
      margin-top: 4px;
      padding: 10px 4px 20px 18px;
    }

    .process-graphic-growth-chart svg {
      display: block;
      width: 100%;
      height: auto;
    }

    .process-graphic-growth-axis {
      fill: none;
      stroke: rgba(17, 24, 39, 0.12);
      stroke-width: 1;
      stroke-linecap: round;
      stroke-linejoin: round;
    }

    .process-graphic-growth-line {
      fill: none;
      stroke: rgba(105, 140, 230, 0.94);
      stroke-width: 1.8;
      stroke-linecap: round;
      stroke-linejoin: round;
      filter: drop-shadow(0 0 4px rgba(126, 164, 236, 0.16));
      stroke-dasharray: 280;
      stroke-dashoffset: 280;
      animation: growth-line-draw 6.4s ease-in-out infinite;
    }

    .process-graphic-growth-chart span {
      position: absolute;
      right: 4px;
      bottom: 2px;
      font-size: 10px;
      font-weight: 700;
      letter-spacing: 0.1em;
      text-transform: uppercase;
      color: rgba(17, 24, 39, 0.44);
    }

    .process-graphic-roi-track {
      margin-top: 8px;
      height: 10px;
    }

    .process-showcase-graphic .hero-visual-card {
      min-height: 100%;
    }

    .process-showcase-visual .process-showcase-graphic.hero-visual {
      width: 100%;
      min-height: 470px;
      height: auto;
      margin: 0;
      border-radius: 0;
      padding: 34px;
      background: none;
      border: 0;
      box-shadow: none;
    }

    .process-showcase-visual .process-showcase-graphic.hero-visual::before,
    .process-showcase-visual .process-showcase-graphic.hero-visual::after {
      content: none;
      display: none;
    }

    .process-showcase-visual .process-showcase-graphic .hero-visual-card-top {
      min-height: 34px;
      margin-bottom: 2px;
    }

    .process-showcase-visual .process-showcase-graphic .hero-visual-card-top span {
      font-size: 11px;
      font-weight: 700;
      letter-spacing: 0.12em;
      text-transform: uppercase;
      color: #bcd6ff;
    }

    .process-showcase-visual .process-showcase-graphic .hero-visual-card-top strong {
      font-size: 13px;
      font-weight: 600;
      color: #ffffff;
    }

    .process-graphic-shell {
      position: relative;
      display: grid;
      gap: 9px;
      grid-template-rows: auto 1fr auto;
      min-height: 100%;
      padding: 12px;
      border-radius: 24px;
      background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.46) 0%, rgba(230, 240, 255, 0.26) 100%);
      border: 1px solid rgba(255, 255, 255, 0.5);
      box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.78),
        0 14px 30px rgba(88, 119, 177, 0.06);
      backdrop-filter: blur(22px) saturate(1.04);
      -webkit-backdrop-filter: blur(22px) saturate(1.04);
    }

    .process-graphic-shell::before {
      content: '';
      position: absolute;
      inset: 8px;
      border-radius: 19px;
      border: 1px solid rgba(255, 255, 255, 0.3);
      pointer-events: none;
    }

    .process-graphic-shell > * {
      position: relative;
      z-index: 1;
    }

    .process-graphic-frame-head {
      margin-bottom: 0;
      align-items: start;
    }

    .process-graphic-frame-head span {
      font-size: 10px;
      font-weight: var(--font-ui-weight);
      letter-spacing: var(--tracking-label);
      text-transform: uppercase;
      color: rgba(38, 58, 94, 0.42);
    }

    .process-graphic-frame-head strong {
      flex: 0 1 auto;
      min-width: 0;
      font-size: clamp(0.76rem, 0.8vw, 0.88rem);
      font-weight: var(--font-ui-weight);
      letter-spacing: var(--tracking-ui-tight);
      color: rgba(22, 34, 58, 0.88);
      line-height: 1.1;
      text-align: right;
      white-space: nowrap;
    }

    .process-graphic-editorial-grid {
      display: grid;
      grid-template-columns: minmax(0, 1fr) minmax(168px, 0.82fr);
      gap: 8px;
      align-items: stretch;
    }

    .process-graphic-lead-card,
    .process-graphic-metric-card,
    .process-graphic-build-outcome-card,
    .process-graphic-build-core,
    .process-graphic-agent-card,
    .process-graphic-prompt-card,
    .process-graphic-flow-card,
    .process-graphic-kpi-card,
    .process-graphic-chart-card,
    .process-graphic-progress-card,
    .process-graphic-shortlist-pill {
      background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.62) 0%, rgba(229, 239, 255, 0.48) 100%);
      border: 1px solid rgba(135, 168, 227, 0.12);
      box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.74),
        0 10px 24px rgba(106, 136, 194, 0.05);
    }

    .process-graphic-lead-card,
    .process-graphic-build-core,
    .process-graphic-chart-card,
    .process-graphic-progress-card {
      border-radius: 20px;
    }

    .process-graphic-metric-card,
    .process-graphic-build-outcome-card,
    .process-graphic-agent-card,
    .process-graphic-prompt-card,
    .process-graphic-flow-card,
    .process-graphic-kpi-card {
      border-radius: 18px;
    }

    .process-graphic-lead-card {
      display: grid;
      align-content: start;
      gap: 0;
      min-height: 100%;
      padding: 14px 14px 13px;
    }

    .process-graphic-lead-card span,
    .process-graphic-metric-copy span,
    .process-graphic-build-outcome-card span,
    .process-graphic-flow-card span,
    .process-graphic-kpi-card span,
    .process-graphic-progress-head span,
    .process-graphic-progress-head i,
    .process-graphic-shortlist-pill span {
      font-size: 11px;
      font-weight: var(--font-ui-weight);
      letter-spacing: var(--tracking-label);
      text-transform: uppercase;
      color: rgba(38, 58, 94, 0.44);
      font-style: normal;
    }

    .process-graphic-lead-card strong {
      display: block;
      max-width: 8.8ch;
      margin-top: 5px;
      font-size: clamp(1.14rem, 1.28vw, 1.42rem);
      font-weight: var(--font-display-weight);
      letter-spacing: var(--tracking-display-tight);
      line-height: var(--line-display);
      color: #223047;
    }

    .process-graphic-lead-card p {
      max-width: 24ch;
      margin: 8px 0 0;
      font-size: clamp(0.7rem, 0.72vw, 0.78rem);
      line-height: 1.38;
      color: rgba(34, 48, 71, 0.66);
    }

    .process-graphic-metric-stack {
      display: grid;
      gap: 7px;
    }

    .process-graphic-metric-card {
      display: grid;
      gap: 7px;
      padding: 10px;
      min-height: 0;
    }

    .process-graphic-metric-copy {
      display: flex;
      align-items: start;
      justify-content: space-between;
      gap: 16px;
    }

    .process-graphic-metric-copy strong,
    .process-graphic-build-outcome-card strong,
    .process-graphic-flow-card strong,
    .process-graphic-kpi-card strong,
    .process-graphic-shortlist-pill strong,
    .process-graphic-agent-card strong,
    .process-graphic-progress-card strong {
      color: #223047;
    }

    .process-graphic-metric-copy strong {
      max-width: 8ch;
      font-size: clamp(0.76rem, 0.76vw, 0.86rem);
      font-weight: var(--font-ui-weight);
      line-height: 1.1;
      letter-spacing: var(--tracking-ui-tight);
      text-align: left;
    }

    .process-graphic-status-bar {
      height: 8px;
      overflow: hidden;
      border-radius: 999px;
      background: rgba(137, 166, 218, 0.2);
      box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.45);
    }

    .process-graphic-status-bar span {
      display: block;
      width: var(--fill);
      height: 100%;
      border-radius: inherit;
      background: linear-gradient(90deg, rgba(111, 136, 228, 0.94), rgba(129, 214, 244, 0.92));
      box-shadow: 0 0 16px rgba(109, 164, 240, 0.2);
    }

    .process-graphic-shortlist-grid {
      display: grid;
      grid-template-columns: 1.2fr 1fr 1fr;
      gap: 7px;
    }

    .process-graphic-shortlist-pill {
      display: flex;
      align-items: center;
      gap: 9px;
      min-height: 42px;
      padding: 0 11px;
      border-radius: 999px;
    }

    .process-graphic-shortlist-pill strong {
      font-size: clamp(0.7rem, 0.72vw, 0.8rem);
      font-weight: var(--font-ui-weight);
      letter-spacing: var(--tracking-ui-tight);
      line-height: 1.2;
    }

    .process-graphic-shortlist-pill.is-emphasis {
      background: linear-gradient(180deg, rgba(255, 255, 255, 0.94) 0%, rgba(228, 238, 255, 0.84) 100%);
      border-color: rgba(128, 164, 231, 0.2);
      box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.94),
        0 18px 34px rgba(108, 136, 189, 0.11);
    }

    .process-graphic-shell-strategy {
      grid-template-rows: auto minmax(0, 1fr);
    }

    .process-graphic-shell-build {
      grid-template-rows: minmax(0, 1fr);
      padding: 20px;
      background:
        radial-gradient(circle at 12% 14%, rgba(255, 255, 255, 0.18) 0%, rgba(255, 255, 255, 0) 24%),
        radial-gradient(circle at 82% 16%, rgba(182, 214, 255, 0.18) 0%, rgba(182, 214, 255, 0) 24%),
        linear-gradient(145deg, #3c6fb6 0%, #3b78ce 44%, #59a3eb 100%);
      border-color: rgba(255, 255, 255, 0.22);
      box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.28),
        0 22px 44px rgba(55, 101, 176, 0.2);
    }

    .process-graphic-shell-build::before {
      border-color: rgba(255, 255, 255, 0.18);
    }

    .process-graphic-shell-build .process-graphic-frame-head span {
      color: rgba(232, 240, 255, 0.72);
    }

    .process-graphic-shell-build .process-graphic-frame-head strong {
      color: rgba(255, 255, 255, 0.96);
    }

    .process-graphic-strategy-scene {
      display: grid;
      gap: 8px;
      min-height: 0;
    }

    .process-graphic-strategy-scene-focus,
    .process-graphic-strategy-scene-foundation {
      grid-template-rows: minmax(0, 1fr) auto;
    }

    .process-graphic-strategy-scene-governance {
      grid-template-rows: auto auto auto;
      align-content: start;
    }

    .process-graphic-strategy-focus-stage,
    .process-graphic-strategy-matrix,
    .process-graphic-strategy-org-root,
    .process-graphic-strategy-org-node,
    .process-graphic-strategy-roadmap-pill,
    .process-graphic-strategy-foundation-pill {
      background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.44) 0%, rgba(229, 239, 255, 0.22) 100%);
      border: 1px solid rgba(157, 184, 228, 0.16);
      box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.76),
        0 8px 22px rgba(106, 136, 194, 0.04);
    }

    .process-graphic-strategy-focus-stage {
      position: relative;
      min-height: 204px;
      border-radius: 20px;
      overflow: hidden;
      isolation: isolate;
      padding: 16px;
    }

    .process-graphic-strategy-focus-stage::before {
      content: "";
      position: absolute;
      inset: 0;
      background:
        radial-gradient(circle at 16% 18%, rgba(150, 195, 255, 0.2) 0%, rgba(150, 195, 255, 0) 30%),
        radial-gradient(circle at 80% 22%, rgba(188, 223, 255, 0.18) 0%, rgba(188, 223, 255, 0) 34%);
      pointer-events: none;
      z-index: 0;
    }

    .process-graphic-strategy-focus-halo {
      position: absolute;
      right: -2%;
      top: -10%;
      width: 224px;
      aspect-ratio: 1;
      border-radius: 50%;
      background:
        radial-gradient(circle, rgba(167, 203, 255, 0.2) 0%, rgba(167, 203, 255, 0.06) 45%, rgba(167, 203, 255, 0) 72%);
      opacity: 0.92;
      animation: strategy-halo-breathe 7.2s ease-in-out infinite;
      z-index: 0;
    }

    .process-graphic-strategy-compass {
      position: absolute;
      right: 42px;
      top: 40px;
      width: 126px;
      aspect-ratio: 1;
      z-index: 1;
    }

    .process-graphic-strategy-compass-ring,
    .process-graphic-strategy-compass-arc,
    .process-graphic-strategy-compass-hub {
      position: absolute;
      border-radius: 50%;
    }

    .process-graphic-strategy-compass-ring {
      inset: 0;
      border: 1px solid rgba(134, 169, 224, 0.22);
      opacity: 0;
      animation: strategy-ring-settle 6.8s ease-in-out infinite;
    }

    .process-graphic-strategy-compass-ring.is-middle {
      inset: 18px;
      animation-delay: 0.16s;
    }

    .process-graphic-strategy-compass-ring.is-inner {
      inset: 38px;
      animation-delay: 0.32s;
    }

    .process-graphic-strategy-compass-arc {
      inset: 16px;
      background:
        conic-gradient(from 222deg at 50% 50%, rgba(127, 182, 244, 0.18) 0deg, rgba(127, 182, 244, 0.18) 40deg, rgba(127, 182, 244, 0) 40deg 360deg);
      -webkit-mask: radial-gradient(circle, transparent 0 35px, #000 36px);
      mask: radial-gradient(circle, transparent 0 35px, #000 36px);
      opacity: 0.88;
      animation: strategy-arc-glow 6.8s ease-in-out infinite;
    }

    .process-graphic-strategy-compass-needle {
      position: absolute;
      left: 50%;
      top: 20px;
      width: 2px;
      height: 50px;
      border-radius: 999px;
      background: linear-gradient(180deg, rgba(122, 177, 244, 1) 0%, rgba(126, 220, 244, 0.9) 100%);
      box-shadow: 0 0 16px rgba(118, 195, 244, 0.2);
      transform: translateX(-50%) rotate(38deg);
      transform-origin: 50% 46px;
      animation: compass-select 6.8s cubic-bezier(0.2, 0.8, 0.22, 1) infinite;
    }

    .process-graphic-strategy-compass-hub {
      inset: 54px;
      background: rgba(255, 255, 255, 0.76);
      box-shadow: 0 0 0 6px rgba(174, 213, 255, 0.12);
    }

    .process-graphic-strategy-focus-callout {
      position: absolute;
      right: 20px;
      top: 80px;
      display: grid;
      gap: 2px;
      max-width: 94px;
      z-index: 1;
      animation: strategy-callout-rise 6.8s ease-in-out infinite;
    }

    .process-graphic-strategy-focus-callout span,
    .process-graphic-strategy-priority-card span,
    .process-graphic-strategy-roadmap-pill span,
    .process-graphic-strategy-org-root span,
    .process-graphic-strategy-org-node span,
    .process-graphic-strategy-foundation-pill span,
    .process-graphic-strategy-matrix-label {
      font-size: 10px;
      font-weight: var(--font-ui-weight);
      letter-spacing: var(--tracking-label);
      text-transform: uppercase;
      color: rgba(38, 58, 94, 0.38);
    }

    .process-graphic-strategy-focus-callout strong {
      font-size: clamp(0.74rem, 0.8vw, 0.88rem);
      font-weight: var(--font-ui-weight);
      letter-spacing: var(--tracking-ui-tight);
      line-height: 1.04;
      color: rgba(34, 48, 71, 0.86);
    }

    .process-graphic-strategy-track {
      display: grid;
      grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: 8px;
    }

    .process-graphic-strategy-track-pill {
      display: grid;
      grid-template-columns: 24px minmax(0, 1fr);
      gap: 9px;
      align-items: center;
      min-height: 46px;
      padding: 0 12px;
      border-radius: 16px;
      background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.42) 0%, rgba(229, 239, 255, 0.18) 100%);
      border: 1px solid rgba(157, 184, 228, 0.14);
      box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.72),
        0 8px 18px rgba(106, 136, 194, 0.04);
      animation: strategy-pill-rise 6.8s ease-in-out infinite;
    }

    .process-graphic-strategy-track-pill:nth-child(2) {
      animation-delay: 0.14s;
    }

    .process-graphic-strategy-track-pill:nth-child(3) {
      animation-delay: 0.28s;
    }

    .process-graphic-strategy-track-pill span {
      font-size: 10px;
      font-weight: var(--font-ui-weight);
      letter-spacing: var(--tracking-label);
      text-transform: uppercase;
      color: rgba(38, 58, 94, 0.42);
    }

    .process-graphic-strategy-track-pill strong {
      font-size: clamp(0.68rem, 0.72vw, 0.78rem);
      font-weight: var(--font-ui-weight);
      line-height: 1.18;
      letter-spacing: var(--tracking-ui-tight);
      color: rgba(34, 48, 71, 0.8);
    }

    .process-graphic-strategy-track-pill.is-emphasis {
      background: linear-gradient(180deg, rgba(255, 255, 255, 0.72) 0%, rgba(229, 239, 255, 0.34) 100%);
      border-color: rgba(128, 164, 231, 0.16);
      box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.86),
        0 12px 24px rgba(108, 136, 189, 0.06);
    }

    .process-graphic-strategy-matrix {
      position: relative;
      min-height: 198px;
      border-radius: 20px;
      overflow: hidden;
      padding: 16px;
    }

    .process-graphic-strategy-matrix::before {
      content: "";
      position: absolute;
      inset: 0;
      background:
        radial-gradient(circle at 18% 18%, rgba(150, 195, 255, 0.18) 0%, rgba(150, 195, 255, 0) 28%),
        linear-gradient(180deg, rgba(255, 255, 255, 0.06), rgba(255, 255, 255, 0));
      pointer-events: none;
    }

    .process-graphic-strategy-matrix-label {
      position: absolute;
      z-index: 1;
    }

    .process-graphic-strategy-matrix-label-x {
      right: 18px;
      bottom: 14px;
    }

    .process-graphic-strategy-matrix-label-y {
      left: 18px;
      top: 18px;
      writing-mode: vertical-rl;
      transform: rotate(180deg);
    }

    .process-graphic-strategy-matrix-grid {
      position: absolute;
      inset: 18px 18px 26px 34px;
      border-left: 1px solid rgba(129, 159, 213, 0.18);
      border-bottom: 1px solid rgba(129, 159, 213, 0.18);
      z-index: 0;
    }

    .process-graphic-strategy-matrix-grid span {
      position: absolute;
      background: rgba(129, 159, 213, 0.12);
    }

    .process-graphic-strategy-matrix-grid span:nth-child(1) {
      left: 0;
      right: 0;
      top: 33%;
      height: 1px;
    }

    .process-graphic-strategy-matrix-grid span:nth-child(2) {
      left: 0;
      right: 0;
      top: 66%;
      height: 1px;
    }

    .process-graphic-strategy-matrix-grid span:nth-child(3) {
      top: 0;
      bottom: 0;
      left: 33%;
      width: 1px;
    }

    .process-graphic-strategy-matrix-grid span:nth-child(4) {
      top: 0;
      bottom: 0;
      left: 66%;
      width: 1px;
    }

    .process-graphic-strategy-priority-card {
      position: absolute;
      display: grid;
      gap: 4px;
      width: 120px;
      padding: 10px 10px 9px;
      border-radius: 16px;
      background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.5) 0%, rgba(229, 239, 255, 0.24) 100%);
      border: 1px solid rgba(157, 184, 228, 0.16);
      box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.76),
        0 10px 22px rgba(106, 136, 194, 0.05);
      z-index: 1;
      animation: strategy-priority-enter 6.8s ease-in-out infinite;
    }

    .process-graphic-strategy-priority-card strong {
      font-size: clamp(0.68rem, 0.72vw, 0.78rem);
      font-weight: var(--font-ui-weight);
      letter-spacing: var(--tracking-ui-tight);
      line-height: 1.12;
      color: rgba(34, 48, 71, 0.86);
    }

    .process-graphic-strategy-priority-card i {
      font-style: normal;
      font-size: 0.64rem;
      line-height: 1.2;
      color: rgba(34, 48, 71, 0.58);
    }

    .process-graphic-strategy-priority-bar {
      height: 6px;
    }

    .process-graphic-strategy-priority-card-1 {
      left: 52px;
      top: 90px;
      animation-delay: 0s;
    }

    .process-graphic-strategy-priority-card-2 {
      left: 186px;
      top: 56px;
      animation-delay: 0.18s;
    }

    .process-graphic-strategy-priority-card-3 {
      left: 218px;
      top: 128px;
      animation-delay: 0.32s;
    }

    .process-graphic-strategy-priority-card.is-emphasis {
      width: 132px;
      box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.82),
        0 14px 28px rgba(105, 136, 189, 0.08);
    }

    .process-graphic-strategy-roadmap {
      display: grid;
      grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: 8px;
    }

    .process-graphic-strategy-roadmap-pill {
      display: grid;
      gap: 4px;
      min-height: 50px;
      padding: 10px 11px 9px;
      border-radius: 16px;
      animation: strategy-roadmap-rise 6.8s ease-in-out infinite;
    }

    .process-graphic-strategy-roadmap-pill:nth-child(2) {
      animation-delay: 0.12s;
    }

    .process-graphic-strategy-roadmap-pill:nth-child(3) {
      animation-delay: 0.24s;
    }

    .process-graphic-strategy-roadmap-pill strong,
    .process-graphic-strategy-org-root strong,
    .process-graphic-strategy-org-node strong,
    .process-graphic-strategy-foundation-pill strong {
      font-size: clamp(0.66rem, 0.7vw, 0.78rem);
      font-weight: var(--font-ui-weight);
      letter-spacing: var(--tracking-ui-tight);
      line-height: 1.18;
      color: rgba(34, 48, 71, 0.84);
    }

    .process-graphic-strategy-org-root {
      justify-self: center;
      display: grid;
      gap: 3px;
      width: min(100%, 214px);
      padding: 10px 13px;
      border-radius: 16px;
      text-align: center;
      animation: strategy-root-rise 6.8s ease-in-out infinite;
    }

    .process-graphic-strategy-org-lines {
      width: 100%;
      height: 58px;
      overflow: visible;
    }

    .process-graphic-strategy-org-lines path {
      fill: none;
      stroke: rgba(129, 159, 213, 0.4);
      stroke-width: 1.35;
      stroke-linecap: round;
      stroke-linejoin: round;
      stroke-dasharray: 240;
      stroke-dashoffset: 240;
      animation: strategy-org-line-draw 6.8s ease-in-out infinite;
    }

    .process-graphic-strategy-org-lines path:nth-child(2) {
      animation-delay: 0.08s;
    }

    .process-graphic-strategy-org-lines path:nth-child(3) {
      animation-delay: 0.14s;
    }

    .process-graphic-strategy-org-lines path:nth-child(4) {
      animation-delay: 0.2s;
    }

    .process-graphic-strategy-org-lines path:nth-child(5) {
      animation-delay: 0.26s;
    }

    .process-graphic-strategy-org-grid {
      display: grid;
      grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: 8px;
      margin-top: -2px;
    }

    .process-graphic-strategy-org-node {
      display: grid;
      gap: 3px;
      min-height: 58px;
      padding: 10px 11px;
      border-radius: 16px;
      animation: strategy-node-rise 6.8s ease-in-out infinite;
    }

    .process-graphic-strategy-org-node:nth-child(2) {
      animation-delay: 0.14s;
    }

    .process-graphic-strategy-org-node:nth-child(3) {
      animation-delay: 0.28s;
    }

    .process-graphic-strategy-foundation-rail {
      display: grid;
      grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: 8px;
      margin-top: 8px;
    }

    .process-graphic-strategy-foundation-pill {
      display: grid;
      gap: 3px;
      min-height: 46px;
      padding: 9px 11px;
      border-radius: 14px;
      animation: strategy-rail-rise 6.8s ease-in-out infinite;
    }

    .process-graphic-strategy-foundation-pill:nth-child(2) {
      animation-delay: 0.1s;
    }

    .process-graphic-strategy-foundation-pill:nth-child(3) {
      animation-delay: 0.2s;
    }

    .process-graphic-build-scene {
      display: grid;
      gap: 28px;
      min-height: 100%;
      align-content: space-between;
    }

    .process-graphic-build-workflow-lane {
      position: relative;
      display: grid;
      gap: 18px;
      padding-left: 2px;
    }

    .process-graphic-build-workflow-rail {
      position: absolute;
      left: 28px;
      top: 18px;
      bottom: 30px;
      width: 3px;
      border-radius: 999px;
      background: linear-gradient(180deg, rgba(255, 255, 255, 0.76) 0%, rgba(255, 255, 255, 0.18) 100%);
      opacity: 0.72;
    }

    .process-graphic-build-workflow-step {
      position: relative;
      z-index: 1;
      display: grid;
      grid-template-columns: 56px minmax(0, 1fr);
      gap: 16px;
      align-items: center;
    }

    .process-graphic-build-workflow-node {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      width: 56px;
      height: 56px;
      border-radius: 50%;
      background: rgba(255, 255, 255, 0.96);
      color: #3f78d0;
      box-shadow: 0 10px 24px rgba(19, 48, 96, 0.16);
    }

    .process-graphic-build-workflow-step.is-pending .process-graphic-build-workflow-node {
      background: rgba(255, 255, 255, 0.14);
      color: rgba(255, 255, 255, 0.78);
      border: 1px solid rgba(255, 255, 255, 0.2);
      box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.12);
    }

    .process-graphic-build-workflow-node svg {
      width: 22px;
      height: 22px;
    }

    .process-graphic-build-workflow-row {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 20px;
      min-height: 92px;
      padding: 0 28px 0 30px;
      border-radius: 32px;
      background: rgba(255, 255, 255, 0.16);
      border: 1px solid rgba(255, 255, 255, 0.16);
      box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.12);
      backdrop-filter: blur(18px);
      -webkit-backdrop-filter: blur(18px);
    }

    .process-graphic-build-workflow-row strong {
      font-size: clamp(1.18rem, 1.3vw, 1.48rem);
      font-weight: 600;
      letter-spacing: -0.03em;
      color: #ffffff;
      line-height: 1.04;
    }

    .process-graphic-build-workflow-row span {
      font-size: 12px;
      font-weight: 700;
      letter-spacing: 0.12em;
      text-transform: uppercase;
      color: rgba(232, 240, 255, 0.72);
      white-space: nowrap;
    }

    .process-graphic-build-sources {
      display: grid;
      gap: 14px;
      align-content: start;
    }

    .process-graphic-build-sources > span {
      font-size: 11px;
      font-weight: 700;
      letter-spacing: 0.16em;
      text-transform: uppercase;
      color: rgba(232, 240, 255, 0.68);
    }

    .process-graphic-build-source-row {
      display: flex;
      flex-wrap: wrap;
      gap: 14px;
    }

    .process-graphic-build-source-pill {
      display: inline-flex;
      align-items: center;
      gap: 9px;
      min-height: 52px;
      padding: 0 18px;
      border-radius: 999px;
      font-style: normal;
      font-size: 0.72rem;
      font-weight: 700;
      letter-spacing: 0.02em;
      color: #ffffff;
      background: rgba(255, 255, 255, 0.12);
      border: 1px solid rgba(255, 255, 255, 0.18);
      box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.1);
    }

    .process-graphic-build-source-pill img {
      width: 22px;
      height: 22px;
      display: block;
      object-fit: contain;
    }

    .process-graphic-kpi-grid {
      display: grid;
      grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: 7px;
    }

    .process-graphic-kpi-card {
      padding: 9px 9px 8px;
    }

    .process-graphic-kpi-card strong {
      display: block;
      margin-top: 4px;
      font-size: clamp(0.8rem, 0.8vw, 0.94rem);
      font-weight: var(--font-ui-weight);
      letter-spacing: var(--tracking-ui-tight);
      line-height: 1;
    }

    .process-graphic-chart-card {
      position: relative;
      padding: 11px 9px 15px 9px;
      min-height: 118px;
    }

    .process-graphic-chart-card svg {
      display: block;
      width: 100%;
      height: auto;
    }

    .process-graphic-growth-axis {
      fill: none;
      stroke: rgba(116, 148, 202, 0.28);
      stroke-width: 1.2;
      stroke-linecap: round;
      stroke-linejoin: round;
    }

    .process-graphic-growth-line {
      fill: none;
      stroke: rgba(114, 185, 243, 0.96);
      stroke-width: 1.8;
      stroke-linecap: round;
      stroke-linejoin: round;
      filter: drop-shadow(0 8px 18px rgba(120, 188, 240, 0.2));
    }

    .process-graphic-chart-card span {
      position: absolute;
      right: 14px;
      bottom: 10px;
      font-size: 10px;
      font-weight: var(--font-ui-weight);
      letter-spacing: var(--tracking-label);
      text-transform: uppercase;
      color: rgba(38, 58, 94, 0.46);
    }

    .process-graphic-progress-card {
      display: grid;
      gap: 6px;
      padding: 9px 11px;
    }

    .process-graphic-progress-head {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 12px;
    }

    .process-graphic-progress-card strong {
      display: block;
      font-size: clamp(0.68rem, 0.68vw, 0.78rem);
      font-weight: var(--font-ui-weight);
      letter-spacing: var(--tracking-ui-tight);
      line-height: 1.2;
    }

    @media (max-width: 1024px) {
      .process-showcase {
        --process-visual-width: 100%;
        --process-visual-height: auto;
        --process-glass-width: min(100%, 500px);
        --process-glass-height: 420px;
        --process-graphic-shell-height: var(--process-glass-height);
      }

      .journey-panel-visual .hero-visual {
        width: min(100%, var(--process-glass-width));
        min-height: var(--process-graphic-shell-height);
        height: var(--process-graphic-shell-height);
        padding: 16px;
      }

      .process-graphic-editorial-grid,
      .process-graphic-flow-grid,
      .process-graphic-kpi-grid {
        grid-template-columns: 1fr;
      }

      .process-graphic-strategy-track,
      .process-graphic-strategy-roadmap,
      .process-graphic-strategy-org-grid,
      .process-graphic-strategy-foundation-rail {
        grid-template-columns: 1fr;
      }

      .process-graphic-shortlist-grid {
        grid-template-columns: 1fr;
      }

      .process-graphic-agent-card,
      .process-graphic-prompt-card {
        max-width: none;
      }

      .process-graphic-build-core {
        grid-template-columns: 1fr;
      }

      .process-graphic-prompt-card {
        justify-self: stretch;
      }

      .process-graphic-strategy-focus-stage,
      .process-graphic-strategy-matrix {
        min-height: 214px;
      }

      .process-graphic-strategy-compass {
        right: 28px;
        top: 44px;
        width: 116px;
      }

      .process-graphic-strategy-focus-callout {
        right: 16px;
        top: 128px;
        max-width: 84px;
      }

      .process-graphic-strategy-priority-card,
      .process-graphic-strategy-priority-card.is-emphasis {
        width: 116px;
      }

      .process-graphic-strategy-priority-card-1 {
        left: 40px;
      }

      .process-graphic-strategy-priority-card-2 {
        left: 158px;
      }

      .process-graphic-strategy-priority-card-3 {
        left: 184px;
      }
    }

    @media (max-width: 768px) {
      .process-graphic-shell {
        padding: 14px;
        border-radius: 22px;
      }

      .process-graphic-shell::before {
        inset: 8px;
        border-radius: 18px;
      }

      .process-graphic-frame-head {
        gap: 10px;
      }

      .process-graphic-frame-head span {
        font-size: 10px;
      }

      .process-graphic-frame-head strong {
        font-size: 0.96rem;
      }

      .process-graphic-lead-card {
        padding: 16px 14px;
      }

      .process-graphic-lead-card strong {
        max-width: 8.4ch;
        font-size: clamp(1.26rem, 7vw, 1.7rem);
      }

      .process-graphic-lead-card p,
      .process-graphic-build-outcome-card p,
      .process-graphic-agent-card p,
      .process-graphic-progress-card p {
        font-size: 0.78rem;
      }

      .process-graphic-metric-card,
      .process-graphic-build-outcome-card,
      .process-graphic-flow-card,
      .process-graphic-kpi-card,
      .process-graphic-progress-card,
      .process-graphic-build-core {
        padding: 14px;
      }

      .process-graphic-shortlist-pill {
        min-height: 46px;
        padding: 0 12px;
      }

      .process-graphic-agent-card {
        grid-template-columns: 38px minmax(0, 1fr);
        padding: 12px;
      }

      .process-graphic-agent-avatar {
        width: 38px;
        height: 38px;
        border-radius: 12px;
      }

      .process-graphic-tag-row {
        gap: 8px;
      }

      .process-graphic-tag {
        min-height: 30px;
        padding: 0 12px;
        font-size: 0.74rem;
      }

      .process-graphic-chart-card {
        min-height: 0;
        padding: 12px 10px 16px;
      }

      .process-graphic-strategy-focus-stage,
      .process-graphic-strategy-matrix {
        min-height: 204px;
        padding: 14px;
      }

      .process-graphic-strategy-compass {
        right: 18px;
        top: 48px;
        width: 102px;
      }

      .process-graphic-strategy-focus-callout {
        right: 14px;
        top: 132px;
        max-width: 78px;
      }

      .process-graphic-strategy-track-pill,
      .process-graphic-strategy-roadmap-pill,
      .process-graphic-strategy-org-node,
      .process-graphic-strategy-foundation-pill {
        min-height: 0;
      }

      .process-graphic-strategy-matrix-grid {
        inset: 18px 16px 26px 30px;
      }

      .process-graphic-strategy-priority-card,
      .process-graphic-strategy-priority-card.is-emphasis {
        width: calc(50% - 16px);
        min-width: 106px;
        padding: 9px;
      }

      .process-graphic-strategy-priority-card-1 {
        left: 22px;
        top: 90px;
      }

      .process-graphic-strategy-priority-card-2 {
        left: auto;
        right: 14px;
        top: 54px;
      }

      .process-graphic-strategy-priority-card-3 {
        left: auto;
        right: 14px;
        top: 132px;
      }

      .process-graphic-strategy-org-lines {
        height: 24px;
      }
    }

    .hero-cta {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      text-decoration: none;
      font-size: 14.5px;
      font-weight: 500;
      color: #1a2533;
      padding: 12px 28px;
      border-radius: 980px;
      background: #fff;
      box-shadow: 0 4px 20px rgba(0, 0, 0, 0.15);
      transition: box-shadow 0.22s ease,
                  transform 0.2s cubic-bezier(0.34, 1.56, 0.64, 1);
      animation: hero-fade-in 0.9s ease-out 0.45s both;
    }

    .hero-cta:hover {
      transform: translateY(-2px) scale(1.015);
      box-shadow: 0 8px 32px rgba(0, 0, 0, 0.22);
    }

    .hero-cta:active {
      transform: scale(0.97);
      box-shadow: 0 2px 10px rgba(0, 0, 0, 0.12);
      transition-duration: 0.06s;
    }

    .hero-cta svg {
      width: 15px;
      height: 15px;
      transition: transform 0.2s cubic-bezier(0.34, 1.56, 0.64, 1);
    }

    .hero-cta:hover svg {
      transform: translateX(4px);
    }

    .hero-visual {
      position: relative;
      min-height: 540px;
      border-radius: 34px;
      overflow: hidden;
      padding: 28px;
      background:
        radial-gradient(circle at 12% 14%, rgba(255, 255, 255, 0.16) 0%, rgba(255, 255, 255, 0) 26%),
        radial-gradient(circle at 82% 16%, rgba(182, 214, 255, 0.16) 0%, rgba(182, 214, 255, 0) 26%),
        rgba(255, 255, 255, 0.06);
      border: 1px solid rgba(255, 255, 255, 0.12);
      backdrop-filter: blur(18px);
      -webkit-backdrop-filter: blur(18px);
      animation: hero-fade-in 0.9s ease-out 0.3s both;
    }

    .hero-visual::before {
      content: '';
      position: absolute;
      inset: 0;
      background:
        linear-gradient(rgba(255, 255, 255, 0.04) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255, 255, 255, 0.04) 1px, transparent 1px);
      background-size: 33.333% 33.333%;
      opacity: 0.26;
    }

    .hero-visual-scene {
      position: absolute;
      inset: 0;
      pointer-events: none;
    }

    .hero-visual-mapping .hero-visual-scene::before {
      display: none;
    }

    .hero-visual-mapping .hero-visual-scene::after {
      content: '';
      position: absolute;
      left: 34px;
      right: 34px;
      top: 108px;
      height: 1px;
      background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.16), transparent);
      opacity: 0.72;
    }

    .hero-visual-build .hero-visual-scene::before {
      display: none;
    }

    .hero-visual-adoption .hero-visual-scene::before {
      content: '';
      position: absolute;
      left: 52px;
      right: 52px;
      top: 80px;
      bottom: 138px;
      background:
        linear-gradient(rgba(255,255,255,0.06) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,0.06) 1px, transparent 1px);
      background-size: 25% 25%;
      border-radius: 18px;
      opacity: 0.6;
    }

    .hero-visual-card {
      position: absolute;
      inset: auto 26px 26px;
      border-radius: 26px;
      padding: 20px;
      background: rgba(255, 255, 255, 0.14);
      border: 1px solid rgba(255, 255, 255, 0.16);
      backdrop-filter: blur(18px);
      -webkit-backdrop-filter: blur(18px);
      box-shadow: 0 24px 56px rgba(8, 16, 32, 0.16);
    }

    .hero-visual-adoption .hero-visual-card {
      top: 54px;
      bottom: 36px;
    }

    .hero-visual-card-top {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 12px;
      margin-bottom: 14px;
    }

    .hero-visual-card-top span {
      font-size: 11px;
      font-weight: 700;
      letter-spacing: 0.12em;
      text-transform: uppercase;
      color: rgba(255, 255, 255, 0.68);
    }

    .hero-visual-card-top strong {
      font-size: 13px;
      font-weight: 700;
      color: #ffffff;
    }

    .hero-visual-compass-wrap {
      position: relative;
      height: 182px;
      margin: 0 0 18px;
    }

    .hero-visual-compass {
      position: relative;
      width: 148px;
      height: 148px;
      margin: 10px auto 0;
    }

    .hero-visual-compass-ring,
    .hero-visual-compass-center,
    .hero-visual-compass-angle {
      position: absolute;
      border-radius: 50%;
    }

    .hero-visual-compass-ring {
      inset: 0;
      border: 1px solid rgba(255, 255, 255, 0.2);
      box-shadow:
        inset 0 0 0 26px rgba(255, 255, 255, 0.03),
        inset 0 0 0 52px rgba(255, 255, 255, 0.03);
    }

    .hero-visual-compass-angle {
      inset: 20px;
      background:
        conic-gradient(from 228deg at 50% 50%, rgba(151, 197, 255, 0.34) 0deg, rgba(151, 197, 255, 0.34) 36deg, rgba(151, 197, 255, 0) 36deg 360deg);
      -webkit-mask: radial-gradient(circle, transparent 0 50px, #000 51px);
      mask: radial-gradient(circle, transparent 0 50px, #000 51px);
      opacity: 0.9;
    }

    .hero-visual-compass-needle {
      position: absolute;
      left: 50%;
      top: 18px;
      width: 2px;
      height: 62px;
      background: linear-gradient(180deg, rgba(151, 197, 255, 1) 0%, rgba(126, 239, 255, 0.82) 100%);
      transform: translateX(-50%) rotate(38deg);
      transform-origin: 50% 56px;
      border-radius: 999px;
      box-shadow: 0 0 20px rgba(126, 239, 255, 0.26);
      animation: compass-select 6.8s cubic-bezier(0.2, 0.8, 0.22, 1) infinite;
    }

    .hero-visual-compass-center {
      inset: 62px;
      background: rgba(255, 255, 255, 0.76);
    }

    .hero-visual-opportunity-label {
      position: absolute;
      right: 26px;
      top: 58px;
      font-size: 13px;
      font-weight: 700;
      line-height: 1.2;
      letter-spacing: 0.03em;
      text-transform: uppercase;
      color: rgba(255, 255, 255, 0.78);
      max-width: 138px;
      text-align: left;
    }

    .hero-visual-priority-panel {
      position: relative;
      display: grid;
      gap: 18px;
      padding: 22px;
      border-radius: 24px;
      background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.18) 0%, rgba(255, 255, 255, 0.09) 100%);
      border: 1px solid rgba(255, 255, 255, 0.16);
      box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.16),
        0 18px 42px rgba(7, 16, 32, 0.13);
      overflow: hidden;
    }

    .hero-visual-priority-panel::before {
      content: "";
      position: absolute;
      inset: -28% -12% auto auto;
      width: 220px;
      height: 220px;
      border-radius: 50%;
      background:
        radial-gradient(circle, rgba(188, 222, 255, 0.28) 0%, rgba(188, 222, 255, 0) 68%);
      pointer-events: none;
    }

    .hero-visual-priority-header,
    .hero-visual-priority-body,
    .hero-visual-usecase-list {
      position: relative;
      z-index: 1;
    }

    .hero-visual-priority-header {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 14px;
      padding-bottom: 16px;
      border-bottom: 1px solid rgba(255, 255, 255, 0.13);
    }

    .hero-visual-priority-header span,
    .hero-visual-priority-kicker,
    .hero-visual-score-row span {
      font-size: 10px;
      font-weight: 700;
      letter-spacing: 0.13em;
      text-transform: uppercase;
      color: rgba(232, 240, 255, 0.6);
    }

    .hero-visual-priority-header strong {
      font-size: 12px;
      font-weight: 700;
      color: rgba(255, 255, 255, 0.92);
    }

    .hero-visual-priority-body {
      display: grid;
      grid-template-columns: minmax(0, 0.92fr) minmax(0, 1fr);
      gap: 22px;
      align-items: stretch;
    }

    .hero-visual-priority-result {
      display: flex;
      flex-direction: column;
      justify-content: center;
      min-height: 158px;
      padding: 18px;
      border-radius: 18px;
      background: rgba(8, 18, 36, 0.24);
      border: 1px solid rgba(255, 255, 255, 0.1);
    }

    .hero-visual-priority-result strong {
      margin-top: 8px;
      font-size: 26px;
      font-weight: 600;
      line-height: 1.02;
      letter-spacing: -0.04em;
      color: #ffffff;
    }

    .hero-visual-priority-result p {
      margin: 12px 0 0;
      font-size: 12.5px;
      line-height: 1.55;
      color: rgba(232, 240, 255, 0.72);
    }

    .hero-visual-score-list {
      display: grid;
      gap: 12px;
      align-content: center;
    }

    .hero-visual-score-row {
      display: grid;
      gap: 9px;
      padding: 13px 14px;
      border-radius: 16px;
      background: rgba(255, 255, 255, 0.1);
      border: 1px solid rgba(255, 255, 255, 0.08);
    }

    .hero-visual-score-row div {
      display: flex;
      align-items: baseline;
      justify-content: space-between;
      gap: 12px;
    }

    .hero-visual-score-row strong {
      font-size: 12px;
      font-weight: 700;
      color: rgba(255, 255, 255, 0.92);
    }

    .hero-visual-score-row i {
      display: block;
      height: 7px;
      border-radius: 999px;
      background: rgba(232, 240, 255, 0.14);
      overflow: hidden;
    }

    .hero-visual-score-row i::before {
      content: "";
      display: block;
      width: var(--score, 70%);
      height: 100%;
      border-radius: inherit;
      background: linear-gradient(90deg, rgba(126, 239, 255, 0.84), rgba(187, 219, 255, 0.92));
      box-shadow: 0 0 20px rgba(126, 209, 255, 0.2);
    }

    .hero-visual-usecase-list {
      display: grid;
      gap: 8px;
    }

    .hero-visual-usecase-list div {
      display: grid;
      grid-template-columns: 24px minmax(0, 1fr);
      gap: 10px;
      align-items: center;
      padding: 10px 12px;
      border-radius: 14px;
      background: rgba(255, 255, 255, 0.12);
    }

    .hero-visual-usecase-list div.is-priority {
      background:
        linear-gradient(90deg, rgba(255, 255, 255, 0.2), rgba(255, 255, 255, 0.12));
      border: 1px solid rgba(255, 255, 255, 0.18);
      box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.12);
    }

    .hero-visual-usecase-list span {
      font-size: 11px;
      font-weight: 700;
      letter-spacing: 0.08em;
      text-transform: uppercase;
      color: rgba(255, 255, 255, 0.58);
    }

    .hero-visual-usecase-list strong {
      font-size: 13px;
      color: #ffffff;
    }

    .hero-visual-data-row span {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      min-height: 30px;
      padding: 0 12px;
      border-radius: 999px;
      background: rgba(255, 255, 255, 0.18);
      color: #ffffff;
      font-size: 12px;
      font-weight: 600;
    }

    .hero-visual-chatbot-shell {
      display: grid;
      gap: 12px;
      padding: 18px;
      border-radius: 22px;
      background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.14) 0%, rgba(255, 255, 255, 0.08) 100%);
      border: 1px solid rgba(255, 255, 255, 0.14);
      box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.12),
        0 14px 38px rgba(5, 12, 24, 0.18);
      backdrop-filter: blur(18px);
    }

    .hero-visual-chatbot-conversation {
      display: grid;
      gap: 10px;
    }

    .hero-visual-chatbot-header {
      display: grid;
      grid-template-columns: 42px minmax(0, 1fr);
      gap: 12px;
      align-items: center;
      margin-bottom: 4px;
    }

    .hero-visual-chatbot-avatar {
      width: 42px;
      height: 42px;
      border-radius: 14px;
      background:
        radial-gradient(circle at 30% 30%, rgba(255, 255, 255, 0.95) 0 16%, transparent 17%),
        linear-gradient(145deg, rgba(140, 214, 255, 0.92) 0%, rgba(102, 144, 255, 0.86) 100%);
      box-shadow: 0 10px 24px rgba(69, 112, 214, 0.16);
    }

    .hero-visual-chatbot-header strong {
      display: block;
      font-size: 13px;
      color: #ffffff;
      margin-bottom: 2px;
    }

    .hero-visual-chatbot-header span {
      font-size: 11px;
      color: rgba(232, 240, 255, 0.72);
    }

    .hero-visual-chatbot-message {
      max-width: 78%;
      padding: 11px 13px;
      border-radius: 16px;
      font-size: 12px;
      line-height: 1.45;
    }

    .hero-visual-chatbot-message.is-user {
      margin-left: auto;
      background: rgba(255, 255, 255, 0.18);
      color: #ffffff;
    }

    .hero-visual-chatbot-message.is-agent {
      display: grid;
      gap: 4px;
      background: rgba(9, 17, 34, 0.42);
      color: rgba(236, 242, 255, 0.9);
    }

    .hero-visual-chatbot-message.is-agent strong {
      font-size: 12px;
      color: #ffffff;
    }

    .hero-visual-chatbot-message.is-agent p {
      margin: 0;
    }

    .hero-visual-chatbot-message-label {
      font-size: 10px;
      font-weight: 700;
      letter-spacing: 0.08em;
      text-transform: uppercase;
      color: rgba(232, 240, 255, 0.54);
    }

    .hero-visual-chatbot-message.is-typing {
      max-width: 100%;
      width: 100%;
      display: flex;
      justify-content: flex-end;
      padding: 0;
      background: transparent;
      overflow: visible;
    }

    .hero-visual-typed-line {
      display: inline-block;
      padding: 11px 13px;
      border-radius: 16px;
      background: rgba(255, 255, 255, 0.18);
      color: #ffffff;
      max-width: 0;
      white-space: nowrap;
      overflow: hidden;
      animation: hero-chat-type 9.6s steps(56, end) infinite;
      position: relative;
      padding-right: 16px;
    }

    .hero-visual-typed-line::after {
      content: '';
      position: absolute;
      right: 9px;
      top: 50%;
      width: 1px;
      height: 1.1em;
      transform: translateY(-50%);
      background: rgba(255, 255, 255, 0.88);
      animation: hero-chat-caret 0.9s steps(1, end) infinite;
    }

    .hero-visual-chatbot-message.is-responding {
      opacity: 0;
      animation: hero-chat-response 9.6s linear infinite;
    }

    .hero-visual-chatbot-sources {
      display: flex;
      gap: 8px;
      flex-wrap: wrap;
      padding-top: 2px;
    }

    .hero-visual-chatbot-sources span {
      display: inline-flex;
      align-items: center;
      gap: 7px;
      min-height: 26px;
      padding: 0 10px;
      border-radius: 999px;
      background: rgba(255, 255, 255, 0.12);
      color: rgba(232, 240, 255, 0.82);
      font-size: 11px;
      font-weight: 600;
    }

    .hero-visual-chatbot-sources svg,
    .hero-visual-chatbot-sources img {
      width: 16px;
      height: 16px;
      flex: 0 0 auto;
    }

    .hero-visual-chatbot-sources img {
      display: block;
      object-fit: contain;
    }

    .hero-visual-source-pill {
      box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.06);
    }

    @keyframes hero-chat-type {
      0%, 8% {
        max-width: 0;
      }
      42%, 100% {
        max-width: 56ch;
      }
    }

    @keyframes hero-chat-caret {
      0%, 50% {
        opacity: 1;
      }
      50.01%, 100% {
        opacity: 0;
      }
    }

    @keyframes hero-chat-response {
      0%, 54% {
        opacity: 0;
      }
      62%, 100% {
        opacity: 1;
      }
    }

    @keyframes strategy-halo-breathe {
      0%, 100% {
        transform: scale(0.94);
        opacity: 0.76;
      }
      45%, 72% {
        transform: scale(1);
        opacity: 0.96;
      }
    }

    @keyframes strategy-ring-settle {
      0%, 12% {
        opacity: 0;
        transform: scale(0.9);
      }
      28%, 84% {
        opacity: 1;
        transform: scale(1);
      }
      100% {
        opacity: 0.92;
        transform: scale(0.985);
      }
    }

    @keyframes strategy-arc-glow {
      0%, 18% {
        opacity: 0;
      }
      32%, 82% {
        opacity: 0.9;
      }
      100% {
        opacity: 0.78;
      }
    }

    @keyframes strategy-callout-rise {
      0%, 12% {
        opacity: 0;
        transform: translateY(10px);
      }
      28%, 100% {
        opacity: 1;
        transform: translateY(0);
      }
    }

    @keyframes strategy-pill-rise {
      0%, 16% {
        opacity: 0;
        transform: translateY(12px);
      }
      30%, 100% {
        opacity: 1;
        transform: translateY(0);
      }
    }

    @keyframes strategy-priority-enter {
      0%, 14% {
        opacity: 0;
        transform: translateY(16px) scale(0.96);
      }
      30%, 100% {
        opacity: 1;
        transform: translateY(0) scale(1);
      }
    }

    @keyframes strategy-roadmap-rise {
      0%, 20% {
        opacity: 0;
        transform: translateY(10px);
      }
      34%, 100% {
        opacity: 1;
        transform: translateY(0);
      }
    }

    @keyframes strategy-root-rise {
      0%, 12% {
        opacity: 0;
        transform: translateY(-10px);
      }
      28%, 100% {
        opacity: 1;
        transform: translateY(0);
      }
    }

    @keyframes strategy-org-line-draw {
      0%, 18% {
        stroke-dashoffset: 240;
        opacity: 0;
      }
      38%, 100% {
        stroke-dashoffset: 0;
        opacity: 1;
      }
    }

    @keyframes strategy-node-rise {
      0%, 26% {
        opacity: 0;
        transform: translateY(10px);
      }
      42%, 100% {
        opacity: 1;
        transform: translateY(0);
      }
    }

    @keyframes strategy-rail-rise {
      0%, 34% {
        opacity: 0;
        transform: translateY(8px);
      }
      50%, 100% {
        opacity: 1;
        transform: translateY(0);
      }
    }

    @keyframes compass-select {
      0% {
        transform: translateX(-50%) rotate(-142deg);
      }
      26% {
        transform: translateX(-50%) rotate(64deg);
      }
      48% {
        transform: translateX(-50%) rotate(-26deg);
      }
      66% {
        transform: translateX(-50%) rotate(52deg);
      }
      78%, 100% {
        transform: translateX(-50%) rotate(38deg);
      }
    }

    @keyframes growth-line-draw {
      0%, 14% {
        stroke-dashoffset: 280;
      }
      54%, 100% {
        stroke-dashoffset: 0;
      }
    }

    @keyframes roi-bar-fill {
      0%, 18% {
        transform: scaleX(0.08);
      }
      54%, 100% {
        transform: scaleX(1);
      }
    }

    .hero-visual-metric-grid {
      display: grid;
      grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: 10px;
    }

    .hero-visual-metric-grid div {
      display: grid;
      gap: 4px;
      padding: 12px;
      border-radius: 14px;
      background: rgba(255, 255, 255, 0.14);
    }

    .hero-visual-metric-grid span {
      font-size: 11px;
      font-weight: 700;
      letter-spacing: 0.08em;
      text-transform: uppercase;
      color: rgba(255, 255, 255, 0.6);
    }

    .hero-visual-metric-grid strong {
      font-size: 18px;
      font-weight: 700;
      color: #ffffff;
    }

    .hero-visual-growth-curve {
      position: relative;
      margin-top: 16px;
      padding: 8px 2px 18px 22px;
    }

    .hero-visual-growth-curve svg {
      display: block;
      width: 100%;
      height: auto;
    }

    .hero-visual-growth-axis {
      fill: none;
      stroke: rgba(255, 255, 255, 0.22);
      stroke-width: 1;
      stroke-linecap: round;
      stroke-linejoin: round;
    }

    .hero-visual-growth-line {
      fill: none;
      stroke: rgba(121, 191, 255, 0.98);
      stroke-width: 1.8;
      stroke-linecap: round;
      stroke-linejoin: round;
      filter: drop-shadow(0 0 6px rgba(121, 191, 255, 0.16));
      stroke-dasharray: 280;
      stroke-dashoffset: 280;
      animation: growth-line-draw 6.4s ease-in-out infinite;
    }

    .hero-visual-growth-labels {
      position: absolute;
      inset: 0;
      pointer-events: none;
    }

    .hero-visual-growth-labels span {
      font-size: 11px;
      font-weight: 700;
      color: rgba(255, 255, 255, 0.58);
      letter-spacing: 0.04em;
      text-transform: uppercase;
    }

    .hero-visual-growth-label-x {
      position: absolute;
      right: 10px;
      bottom: -2px;
    }

    .hero-visual-roi-bar {
      margin-top: 14px;
      height: 14px;
      border-radius: 999px;
      overflow: hidden;
      background: rgba(255, 255, 255, 0.14);
    }

    .hero-visual-roi-bar span {
      display: block;
      width: 72%;
      height: 100%;
      border-radius: inherit;
      background: linear-gradient(90deg, rgba(151, 197, 255, 0.98) 0%, rgba(126, 239, 255, 0.9) 100%);
      transform-origin: left center;
      animation: roi-bar-fill 6.4s ease-in-out infinite;
    }

    .hero-visual-roi-caption {
      margin-top: 8px;
      font-size: 12px;
      font-weight: 600;
      color: rgba(255, 255, 255, 0.72);
    }

    .hero-highlights {
      margin-top: 26px;
      display: flex;
      align-items: center;
      justify-content: flex-start;
      gap: 10px;
      flex-wrap: wrap;
      animation: hero-fade-in 0.9s ease-out 0.6s both;
    }

    .hero-highlight-pill {
      font-size: 12px;
      font-weight: 600;
      letter-spacing: 0.03em;
      color: rgba(255, 255, 255, 0.84);
      padding: 8px 14px;
      border-radius: 980px;
      border: 1px solid rgba(255, 255, 255, 0.24);
      background: rgba(255, 255, 255, 0.08);
      backdrop-filter: blur(10px);
      -webkit-backdrop-filter: blur(10px);
    }

    @media (max-width: 1024px) {
      .process-showcase-body {
        grid-template-columns: 1fr;
        grid-template-areas:
          "stages"
          "visual"
          "detail";
        gap: 30px;
      }

      .process-showcase-section.is-reversed .process-showcase-body {
        grid-template-columns: 1fr;
        grid-template-areas:
          "stages"
          "visual"
          "detail";
      }

      .process-showcase-stack {
        gap: 24px;
      }

      .process-showcase-section {
        padding: 8px 0 0;
      }

      .process-showcase-heading h2 {
        max-width: none;
        white-space: nowrap;
      }

      .process-showcase-visual,
      .process-showcase-section.is-reversed .process-showcase-visual {
        width: 100%;
        min-height: 0;
        justify-self: center;
      }

      .process-showcase-stage-list,
      .process-showcase-detail {
        max-width: none;
      }

      .journey-panel-body,
      .journey-panel-body.is-reversed {
        grid-template-columns: 1fr;
        gap: 32px;
      }

      .journey-panel-body.is-reversed .journey-panel-visual,
      .journey-panel-body.is-reversed .journey-panel-aside {
        order: initial;
      }

      .journey-panel-aside {
        padding-top: 0;
        max-width: none;
      }

      .journey-panel-points {
        max-width: none;
      }

      .journey-panel-visual .hero-visual {
        width: 100%;
        min-height: 520px;
      }

      .process-graphic-focus-grid,
      .process-graphic-foundation-grid,
      .process-graphic-guide-grid,
      .process-graphic-execution-lane,
      .process-graphic-governance-grid,
      .process-graphic-mini-grid,
      .process-graphic-training-grid,
      .process-graphic-search-results {
        grid-template-columns: 1fr;
      }

      .process-graphic-layer-row {
        align-items: flex-start;
        flex-direction: column;
      }

      .process-graphic-layer-row div {
        justify-content: flex-start;
      }

      .process-graphic-execution-step b {
        display: none;
      }
    }

    @media (max-width: 768px) {
      .hero-shell {
        margin: -64px 0 0;
      }

      .hero {
        border-radius: 0;
        min-height: auto;
      }

      .hero-content h1 {
        font-size: 36px;
        letter-spacing: -1px;
      }

      .hero-rotator-stage {
        min-height: 520px;
      }

      .hero-rotator-card {
      }

      .hero-rotator-card.is-hidden {
        opacity: 0;
        pointer-events: none;
        transform: scale(1.03);
      }

      .hero-rotator-overlay {
        left: 18px;
        right: 18px;
        bottom: 18px;
        gap: 16px;
        max-width: none;
      }

      .hero-rotator-title {
        max-width: 8.5ch;
      }

      .hero-rotator-description {
        font-size: 0.98rem;
        line-height: 1.62;
        max-width: 31ch;
      }

      .hero-visual {
        min-height: 420px;
      }

      .hero-visual-card {
        inset: auto 16px 16px;
      }

      .hero-visual-adoption .hero-visual-card {
        top: 26px;
        bottom: 16px;
      }

      .hero-visual-opportunity-label {
        position: static;
        display: block;
        width: fit-content;
        max-width: min(100%, 180px);
        margin: -8px auto 14px;
        padding: 4px 8px;
        border-radius: 999px;
        background: rgba(255, 255, 255, 0.12);
        border: 1px solid rgba(255, 255, 255, 0.16);
        text-align: center;
        font-size: 10px;
        letter-spacing: 0.08em;
        line-height: 1.2;
        overflow-wrap: anywhere;
      }

      .journey-sections {
        margin-top: 72px;
        padding: 0 20px;
      }

      .hero-light {
        margin: -64px 0 0;
        padding: clamp(120px, 16vh, 160px) 20px clamp(72px, 10vh, 100px);
      }

      .hero-light-title {
        font-size: clamp(2.2rem, 9vw, 3rem);
      }

      .hero-light-description {
        font-size: 1rem;
        margin-bottom: 32px;
      }

      .hero-light-actions {
        gap: 12px;
      }

      .hero-light-cta-primary,
      .hero-light-cta-secondary {
        min-height: 44px;
        padding: 0 22px;
        font-size: 0.9rem;
      }

      .process-showcase {
        margin-top: 72px;
        padding: 0 20px;
        --process-graphic-shell-height: 420px;
      }

      .process-showcase-section {
        padding: 6px 0 0;
      }

      .process-showcase-stack {
        gap: 42px;
      }

      .process-showcase-label {
        margin: 0 auto 24px;
        font-size: clamp(1.7rem, 7vw, 2.25rem);
        font-weight: 500;
        letter-spacing: -0.05em;
        line-height: 1;
      }

      .process-showcase-heading {
        grid-template-columns: auto minmax(0, 1fr);
        gap: 12px;
        margin-bottom: 24px;
      }

      .process-showcase-step-number {
        font-size: clamp(2.3rem, 11vw, 3.2rem);
      }

      .process-showcase-heading h2 {
        font-size: clamp(1.65rem, 6.4vw, 2.2rem);
        max-width: none;
        white-space: normal;
      }

      .process-showcase-stage-list {
        gap: 14px;
        padding-top: 0;
      }

      .process-showcase-stage {
        gap: 8px;
        padding-top: 12px;
      }

      .process-showcase-stage-title {
        font-size: clamp(0.98rem, 5.4vw, 1.24rem);
      }

      .process-showcase-stage-summary {
        max-width: none;
        font-size: 0.84rem;
        line-height: 1.5;
      }

      .process-showcase-detail {
        margin-top: 18px;
        min-height: 0;
      }

      .journey-panel-visual {
        min-height: 0;
        padding: 16px;
      }

      .journey-panel-visual .hero-visual {
        min-height: var(--process-graphic-shell-height);
        padding: 18px;
      }

      .process-graphic-panel,
      .process-graphic-note-strip,
      .process-graphic-callout,
      .process-graphic-feature-card,
      .process-graphic-response-card,
      .process-graphic-exception-card,
      .process-graphic-guide-step,
      .process-graphic-guide-card,
      .process-graphic-result-card,
      .process-graphic-stat-card,
      .process-graphic-governance-card,
      .process-graphic-literacy-row {
        border-radius: 16px;
      }

      .process-graphic-chip-grid,
      .process-graphic-pill-row,
      .process-graphic-rhythm-row {
        gap: 8px;
      }

      .process-graphic-chip-card,
      .process-graphic-pill-row i,
      .process-graphic-rhythm-row i {
        min-height: 38px;
        padding: 0 12px;
      }

      .process-graphic-callout strong,
      .process-graphic-feature-card strong {
        font-size: 1.28rem;
      }

      .process-graphic-callout p,
      .process-graphic-feature-card p,
      .process-graphic-response-card p,
      .process-graphic-exception-card p,
      .process-graphic-note-strip span {
        font-size: 0.84rem;
      }

      .process-graphic-search-prompt {
        font-size: 0.86rem;
      }

      .process-graphic-growth-chart {
        padding-left: 8px;
      }

      .journey-sections-heading {
        margin-bottom: 24px;
      }

      .journey-sections-stack {
        gap: 56px;
      }

      .journey-panel {
        gap: 28px;
        padding: 12px 0 0;
      }

      .journey-panel-overview {
        grid-template-columns: 1fr;
        gap: 18px;
      }

      .journey-panel-copy {
        padding: 0;
        max-width: none;
      }

      .journey-panel-copy h3 {
        font-size: clamp(1.9rem, 8vw, 2.8rem);
        max-width: none;
      }

      .journey-panel-description {
        font-size: 0.98rem;
        line-height: 1.68;
        margin: 0 0 22px;
      }

      .journey-panel-link {
        margin-top: 0;
        justify-self: start;
      }

      .journey-panel-body,
      .journey-panel-body.is-reversed {
        grid-template-columns: 1fr;
        gap: 24px;
      }

      .journey-panel-body.is-reversed .journey-panel-visual,
      .journey-panel-body.is-reversed .journey-panel-aside {
        order: initial;
      }

      .journey-panel-aside {
        padding-top: 0;
        max-width: none;
      }

      .journey-panel-points {
        max-width: none;
        gap: 0;
      }

      .journey-panel-visual {
        padding: 14px;
      }

      .journey-panel-visual::before {
        left: 14px;
        top: 14px;
        width: 42%;
        height: 18%;
      }

      .journey-panel-visual::after {
        right: 16px;
        bottom: 16px;
        width: 36%;
        height: 16%;
      }

      .journey-panel-visual .hero-visual {
        width: 100%;
        min-height: 460px;
        padding: 20px;
      }

      .journey-panel-visual .hero-visual-compass-wrap {
        height: auto;
        margin-bottom: 14px;
      }

      .hero-visual-priority-body {
        grid-template-columns: 1fr;
      }

      .hero-visual-priority-result {
        min-height: 0;
      }

      .journey-panel-visual .hero-visual-card {
        inset: auto;
        padding: 0;
      }

      .journey-panel-visual .hero-visual-adoption .hero-visual-card {
        top: auto;
        bottom: auto;
        width: 100%;
        margin: 0;
      }

      .hero-visual-compass-needle,
      .hero-visual-growth-line,
      .hero-visual-roi-bar span {
        animation-duration: 7.2s;
      }

      .hero-visual-mapping .hero-visual-scene::before,
      .hero-visual-build .hero-visual-scene::before,
      .hero-visual-adoption .hero-visual-scene::before {
        display: none;
      }

      .hero-visual-metric-grid {
        grid-template-columns: 1fr;
      }

      .journey-panel-visual .hero-visual-adoption {
        width: 100%;
        padding: 22px 20px 28px;
        min-height: 420px;
      }

      .journey-panel-visual .hero-visual-adoption .hero-visual-growth-curve,
      .journey-panel-visual .hero-visual-adoption .hero-visual-roi-bar,
      .journey-panel-visual .hero-visual-adoption .hero-visual-roi-caption {
        width: 100%;
      }

      .journey-panel-visual .hero-visual-chatbot-shell {
        min-width: 0;
        padding: 18px;
      }

      .journey-panel-visual .hero-visual-chatbot-header {
        grid-template-columns: 34px minmax(0, 1fr);
        gap: 10px;
      }

      .journey-panel-visual .hero-visual-chatbot-avatar {
        width: 34px;
        height: 34px;
        border-radius: 12px;
      }

      .journey-panel-visual .hero-visual-chatbot-header strong,
      .journey-panel-visual .hero-visual-chatbot-header span {
        overflow-wrap: anywhere;
      }

      .journey-panel-visual .hero-visual-chatbot-message.is-typing {
        min-height: 0;
      }

      .journey-panel-visual .hero-visual-typed-line {
        max-width: 100%;
        white-space: normal;
        overflow: visible;
        animation: none;
        padding-right: 0;
      }

      .journey-panel-visual .hero-visual-typed-line::after {
        display: none;
      }

      .journey-panel-visual .hero-visual-chatbot-message,
      .journey-panel-visual .hero-visual-chatbot-message.is-agent {
        max-width: 100%;
      }

      .journey-panel-visual .hero-visual-chatbot-sources {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
      }

      .journey-panel-visual .hero-visual-chatbot-sources span {
        justify-content: center;
        min-width: 0;
        padding: 0 8px;
        font-size: 10px;
      }
    }

    @media (max-width: 1080px) and (min-width: 769px) {
      .hero-rotator-stage {
        min-height: 680px;
      }
    }

    @media (prefers-reduced-motion: reduce) {
      .hero-rotator-card,
      .hero-rotator-link,
      .hero-rotator-link svg {
        transition: none;
      }

      .hero-visual-compass-needle,
      .hero-visual-growth-line,
      .hero-visual-roi-bar span {
        animation: none;
      }

      .process-graphic-strategy-focus-halo,
      .process-graphic-strategy-compass-ring,
      .process-graphic-strategy-compass-arc,
      .process-graphic-strategy-compass-needle,
      .process-graphic-strategy-focus-callout,
      .process-graphic-strategy-track-pill,
      .process-graphic-strategy-priority-card,
      .process-graphic-strategy-roadmap-pill,
      .process-graphic-strategy-org-root,
      .process-graphic-strategy-org-lines path,
      .process-graphic-strategy-org-node,
      .process-graphic-strategy-foundation-pill {
        animation: none;
        transition: none;
      }

      .process-graphic-strategy-compass-ring,
      .process-graphic-strategy-compass-arc,
      .process-graphic-strategy-focus-callout,
      .process-graphic-strategy-track-pill,
      .process-graphic-strategy-priority-card,
      .process-graphic-strategy-roadmap-pill,
      .process-graphic-strategy-org-root,
      .process-graphic-strategy-org-node,
      .process-graphic-strategy-foundation-pill {
        opacity: 1;
        transform: none;
      }

      .process-graphic-strategy-org-lines path {
        stroke-dashoffset: 0;
        opacity: 1;
      }
    }

    /* ── Remote homepage journey visuals ── */
    .journey-panel-visual {
      position: relative;
      display: flex;
      align-items: stretch;
      min-width: 0;
      width: 100%;
      padding: 0;
      border-radius: 32px;
      overflow: hidden;
      background:
        radial-gradient(circle at 82% 6%, rgba(255, 255, 255, 0.2) 0%, rgba(255, 255, 255, 0) 55%),
        linear-gradient(150deg, #2d6199 0%, #3b7ddb 58%, #5ba3d9 100%);
      border: 1px solid rgba(255, 255, 255, 0.16);
      box-shadow:
        0 18px 40px rgba(19, 44, 84, 0.22),
        0 2px 8px rgba(19, 44, 84, 0.1);
      transition: transform 0.25s ease, box-shadow 0.25s ease;
    }

    .journey-panel:hover .journey-panel-visual {
      transform: translateY(-4px);
      box-shadow:
        0 28px 56px rgba(19, 44, 84, 0.28),
        0 2px 8px rgba(19, 44, 84, 0.12);
    }

    .hero-visual {
      width: 100%;
      min-height: 470px;
      padding: 34px;
    }

    .hero-visual-card {
      display: flex;
      flex-direction: column;
      gap: 16px;
      min-height: 100%;
    }

    .hero-visual-card-top {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 12px;
      min-height: 34px;
      margin-bottom: 2px;
    }

    .hero-visual-card-top > span {
      font-size: 11px;
      font-weight: 700;
      letter-spacing: 0.12em;
      text-transform: uppercase;
      color: #bcd6ff;
    }

    .hero-visual-card-top > strong {
      font-size: 13px;
      font-weight: 600;
      color: #ffffff;
    }

    .hero-visual-shortlist-lead,
    .hero-visual-shortlist-row,
    .hero-visual-workflow-text,
    .hero-visual-stat,
    .hero-visual-team-list {
      background: rgba(255, 255, 255, 0.12);
      border: 1px solid rgba(255, 255, 255, 0.18);
      border-radius: 18px;
      box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.12);
      backdrop-filter: blur(20px);
      -webkit-backdrop-filter: blur(20px);
    }

    .hero-visual-shortlist {
      display: grid;
      gap: 13px;
    }

    .hero-visual-shortlist-lead {
      display: flex;
      align-items: center;
      gap: 18px;
      padding: 22px;
      background: rgba(255, 255, 255, 0.17);
      border-color: rgba(255, 255, 255, 0.26);
    }

    .hero-visual-fit-ring {
      position: relative;
      flex: 0 0 auto;
      width: 76px;
      height: 76px;
    }

    .hero-visual-fit-ring svg {
      width: 100%;
      height: 100%;
      transform: rotate(-90deg);
    }

    .hero-visual-fit-track {
      fill: none;
      stroke: rgba(255, 255, 255, 0.16);
      stroke-width: 6;
    }

    .hero-visual-fit-arc {
      fill: none;
      stroke: #ffffff;
      stroke-width: 6;
      stroke-linecap: round;
      stroke-dasharray: 144.5;
      stroke-dashoffset: 144.5px;
    }

    .journey-panel.is-micro-visible .hero-visual-fit-arc {
      animation: hero-fit-draw 1.3s cubic-bezier(0.22, 1, 0.36, 1) 0.2s forwards;
    }

    .hero-visual-fit-center {
      position: absolute;
      inset: 0;
      display: flex;
      flex-direction: column;
      align-items: center;
      justify-content: center;
      gap: 1px;
    }

    .hero-visual-fit-center strong {
      font-size: 21px;
      font-weight: 600;
      letter-spacing: -0.03em;
      color: #ffffff;
    }

    .hero-visual-fit-center span {
      font-size: 8.5px;
      font-weight: 700;
      letter-spacing: 0.14em;
      text-transform: uppercase;
      color: rgba(255, 255, 255, 0.62);
    }

    .hero-visual-shortlist-lead-main {
      flex: 1;
      min-width: 0;
      display: grid;
      gap: 14px;
    }

    .hero-visual-shortlist-lead-top {
      display: flex;
      align-items: center;
      gap: 10px;
    }

    .hero-visual-rank {
      flex: 0 0 auto;
      min-width: 28px;
      height: 24px;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      padding: 0 8px;
      border-radius: 8px;
      background: rgba(255, 255, 255, 0.16);
      font-size: 11px;
      font-weight: 700;
      letter-spacing: 0.04em;
      color: #ffffff;
    }

    .hero-visual-shortlist-lead-top strong {
      font-size: 17px;
      font-weight: 600;
      letter-spacing: -0.02em;
      color: #ffffff;
    }

    .hero-visual-meters {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 14px;
    }

    .hero-visual-meter {
      display: grid;
      gap: 8px;
    }

    .hero-visual-meter > div {
      display: flex;
      align-items: baseline;
      justify-content: space-between;
      gap: 8px;
    }

    .hero-visual-meter span {
      font-size: 10px;
      font-weight: 700;
      letter-spacing: 0.12em;
      text-transform: uppercase;
      color: rgba(255, 255, 255, 0.62);
    }

    .hero-visual-meter strong {
      font-size: 13px;
      font-weight: 700;
      color: #ffffff;
    }

    .hero-visual-meter i,
    .hero-visual-team-row i {
      display: block;
      height: 6px;
      border-radius: 999px;
      background: rgba(255, 255, 255, 0.16);
      overflow: hidden;
    }

    .hero-visual-meter i::before,
    .hero-visual-team-row i::before {
      content: "";
      display: block;
      height: 100%;
      width: var(--score, 70%);
      border-radius: inherit;
      background: linear-gradient(90deg, #ffffff, rgba(255, 255, 255, 0.7));
      transform: scaleX(0);
      transform-origin: left center;
    }

    .journey-panel.is-micro-visible .hero-visual-meter i::before,
    .journey-panel.is-micro-visible .hero-visual-team-row i::before {
      animation: hero-bar-grow 1.1s cubic-bezier(0.22, 1, 0.36, 1) 0.15s forwards;
    }

    .hero-visual-shortlist-row {
      display: flex;
      align-items: center;
      gap: 12px;
      padding: 16px;
      transition: background 0.2s ease, transform 0.2s ease;
    }

    .journey-panel-visual:hover .hero-visual-shortlist-row {
      background: rgba(255, 255, 255, 0.18);
    }

    .hero-visual-shortlist-row strong {
      flex: 1;
      font-size: 13.5px;
      font-weight: 600;
      color: #ffffff;
    }

    .hero-visual-score-chip {
      flex: 0 0 auto;
      padding: 4px 10px;
      border-radius: 999px;
      background: rgba(255, 255, 255, 0.14);
      font-size: 11px;
      font-weight: 600;
      white-space: nowrap;
      color: rgba(255, 255, 255, 0.82);
    }

    .hero-visual-shortlist-foot {
      display: flex;
      align-items: center;
      gap: 10px;
      margin-top: auto;
      padding-top: 6px;
    }

    .hero-visual-foot-check {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      width: 22px;
      height: 22px;
      border-radius: 50%;
      background: #ffffff;
      color: #3b7ddb;
    }

    .hero-visual-foot-check svg {
      width: 13px;
      height: 13px;
    }

    .hero-visual-shortlist-foot > span:last-child {
      font-size: 11px;
      font-weight: 700;
      letter-spacing: 0.12em;
      text-transform: uppercase;
      color: rgba(255, 255, 255, 0.82);
    }

    .hero-visual-workflow {
      display: grid;
      gap: 0;
    }

    .hero-visual-workflow-step {
      position: relative;
      display: grid;
      grid-template-columns: 30px minmax(0, 1fr);
      gap: 14px;
      padding-bottom: 14px;
    }

    .hero-visual-workflow-step:last-child {
      padding-bottom: 0;
    }

    .hero-visual-workflow-step::before {
      content: "";
      position: absolute;
      left: 14px;
      top: 30px;
      bottom: -2px;
      width: 2px;
      background: rgba(255, 255, 255, 0.18);
    }

    .hero-visual-workflow-step.is-done::before {
      background: rgba(255, 255, 255, 0.66);
    }

    .hero-visual-workflow-step:last-child::before {
      display: none;
    }

    .hero-visual-workflow-node {
      position: relative;
      z-index: 1;
      width: 30px;
      height: 30px;
      display: flex;
      align-items: center;
      justify-content: center;
      border-radius: 50%;
      background: rgba(255, 255, 255, 0.14);
      border: 1px solid rgba(255, 255, 255, 0.26);
      color: #ffffff;
    }

    .hero-visual-workflow-node svg {
      width: 15px;
      height: 15px;
    }

    .hero-visual-workflow-step.is-done .hero-visual-workflow-node {
      background: #ffffff;
      border-color: #ffffff;
      color: #3b7ddb;
    }

    .hero-visual-workflow-step.is-active .hero-visual-workflow-node {
      background: #ffffff;
      border-color: #ffffff;
      color: #3b7ddb;
      animation: hero-node-pulse 2.8s ease-in-out infinite;
    }

    .hero-visual-workflow-text {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 10px;
      padding: 14px 16px;
    }

    .hero-visual-workflow-step.is-active .hero-visual-workflow-text {
      background: rgba(255, 255, 255, 0.2);
      border-color: rgba(255, 255, 255, 0.32);
    }

    .hero-visual-workflow-step.is-pending .hero-visual-workflow-text {
      opacity: 0.6;
    }

    .hero-visual-workflow-text strong {
      font-size: 13.5px;
      font-weight: 600;
      color: #ffffff;
    }

    .hero-visual-workflow-status {
      flex: 0 0 auto;
      font-size: 10px;
      font-weight: 700;
      letter-spacing: 0.08em;
      text-transform: uppercase;
      color: rgba(255, 255, 255, 0.6);
    }

    .hero-visual-workflow-step.is-active .hero-visual-workflow-status {
      color: #ffffff;
    }

    .hero-visual-workflow-sources {
      margin-top: auto;
      padding-top: 8px;
    }

    .hero-visual-workflow-sources-label {
      display: block;
      margin-bottom: 10px;
      font-size: 10px;
      font-weight: 700;
      letter-spacing: 0.12em;
      text-transform: uppercase;
      color: rgba(255, 255, 255, 0.58);
    }

    .hero-visual-source-pills {
      display: flex;
      flex-wrap: wrap;
      gap: 8px;
    }

    .hero-visual-source-pill {
      display: inline-flex;
      align-items: center;
      gap: 7px;
      min-height: 30px;
      padding: 0 12px;
      border-radius: 999px;
      background: rgba(255, 255, 255, 0.12);
      border: 1px solid rgba(255, 255, 255, 0.2);
      font-size: 11px;
      font-weight: 600;
      color: #ffffff;
      transition: background 0.2s ease, transform 0.2s ease;
    }

    .journey-panel-visual:hover .hero-visual-source-pill {
      background: rgba(255, 255, 255, 0.2);
    }

    .hero-visual-source-pill img {
      width: 15px;
      height: 15px;
      flex: 0 0 auto;
      object-fit: contain;
    }

    .hero-visual-chart {
      width: 100%;
      padding: 4px 0 2px;
    }

    .hero-visual-chart svg {
      display: block;
      width: 100%;
      height: auto;
      overflow: visible;
    }

    .hero-visual-chart-area {
      fill: url(#adoption-area);
      stroke: none;
    }

    .hero-visual-chart-dot {
      fill: #ffffff;
      filter: drop-shadow(0 0 6px rgba(255, 255, 255, 0.55));
      opacity: 0;
    }

    .journey-panel.is-micro-visible .hero-visual-chart-dot {
      animation: hero-dot-pulse 0.5s ease-out 1.2s forwards;
    }

    .hero-visual-stat-row {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 12px;
    }

    .hero-visual-stat {
      display: grid;
      gap: 6px;
      padding: 16px 18px;
    }

    .hero-visual-stat-top {
      display: flex;
      align-items: baseline;
      gap: 8px;
    }

    .hero-visual-stat-top strong {
      font-size: 30px;
      font-weight: 600;
      line-height: 1;
      letter-spacing: -0.04em;
      color: #ffffff;
    }

    .hero-visual-stat-delta {
      display: inline-flex;
      align-items: center;
      gap: 4px;
      padding: 3px 8px;
      border-radius: 999px;
      background: rgba(255, 255, 255, 0.18);
      font-size: 10.5px;
      font-weight: 700;
      color: #ffffff;
    }

    .hero-visual-stat-delta::before {
      content: "";
      width: 0;
      height: 0;
      border-left: 3.5px solid transparent;
      border-right: 3.5px solid transparent;
      border-bottom: 5px solid #ffffff;
    }

    .hero-visual-stat-label {
      font-size: 11px;
      font-weight: 600;
      color: rgba(255, 255, 255, 0.72);
    }

    .hero-visual-team-list {
      display: grid;
      gap: 15px;
      padding: 20px;
      margin-top: auto;
    }

    .hero-visual-team-list-label {
      font-size: 10px;
      font-weight: 700;
      letter-spacing: 0.12em;
      text-transform: uppercase;
      color: rgba(255, 255, 255, 0.62);
    }

    .hero-visual-team-row {
      display: grid;
      grid-template-columns: 96px minmax(0, 1fr) 38px;
      gap: 12px;
      align-items: center;
    }

    .hero-visual-team-name {
      font-size: 12.5px;
      font-weight: 600;
      color: #ffffff;
    }

    .hero-visual-team-row strong {
      font-size: 12.5px;
      font-weight: 700;
      color: #ffffff;
      text-align: right;
    }

    .hero-visual-growth-line {
      --dash: 380;
      fill: none;
      stroke: #ffffff;
      stroke-width: 2.6;
      stroke-linecap: round;
      stroke-linejoin: round;
      stroke-dasharray: var(--dash);
      stroke-dashoffset: var(--dash);
    }

    .journey-panel.is-micro-visible .hero-visual-growth-line {
      animation: growth-line-draw 1.5s ease-out 0.1s forwards;
    }

    @keyframes growth-line-draw {
      from {
        stroke-dashoffset: var(--dash, 380);
      }

      to {
        stroke-dashoffset: 0;
      }
    }

    @keyframes hero-bar-grow {
      from {
        transform: scaleX(0);
      }

      to {
        transform: scaleX(1);
      }
    }

    @keyframes hero-fit-draw {
      from {
        stroke-dashoffset: 144.5px;
      }

      to {
        stroke-dashoffset: calc(144.5px - 144.5px * var(--fit, 80) / 100);
      }
    }

    @keyframes hero-node-pulse {
      0%,
      100% {
        box-shadow: 0 0 0 0 rgba(255, 255, 255, 0.5);
      }

      60% {
        box-shadow: 0 0 0 9px rgba(255, 255, 255, 0);
      }
    }

    @keyframes hero-dot-pulse {
      from {
        opacity: 0;
      }

      to {
        opacity: 1;
      }
    }

    @media (max-width: 1024px) {
      .journey-panel-body,
      .journey-panel-body.is-reversed {
        grid-template-columns: 1fr;
        gap: 32px;
      }

      .journey-panel-body.is-reversed .journey-panel-visual,
      .journey-panel-body.is-reversed .journey-panel-aside {
        order: initial;
      }

      .journey-panel-aside {
        padding-top: 0;
        max-width: none;
      }

      .journey-panel-points {
        max-width: none;
      }

      .journey-panel-visual .hero-visual {
        min-height: 520px;
      }
    }

    @media (max-width: 768px) {
      .journey-sections {
        margin-top: 72px;
        padding: 0 20px;
      }

      .journey-sections-heading {
        margin-bottom: 24px;
      }

      .journey-sections-stack {
        gap: 56px;
      }

      .journey-panel {
        gap: 28px;
        padding: 12px 0 0;
      }

      .journey-panel-overview {
        grid-template-columns: 1fr;
        gap: 18px;
      }

      .journey-panel-copy {
        padding: 0;
        max-width: none;
      }

      .journey-panel-copy h3 {
        font-size: clamp(1.9rem, 8vw, 2.8rem);
        max-width: none;
      }

      .journey-panel-description {
        font-size: 0.98rem;
        line-height: 1.68;
        margin: 0 0 22px;
      }

      .journey-panel-link {
        margin-top: 0;
        justify-self: start;
      }

      .journey-panel-body,
      .journey-panel-body.is-reversed {
        grid-template-columns: 1fr;
        gap: 24px;
      }

      .journey-panel-body.is-reversed .journey-panel-visual,
      .journey-panel-body.is-reversed .journey-panel-aside {
        order: initial;
      }

      .journey-panel-aside {
        padding-top: 0;
        max-width: none;
      }

      .journey-panel-points {
        max-width: none;
        gap: 0;
      }

      .journey-panel-visual .hero-visual {
        min-height: 0;
        padding: 22px;
      }

      .hero-visual-meters,
      .hero-visual-stat-row {
        gap: 10px;
      }

      .hero-visual-shortlist-lead {
        flex-direction: column;
        align-items: flex-start;
        gap: 16px;
      }

      .hero-visual-shortlist-lead-main {
        width: 100%;
      }

      .hero-visual-fit-ring {
        width: 64px;
        height: 64px;
      }
    }

    @media (prefers-reduced-motion: reduce) {
      .journey-panel .hero-visual-growth-line,
      .journey-panel .hero-visual-chart-dot,
      .journey-panel .hero-visual-fit-arc,
      .journey-panel .hero-visual-meter i::before,
      .journey-panel .hero-visual-team-row i::before,
      .hero-visual-workflow-step.is-active .hero-visual-workflow-node {
        animation: none;
      }

      .journey-panel .hero-visual-meter i::before,
      .journey-panel .hero-visual-team-row i::before {
        transform: scaleX(1);
      }

      .journey-panel .hero-visual-growth-line {
        stroke-dashoffset: 0;
      }

      .journey-panel .hero-visual-fit-arc {
        stroke-dashoffset: calc(144.5px - 144.5px * var(--fit, 80) / 100);
      }

      .journey-panel .hero-visual-chart-dot {
        opacity: 1;
      }

      .journey-panel:hover .journey-panel-visual {
        transform: none;
      }
    }

    /* ── Clients section ── */
    .clients {
      max-width: 1280px;
      margin: 80px auto 0;
      padding: 0 24px;
      text-align: center;
    }

    .clients-label {
      font-size: 13px;
      font-weight: 500;
      color: #8a919c;
      text-transform: uppercase;
      letter-spacing: 0.08em;
      margin-bottom: 28px;
    }

    .clients-track-wrapper {
      overflow: hidden;
      padding: 14px 0;
      margin: -14px 0;
      mask-image: linear-gradient(to right, transparent 0%, black 10%, black 90%, transparent 100%);
      -webkit-mask-image: linear-gradient(to right, transparent 0%, black 10%, black 90%, transparent 100%);
    }

    .clients-track {
      display: flex;
      align-items: center;
      gap: 64px;
      width: max-content;
      animation: scroll-logos 45s linear infinite;
    }

    .clients-track img {
      height: 32px;
      width: auto;
      opacity: 0.42;
      filter: grayscale(1) contrast(0.82) brightness(0.74);
      transition:
        opacity 0.26s ease,
        filter 0.26s ease,
        transform 0.3s cubic-bezier(0.22, 1, 0.36, 1);
      flex-shrink: 0;
      will-change: transform;
    }

    .clients-track img:hover {
      opacity: 0.72;
      filter: grayscale(0.22) contrast(0.96) brightness(0.72) saturate(1.08);
      transform: translateY(-3px) scale(1.08);
    }

    @keyframes scroll-logos {
      0% { transform: translateX(0); }
      100% { transform: translateX(-50%); }
    }

    /* ── Reimagined homepage sections ── */
    .home-expertise,
    .home-services-reimagined,
    .home-house-framework {
      max-width: 1280px;
      margin: 96px auto 0;
      padding: 0 24px;
    }

    .home-contact-reimagined {
      max-width: min(calc(100% - 48px), 1280px);
      margin: 96px auto 0;
      padding: 0;
    }

    .home-section-heading {
      max-width: 760px;
      margin-bottom: 34px;
    }

    .home-section-heading-centered {
      text-align: center;
      margin-left: auto;
      margin-right: auto;
    }

    .home-section-label {
      font-size: 13px;
      font-weight: var(--font-ui-weight);
      text-transform: uppercase;
      letter-spacing: var(--tracking-label);
      color: #8c6d3f;
      margin-bottom: 10px;
    }

    .home-section-heading h2 {
      font-size: 44px;
      font-weight: var(--font-display-weight);
      letter-spacing: var(--tracking-display-tight);
      line-height: var(--line-display);
      color: #1a2533;
      margin-bottom: 12px;
    }

    .home-section-heading p {
      font-size: 16px;
      line-height: 1.75;
      color: #5a6270;
    }

    .home-expertise-grid {
      display: grid;
      grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: 20px;
    }

    .home-expertise-card {
      background: rgba(255, 255, 255, 0.4);
      border: 1px solid rgba(255, 255, 255, 0.54);
      border-radius: 20px;
      box-shadow:
        0 4px 24px rgba(0, 0, 0, 0.03),
        0 1px 0 rgba(255, 255, 255, 0.62) inset;
      padding: 30px;
      display: flex;
      flex-direction: column;
      gap: 14px;
    }

    .home-expertise-card h3 {
      font-size: 24px;
      line-height: 1.25;
      letter-spacing: -0.45px;
      color: #1a2533;
    }

    .home-expertise-card p {
      font-size: 15px;
      line-height: 1.75;
      color: #4f5a69;
    }

    .home-expertise-card a {
      margin-top: auto;
      display: inline-flex;
      align-items: center;
      gap: 8px;
      text-decoration: none;
      color: #245a9f;
      font-size: 14px;
      font-weight: 600;
    }

    .home-expertise-card a svg {
      width: 14px;
      height: 14px;
    }

    .home-services-reimagined {
      margin-top: 92px;
    }

    .home-services-reimagined .home-section-heading {
      max-width: 700px;
      margin-bottom: 22px;
    }

    .home-services-kicker {
      max-width: 560px;
      margin: 0 auto;
      font-size: 15px;
      line-height: 1.7;
      color: #5e6978;
    }

    .home-services-reveal {
      position: relative;
      padding-top: 10px;
      isolation: isolate;
      overflow: hidden;
    }

    .home-services-reveal::before {
      content: '';
      position: absolute;
      inset: 18px 14px auto;
      height: 1px;
      background: linear-gradient(90deg, transparent, rgba(59, 125, 219, 0.18), rgba(91, 163, 217, 0.42), rgba(59, 125, 219, 0.18), transparent);
      opacity: 0;
      pointer-events: none;
    }

    .home-services-reveal-sweep {
      position: absolute;
      inset: -18px;
      pointer-events: none;
      opacity: 0;
      background:
        radial-gradient(circle at 12% 34%, rgba(91, 163, 217, 0.16), transparent 22%),
        radial-gradient(circle at 88% 12%, rgba(59, 125, 219, 0.12), transparent 18%),
        linear-gradient(110deg, transparent 28%, rgba(91, 163, 217, 0.18) 49%, transparent 70%);
      transform: translateX(-10%) scaleX(0.88);
      filter: blur(1px);
      z-index: 0;
    }

    .home-services-reveal-sweep::after {
      content: '';
      position: absolute;
      inset: 0;
      background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.42), transparent);
      transform: translateX(-110%);
    }

    .home-services-compact-grid {
      position: relative;
      z-index: 1;
      display: grid;
      grid-template-columns: repeat(4, minmax(0, 1fr));
      gap: 22px;
    }

    .home-service-node {
      min-height: 168px;
      padding: 18px 16px;
      border-radius: 16px;
      border: 1px solid rgba(59, 125, 219, 0.14);
      background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.9) 0%, rgba(246, 250, 255, 0.8) 100%);
      box-shadow:
        0 8px 20px rgba(26, 37, 51, 0.04),
        0 1px 0 rgba(255, 255, 255, 0.72) inset;
      text-decoration: none;
      color: inherit;
      display: flex;
      flex-direction: column;
      position: relative;
      overflow: hidden;
      opacity: 0;
      transform: translate3d(0, 18px, 0) scale(0.985);
      animation: none;
      transition:
        transform 0.28s cubic-bezier(0.2, 0.8, 0.2, 1),
        border-color 0.28s ease,
        box-shadow 0.28s ease,
        background-color 0.28s ease;
      will-change: transform, opacity;
    }

    .home-service-node::before {
      content: '';
      position: absolute;
      inset: 0 0 auto;
      height: 2px;
      background: linear-gradient(90deg, transparent, rgba(59, 125, 219, 0.7), rgba(91, 163, 217, 0.95), rgba(59, 125, 219, 0.7), transparent);
      transform: scaleX(0.18);
      transform-origin: left center;
      opacity: 0;
      transition: transform 0.28s ease, opacity 0.28s ease;
      pointer-events: none;
    }

    .home-service-node:hover {
      transform: translate3d(0, -5px, 0) scale(1.01);
      border-color: rgba(59, 125, 219, 0.28);
      box-shadow:
        0 16px 32px rgba(26, 37, 51, 0.08),
        0 1px 0 rgba(255, 255, 255, 0.72) inset;
    }

    .home-service-node:hover::before {
      opacity: 1;
      transform: scaleX(1);
    }

    .home-services-reimagined.is-visible .home-services-reveal::before {
      animation: home-services-rail-in 780ms ease both;
    }

    .home-services-reimagined.is-visible .home-services-reveal-sweep {
      animation: home-services-sweep 1100ms cubic-bezier(0.22, 1, 0.36, 1) both;
    }

    .home-services-reimagined.is-visible .home-services-reveal-sweep::after {
      animation: home-services-sweep-glint 1100ms cubic-bezier(0.22, 1, 0.36, 1) both;
    }

    .home-services-reimagined.is-visible .home-service-node {
      animation: home-service-node-rise 700ms cubic-bezier(0.22, 1, 0.36, 1) both;
      animation-delay: var(--service-delay, 0ms);
    }

    .home-service-node:focus-visible {
      outline: 2px solid rgba(59, 125, 219, 0.6);
      outline-offset: 3px;
    }

    .home-service-node-meta {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 8px;
      margin-bottom: 12px;
    }

    .home-service-track-index {
      font-size: 11.5px;
      font-weight: 700;
      letter-spacing: 0.1em;
      color: #8c6d3f;
      font-variant-numeric: tabular-nums;
    }

    .home-service-track-phase {
      display: inline-flex;
      align-items: center;
      font-size: 10px;
      font-weight: 700;
      letter-spacing: 0.09em;
      text-transform: uppercase;
      color: #8c6d3f;
      padding: 4px 9px;
      border-radius: 980px;
      background: rgba(140, 109, 63, 0.1);
    }

    .home-service-node h3 {
      font-size: 20px;
      line-height: 1.24;
      letter-spacing: -0.32px;
      color: #1a2533;
      margin-bottom: 8px;
    }

    .home-service-track-description {
      font-size: 13.5px;
      line-height: 1.62;
      color: #5b6675;
      margin-bottom: 14px;
    }

    .home-service-track-link {
      margin-top: auto;
      display: inline-flex;
      align-items: center;
      gap: 8px;
      color: #245a9f;
      font-size: 13.5px;
      font-weight: 600;
    }

    .home-service-track-link svg {
      width: 14px;
      height: 14px;
      transition: transform 0.24s ease;
    }

    @keyframes home-services-rail-in {
      from {
        opacity: 0;
        transform: scaleX(0.22);
      }

      35% {
        opacity: 1;
      }

      to {
        opacity: 0.85;
        transform: scaleX(1);
      }
    }

    @keyframes home-services-sweep {
      0% {
        opacity: 0;
        transform: translateX(-10%) scaleX(0.88);
      }

      28% {
        opacity: 1;
      }

      100% {
        opacity: 0;
        transform: translateX(10%) scaleX(1.08);
      }
    }

    @keyframes home-services-sweep-glint {
      0% {
        transform: translateX(-110%);
        opacity: 0;
      }

      32% {
        opacity: 1;
      }

      100% {
        transform: translateX(110%);
        opacity: 0;
      }
    }

    .home-service-node:hover .home-service-track-link svg {
      transform: translateX(5px);
    }

    .home-house-framework {
      display: grid;
      grid-template-columns: 1.15fr 0.85fr;
      gap: 22px;
      align-items: stretch;
    }

    .home-house-framework-copy,
    .home-house-framework-panel {
      border-radius: 22px;
      padding: 32px;
    }

    .home-house-framework-copy {
      background: rgba(255, 255, 255, 0.45);
      backdrop-filter: blur(24px) saturate(1.3);
      -webkit-backdrop-filter: blur(24px) saturate(1.3);
    }

    .home-house-framework-label {
      font-size: 13px;
      font-weight: 600;
      letter-spacing: 0.08em;
      text-transform: uppercase;
      color: #8c6d3f;
      margin-bottom: 10px;
    }

    .home-house-framework-copy h2 {
      font-size: 39px;
      font-weight: 500;
      letter-spacing: -1px;
      line-height: 1.14;
      color: #1a2533;
      margin-bottom: 14px;
    }

    .home-house-framework-copy p {
      font-size: 15.5px;
      line-height: 1.8;
      color: #526174;
      margin-bottom: 20px;
    }

    .home-house-framework-link {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      text-decoration: none;
      font-size: 14px;
      font-weight: 600;
      color: #fff;
      background: #0e0f19;
      border-radius: 980px;
      padding: 10px 18px;
    }

    .home-house-framework-link svg {
      width: 14px;
      height: 14px;
    }

    .home-house-framework-panel {
      background: linear-gradient(145deg, #132c54 0%, #214779 72%, #2d6199 100%);
      color: #fff;
      position: relative;
      overflow: hidden;
    }

    .home-house-framework-panel::before {
      content: '';
      position: absolute;
      inset: 0;
      background: radial-gradient(circle at top right, rgba(121, 186, 235, 0.35), transparent 55%);
      pointer-events: none;
    }

    .home-house-framework-panel h3 {
      position: relative;
      z-index: 1;
      font-size: 28px;
      letter-spacing: -0.5px;
      margin-bottom: 18px;
    }

    .home-house-framework-panel ul {
      position: relative;
      z-index: 1;
      list-style: none;
      display: grid;
      gap: 12px;
      padding: 0;
    }

    .home-house-framework-panel li {
      position: relative;
      padding-left: 16px;
      font-size: 14.5px;
      line-height: 1.76;
      color: rgba(255, 255, 255, 0.88);
    }

    .home-house-framework-panel li::before {
      content: '';
      position: absolute;
      left: 0;
      top: 11px;
      width: 6px;
      height: 6px;
      border-radius: 999px;
      background: #9dd2f4;
    }

    .testimonials-more-link {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      margin-top: 24px;
      text-decoration: none;
      font-size: 14px;
      font-weight: 600;
      color: #2f6ab1;
    }

    .testimonials-more-link svg {
      width: 14px;
      height: 14px;
    }

    .home-contact-band {
      display: grid;
      grid-template-columns: minmax(0, 1fr) minmax(220px, 280px);
      gap: 22px;
      max-width: 1280px;
      margin: 100px 24px 0;
      margin-left: max(24px, calc((100% - 1280px) / 2));
      margin-right: max(24px, calc((100% - 1280px) / 2));
      align-items: stretch;
    }

    .home-contact-reimagined {
      position: relative;
      overflow: hidden;
      border-radius: 24px;
      padding: 0;
      background:
        radial-gradient(circle at 8% 12%, rgba(59, 125, 219, 0.65) 0%, rgba(59, 125, 219, 0) 32%),
        radial-gradient(circle at 40% 20%, rgba(123, 188, 241, 0.6) 0%, rgba(123, 188, 241, 0) 32%),
        radial-gradient(circle at 88% 8%, rgba(206, 226, 255, 0.9) 0%, rgba(206, 226, 255, 0) 38%),
        radial-gradient(circle at 14% 90%, rgba(191, 215, 255, 0.48) 0%, rgba(191, 215, 255, 0) 28%),
        linear-gradient(145deg, #eef5ff 0%, #d8eaff 38%, #b8d4f5 72%, #d4e5ff 100%);
      color: #1a2533;
      text-align: left;
      margin: 0;
    }

    .home-contact-reimagined-glow {
      position: absolute;
      width: 460px;
      height: 460px;
      border-radius: 50%;
      background: radial-gradient(circle, rgba(129, 189, 240, 0.3) 0%, rgba(129, 189, 240, 0) 68%);
      filter: blur(10px);
      top: -220px;
      right: -160px;
      pointer-events: none;
    }

    .home-contact-reimagined-shell {
      position: relative;
      z-index: 1;
      display: grid;
      grid-template-columns: minmax(0, 1.2fr) minmax(280px, 0.8fr);
      align-items: center;
      gap: 48px;
      padding: 52px 52px 48px;
      min-width: 0;
    }

    .home-contact-reimagined-intro {
      max-width: 580px;
      min-width: 0;
    }

    .home-contact-reimagined-label {
      font-size: 11.5px;
      letter-spacing: 0.14em;
      text-transform: uppercase;
      color: #2f5ea8;
      margin-bottom: 14px;
      font-weight: 700;
    }

    .home-contact-reimagined h2 {
      font-size: clamp(32px, 4vw, 46px);
      line-height: 1.08;
      letter-spacing: -1.4px;
      margin-bottom: 14px;
      color: #1a2533;
      font-weight: 500;
    }

    .home-contact-reimagined-copy {
      font-size: 15.5px;
      line-height: 1.75;
      color: rgba(36, 58, 92, 0.78);
      max-width: 480px;
    }

    .home-contact-reimagined-actions {
      display: grid;
      gap: 0;
      align-content: start;
      min-width: 0;
      background: rgba(255, 255, 255, 0.55);
      border: 1px solid rgba(255, 255, 255, 0.7);
      border-radius: 16px;
      padding: 24px 28px;
      backdrop-filter: blur(12px);
      box-shadow: 0 4px 20px rgba(26, 37, 51, 0.06), inset 0 1px 0 rgba(255,255,255,0.8);
    }

    .home-contact-reimagined-availability {
      font-size: 11px;
      font-weight: 700;
      letter-spacing: 0.08em;
      text-transform: uppercase;
      color: #5a7caa;
    }

    .home-contact-reimagined-channels {
      display: grid;
      gap: 0;
      margin-bottom: 20px;
    }

    .home-contact-reimagined-channels a {
      display: grid;
      grid-template-columns: auto minmax(0, 1fr);
      align-items: start;
      gap: 14px;
      text-decoration: none;
      padding: 12px 0;
      color: #1d314b;
      border-bottom: 1px solid rgba(59, 125, 219, 0.1);
      transition: color 0.2s ease;
    }

    .home-contact-reimagined-channels a:last-child {
      border-bottom: none;
    }

    .home-contact-reimagined-channels a:hover {
      color: #2f6ab1;
    }

    .home-contact-reimagined-channels a span {
      font-size: 10.5px;
      font-weight: 700;
      letter-spacing: 0.1em;
      text-transform: uppercase;
      color: #5a7caa;
      flex-shrink: 0;
    }

    .home-contact-reimagined-channels a strong {
      display: block;
      font-size: 13.5px;
      font-weight: 600;
      line-height: 1.42;
      letter-spacing: -0.01em;
      color: #1a2d47;
      min-width: 0;
      padding-bottom: 1px;
      text-align: right;
      overflow-wrap: anywhere;
    }

    .home-contact-reimagined-cta {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      gap: 8px;
      text-decoration: none;
      border-radius: 10px;
      font-size: 14px;
      font-weight: 600;
      color: #fff;
      background: #2f6ab1;
      padding: 13px 22px;
      transition: background 0.18s ease,
                  box-shadow 0.22s ease,
                  transform 0.2s cubic-bezier(0.34, 1.56, 0.64, 1);
      width: 100%;
    }

    .home-contact-reimagined-cta:hover {
      background: #2460a0;
      transform: translateY(-2px);
      box-shadow: 0 6px 20px rgba(47, 106, 177, 0.35);
    }

    .home-contact-reimagined-cta:active {
      transform: scale(0.97);
      box-shadow: none;
      transition-duration: 0.06s;
    }

    .home-contact-reimagined-cta:focus-visible {
      outline: 2px solid rgba(59, 125, 219, 0.5);
      outline-offset: 3px;
    }

    .home-contact-reimagined-cta svg {
      width: 14px;
      height: 14px;
      transition: transform 0.2s cubic-bezier(0.34, 1.56, 0.64, 1);
    }

    .home-contact-reimagined-cta:hover svg {
      transform: translateX(3px);
    }

    .home-contact-reimagined-footnote {
      font-size: 12px;
      line-height: 1.6;
      color: rgba(47, 80, 130, 0.6);
      text-align: center;
      margin-top: 10px;
    }

    .home-contact-reimagined-about {
      align-self: stretch;
      display: flex;
      flex-direction: column;
      justify-content: space-between;
      gap: 18px;
      min-height: 100%;
      padding: 24px 22px;
      text-decoration: none;
      color: #1a2533;
      background: rgba(255, 255, 255, 0.44);
      border: 1px solid rgba(255, 255, 255, 0.62);
      border-radius: 16px;
      backdrop-filter: blur(12px);
      -webkit-backdrop-filter: blur(12px);
      box-shadow: 0 4px 20px rgba(26, 37, 51, 0.05), inset 0 1px 0 rgba(255,255,255,0.78);
      transition: transform 0.18s ease, box-shadow 0.18s ease, background 0.18s ease;
    }

    .home-contact-reimagined-about:hover {
      transform: translateY(-2px);
      background: rgba(255, 255, 255, 0.52);
      box-shadow: 0 10px 24px rgba(26, 37, 51, 0.08), inset 0 1px 0 rgba(255,255,255,0.82);
    }

    .home-contact-reimagined-about-label {
      font-size: 10.5px;
      font-weight: 700;
      letter-spacing: 0.12em;
      text-transform: uppercase;
      color: #5a7caa;
    }

    .home-contact-reimagined-about strong {
      display: block;
      font-size: 18px;
      line-height: 1.35;
      letter-spacing: -0.03em;
      color: #1a2d47;
      font-weight: 600;
    }

    .home-contact-reimagined-about-link {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      font-size: 13px;
      font-weight: 600;
      color: #2f6ab1;
    }

    .home-contact-reimagined-about-link svg {
      width: 13px;
      height: 13px;
      transition: transform 0.18s ease;
    }

    .home-contact-reimagined-about:hover .home-contact-reimagined-about-link svg {
      transform: translateX(3px);
    }

    @media (max-width: 1080px) {
      .home-expertise-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
      }

      .home-services-compact-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 18px;
      }

      .home-house-framework {
        grid-template-columns: 1fr;
      }

      .home-section-heading h2 {
        font-size: 36px;
      }

      .home-house-framework-copy h2 {
        font-size: 34px;
      }

      .home-contact-band {
        grid-template-columns: 1fr;
        gap: 20px;
        max-width: min(calc(100% - 48px), 1280px);
      }

      .home-contact-reimagined-shell {
        grid-template-columns: 1fr;
        gap: 24px;
      }

      .home-contact-reimagined h2 {
        font-size: 38px;
      }

      .home-contact-reimagined-actions {
        max-width: 560px;
      }

      .home-contact-reimagined-about {
        max-width: none;
        min-height: 0;
      }
    }

    @media (max-width: 768px) {
      .hero-highlights {
        gap: 8px;
      }

      .hero-highlight-pill {
        font-size: 11px;
      }

      .home-expertise,
      .home-services-reimagined,
      .home-house-framework {
        margin-top: 72px;
        padding: 0 16px;
      }

      .home-contact-band {
        width: 100%;
        max-width: none;
        margin: 72px 0 0;
        padding: 0 16px;
        gap: 16px;
      }

      .home-contact-reimagined,
      .home-contact-reimagined-about {
        width: 100%;
      }

      .home-section-heading h2 {
        font-size: 29px;
        letter-spacing: -0.8px;
      }

      .home-section-heading p {
        font-size: 15px;
      }

      .home-expertise-grid {
        grid-template-columns: 1fr;
      }

      .home-expertise-card,
      .home-house-framework-copy,
      .home-house-framework-panel {
        padding: 24px;
      }

      .home-contact-reimagined-shell {
        padding: 28px 22px 24px;
        gap: 18px;
        grid-template-columns: minmax(0, 1fr);
      }

      .home-services-kicker {
        font-size: 15px;
      }

      .home-services-compact-grid {
        grid-template-columns: 1fr;
        gap: 12px;
      }

      .home-service-node {
        opacity: 0;
        transform: translate3d(0, 18px, 0) scale(0.985);
        padding: 20px;
        min-height: 0;
      }

      .home-service-node h3 {
        font-size: 21px;
      }

      .home-service-track-description {
        margin-bottom: 14px;
      }

      .home-expertise-card h3 {
        font-size: 22px;
      }

      .home-house-framework-copy h2 {
        font-size: 29px;
      }

      .home-contact-reimagined h2 {
        font-size: 31px;
        letter-spacing: -0.8px;
      }

      .home-contact-reimagined-copy {
        font-size: 15px;
      }

      .home-contact-reimagined-availability {
        font-size: 11px;
      }

      .home-contact-reimagined-channels a strong {
        font-size: 14.5px;
      }

      .home-contact-reimagined-cta {
        width: 100%;
      }
    }

    @media (max-width: 420px) {
      .home-contact-band {
        grid-template-columns: minmax(0, 1fr);
        width: 100vw;
        margin-left: calc(50% - 50vw);
        margin-right: calc(50% - 50vw);
        padding: 0 14px;
      }

      .home-contact-band > * {
        min-width: 0;
        max-width: none;
      }

      .home-contact-reimagined {
        min-width: 0;
        border-radius: 20px;
      }

      .home-contact-reimagined-shell {
        padding: 24px 20px 22px;
      }

      .home-contact-reimagined h2 {
        font-size: clamp(26px, 8vw, 30px);
        line-height: 1.12;
        letter-spacing: -0.6px;
      }

      .home-contact-reimagined-copy {
        font-size: 14px;
        line-height: 1.65;
      }

      .home-contact-reimagined-actions {
        padding: 18px;
        border-radius: 16px;
      }

      .home-contact-reimagined-channels {
        gap: 8px;
      }

      .home-contact-reimagined-channels a {
        display: grid;
        grid-template-columns: 1fr;
        gap: 4px;
        align-items: start;
        padding: 10px 0;
      }

      .home-contact-reimagined-channels a strong {
        font-size: 13.5px;
        line-height: 1.35;
      }

      .home-contact-reimagined-cta {
        min-height: 56px;
        padding: 11px 16px;
        text-align: center;
        line-height: 1.25;
        overflow-wrap: anywhere;
      }

      .home-contact-reimagined-footnote {
        font-size: 11.5px;
      }
    }

    /* ── Services preview (home page) ── */
    .services-preview {
      max-width: 1320px;
      margin: 96px auto 0;
      padding: 0 24px;
    }

    .services-preview-heading {
      text-align: center;
      margin: 0 auto 24px;
    }

    .services-preview-heading h2 {
      font-size: clamp(2.25rem, 4vw, 4.25rem);
      font-weight: 500;
      letter-spacing: -0.06em;
      color: #05070c;
      line-height: 0.98;
      max-width: 900px;
      margin: 0 auto 22px;
    }

    .services-preview-sub {
      font-size: clamp(1rem, 1.25vw, 1.18rem);
      line-height: 1.65;
      color: #202634;
      max-width: 740px;
      margin: 0 auto;
    }

    .services-preview-legacy {
      margin: 44px 0 54px;
    }

    .services-preview-legacy-heading {
      margin: 0 0 24px;
      text-align: center;
    }

    .services-preview-legacy-heading p {
      font-size: 0.8rem;
      font-weight: 700;
      letter-spacing: 0.16em;
      text-transform: uppercase;
      color: rgba(59, 94, 150, 0.62);
      margin-bottom: 10px;
    }

    .services-preview-legacy-heading h3 {
      font-size: clamp(1.85rem, 2.6vw, 2.6rem);
      font-weight: 500;
      letter-spacing: -0.05em;
      line-height: 1;
      color: #10131d;
    }

    .services-preview-legacy-grid {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 22px;
    }

    .services-preview-legacy-card {
      position: relative;
      min-height: 620px;
      padding: 0 0 30px;
      border-radius: 8px;
      overflow: hidden;
      transition: transform 220ms ease;
    }

    .services-preview-legacy-card:hover {
      transform: translateY(-2px);
    }

    .services-preview-legacy-card-strategy {
      background:
        radial-gradient(circle at 16% 18%, rgba(247, 199, 126, 0.78) 0%, rgba(247, 199, 126, 0) 30%),
        radial-gradient(circle at 46% 22%, rgba(251, 223, 176, 0.88) 0%, rgba(251, 223, 176, 0) 34%),
        radial-gradient(circle at 82% 14%, rgba(233, 217, 255, 0.76) 0%, rgba(233, 217, 255, 0) 36%),
        radial-gradient(circle at 78% 82%, rgba(193, 220, 255, 0.62) 0%, rgba(193, 220, 255, 0) 28%),
        linear-gradient(145deg, #f7dfad 0%, #f4d39c 32%, #ebd7f7 68%, #d8e6fb 100%);
    }

    .services-preview-legacy-card-build {
      background:
        radial-gradient(circle at 14% 18%, rgba(229, 181, 232, 0.76) 0%, rgba(229, 181, 232, 0) 30%),
        radial-gradient(circle at 42% 26%, rgba(243, 204, 245, 0.88) 0%, rgba(243, 204, 245, 0) 34%),
        radial-gradient(circle at 82% 14%, rgba(222, 213, 255, 0.76) 0%, rgba(222, 213, 255, 0) 36%),
        radial-gradient(circle at 74% 80%, rgba(198, 223, 255, 0.54) 0%, rgba(198, 223, 255, 0) 28%),
        linear-gradient(145deg, #efc5ef 0%, #eabeea 34%, #ddd2fb 68%, #d3e2fb 100%);
    }

    .services-preview-legacy-card-adoption {
      background:
        radial-gradient(circle at 14% 20%, rgba(166, 198, 244, 0.76) 0%, rgba(166, 198, 244, 0) 30%),
        radial-gradient(circle at 42% 24%, rgba(191, 210, 250, 0.86) 0%, rgba(191, 210, 250, 0) 34%),
        radial-gradient(circle at 84% 14%, rgba(221, 230, 255, 0.78) 0%, rgba(221, 230, 255, 0) 36%),
        radial-gradient(circle at 72% 82%, rgba(192, 229, 240, 0.54) 0%, rgba(192, 229, 240, 0) 28%),
        linear-gradient(145deg, #cad7f6 0%, #bfd1f5 36%, #d5d9fb 68%, #d2eaf2 100%);
    }

    .services-preview-legacy-visual {
      position: absolute;
      inset: 0 0 auto;
      height: 280px;
      overflow: hidden;
    }

    .services-preview-legacy-visual::before {
      content: '';
      position: absolute;
      inset: 0;
      background:
        radial-gradient(circle at 50% 50%, rgba(255, 255, 255, 0.1) 0%, rgba(255,255,255,0) 42%);
    }

    .services-preview-legacy-icon {
      position: absolute;
      inset: 0;
      display: grid;
      place-items: center;
      color: rgba(25, 52, 91, 0.78);
    }

    .services-preview-legacy-icon svg {
      width: 74px;
      height: 74px;
      position: relative;
      z-index: 2;
    }

    .services-preview-legacy-diagram {
      position: absolute;
      inset: auto 24px 18px;
      display: flex;
      gap: 8px;
      justify-content: center;
      flex-wrap: wrap;
      z-index: 1;
    }

    .services-preview-legacy-diagram span {
      display: inline-flex;
      align-items: center;
      min-height: 28px;
      padding: 0 12px;
      border-radius: 999px;
      background: rgba(255, 255, 255, 0.52);
      color: rgba(25, 36, 56, 0.82);
      font-size: 0.78rem;
      font-weight: 600;
      letter-spacing: -0.01em;
    }

    .services-preview-legacy-diagram-build span {
      background: rgba(255, 255, 255, 0.46);
    }

    .services-preview-legacy-diagram-roi span:last-child {
      background: rgba(17, 19, 29, 0.86);
      color: #ffffff;
    }

    .services-preview-legacy-copy {
      display: flex;
      flex-direction: column;
      min-height: 100%;
      padding: 308px 30px 0;
    }

    .services-preview-legacy-card h3 {
      font-size: clamp(2rem, 2.5vw, 2.7rem);
      font-weight: 500;
      letter-spacing: -0.055em;
      line-height: 0.95;
      color: rgba(34, 27, 39, 0.96);
      margin-bottom: 18px;
    }

    .services-preview-legacy-eyebrow {
      max-width: none;
      font-size: 0.92rem;
      font-weight: 700;
      text-transform: uppercase;
      letter-spacing: 0.08em;
      color: rgba(33, 47, 72, 0.66);
      margin-bottom: 14px;
    }

    .services-preview-legacy-description {
      font-size: 1rem;
      line-height: 1.65;
      color: rgba(34, 45, 63, 0.88);
      margin-bottom: 0;
    }

    .services-preview-legacy-copy ul {
      list-style: none;
      padding: 0;
      margin: 0;
      margin-top: auto;
      padding-top: 24px;
      display: grid;
      gap: 10px;
    }

    .services-preview-legacy-copy li {
      position: relative;
      padding-left: 18px;
      font-size: 0.95rem;
      line-height: 1.35;
      color: rgba(36, 53, 82, 0.8);
    }

    .services-preview-legacy-copy li::before {
      content: '';
      position: absolute;
      left: 0;
      top: 0.58em;
      width: 6px;
      height: 6px;
      border-radius: 999px;
      background: rgba(58, 110, 204, 0.46);
      transform: translateY(-50%);
    }

    .services-preview-legacy-link {
      display: inline-flex;
      align-items: center;
      gap: 9px;
      margin-top: 28px;
      min-height: 48px;
      padding: 14px 22px;
      border-radius: 999px;
      background: rgba(36, 53, 82, 0.12);
      backdrop-filter: blur(12px) saturate(1.2);
      -webkit-backdrop-filter: blur(12px) saturate(1.2);
      border: 1px solid rgba(36, 53, 82, 0.15);
      color: #1a2533;
      font-size: 0.98rem;
      font-weight: 600;
      line-height: 1;
      text-decoration: none;
      opacity: 0;
      transform: translateY(10px);
      pointer-events: none;
      transition:
        opacity 180ms ease,
        transform 180ms ease,
        background 180ms ease,
        border-color 180ms ease;
    }

    .services-preview-legacy-card:hover .services-preview-legacy-link,
    .services-preview-legacy-card:focus-within .services-preview-legacy-link {
      opacity: 1;
      transform: translateY(0);
      pointer-events: auto;
    }

    .services-preview-legacy-link:hover {
      background: rgba(36, 53, 82, 0.18);
      border-color: rgba(36, 53, 82, 0.22);
    }

    .services-preview-legacy-link svg {
      width: 14px;
      height: 14px;
    }

    .services-preview-feature-grid-shell {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 38px;
      align-items: start;
    }

    .services-preview-feature-card {
      position: relative;
      display: flex;
      flex-direction: column;
      gap: 20px;
      color: inherit;
      text-decoration: none;
      padding: 10px 10px 22px;
      border-radius: 18px;
      overflow: hidden;
      --icon-ink: #132c54;
      --icon-accent: #2f6ab1;
      --icon-soft: rgba(59, 125, 219, 0.18);
      --icon-glow: rgba(91, 163, 217, 0.28);
      --icon-glow-strong: rgba(59, 125, 219, 0.22);
      transition:
        background 0.24s ease,
        box-shadow 0.24s ease,
        border-color 0.24s ease;
    }

    .services-preview-feature-visual {
      position: relative;
      min-height: 348px;
      overflow: hidden;
      border-radius: 8px;
      isolation: isolate;
      box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.38),
        0 14px 28px rgba(19, 44, 84, 0.07);
      transition:
        transform 0.24s ease,
        box-shadow 0.24s ease,
        filter 0.24s ease;
    }

    .services-preview-feature-copy {
      padding: 0 4px;
      min-width: 0;
    }

    .services-preview-feature-card-focus .services-preview-feature-visual {
      background:
        radial-gradient(circle at 10% 14%, rgba(59, 125, 219, 0.3) 0%, rgba(59, 125, 219, 0) 32%),
        radial-gradient(circle at 42% 18%, rgba(123, 188, 241, 0.28) 0%, rgba(123, 188, 241, 0) 32%),
        radial-gradient(circle at 88% 10%, rgba(206, 226, 255, 0.82) 0%, rgba(206, 226, 255, 0) 38%),
        radial-gradient(circle at 16% 90%, rgba(191, 215, 255, 0.3) 0%, rgba(191, 215, 255, 0) 28%),
        linear-gradient(145deg, #eef5ff 0%, #dbeaff 38%, #c3dbf8 72%, #d8e7ff 100%);
    }

    .services-preview-feature-card-focus {
      --icon-accent: #2f6ab1;
      --icon-soft: rgba(59, 125, 219, 0.2);
      --icon-glow: rgba(91, 163, 217, 0.3);
      --icon-glow-strong: rgba(47, 106, 177, 0.24);
    }

    .services-preview-feature-card-build .services-preview-feature-visual {
      background:
        radial-gradient(circle at 12% 16%, rgba(59, 125, 219, 0.28) 0%, rgba(59, 125, 219, 0) 32%),
        radial-gradient(circle at 46% 18%, rgba(123, 188, 241, 0.3) 0%, rgba(123, 188, 241, 0) 32%),
        radial-gradient(circle at 88% 12%, rgba(206, 226, 255, 0.84) 0%, rgba(206, 226, 255, 0) 38%),
        radial-gradient(circle at 22% 86%, rgba(191, 215, 255, 0.28) 0%, rgba(191, 215, 255, 0) 28%),
        linear-gradient(145deg, #edf5ff 0%, #d8e9ff 38%, #bfd9f8 72%, #d5e6ff 100%);
    }

    .services-preview-feature-card-build {
      --icon-accent: #3b7ddb;
      --icon-soft: rgba(74, 138, 212, 0.18);
      --icon-glow: rgba(74, 138, 212, 0.28);
      --icon-glow-strong: rgba(59, 125, 219, 0.24);
    }

    .services-preview-feature-card-use .services-preview-feature-visual {
      background:
        radial-gradient(circle at 10% 16%, rgba(59, 125, 219, 0.26) 0%, rgba(59, 125, 219, 0) 32%),
        radial-gradient(circle at 40% 18%, rgba(123, 188, 241, 0.26) 0%, rgba(123, 188, 241, 0) 32%),
        radial-gradient(circle at 86% 12%, rgba(206, 226, 255, 0.84) 0%, rgba(206, 226, 255, 0) 38%),
        radial-gradient(circle at 20% 88%, rgba(191, 215, 255, 0.3) 0%, rgba(191, 215, 255, 0) 28%),
        linear-gradient(145deg, #eef5ff 0%, #d9eaff 38%, #c1daf8 72%, #d7e7ff 100%);
    }

    .services-preview-feature-card-use {
      --icon-accent: #2d6199;
      --icon-soft: rgba(45, 97, 153, 0.18);
      --icon-glow: rgba(91, 163, 217, 0.28);
      --icon-glow-strong: rgba(45, 97, 153, 0.22);
    }

    .services-preview-feature-visual::before {
      content: '';
      position: absolute;
      left: 50%;
      top: 50%;
      width: 190px;
      height: 190px;
      z-index: 0;
      border-radius: 999px;
      background: radial-gradient(circle, rgba(255, 255, 255, 0.56) 0%, rgba(255, 255, 255, 0) 66%);
      opacity: 0.8;
      transform: translate(-50%, -50%);
      pointer-events: none;
      transition:
        opacity 0.24s ease,
        transform 0.24s ease;
    }

    .services-preview-feature-visual::after {
      content: '';
      position: absolute;
      left: 50%;
      top: 50%;
      width: 170px;
      height: 170px;
      z-index: 0;
      border-radius: 999px;
      background: radial-gradient(circle, var(--icon-glow) 0%, rgba(91, 163, 217, 0) 68%);
      filter: blur(10px);
      opacity: 0.76;
      transform: translate(-50%, -50%);
      pointer-events: none;
      transition:
        opacity 0.24s ease,
        transform 0.24s ease,
        filter 0.24s ease;
    }

    .services-preview-feature-grid,
    .services-preview-feature-diagonals {
      position: absolute;
      inset: 0;
    }

    .services-preview-feature-grid {
      display: none;
    }

    .services-preview-feature-diagonals::before,
    .services-preview-feature-diagonals::after {
      content: '';
      position: absolute;
      left: 50%;
      top: 50%;
      z-index: 1;
      width: 154px;
      height: 154px;
      border-radius: 999px;
      border: 1px solid rgba(255, 255, 255, 0.42);
      opacity: 0;
      transform: translate(-50%, -50%) scale(0.86);
      pointer-events: none;
      transition:
        opacity 0.24s ease,
        transform 0.24s ease,
        border-color 0.24s ease;
    }

    .services-preview-feature-diagonals::after {
      width: 190px;
      height: 190px;
      border-color: rgba(47, 106, 177, 0.12);
      transition-duration: 0.3s;
    }

    .services-preview-feature-icon {
      position: absolute;
      inset: 0;
      display: grid;
      place-items: center;
      z-index: 2;
      color: var(--icon-ink);
      transition: transform 0.2s ease;
    }

    .services-preview-feature-icon::before {
      content: '';
      position: absolute;
      width: 136px;
      height: 136px;
      border-radius: 999px;
      background:
        linear-gradient(145deg, rgba(255, 255, 255, 0.68), rgba(255, 255, 255, 0.22)),
        radial-gradient(circle at 28% 20%, rgba(255, 255, 255, 0.86), rgba(255, 255, 255, 0) 54%);
      border: 1px solid rgba(255, 255, 255, 0.5);
      box-shadow:
        0 16px 30px rgba(19, 44, 84, 0.1),
        inset 0 1px 0 rgba(255, 255, 255, 0.76);
      backdrop-filter: blur(18px) saturate(1.15);
      -webkit-backdrop-filter: blur(18px) saturate(1.15);
      transition:
        box-shadow 0.24s ease,
        transform 0.24s ease,
        border-color 0.24s ease,
        background 0.24s ease;
    }

    .services-preview-feature-icon::after {
      content: '';
      position: absolute;
      width: 86px;
      height: 86px;
      border-radius: 999px;
      background: var(--icon-soft);
      filter: blur(18px);
      transform: translate(14px, 14px);
      transition:
        opacity 0.24s ease,
        transform 0.24s ease,
        filter 0.24s ease;
    }

    .services-preview-feature-icon svg {
      width: 68px;
      height: 68px;
      position: relative;
      z-index: 1;
      overflow: visible;
      stroke: currentColor;
      stroke-width: 1.85;
      stroke-linecap: round;
      stroke-linejoin: round;
    }

    .services-preview-feature-icon svg * {
      vector-effect: non-scaling-stroke;
    }

    .services-preview-icon-accent {
      fill: none;
      stroke: var(--icon-accent);
      stroke-width: 2.1;
      stroke-linecap: round;
      stroke-linejoin: round;
    }

    .services-preview-icon-core {
      fill: var(--icon-accent);
      stroke: none;
    }

    .services-preview-feature-card.micro-spotlight::after {
      z-index: 0;
      border-radius: inherit;
      background:
        radial-gradient(
          circle at var(--micro-x) var(--micro-y),
          rgba(255, 255, 255, 0.32) 0%,
          rgba(91, 163, 217, 0.1) 27%,
          rgba(91, 163, 217, 0.045) 48%,
          rgba(91, 163, 217, 0) 74%
        );
    }

    .services-preview-feature-card.is-micro-hovering,
    .services-preview-feature-card:hover,
    .services-preview-feature-card:focus-within {
      background: rgba(255, 255, 255, 0.07);
      box-shadow:
        0 8px 18px rgba(19, 44, 84, 0.035),
        inset 0 1px 0 rgba(255, 255, 255, 0.16);
    }

    .services-preview-feature-card.is-micro-hovering.micro-spotlight::after,
    .services-preview-feature-card:hover.micro-spotlight::after,
    .services-preview-feature-card:focus-within.micro-spotlight::after {
      opacity: 1;
    }

    .services-preview-feature-card.is-micro-hovering .services-preview-feature-visual,
    .services-preview-feature-card:hover .services-preview-feature-visual {
      transform: translateY(-1px);
      box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.28),
        0 8px 16px rgba(19, 44, 84, 0.045);
    }

    .services-preview-feature-card.is-micro-hovering .services-preview-feature-visual::before {
      opacity: 0.7;
      transform: translate(-50%, -50%) scale(1.01);
    }

    .services-preview-feature-card.is-micro-hovering .services-preview-feature-visual::after {
      opacity: 0.5;
      filter: blur(11px);
      transform: translate(-50%, -50%) scale(1.04);
    }

    .services-preview-feature-card.is-micro-hovering .services-preview-feature-diagonals::before,
    .services-preview-feature-card.is-micro-hovering .services-preview-feature-diagonals::after {
      opacity: 0.14;
      transform: translate(-50%, -50%) scale(1);
    }

    .services-preview-feature-card.is-micro-hovering .services-preview-feature-diagonals::after {
      transform: translate(-50%, -50%) scale(1.04);
    }

    .services-preview-feature-card.is-micro-hovering .services-preview-feature-icon,
    .services-preview-feature-card:hover .services-preview-feature-icon {
      transform: translateY(-1px);
    }

    .services-preview-feature-card.is-micro-hovering .services-preview-feature-icon::before {
      border-color: rgba(255, 255, 255, 0.42);
      box-shadow:
        0 10px 20px rgba(19, 44, 84, 0.07),
        0 0 16px var(--icon-glow-strong),
        inset 0 1px 0 rgba(255, 255, 255, 0.6);
      transform: scale(1.005);
    }

    .services-preview-feature-card.is-micro-hovering .services-preview-feature-icon::after {
      opacity: 0.5;
      filter: blur(18px);
      transform: translate(14px, 15px) scale(1.02);
    }

    .services-preview-feature-copy h3 {
      font-size: clamp(1.85rem, 2vw, 2.35rem);
      font-weight: 500;
      letter-spacing: -0.05em;
      line-height: 1.02;
      color: #10131d;
      margin-bottom: 18px;
    }

    .services-preview-feature-copy p {
      font-size: 1.04rem;
      line-height: 1.72;
      color: #232933;
      margin-bottom: 24px;
      max-width: 58ch;
    }

    .services-preview-feature-copy ul {
      list-style: none;
      display: grid;
      gap: 0;
      width: 100%;
      padding: 0;
      margin: 0;
    }

    .services-preview-feature-copy li {
      padding: 12px 0;
      border-top: 1px solid rgba(17, 19, 29, 0.1);
      font-size: 1rem;
      line-height: 1.5;
      color: #4a4f59;
    }

    .services-preview-feature-link {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      gap: 8px;
      margin-top: 28px;
      text-decoration: none;
      color: #171717;
      font-size: 0.92rem;
      font-weight: 600;
      letter-spacing: -0.01em;
      min-height: 42px;
      padding: 0 18px;
      border-radius: 999px;
      background: #f2f4f8;
      border: 1px solid rgba(17, 24, 39, 0.12);
      box-shadow: 0 2px 8px rgba(17, 24, 39, 0.04);
      transition: background 0.18s ease, border-color 0.18s ease, transform 0.18s ease, box-shadow 0.18s ease;
    }

    .services-preview-feature-link-icon {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      width: 14px;
      height: 14px;
      border: 0;
      transition: transform 180ms ease;
    }

    .services-preview-feature-link:hover {
      background: #eef1f6;
      border-color: rgba(17, 24, 39, 0.16);
      box-shadow: 0 6px 18px rgba(17, 24, 39, 0.08);
      transform: translateY(-1px);
    }

    .services-preview-feature-link:hover .services-preview-feature-link-icon {
      transform: translateX(3px);
    }

    .services-preview-feature-link-icon svg {
      width: 14px;
      height: 14px;
    }

    @media (max-width: 1180px) {
      .services-preview-legacy-grid,
      .services-preview-feature-grid-shell {
        grid-template-columns: 1fr;
        gap: 34px;
      }
    }

    @media (max-width: 768px) {
      .services-preview {
        margin-top: 72px;
        padding: 0 16px;
      }

      .services-preview-heading {
        margin-bottom: 22px;
      }

      .services-preview-legacy {
        margin: 34px 0 42px;
      }

      .services-preview-legacy-grid,
      .services-preview-feature-grid-shell {
        gap: 28px;
      }

      .services-preview-legacy-card {
        min-height: 520px;
      }

      .services-preview-legacy-visual {
        height: 220px;
      }

      .services-preview-legacy-copy {
        padding: 246px 24px 0;
      }

      .services-preview-legacy-link {
        opacity: 1;
        transform: none;
        pointer-events: auto;
      }

      .services-preview-feature-visual {
        min-height: 240px;
      }

      .services-preview-feature-icon svg {
        width: 60px;
        height: 60px;
      }

      .services-preview-feature-icon::before {
        width: 116px;
        height: 116px;
      }

      .services-preview-feature-icon::after {
        width: 72px;
        height: 72px;
      }

      .services-preview-feature-copy h3 {
        font-size: 1.7rem;
      }

      .services-preview-feature-copy p,
      .services-preview-feature-copy li {
        font-size: 0.98rem;
      }
    }

    /* ── Testimonials ── */
    .testimonials {
      position: relative;
      overflow: hidden;
      margin: 120px 24px 0;
      padding: 80px 0;
      border-radius: 28px;
      background:
        radial-gradient(circle at 10% 14%, rgba(59, 125, 219, 0.3) 0%, rgba(59, 125, 219, 0) 32%),
        radial-gradient(circle at 42% 18%, rgba(123, 188, 241, 0.25) 0%, rgba(123, 188, 241, 0) 32%),
        radial-gradient(circle at 88% 10%, rgba(206, 226, 255, 0.5) 0%, rgba(206, 226, 255, 0) 38%),
        radial-gradient(circle at 16% 90%, rgba(191, 215, 255, 0.2) 0%, rgba(191, 215, 255, 0) 28%),
        linear-gradient(145deg, #f4f8ff 0%, #e8f0ff 38%, #d4e5fa 72%, #e4edff 100%);
      isolation: isolate;
      box-shadow: 0 4px 24px rgba(26, 37, 51, 0.04);
    }

    .testimonials-bg {
      position: absolute;
      inset: 0;
      overflow: hidden;
      z-index: 0;
      background:
        radial-gradient(ellipse 72% 54% at 24% 28%, rgba(59, 125, 219, 0.3) 0%, transparent 60%),
        radial-gradient(ellipse 64% 62% at 72% 24%, rgba(123, 188, 241, 0.28) 0%, transparent 56%),
        radial-gradient(ellipse 54% 42% at 54% 72%, rgba(184, 212, 249, 0.24) 0%, transparent 48%);
    }

    .testimonials-blob {
      position: absolute;
      border-radius: 50%;
      filter: blur(80px);
    }

    .testimonials-blob-1 {
      width: 50%;
      height: 60%;
      top: -10%;
      left: 10%;
      background: radial-gradient(circle, rgba(59, 125, 219, 0.32) 0%, transparent 70%);
    }

    .testimonials-blob-2 {
      width: 45%;
      height: 55%;
      bottom: -10%;
      right: 10%;
      background: radial-gradient(circle, rgba(91, 163, 217, 0.28) 0%, transparent 70%);
    }

    .testimonials-content {
      position: relative;
      z-index: 1;
      text-align: center;
    }

    .testimonials-label {
      font-size: 13px;
      font-weight: 500;
      text-transform: uppercase;
      letter-spacing: 0.08em;
      color: #2f5ea8;
      margin-bottom: 12px;
    }

    .testimonials-content h2 {
      font-size: 36px;
      color: #1a2533;
      letter-spacing: -1px;
      margin-bottom: 48px;
    }

    .testimonials-carousel {
      display: flex;
      align-items: center;
      gap: 16px;
      max-width: 1280px;
      margin: 0 auto;
      padding: 0 24px;
    }

    .testimonial-dots {
      display: flex;
      align-items: center;
      justify-content: center;
      gap: 8px;
      margin-top: 20px;
    }

    .testimonial-dot {
      width: 8px;
      height: 8px;
      border-radius: 999px;
      border: 0;
      padding: 0;
      cursor: pointer;
      background: rgba(47, 106, 177, 0.28);
      transition: width 0.2s ease, background 0.2s ease, transform 0.2s ease;
    }

    .testimonial-dot.active,
    .testimonial-dot[aria-current="true"] {
      width: 24px;
      background: #2f6ab1;
    }

    .testimonial-dot:focus-visible {
      outline: 3px solid rgba(59, 125, 219, 0.35);
      outline-offset: 4px;
    }

    .testimonial-arrow {
      flex-shrink: 0;
      width: 44px;
      height: 44px;
      border-radius: 50%;
      border: none;
      background: rgba(255, 255, 255, 0.42);
      backdrop-filter: blur(12px);
      color: #1a2533;
      cursor: pointer;
      display: flex;
      align-items: center;
      justify-content: center;
      transition: background 0.2s ease;
      z-index: 2;
    }

    .testimonial-arrow:hover {
      background: rgba(255, 255, 255, 0.62);
    }

    .testimonial-arrow svg {
      width: 20px;
      height: 20px;
    }

    .testimonials-track-wrap {
      flex: 1;
      overflow: hidden;
      mask-image: linear-gradient(to right, transparent 0%, black 10%, black 90%, transparent 100%);
      -webkit-mask-image: linear-gradient(to right, transparent 0%, black 10%, black 90%, transparent 100%);
      cursor: grab;
      touch-action: pan-y;
    }

    .testimonials-track-wrap.is-dragging {
      cursor: grabbing;
    }

    .testimonials-track {
      display: flex;
      gap: 24px;
      transition: transform 0.5s cubic-bezier(0.4, 0, 0.2, 1);
      user-select: none;
      -webkit-user-select: none;
    }

    .testimonial-card {
      flex: 0 0 calc(50% - 12px);
      padding: 40px;
      min-height: 320px;
      display: flex;
      flex-direction: column;
      border-radius: 20px;
      background: rgba(255, 255, 255, 0.38);
      backdrop-filter: blur(24px) saturate(1.3);
      -webkit-backdrop-filter: blur(24px) saturate(1.3);
      border: 1px solid rgba(255, 255, 255, 0.52);
      text-align: left;
      transition: opacity 0.4s ease, transform 0.4s ease;
      opacity: 0.4;
      transform: scale(0.95);
    }

    .testimonial-card.active {
      opacity: 1;
      transform: scale(1);
    }

    .testimonial-header {
      display: flex;
      justify-content: space-between;
      align-items: flex-start;
      margin-bottom: 20px;
    }

    .testimonial-name {
      font-size: 15px;
      font-weight: 500;
      color: #1a2533;
    }

    .testimonial-role {
      font-size: 13px;
      color: rgba(36, 58, 92, 0.58);
      margin-top: 2px;
    }

    .testimonial-logo {
    height: 63px;
    width: 81px;
    object-fit: contain;
    opacity: 0.66;
    margin-top: -20px;
    }

    .testimonial-logo-fallback {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      min-height: 24px;
      padding: 0 10px;
      border-radius: 980px;
      border: 1px solid rgba(47, 106, 177, 0.18);
      color: rgba(36, 58, 92, 0.72);
      font-size: 11px;
      font-weight: 600;
      text-transform: uppercase;
      letter-spacing: 0.08em;
      white-space: nowrap;
    }

    .testimonial-quote {
      font-size: 16px;
      line-height: 1.7;
      color: rgba(26, 45, 71, 0.82);
      font-style: italic;
      margin: 0;
      flex: 1;
    }

    @media (max-width: 768px) {
      .testimonials {
        margin: 60px 16px 0;
        padding: 48px 0;
        border-radius: 20px;
      }

      .testimonials-content h2 {
        font-size: 26px;
        padding: 0 24px;
      }

      .testimonial-card {
        flex: 0 0 85%;
        padding: 34px 28px;
        min-height: 420px;
      }

      .testimonial-arrow {
        display: none;
      }
    }

    /* ── Approach ── */
    .approach {
      max-width: 1280px;
      margin: 80px auto 0;
      padding: 0 24px;
    }

    .approach-header {
      text-align: center;
      margin-bottom: 48px;
    }

    .approach-label {
      font-size: 13px;
      font-weight: 600;
      text-transform: uppercase;
      letter-spacing: 1.5px;
      color: #8c6d3f;
      margin-bottom: 12px;
    }

    .approach-header h2 {
      font-size: 36px;
      font-weight: 500;
      color: #1a2533;
      letter-spacing: -0.5px;
      margin-bottom: 12px;
    }

    .approach-sub {
      font-size: 16px;
      color: #5a6270;
      max-width: 520px;
      margin: 0 auto;
      line-height: 1.6;
    }

    .approach-steps {
      display: flex;
      border-radius: 24px;
      overflow: hidden;
      background: rgba(255, 255, 255, 0.35);
      backdrop-filter: blur(28px) saturate(1.3);
      -webkit-backdrop-filter: blur(28px) saturate(1.3);
      border: 1px solid rgba(255, 255, 255, 0.5);
      box-shadow:
        0 4px 24px rgba(0, 0, 0, 0.03),
        0 1px 0 rgba(255, 255, 255, 0.6) inset;
      min-height: 520px;
    }

    .approach-card {
      display: flex;
      flex-direction: column;
      position: relative;
      flex: 1;
      cursor: pointer;
      overflow: hidden;
      transition: flex 0.5s cubic-bezier(0.4, 0, 0.2, 1);
    }

    .approach-card:not(.active) {
      background: rgba(0, 0, 0, 0.03);
    }

    .approach-card:not(.active):hover {
      background: rgba(0, 0, 0, 0.05);
    }

    .approach-card.active {
      flex: 3;
      cursor: default;
    }

    .approach-card + .approach-card {
      border-left: 1px solid rgba(255, 255, 255, 0.45);
    }

    .approach-card-content {
      padding: 32px 28px;
      flex: 1;
    }

    .approach-card-content h3 {
      font-size: 20px;
      font-weight: 600;
      color: #1a2533;
      margin-bottom: 16px;
      letter-spacing: -0.3px;
      white-space: nowrap;
    }

    .approach-card-content p {
      font-size: 15px;
      color: #5a6270;
      line-height: 1.7;
      opacity: 0;
      max-height: 0;
      overflow: hidden;
      transition: opacity 0.3s ease 0s, max-height 0.4s ease;
    }

    .approach-card.active .approach-card-content p {
      opacity: 1;
      max-height: 300px;
      transition: opacity 0.4s ease 0.2s, max-height 0.5s ease;
    }

    .approach-card-visual {
      position: relative;
      display: flex;
      align-items: flex-end;
      justify-content: flex-start;
      padding: 20px 28px 28px;
      margin-top: auto;
      opacity: 0.28;
      transition: opacity 0.3s ease 0s;
    }

    .approach-card.active .approach-card-visual {
      opacity: 1;
      transition: opacity 0.4s ease 0.25s;
    }

    .approach-illustration {
      width: 72%;
      max-width: 260px;
      height: auto;
      color: #3b7ddb;
    }

    .approach-number {
      position: absolute;
      bottom: -8px;
      right: 16px;
      font-size: 100px;
      font-weight: 700;
      color: rgba(59, 125, 219, 0.07);
      line-height: 1;
      pointer-events: none;
      user-select: none;
      transition: opacity 0.3s ease;
    }

    .approach-card:not(.active) .approach-number {
      opacity: 1;
    }

    @media (max-width: 768px) {
      .approach-steps {
        flex-direction: column;
        min-height: auto;
      }

      .approach-card {
        flex: none !important;
      }

      .approach-card:not(.active) {
        min-height: 64px;
      }

      .approach-card.active {
        min-height: 360px;
      }

      .approach-card + .approach-card {
        border-left: none;
        border-top: 1px solid rgba(255, 255, 255, 0.45);
      }

      .approach-card-content h3 {
        white-space: normal;
      }

      .approach-card:not(.active) .approach-card-content {
        padding: 20px 24px;
      }

      .approach-header h2 {
        font-size: 28px;
      }
    }

    /* ── Footer ── */
    .footer-wrap {
      margin: 80px 0 0;
      padding: 0;
    }

    footer.site-footer {
      position: relative;
      background:
        linear-gradient(180deg, rgba(252, 253, 255, 0.6) 0%, rgba(240, 245, 251, 0.5) 100%);
      backdrop-filter: blur(28px) saturate(1.02);
      -webkit-backdrop-filter: blur(28px) saturate(1.02);
      box-shadow:
        0 12px 32px rgba(24, 44, 72, 0.04),
        inset 0 1px 0 rgba(255, 255, 255, 0.34);
      border-radius: 0;
      padding: 38px 45px 32px;
      color: #1a2533;
    }

    .footer-grid {
      display: grid;
      grid-template-columns: minmax(150px, 1fr) repeat(4, minmax(120px, max-content));
      justify-content: space-between;
      gap: 32px 40px;
      align-items: start;
      max-width: 1280px;
      margin: 0 auto;
    }

    .footer-logo a {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      text-decoration: none;
      isolation: isolate;
    }

    .footer-mark {
      display: inline-flex;
      position: relative;
      align-items: center;
      justify-content: center;
      width: 32px;
      height: 32px;
      perspective: 400px;
      transition: transform 0.2s ease;
    }

    .footer-mark::before {
      content: "";
      position: absolute;
      inset: -7px;
      border-radius: 50%;
      background: radial-gradient(circle, rgba(91, 163, 217, 0.24) 0%, rgba(91, 163, 217, 0) 68%);
      opacity: 0;
      transform: scale(0.72);
      transition: opacity 0.2s ease, transform 0.2s ease;
      z-index: -1;
    }

    .footer-mark-svg {
      width: 100%;
      height: 100%;
      transform-origin: 50% 50%;
      transition: transform 0.2s ease, filter 0.2s ease;
    }

    .footer-logo a:hover .footer-mark {
      transform: translateY(-1px) scale(1.04);
    }

    .footer-logo a:hover .footer-mark::before {
      opacity: 1;
      transform: scale(1);
    }

    .footer-logo a:hover .footer-mark-svg {
      transform: rotate(18deg);
      filter: drop-shadow(0 8px 14px rgba(59, 125, 219, 0.22));
    }

    .footer-wordmark {
      height: 18px;
      width: auto;
      object-fit: contain;
      transition: transform 0.2s ease, filter 0.2s ease;
    }

    .footer-logo a:hover .footer-wordmark {
      transform: translateX(2px);
      filter: drop-shadow(0 6px 16px rgba(26, 37, 51, 0.08));
    }

    @media (prefers-reduced-motion: reduce) {
      .footer-logo a:hover .footer-mark,
      .footer-logo a:hover .footer-mark-svg,
      .footer-logo a:hover .footer-wordmark {
        transform: none;
      }
    }

    .footer-col h4 {
      font-size: 12px;
      font-weight: var(--font-ui-weight);
      text-transform: uppercase;
      letter-spacing: var(--tracking-label);
      margin-bottom: 14px;
      color: rgba(26, 37, 51, 0.52);
    }

    .footer-col ul {
      list-style: none;
      display: flex;
      flex-direction: column;
      gap: 8px;
    }

    .footer-col a,
    .footer-col li {
      color: #1a2533;
      text-decoration: none;
      font-size: 13.5px;
      font-weight: var(--font-ui-weight);
      letter-spacing: var(--tracking-ui-tight);
      transition: opacity 0.2s ease;
    }

    .footer-col a:hover {
      opacity: 0.75;
    }

    .footer-contact .contact-name {
      font-weight: var(--font-ui-weight);
      font-size: 13.5px;
      letter-spacing: var(--tracking-ui-tight);
      color: #1a2533;
      margin-bottom: 10px;
    }

    .contact-icons {
      display: flex;
      gap: 6px;
    }

    .contact-icon {
      position: relative;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      width: 26px;
      height: 26px;
      border-radius: 7px;
      background: rgba(26, 37, 51, 0.06);
      transition: background 0.2s ease;
      text-decoration: none;
    }

    .contact-icon:hover {
      background: rgba(26, 37, 51, 0.1);
    }

    .contact-icon svg {
      width: 13px;
      height: 13px;
    }

    /* Stroke-based icons (email, phone) */
    .contact-icon svg[fill="none"] {
      color: #1a2533;
    }

    /* Fill-based icons (LinkedIn) */
    .contact-icon svg:not([fill="none"]) {
      fill: #1a2533;
    }

    .contact-tooltip {
      position: absolute;
      bottom: calc(100% + 8px);
      left: 50%;
      transform: translateX(-50%);
      white-space: nowrap;
      font-size: 11.5px;
      color: #1a2533;
      background: #fff;
      padding: 5px 10px;
      border-radius: 7px;
      box-shadow: 0 4px 16px rgba(0, 0, 0, 0.15);
      opacity: 0;
      visibility: hidden;
      transition: opacity 0.15s ease, visibility 0.15s ease;
      pointer-events: none;
    }

    .contact-icon:hover .contact-tooltip {
      opacity: 1;
      visibility: visible;
    }

    .footer-bottom {
      margin-top: 28px;
      padding-top: 18px;
      border-top: 1px solid rgba(79, 101, 132, 0.12);
      font-family: inherit;
      font-size: 12px;
      font-weight: 400;
      letter-spacing: -0.01em;
      text-transform: none;
      color: rgba(26, 37, 51, 0.5);
      max-width: 1280px;
      margin-left: auto;
      margin-right: auto;
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 16px;
      flex-wrap: wrap;
    }

    .footer-privacy-link {
      color: inherit;
      text-decoration: none;
      opacity: 0.85;
      transition: opacity 0.15s ease;
    }

    .footer-privacy-link:hover {
      opacity: 1;
    }

    @media (max-width: 1080px) {
      .footer-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
      }
      .footer-logo {
        grid-column: 1 / -1;
      }
    }

    /* ── Cookie Consent Banner ── */
    .cookie-banner {
      position: fixed;
      bottom: 24px;
      left: 50%;
      transform: translateX(-50%);
      z-index: 9000;
      width: calc(100% - 48px);
      max-width: 680px;
      background: #fff;
      border: 1px solid rgba(0, 0, 0, 0.08);
      border-radius: 16px;
      box-shadow: 0 8px 40px rgba(0, 0, 0, 0.12);
      padding: 18px 22px;
      animation: cookie-slide-in 0.3s ease;
    }

    @keyframes cookie-slide-in {
      from { opacity: 0; transform: translateX(-50%) translateY(12px); }
      to   { opacity: 1; transform: translateX(-50%) translateY(0); }
    }

    .cookie-banner-inner {
      display: flex;
      align-items: center;
      gap: 20px;
      flex-wrap: wrap;
    }

    .cookie-banner-text {
      flex: 1;
      min-width: 220px;
      font-size: 13.5px;
      line-height: 1.55;
      color: #5a6270;
      margin: 0;
    }

    .cookie-banner-link {
      color: #1a2533;
      text-decoration: underline;
      text-underline-offset: 2px;
    }

    .cookie-banner-actions {
      display: flex;
      gap: 8px;
      flex-shrink: 0;
    }

    .cookie-banner-accept,
    .cookie-banner-decline {
      padding: 8px 18px;
      border-radius: 980px;
      font-size: 13.5px;
      font-weight: 500;
      cursor: pointer;
      border: none;
      white-space: nowrap;
      font-family: inherit;
      transition: all 0.15s ease;
    }

    .cookie-banner-accept {
      background: #0e0f19;
      color: #fff;
    }

    .cookie-banner-accept:hover {
      background: #1a1b2e;
    }

    .cookie-banner-decline {
      background: transparent;
      color: #5a6270;
      border: 1px solid rgba(0, 0, 0, 0.14);
    }

    .cookie-banner-decline:hover {
      background: rgba(0, 0, 0, 0.04);
    }

    @media (max-width: 600px) {
      .cookie-banner {
        bottom: 0;
        left: 0;
        right: 0;
        width: 100%;
        transform: none;
        border-radius: 16px 16px 0 0;
        max-width: none;
        animation: cookie-slide-in-mobile 0.3s ease;
      }

      @keyframes cookie-slide-in-mobile {
        from { opacity: 0; transform: translateY(12px); }
        to   { opacity: 1; transform: translateY(0); }
      }

      .cookie-banner-inner {
        flex-direction: column;
        align-items: flex-start;
        gap: 14px;
      }
    }

    @media (max-width: 768px) {
      footer.site-footer {
        padding: 30px 24px 24px;
      }
      .footer-grid {
        grid-template-columns: 1fr 1fr;
        gap: 24px;
      }
      .footer-logo {
        grid-column: 1 / -1;
      }
    }

    @media (max-width: 768px) {
      body.nav-open {
        overflow: hidden;
      }

      body.nav-open header {
        position: fixed;
        inset: 0;
        overflow-y: auto;
      }

      body.nav-open header::before {
        background:
          radial-gradient(circle at 18% 8%, rgba(91, 163, 217, 0.34) 0%, rgba(91, 163, 217, 0) 34%),
          radial-gradient(circle at 82% 18%, rgba(59, 125, 219, 0.2) 0%, rgba(59, 125, 219, 0) 36%),
          linear-gradient(180deg, rgba(239, 247, 255, 0.98) 0%, rgba(222, 238, 255, 0.97) 58%, rgba(244, 248, 253, 0.98) 100%);
        box-shadow: none;
      }

      body.nav-open header::after {
        opacity: 0;
      }

      header {
        padding: 10px 16px;
      }

      nav {
        display: grid;
        grid-template-columns: 1fr auto;
        grid-template-rows: auto minmax(0, 1fr) auto;
        padding: 8px 16px;
        height: auto;
        min-height: 56px;
        align-items: center;
        gap: 0;
      }

      .nav-logo {
        padding: 8px 0;
        grid-column: 1;
        grid-row: 1;
      }

      .nav-toggle {
        display: flex;
        position: relative;
        grid-column: 2;
        grid-row: 1;
        z-index: 3;
        width: 40px;
        height: 40px;
        align-items: center;
        justify-content: center;
        gap: 0;
        border-radius: 999px;
        transition: background 0.2s ease;
      }

      .nav-toggle span {
        position: absolute;
        transition: transform 0.2s ease, opacity 0.2s ease, background 0.2s ease;
      }

      .nav-toggle span:nth-child(1) {
        transform: translateY(-7px);
      }

      .nav-toggle span:nth-child(3) {
        transform: translateY(7px);
      }

      .mobile-menu-open .nav-toggle {
        background: rgba(255, 255, 255, 0.56);
        box-shadow: 0 8px 22px rgba(26, 37, 51, 0.08);
      }

      .mobile-menu-open .nav-toggle span:nth-child(1) {
        transform: rotate(45deg);
      }

      .mobile-menu-open .nav-toggle span:nth-child(2) {
        opacity: 0;
        transform: scaleX(0.2);
      }

      .mobile-menu-open .nav-toggle span:nth-child(3) {
        transform: rotate(-45deg);
      }

      .nav-center {
        display: none;
        grid-column: 1 / -1;
        grid-row: 2;
        align-self: center;
        width: 100%;
        flex-direction: column;
        gap: 10px;
        padding: 32px 0 24px;
        margin: 0;
      }

      .nav-center.open {
        display: flex;
      }

      .nav-center a,
      .nav-dropdown-toggle {
        width: 100%;
        text-align: center;
        justify-content: center;
        padding: 15px 20px;
        border-radius: 18px;
        font-size: 18px;
        line-height: 1.2;
        color: #1a2533;
        background: rgba(255, 255, 255, 0.42);
        border: 1px solid rgba(255, 255, 255, 0.56);
        box-shadow:
          0 8px 20px rgba(26, 37, 51, 0.045),
          inset 0 1px 0 rgba(255, 255, 255, 0.64);
        backdrop-filter: blur(18px) saturate(1.2);
        -webkit-backdrop-filter: blur(18px) saturate(1.2);
      }

      .nav-center a:hover,
      .nav-dropdown-toggle:hover,
      .nav-center a.active,
      .nav-dropdown-toggle.active {
        color: #2f6ab1;
        background: rgba(255, 255, 255, 0.58);
      }

      .nav-right {
        display: none;
        grid-column: 1 / -1;
        grid-row: 3;
        width: 100%;
        justify-content: center;
        align-items: center;
        gap: 12px;
        padding: 0 0 8px;
      }

      .nav-center.open ~ .nav-right {
        display: flex;
      }

      .nav-center.open ~ .nav-right .nav-cta {
        min-height: 44px;
        padding: 0 24px;
        box-shadow: 0 10px 24px rgba(19, 44, 84, 0.16);
      }

      .nav-dropdown-menu {
        position: static !important;
        transform: none !important;
        display: grid;
        gap: 8px;
        max-height: 0;
        margin: 0;
        padding: 0;
        overflow: hidden;
        opacity: 0;
        visibility: hidden;
        pointer-events: none;
        min-width: 0;
        border-radius: 0;
        border: none;
        box-shadow: none;
        background: transparent;
        backdrop-filter: none;
        -webkit-backdrop-filter: none;
        transition: max-height 0.24s ease, opacity 0.2s ease, margin 0.2s ease;
      }

      .nav-dropdown.open .nav-chevron {
        transform: rotate(180deg);
      }

      .nav-dropdown.open > .nav-dropdown-menu {
        max-height: 260px;
        margin-top: 8px;
        opacity: 1;
        visibility: visible;
        pointer-events: auto;
      }

      .nav-dropdown-menu a {
        text-align: center;
      }

      .nav-dropdown-menu a + a {
        border-top: none;
      }

      .nav-dropdown-item {
        width: 100%;
      }

      .nav-dropdown-item > .nav-dropdown-link {
        justify-content: space-between;
        text-align: left;
      }

      .nav-dropdown-item-has-children.open > .nav-dropdown-link .dropdown-submenu-chevron {
        transform: rotate(90deg);
      }

      .nav-submenu {
        position: static;
        transform: translateY(-4px);
        opacity: 0;
        visibility: visible;
        pointer-events: none;
        min-width: 0;
        max-width: none;
        max-height: 0;
        margin: 2px 0 8px;
        padding: 0 0 0 12px;
        border: none;
        border-radius: 0;
        background: transparent;
        box-shadow: none;
        backdrop-filter: none;
        -webkit-backdrop-filter: none;
        overflow: hidden;
        transition:
          max-height 0.3s cubic-bezier(0.22, 1, 0.36, 1),
          opacity 0.22s ease,
          transform 0.28s ease;
      }

      .nav-dropdown-item-has-children.open > .nav-submenu {
        max-height: 900px;
        opacity: 1;
        transform: translateY(0);
        pointer-events: auto;
      }

      .nav-submenu .nav-submenu-link {
        justify-content: flex-start;
        text-align: left;
        padding: 9px 12px;
      }

      .nav-submenu .nav-submenu-text {
        text-align: left;
      }

      .nav-submenu .nav-submenu-icon,
      .nav-submenu .nav-submenu-arrow {
        display: none;
      }

      .nav-submenu-desc {
        font-size: 12px;
      }

      /* Mobile menu: clean up dropdown items */
      .nav-dropdown-toggle {
        width: 100%;
        justify-content: center;
      }

      .nav-dropdown-toggle.active {
        color: #1a2533;
      }

      .nav-dropdown-toggle:hover {
        color: #1a2533;
      }

      .nav-chevron {
        width: 12px;
        height: 12px;
        opacity: 0.45;
      }

      .nav-dropdown-menu {
        padding: 0;
      }

      .nav-dropdown-menu a {
        justify-content: center;
        gap: 0;
        padding: 12px 16px;
        border-radius: 14px;
        background: rgba(255, 255, 255, 0.38);
      }

      .nav-dropdown-menu a:hover {
        background: rgba(255, 255, 255, 0.56);
      }

      .dropdown-icon,
      .dropdown-desc,
      .dropdown-arrow {
        display: none;
      }

      .dropdown-title {
        font-size: 14px;
        color: #5a6270;
      }
    }

    /* ── Page placeholder ── */
    .page-placeholder {
      max-width: 1280px;
      margin: 80px auto;
      padding: 0 24px;
      text-align: center;
      min-height: 40vh;
    }
    .page-placeholder h1 {
      font-size: 48px;
      font-weight: 500;
      letter-spacing: -1px;
      color: #1a2533;
      margin-bottom: 16px;
    }
    .page-placeholder p {
      font-size: 17px;
      color: #5a6270;
    }

    /* ── Careers ── */
    .careers-hero {
      max-width: 780px;
      margin: 80px auto 0;
      padding: 0 24px;
      text-align: center;
    }

    .careers-hero h1 {
      font-size: 48px;
      font-weight: 500;
      letter-spacing: -1.5px;
      line-height: 1.1;
      color: #1a2533;
      margin-bottom: 20px;
    }

    .careers-hero p {
      font-size: 17px;
      line-height: 1.7;
      color: #5a6270;
      max-width: 560px;
      margin: 0 auto 32px;
    }

    .careers-hero-cta {
      display: inline-block;
      text-decoration: none;
      font-size: 14px;
      font-weight: 500;
      color: #fff;
      padding: 11px 28px;
      border-radius: 980px;
      background: #0e0f19;
      box-shadow: 0 4px 14px rgba(0, 0, 0, 0.18);
      transition: box-shadow 0.22s ease,
                  transform 0.2s cubic-bezier(0.34, 1.56, 0.64, 1);
    }

    .careers-hero-cta:hover {
      transform: translateY(-2px);
      box-shadow: 0 8px 24px rgba(0, 0, 0, 0.26);
    }

    .careers-hero-cta:active {
      transform: scale(0.97);
      box-shadow: 0 2px 8px rgba(0, 0, 0, 0.14);
      transition-duration: 0.06s;
    }

    /* Label */
    .careers-label {
      font-size: 13px;
      font-weight: 600;
      text-transform: uppercase;
      letter-spacing: 0.08em;
      color: #8c6d3f;
      margin-bottom: 12px;
    }

    /* Mission */
    .careers-mission {
      max-width: 780px;
      margin: 80px auto 0;
      padding: 0 24px;
    }

    .careers-mission h2 {
      font-size: 32px;
      font-weight: 500;
      letter-spacing: -0.8px;
      line-height: 1.2;
      color: #1a2533;
      margin-bottom: 24px;
    }

    .careers-mission-body {
      font-size: 16px;
      line-height: 1.8;
      color: #5a6270;
    }

    /* Values */
    .careers-values {
      max-width: 1080px;
      margin: 80px auto 0;
      padding: 0 24px;
    }

    .careers-values h2 {
      font-size: 32px;
      font-weight: 500;
      letter-spacing: -0.8px;
      color: #1a2533;
      margin-bottom: 40px;
    }

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

    .value-card {
      background: #fff;
      border-radius: 20px;
      padding: 36px 32px;
      border: 1px solid rgba(0, 0, 0, 0.06);
    }

    .value-number {
      display: inline-block;
      font-size: 13px;
      font-weight: 600;
      color: #8c6d3f;
      margin-bottom: 20px;
      font-variant-numeric: tabular-nums;
    }

    .value-card h3 {
      font-size: 19px;
      font-weight: 500;
      color: #1a2533;
      margin-bottom: 12px;
      letter-spacing: -0.3px;
    }

    .value-card p {
      font-size: 14.5px;
      line-height: 1.7;
      color: #5a6270;
    }

    /* Open Roles */
    .careers-roles {
      max-width: 780px;
      margin: 80px auto 0;
      padding: 0 24px;
    }

    .careers-roles h2 {
      font-size: 32px;
      font-weight: 500;
      letter-spacing: -0.8px;
      color: #1a2533;
      margin-bottom: 32px;
    }

    .roles-list {
      display: flex;
      flex-direction: column;
      gap: 16px;
    }

    .role-card {
      display: flex;
      align-items: center;
      gap: 24px;
      text-decoration: none;
      background: #fff;
      border-radius: 20px;
      padding: 32px;
      border: 1px solid rgba(0, 0, 0, 0.06);
      transition: all 0.2s ease;
    }

    .role-card:hover {
      border-color: rgba(59, 125, 219, 0.25);
      box-shadow: 0 4px 20px rgba(59, 125, 219, 0.08);
    }

    .role-info {
      flex: 1;
    }

    .role-info h3 {
      font-size: 19px;
      font-weight: 500;
      color: #1a2533;
      margin-bottom: 8px;
      letter-spacing: -0.3px;
    }

    .role-info p {
      font-size: 14.5px;
      line-height: 1.7;
      color: #5a6270;
    }

    .role-meta {
      display: flex;
      gap: 8px;
      flex-shrink: 0;
      flex-wrap: wrap;
    }

    .role-tag {
      font-size: 12px;
      font-weight: 500;
      color: #5a6270;
      padding: 5px 14px;
      border-radius: 980px;
      background: #f2f4f8;
      white-space: nowrap;
    }

    .role-arrow {
      width: 20px;
      height: 20px;
      color: #3b7ddb;
      flex-shrink: 0;
      transition: transform 0.2s ease;
    }

    .role-card:hover .role-arrow {
      transform: translateX(3px);
    }

    /* Open application */
    .careers-open-application {
      margin-top: 40px;
      text-align: center;
      padding: 40px 24px;
      background: #fff;
      border-radius: 20px;
      border: 1px solid rgba(0, 0, 0, 0.06);
    }

    .careers-open-application p {
      font-size: 16px;
      color: #5a6270;
      margin-bottom: 20px;
    }

    .careers-open-cta {
      display: inline-block;
      text-decoration: none;
      font-size: 14px;
      font-weight: 500;
      color: #1a2533;
      padding: 10px 24px;
      border-radius: 980px;
      border: 1.5px solid #1a2533;
      transition: background 0.18s ease, border-color 0.18s ease,
                  color 0.18s ease, box-shadow 0.22s ease,
                  transform 0.2s cubic-bezier(0.34, 1.56, 0.64, 1);
    }

    .careers-open-cta:hover {
      background: #0e0f19;
      border-color: #0e0f19;
      color: #fff;
      transform: translateY(-2px);
      box-shadow: 0 6px 18px rgba(0, 0, 0, 0.2);
    }

    .careers-open-cta:active {
      transform: scale(0.97);
      box-shadow: none;
      transition-duration: 0.06s;
    }

    /* Careers responsive */
    @media (max-width: 768px) {
      .careers-hero h1 {
        font-size: 32px;
      }

      .careers-mission h2,
      .careers-values h2,
      .careers-roles h2 {
        font-size: 26px;
      }

      .values-grid {
        grid-template-columns: 1fr;
      }

      .role-card {
        flex-direction: column;
        align-items: flex-start;
      }

      .role-arrow {
        align-self: flex-end;
      }
    }

    /* ── Portfolio / Services ── */
    .portfolio {
      max-width: 1180px;
      margin: 80px auto 0;
      padding: 0 24px;
    }

    .portfolio-header {
      text-align: center;
      margin-bottom: 56px;
    }

    .portfolio-label {
      font-size: 13px;
      font-weight: 600;
      text-transform: uppercase;
      letter-spacing: 0.08em;
      color: #3b7ddb;
      margin-bottom: 12px;
    }

    .portfolio-header h1 {
      font-size: 48px;
      font-weight: 500;
      letter-spacing: -1.5px;
      color: #1a2533;
      margin-bottom: 12px;
    }

    .portfolio-sub {
      font-size: 17px;
      color: #5a6270;
    }

    .services-category-grid {
      display: grid;
      grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: 20px;
      align-items: stretch;
    }

    .services-category-card {
      position: relative;
      min-height: 340px;
      display: flex;
      flex-direction: column;
      gap: 16px;
      padding: 30px;
      border-radius: 18px;
      text-decoration: none;
      color: inherit;
      overflow: hidden;
      background:
        radial-gradient(circle at 68% 18%, rgba(91, 163, 217, 0.45), transparent 34%),
        linear-gradient(145deg, rgba(151, 199, 246, 0.74), rgba(217, 238, 248, 0.86));
      border: 1px solid rgba(255, 255, 255, 0.58);
      box-shadow:
        0 10px 28px rgba(26, 37, 51, 0.06),
        inset 0 1px 0 rgba(255, 255, 255, 0.72);
      transition: transform 0.22s ease, box-shadow 0.22s ease;
    }

    .services-category-card:nth-child(2) {
      background:
        radial-gradient(circle at 70% 12%, rgba(91, 163, 217, 0.34), transparent 36%),
        linear-gradient(145deg, rgba(205, 225, 255, 0.8), rgba(211, 237, 246, 0.88));
    }

    .services-category-card:nth-child(3) {
      background:
        radial-gradient(circle at 66% 18%, rgba(91, 163, 217, 0.32), transparent 34%),
        linear-gradient(145deg, rgba(228, 224, 214, 0.92), rgba(200, 218, 238, 0.74));
    }

    .services-category-card:hover,
    .services-category-card:focus-visible {
      transform: translateY(-4px);
      box-shadow:
        0 16px 38px rgba(26, 37, 51, 0.11),
        inset 0 1px 0 rgba(255, 255, 255, 0.78);
      outline: none;
    }

    .services-category-eyebrow {
      font-size: 11px;
      font-weight: var(--font-ui-weight);
      letter-spacing: var(--tracking-label);
      text-transform: uppercase;
      color: #2f6ab1;
    }

    .services-category-card h2 {
      font-size: 34px;
      line-height: var(--line-display-relaxed);
      letter-spacing: var(--tracking-display);
      color: #1a2533;
    }

    .services-category-card > p:not(.services-category-eyebrow) {
      font-size: 15px;
      line-height: 1.65;
      color: #405069;
    }

    .services-category-card ul {
      margin-top: auto;
      list-style: none;
      display: grid;
      gap: 8px;
    }

    .services-category-card li {
      position: relative;
      padding-left: 14px;
      font-size: 13px;
      line-height: 1.45;
      color: #50617a;
    }

    .services-category-card li::before {
      content: "";
      position: absolute;
      left: 0;
      top: 0.64em;
      width: 4px;
      height: 4px;
      border-radius: 50%;
      background: rgba(47, 106, 177, 0.7);
    }

    .services-category-link {
      margin-top: 6px;
      display: inline-flex;
      align-items: center;
      gap: 8px;
      width: fit-content;
      font-size: 13.5px;
      font-weight: 700;
      color: #2f6ab1;
    }

    .services-category-link svg {
      width: 14px;
      height: 14px;
      transition: transform 0.2s ease;
    }

    .services-category-card:hover .services-category-link svg,
    .services-category-card:focus-visible .services-category-link svg {
      transform: translateX(3px);
    }

    .portfolio-grid {
      position: relative;
      display: flex;
      flex-direction: column;
      gap: 32px;
    }

    .portfolio-lines {
      position: absolute;
      inset: 0;
      width: 100%;
      height: 100%;
      pointer-events: none;
      z-index: 0;
    }

    .flow-line {
      stroke-dasharray: 8 6;
      animation: dash-flow 1.5s linear infinite;
    }

    .flow-line-2 {
      animation-delay: 0.5s;
    }

    .flow-line-3 {
      animation-delay: 1s;
    }

    @keyframes home-service-node-rise {
      from {
        opacity: 0;
        transform: translate3d(0, 14px, 0) scale(0.985);
      }

      to {
        opacity: 1;
        transform: translate3d(0, 0, 0) scale(1);
      }
    }

    .flow-dot {
      opacity: 1;
    }

    .portfolio-lines {
      z-index: 2;
    }

    .portfolio-card .card-desc {
      font-size: 14px;
      color: #5a6270;
      line-height: 1.6;
      margin-top: 6px;
    }

    .portfolio-card {
      position: relative;
      z-index: 1;
      text-align: center;
      padding: 32px 28px;
      border-radius: 20px;

      /* Glass UI — matches header */
      background: rgba(255, 255, 255, 0.35);

      border: 1px solid rgba(255, 255, 255, 0.5);
      box-shadow:
        0 4px 24px rgba(0, 0, 0, 0.03),
        0 1px 0 rgba(255, 255, 255, 0.6) inset;
      transition: all 0.25s ease;
    }

    .portfolio-card:hover {
      background: rgba(255, 255, 255, 0.55);
      box-shadow:
        0 8px 32px rgba(59, 125, 219, 0.08),
        0 1px 0 rgba(255, 255, 255, 0.7) inset;
      transform: translateY(-2px);
    }

    .portfolio-card h3 {
      font-size: 21px;
      font-weight: 500;
      color: #1a2533;
      margin-bottom: 8px;
      letter-spacing: -0.3px;
    }

    .portfolio-card p {
      font-size: 14.5px;
      color: #5a6270;
      line-height: 1.6;
    }

    .portfolio-row {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 24px;
      position: relative;
      z-index: 1;
    }

    /* ── Service tab buttons ── */
    .service-tabs {
      display: flex;
      flex-wrap: wrap;
      gap: 8px;
      margin-top: 20px;
      justify-content: center;
    }

    .service-tab {
      display: inline-block;
      padding: 8px 20px;
      border-radius: 980px;
      border: 1.5px solid rgba(0, 0, 0, 0.1);
      background: transparent;
      font-family: inherit;
      font-size: 14px;
      font-weight: 500;
      color: #5a6270;
      cursor: pointer;
      transition: all 0.25s ease;
      white-space: nowrap;
    }

    .service-tab:hover {
      border-color: rgba(59, 125, 219, 0.4);
      color: #3b7ddb;
    }

    .service-tab.active {
      background: linear-gradient(135deg, #4a8ad4 0%, #5ba3d9 100%);
      border-color: transparent;
      color: #fff;
      box-shadow: 0 4px 14px rgba(74, 138, 212, 0.25);
    }

    .service-panel {
      margin-top: 20px;
      max-height: 0;
      overflow: hidden;
      opacity: 0;
      transition: max-height 0.35s ease, opacity 0.25s ease, margin 0.35s ease;
    }

    .service-panel.visible {
      max-height: 280px;
      opacity: 1;
    }

    .service-panel-inner {
      padding: 16px 20px;
      background: rgba(59, 125, 219, 0.06);
      border-radius: 14px;
      text-align: left;
    }

    .service-panel-inner p {
      font-size: 14.5px;
      line-height: 1.7;
      color: #3a4a5c;
    }

    .service-panel-link {
      margin-top: 12px;
      display: inline-flex;
      align-items: center;
      gap: 8px;
      text-decoration: none;
      font-size: 13.5px;
      font-weight: 600;
      color: #2f6ab1;
      transition: opacity 0.2s ease;
    }

    .service-panel-link:hover {
      opacity: 0.75;
    }

    .service-panel-link svg {
      width: 14px;
      height: 14px;
    }

    /* ── Services deep-dive pages ── */
    .service-pages {
      max-width: 1080px;
      margin: 72px auto 0;
      padding: 0 24px;
    }

    .service-pages-header {
      text-align: center;
      margin-bottom: 30px;
    }

    .service-pages-label {
      font-size: 12.5px;
      font-weight: 600;
      text-transform: uppercase;
      letter-spacing: 0.1em;
      color: #3b7ddb;
      margin-bottom: 10px;
    }

    .service-pages-header h2 {
      font-size: 42px;
      letter-spacing: -1.1px;
      color: #1a2533;
      margin-bottom: 10px;
    }

    .service-pages-sub {
      max-width: 760px;
      margin: 0 auto;
      font-size: 16px;
      line-height: 1.75;
      color: #5a6270;
    }

    .service-pages-grid {
      display: grid;
      grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: 18px;
    }

    .services-category-sections {
      display: grid;
      gap: 24px;
    }

    .services-category-section {
      scroll-margin-top: 92px;
      display: grid;
      grid-template-columns: 260px minmax(0, 1fr);
      gap: 22px;
      align-items: start;
      padding: 24px;
      border-radius: 22px;
      background: rgba(255, 255, 255, 0.32);
      border: 1px solid rgba(255, 255, 255, 0.58);
      box-shadow:
        0 8px 26px rgba(26, 37, 51, 0.045),
        inset 0 1px 0 rgba(255, 255, 255, 0.62);
    }

    .services-category-section-copy {
      position: sticky;
      top: 92px;
    }

    .services-category-section-copy h3 {
      margin: 8px 0 10px;
      font-size: 32px;
      line-height: 1.08;
      letter-spacing: -0.85px;
      color: #1a2533;
    }

    .services-category-section-copy p:not(.services-category-eyebrow) {
      font-size: 14.5px;
      line-height: 1.7;
      color: #5a6270;
    }

    .service-page-card {
      display: flex;
      flex-direction: column;
      gap: 10px;
      text-decoration: none;
      color: inherit;
      padding: 24px 22px;
      border-radius: 18px;
      background: rgba(255, 255, 255, 0.45);
      border: 1px solid rgba(255, 255, 255, 0.58);
      box-shadow:
        0 8px 24px rgba(26, 37, 51, 0.05),
        0 1px 0 rgba(255, 255, 255, 0.62) inset;
      transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
    }

    .service-page-card:hover {
      transform: translateY(-3px);
      border-color: rgba(74, 138, 212, 0.28);
      box-shadow:
        0 14px 30px rgba(26, 37, 51, 0.1),
        0 1px 0 rgba(255, 255, 255, 0.72) inset;
    }

    .service-page-card-category {
      font-size: 11px;
      font-weight: 700;
      text-transform: uppercase;
      letter-spacing: 0.1em;
      color: #3b7ddb;
    }

    .service-page-card h3,
    .service-page-card h4 {
      font-size: 24px;
      line-height: 1.22;
      letter-spacing: -0.45px;
      color: #1a2533;
    }

    .service-page-card p {
      font-size: 14.5px;
      line-height: 1.72;
      color: #526074;
    }

    .service-page-card-link {
      margin-top: auto;
      display: inline-flex;
      align-items: center;
      gap: 8px;
      font-size: 13.5px;
      font-weight: 600;
      color: #2f6ab1;
    }

    .service-page-card-link svg {
      width: 14px;
      height: 14px;
      transition: transform 0.2s ease;
    }

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

    .service-domain-note {
      margin-top: 24px;
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 28px;
      padding: 24px;
      border-radius: 22px;
      background: rgba(19, 44, 84, 0.08);
      border: 1px solid rgba(74, 138, 212, 0.16);
    }

    .service-domain-note h3 {
      font-size: 24px;
      letter-spacing: -0.4px;
      color: #1a2533;
      margin-bottom: 8px;
    }

    .service-domain-note p:not(.service-pages-label) {
      max-width: 680px;
      font-size: 14.5px;
      line-height: 1.7;
      color: #526074;
    }

    .service-domain-note a {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      flex-shrink: 0;
      text-decoration: none;
      border-radius: 980px;
      background: #1a2533;
      color: #fff;
      padding: 12px 18px;
      font-size: 13.5px;
      font-weight: 700;
      transition: transform 0.2s ease, box-shadow 0.2s ease;
    }

    .service-domain-note a:hover {
      transform: translateY(-1px);
      box-shadow: 0 10px 22px rgba(15, 26, 40, 0.18);
    }

    .service-domain-note svg {
      width: 14px;
      height: 14px;
    }

    @media (max-width: 1080px) {
      .service-pages-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
      }
    }

    /* ── Services reference card ── */
    .service-reference {
      max-width: 900px;
      margin: 28px auto 0;
      padding: 0 24px;
    }

    .service-reference-card {
      display: flex;
      align-items: flex-end;
      justify-content: space-between;
      gap: 24px;
      padding: 24px;
      border-radius: 20px;
      background:
        linear-gradient(140deg, rgba(26, 37, 51, 0.96), rgba(44, 88, 145, 0.95)),
        radial-gradient(circle at 18% 18%, rgba(106, 179, 235, 0.32), transparent 60%);
      border: 1px solid rgba(255, 255, 255, 0.16);
      box-shadow: 0 16px 34px rgba(16, 35, 65, 0.28);
      color: #fff;
    }

    .service-reference-copy {
      max-width: 620px;
    }

    .service-reference-label {
      font-size: 12px;
      letter-spacing: 0.12em;
      text-transform: uppercase;
      color: rgba(255, 255, 255, 0.64);
      margin-bottom: 8px;
      font-weight: 600;
    }

    .service-reference-copy h2 {
      font-size: 28px;
      letter-spacing: -0.6px;
      margin-bottom: 10px;
      color: #fff;
    }

    .service-reference-copy p {
      font-size: 15px;
      line-height: 1.72;
      color: rgba(255, 255, 255, 0.85);
    }

    .service-reference-link {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      white-space: nowrap;
      text-decoration: none;
      color: #1a2533;
      background: #fff;
      border-radius: 980px;
      padding: 10px 20px;
      font-size: 14px;
      font-weight: 600;
      box-shadow: 0 8px 18px rgba(0, 0, 0, 0.16);
      transition: transform 0.2s ease, box-shadow 0.2s ease;
    }

    .service-reference-link:hover {
      transform: translateY(-1px);
      box-shadow: 0 10px 22px rgba(0, 0, 0, 0.2);
    }

    .service-reference-link svg {
      width: 15px;
      height: 15px;
    }

    /* ── Service category pages ── */
    .svc-hero {
      position: relative;
      overflow: hidden;
      margin: 0;
      padding: clamp(140px, 18vh, 200px) 24px clamp(80px, 12vh, 140px);
      background:
        radial-gradient(ellipse 80% 60% at 50% 0%, rgba(184, 212, 245, 0.4) 0%, transparent 60%),
        radial-gradient(ellipse 60% 50% at 80% 20%, rgba(123, 188, 241, 0.18) 0%, transparent 50%),
        linear-gradient(180deg, #f6f9fd 0%, #eef3fa 40%, #f2f4f8 100%);
      isolation: isolate;
    }

    .svc-hero-bg {
      position: absolute;
      inset: 0;
      overflow: hidden;
      z-index: 0;
      pointer-events: none;
    }

    .svc-hero-blob {
      position: absolute;
      border-radius: 50%;
      filter: blur(80px);
      opacity: 0;
      animation: hero-light-blob-in 1.4s ease-out forwards;
    }

    .svc-hero-blob-1 {
      width: 45%;
      height: 45%;
      top: -5%;
      left: 5%;
      background: radial-gradient(circle, rgba(59, 125, 219, 0.12) 0%, transparent 70%);
      animation-delay: 0.2s;
    }

    .svc-hero-blob-2 {
      width: 35%;
      height: 40%;
      top: 10%;
      right: 5%;
      background: radial-gradient(circle, rgba(123, 188, 241, 0.1) 0%, transparent 70%);
      animation-delay: 0.4s;
    }

    .svc-hero-content {
      position: relative;
      z-index: 1;
      max-width: 820px;
      margin: 0 auto;
      text-align: center;
      animation: hero-fade-in 0.9s ease-out both;
    }

    .svc-hero-label {
      font-size: 13px;
      font-weight: var(--font-ui-weight);
      letter-spacing: var(--tracking-label);
      text-transform: uppercase;
      color: #2f5ea8;
      margin-bottom: 14px;
    }

    .svc-hero-title {
      font-size: clamp(2.6rem, 5vw, 4.2rem);
      font-weight: var(--font-display-weight);
      letter-spacing: var(--tracking-display-tight);
      line-height: var(--line-display);
      color: #1a2533;
      margin: 0 0 20px;
    }

    .svc-hero-description {
      font-size: clamp(1rem, 1.3vw, 1.12rem);
      line-height: 1.75;
      color: rgba(26, 37, 51, 0.65);
      max-width: 640px;
      margin: 0 auto 36px;
      animation: hero-fade-in 0.9s ease-out 0.15s both;
    }

    .svc-hero-actions {
      display: flex;
      align-items: center;
      justify-content: center;
      gap: 14px;
      flex-wrap: wrap;
      animation: hero-fade-in 0.9s ease-out 0.3s both;
    }

    .svc-hero-cta-primary {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      min-height: 48px;
      padding: 0 28px;
      border-radius: 999px;
      text-decoration: none;
      font-size: 0.95rem;
      font-weight: 600;
      color: #fff;
      background: #2f6ab1;
      border: 1px solid #2f6ab1;
      box-shadow: 0 4px 14px rgba(47, 106, 177, 0.25);
      transition: transform 0.18s ease, box-shadow 0.18s ease, background 0.18s ease;
    }

    .svc-hero-cta-primary:hover {
      background: #2460a0;
      transform: translateY(-2px);
      box-shadow: 0 8px 24px rgba(47, 106, 177, 0.3);
    }

    .svc-hero-cta-primary:active {
      transform: scale(0.97);
      box-shadow: none;
    }

    .svc-hero-cta-secondary {
      display: inline-flex;
      align-items: center;
      gap: 6px;
      min-height: 48px;
      padding: 0 24px;
      border-radius: 999px;
      text-decoration: none;
      font-size: 0.95rem;
      font-weight: 600;
      color: #1a2533;
      background: transparent;
      border: 1px solid rgba(26, 37, 51, 0.18);
      transition: transform 0.18s ease, border-color 0.18s ease, background 0.18s ease;
    }

    .svc-hero-cta-secondary svg {
      width: 14px;
      height: 14px;
      transition: transform 0.18s ease;
    }

    .svc-hero-cta-secondary:hover {
      border-color: rgba(26, 37, 51, 0.32);
      background: rgba(255, 255, 255, 0.6);
      transform: translateY(-1px);
    }

    .svc-hero-cta-secondary:hover svg {
      transform: translateX(2px);
    }

    @media (max-width: 768px) {
      .svc-hero {
        padding: clamp(120px, 16vh, 160px) 20px clamp(60px, 10vh, 100px);
      }

      .svc-hero-title {
        font-size: clamp(2rem, 9vw, 2.8rem);
      }

      .svc-hero-description {
        font-size: 1rem;
      }

      .svc-hero-cta-primary,
      .svc-hero-cta-secondary {
        min-height: 44px;
        padding: 0 22px;
        font-size: 0.9rem;
      }

    }

    /* ── Service category — shared section layout ── */
    .svc-section {
      margin: 0 24px;
    }

    .svc-section-inner {
      max-width: 1080px;
      margin: 0 auto;
      padding: 88px 0;
    }

    /* Section header — split layout: h2 left, description right */
    .svc-section-header {
      display: grid;
      grid-template-columns: 1fr;
      gap: 18px;
      align-items: start;
      justify-items: center;
      margin-bottom: 48px;
      text-align: center;
    }

    .svc-section-header h2 {
      margin: 0;
    }

    .svc-section-header > div {
      display: grid;
      gap: 8px;
      justify-items: center;
    }

    .svc-section-header .svc-section-description {
      margin: 0;
      max-width: 62ch;
      padding-top: 0;
    }

    .svc-section-inner h2 {
      font-size: clamp(1.8rem, 3vw, 2.6rem);
      font-weight: var(--font-display-weight);
      letter-spacing: var(--tracking-display-tight);
      line-height: var(--line-display);
      color: #111827;
      margin: 0 0 16px;
    }

    .svc-section-eyebrow {
      display: block;
      font-size: 11px;
      font-weight: 700;
      letter-spacing: 0.12em;
      text-transform: uppercase;
      color: #2f6ab1;
      margin-bottom: 12px;
    }

    .svc-section-description {
      font-size: 1.02rem;
      line-height: 1.72;
      color: rgba(26, 37, 51, 0.64);
      max-width: 600px;
      margin: 0 0 36px;
    }

    .svc-divider {
      max-width: 1080px;
      margin: 0 auto;
      border: none;
      border-top: 1px solid rgba(26, 37, 51, 0.06);
      padding: 0;
    }

    /* Alternating tinted sections */
    .svc-section-tinted {
      background: rgba(247, 249, 252, 0.6);
    }

    .svc-hero-best-for {
      margin-top: 20px;
      text-align: center;
      font-size: 0.88rem;
      color: rgba(26, 37, 51, 0.48);
      animation: hero-fade-in 0.9s ease-out 0.45s both;
    }

    /* POV section */
    .svc-pov-thesis {
      margin: 0;
      padding: 0 0 0 24px;
      border-left: 3px solid rgba(47, 106, 177, 0.25);
    }

    .svc-pov-thesis p {
      font-size: clamp(1.15rem, 2.2vw, 1.4rem);
      font-weight: 500;
      line-height: 1.55;
      color: #1a2533;
      letter-spacing: -0.02em;
      margin: 0;
    }

    /* Programme grid — 2-column with descriptions */
    .svc-programme-grid {
      display: grid;
      grid-template-columns: repeat(2, 1fr);
      gap: 0;
    }

    .svc-programme-item {
      padding: 28px 24px;
      border-top: 1px solid rgba(26, 37, 51, 0.06);
      display: flex;
      flex-direction: column;
      align-items: flex-start;
    }

    .svc-programme-item:nth-child(odd) {
      border-right: 1px solid rgba(26, 37, 51, 0.06);
    }

    .svc-programme-item:nth-child(-n+2) {
      border-top: none;
    }

    .svc-programme-icon {
      width: 48px;
      height: 48px;
      display: flex;
      align-items: center;
      justify-content: center;
      border-radius: 12px;
      background: rgba(47, 106, 177, 0.07);
      color: #2f6ab1;
      margin-bottom: 14px;
    }

    .svc-programme-icon svg {
      width: 24px;
      height: 24px;
    }

    .svc-programme-item h3 {
      font-size: 0.95rem;
      font-weight: 600;
      color: #1a2533;
      letter-spacing: -0.01em;
      margin: 0 0 6px 0;
      line-height: 1.35;
    }

    .svc-programme-item p {
      font-size: 0.88rem;
      line-height: 1.6;
      color: rgba(26, 37, 51, 0.6);
      margin: 0;
    }

    /* Programme cards — tiered 3-column */
    .svc-programme-cards {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 24px;
    }

    .svc-programme-card {
      display: flex;
      flex-direction: column;
      padding: 32px 28px;
      border-radius: 14px;
      background: #fff;
      border: 1px solid rgba(26, 37, 51, 0.08);
      transition: box-shadow 0.2s ease, border-color 0.2s ease;
    }

    .svc-programme-card:hover {
      border-color: rgba(47, 106, 177, 0.18);
      box-shadow: 0 4px 24px rgba(26, 37, 51, 0.06);
    }

    .svc-programme-card:last-child {
      border-color: rgba(47, 106, 177, 0.18);
      background: linear-gradient(180deg, rgba(47, 106, 177, 0.03) 0%, #fff 100%);
    }

    .svc-programme-card-icon {
      width: 44px;
      height: 44px;
      display: flex;
      align-items: center;
      justify-content: center;
      border-radius: 10px;
      background: rgba(47, 106, 177, 0.07);
      color: #2f6ab1;
      margin-bottom: 18px;
    }

    .svc-programme-card-icon svg {
      width: 22px;
      height: 22px;
    }

    .svc-programme-card h3 {
      font-size: 1.15rem;
      font-weight: 600;
      color: #1a2533;
      letter-spacing: -0.02em;
      margin: 0 0 8px 0;
      line-height: 1.3;
    }

    .svc-programme-card p {
      font-size: 0.9rem;
      line-height: 1.6;
      color: rgba(26, 37, 51, 0.6);
      margin: 0 0 18px 0;
    }

    .svc-programme-card ul {
      list-style: none;
      padding: 0;
      margin: 0;
      display: flex;
      flex-direction: column;
      gap: 8px;
    }

    .svc-programme-card li {
      font-size: 0.85rem;
      line-height: 1.5;
      color: rgba(26, 37, 51, 0.7);
      padding-left: 18px;
      position: relative;
    }

    .svc-programme-card li::before {
      content: '';
      position: absolute;
      left: 0;
      top: 7px;
      width: 6px;
      height: 6px;
      border-radius: 50%;
      background: rgba(47, 106, 177, 0.35);
    }

    /* Card grids */
    .svc-card-grid {
      display: grid;
      grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
      gap: 18px;
    }

    .svc-card {
      display: flex;
      flex-direction: column;
      gap: 8px;
      padding: 20px 0 20px 0;
      border-top: 2px solid rgba(47, 106, 177, 0.12);
    }

    .svc-card h3 {
      font-size: 1.05rem;
      font-weight: 600;
      color: #1a2533;
      letter-spacing: -0.02em;
    }

    .svc-card p {
      font-size: 0.9rem;
      line-height: 1.6;
      color: rgba(26, 37, 51, 0.6);
    }

    /* Step grid — process steps */
    .svc-steps-grid {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 24px;
      margin-top: 40px;
    }

    .svc-step {
      display: flex;
      flex-direction: column;
      gap: 8px;
    }

    .svc-step-number {
      font-size: 2.5rem;
      font-weight: 700;
      line-height: 1;
      color: rgba(47, 106, 177, 0.12);
      letter-spacing: -0.04em;
    }

    .svc-step h3 {
      font-size: 0.95rem;
      font-weight: 600;
      color: #1a2533;
      letter-spacing: -0.02em;
      margin: 0;
      line-height: 1.35;
    }

    .svc-step p {
      font-size: 0.88rem;
      line-height: 1.6;
      color: rgba(26, 37, 51, 0.6);
      margin: 0;
    }

    /* Outcomes card */
    .svc-outcomes-card {
      background: linear-gradient(135deg, rgba(47, 106, 177, 0.04) 0%, rgba(47, 106, 177, 0.08) 100%);
      border-radius: 20px;
      padding: 40px;
      margin-top: 32px;
    }

    .svc-stats-row {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: 24px;
      margin-bottom: 32px;
      padding-bottom: 32px;
      border-bottom: 1px solid rgba(47, 106, 177, 0.1);
    }

    .svc-stat {
      display: flex;
      flex-direction: column;
      gap: 4px;
      text-align: center;
    }

    .svc-stat-value {
      font-size: clamp(1.8rem, 4vw, 2.5rem);
      font-weight: 700;
      letter-spacing: -0.03em;
      line-height: 1;
      color: #2f6ab1;
    }

    .svc-stat-unit {
      font-size: 0.5em;
      font-weight: 600;
      color: rgba(47, 106, 177, 0.6);
    }

    .svc-stat-label {
      font-size: 0.82rem;
      line-height: 1.4;
      color: rgba(26, 37, 51, 0.55);
    }

    .svc-outcomes-list {
      list-style: none;
      padding: 0;
      display: grid;
      gap: 14px;
      margin-top: 24px;
    }

    .svc-outcomes-list li {
      position: relative;
      padding-left: 20px;
      font-size: 1rem;
      line-height: 1.6;
      color: rgba(26, 37, 51, 0.72);
    }

    .svc-outcomes-list li::before {
      content: '';
      position: absolute;
      left: 0;
      top: 0.65em;
      width: 8px;
      height: 8px;
      border-radius: 999px;
      background: #2f6ab1;
      opacity: 0.4;
    }

    /* Related services */
    .svc-related-grid {
      display: grid;
      grid-template-columns: repeat(2, 1fr);
      gap: 18px;
    }

    .svc-related-card {
      display: flex;
      flex-direction: column;
      gap: 12px;
      padding: 32px 28px;
      border-radius: 20px;
      background: rgba(255, 255, 255, 0.55);
      border: 1px solid rgba(255, 255, 255, 0.7);
      box-shadow: 0 4px 16px rgba(26, 37, 51, 0.04);
      text-decoration: none;
      color: #1a2533;
      transition: transform 0.2s ease, box-shadow 0.2s ease;
    }

    .svc-related-card:hover {
      transform: translateY(-3px);
      box-shadow: 0 12px 28px rgba(26, 37, 51, 0.08);
    }

    .svc-related-prompt {
      font-size: 0.88rem;
      color: rgba(26, 37, 51, 0.5);
    }

    .svc-related-card strong {
      font-size: 1.2rem;
      font-weight: 600;
      letter-spacing: -0.02em;
    }

    .svc-related-link {
      display: inline-flex;
      align-items: center;
      gap: 6px;
      font-size: 0.9rem;
      font-weight: 600;
      color: #2f6ab1;
      margin-top: auto;
    }

    .svc-related-link svg {
      width: 14px;
      height: 14px;
      transition: transform 0.18s ease;
    }

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

    /* Final CTA */
    .svc-final-cta-card {
      padding: 56px;
      border-radius: 24px;
      background:
        radial-gradient(circle at 8% 12%, rgba(59, 125, 219, 0.45) 0%, transparent 32%),
        radial-gradient(circle at 88% 8%, rgba(206, 226, 255, 0.7) 0%, transparent 38%),
        linear-gradient(145deg, #eef5ff 0%, #d8eaff 38%, #c4daf5 72%, #d4e5ff 100%);
      text-align: center;
    }

    .svc-final-cta-card h2 {
      max-width: 520px;
      margin: 0 auto 14px;
    }

    .svc-final-cta-card > p {
      font-size: 1rem;
      line-height: 1.72;
      color: rgba(36, 58, 92, 0.68);
      max-width: 500px;
      margin: 0 auto 32px;
    }

    .svc-final-cta-actions {
      display: flex;
      flex-direction: column;
      align-items: center;
      gap: 24px;
    }

    .svc-final-cta-button {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      min-height: 52px;
      padding: 0 32px;
      border-radius: 999px;
      text-decoration: none;
      font-size: 1rem;
      font-weight: 600;
      color: #fff;
      background: #2f6ab1;
      box-shadow: 0 4px 14px rgba(47, 106, 177, 0.3);
      transition: transform 0.18s ease, box-shadow 0.18s ease, background 0.18s ease;
    }

    .svc-final-cta-button:hover {
      background: #2460a0;
      transform: translateY(-2px);
      box-shadow: 0 8px 24px rgba(47, 106, 177, 0.35);
    }

    .svc-final-cta-button:active {
      transform: scale(0.97);
      box-shadow: none;
    }

    .svc-final-cta-button svg {
      width: 14px;
      height: 14px;
      transition: transform 0.18s ease;
    }

    .svc-final-cta-button:hover svg {
      transform: translateX(3px);
    }

    .svc-final-cta-channels {
      display: flex;
      gap: 32px;
    }

    .svc-final-cta-channels a {
      display: flex;
      flex-direction: column;
      align-items: center;
      gap: 2px;
      text-decoration: none;
      color: #1d314b;
      transition: color 0.2s ease;
    }

    .svc-final-cta-channels a:hover {
      color: #2f6ab1;
    }

    .svc-final-cta-channels a span {
      font-size: 10.5px;
      font-weight: 700;
      letter-spacing: 0.1em;
      text-transform: uppercase;
      color: #5a7caa;
    }

    .svc-final-cta-channels a strong {
      font-size: 13px;
      font-weight: 600;
      color: inherit;
    }

    /* Service category responsive */
    @media (max-width: 1024px) {
      .svc-section-header {
        grid-template-columns: 1fr;
        gap: 8px;
      }

      .svc-section-header .svc-section-description {
        padding-top: 0;
        max-width: 600px;
      }

      .svc-related-grid {
        grid-template-columns: 1fr;
      }

      .svc-steps-grid {
        grid-template-columns: repeat(2, 1fr);
      }
    }

    @media (max-width: 768px) {
      .svc-section {
        margin: 0 16px;
      }

      .svc-section-inner {
        padding: 56px 0;
      }

      .svc-section-inner h2 {
        font-size: clamp(1.5rem, 7vw, 2rem);
      }

      .svc-card-grid {
        grid-template-columns: 1fr;
      }

      .svc-programme-grid {
        grid-template-columns: 1fr;
      }

      .svc-programme-item:nth-child(odd) {
        border-right: none;
      }

      .svc-programme-cards {
        grid-template-columns: 1fr;
        gap: 16px;
      }

      .svc-programme-card {
        padding: 24px 20px;
      }

      .svc-steps-grid {
        grid-template-columns: 1fr;
      }

      .svc-stats-row {
        grid-template-columns: 1fr;
        gap: 24px;
      }

      .svc-outcomes-card {
        padding: 28px 20px;
      }

      .svc-final-cta-card {
        padding: 32px 22px;
        border-radius: 18px;
      }

      .svc-final-cta-channels {
        flex-direction: column;
        gap: 16px;
      }

    }

    /* ── Procurement expertise page ── */
    .procurement-hero {
      position: relative;
      overflow: hidden;
      margin: 0;
      border-radius: 0;
      min-height: clamp(560px, 82vh, 840px);
      display: flex;
      align-items: flex-end;
      background: #0d1b2d;
      isolation: isolate;
      padding: 144px 0 88px;
    }

    .procurement-hero-media {
      position: absolute;
      inset: 0;
      background-position: center center;
      background-repeat: no-repeat;
      background-size: cover;
      z-index: 0;
      transform: scale(1.02);
    }

    .procurement-hero-with-image {
      background: #0d1b2d;
    }

    .procurement-hero-with-image::before {
      content: '';
      position: absolute;
      inset: 0;
      background:
        linear-gradient(180deg, rgba(7, 15, 28, 0.38) 0%, rgba(7, 15, 28, 0.24) 24%, rgba(7, 15, 28, 0.56) 100%),
        radial-gradient(circle at 18% 22%, rgba(95, 146, 224, 0.24) 0%, rgba(95, 146, 224, 0) 34%),
        radial-gradient(circle at 80% 78%, rgba(102, 196, 230, 0.18) 0%, rgba(102, 196, 230, 0) 34%);
      z-index: 1;
      pointer-events: none;
    }

    .procurement-hero-with-image .procurement-hero-grid,
    .procurement-hero-with-image .procurement-hero-glow {
      display: none;
    }

    .procurement-hero-grid {
      position: absolute;
      inset: 0;
      background-image:
        linear-gradient(rgba(255, 255, 255, 0.08) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255, 255, 255, 0.08) 1px, transparent 1px);
      background-size: 44px 44px;
      opacity: 0.18;
      z-index: 1;
      mask-image: radial-gradient(circle at 60% 45%, black 42%, transparent 100%);
      -webkit-mask-image: radial-gradient(circle at 60% 45%, black 42%, transparent 100%);
    }

    .procurement-hero-glow {
      position: absolute;
      border-radius: 50%;
      filter: blur(90px);
      z-index: 1;
      pointer-events: none;
    }

    .procurement-hero-glow-1 {
      width: 440px;
      height: 440px;
      top: -80px;
      left: -70px;
      background: rgba(91, 163, 217, 0.55);
    }

    .procurement-hero-glow-2 {
      width: 420px;
      height: 420px;
      right: -80px;
      bottom: -120px;
      background: rgba(115, 188, 235, 0.4);
    }

    .procurement-hero-inner {
      position: relative;
      z-index: 2;
      width: 100%;
      max-width: 920px;
      margin: 0 auto;
      padding: 0 clamp(28px, 6vw, 72px);
      text-align: center;
    }

    .procurement-hero-label {
      font-size: 13px;
      font-weight: 700;
      text-transform: uppercase;
      letter-spacing: 0.12em;
      color: rgba(255, 255, 255, 0.72);
      margin-bottom: 18px;
    }

    .procurement-hero h1 {
      font-size: clamp(3.15rem, 5.4vw, 5.4rem);
      font-weight: 500;
      line-height: 0.94;
      letter-spacing: -0.06em;
      color: #fff;
      max-width: 12ch;
      margin: 0 auto 18px;
      text-shadow: 0 18px 36px rgba(4, 11, 25, 0.34);
    }

    .procurement-hero-sub {
      max-width: 52ch;
      font-size: clamp(1rem, 1.35vw, 1.18rem);
      line-height: 1.72;
      color: rgba(255, 255, 255, 0.82);
      margin: 0 auto 30px;
      text-shadow: 0 12px 28px rgba(4, 11, 25, 0.24);
    }

    .procurement-hero-actions {
      display: flex;
      align-items: center;
      justify-content: center;
      gap: 18px;
      flex-wrap: wrap;
    }

    .procurement-hero-cta,
    .procurement-outro-link {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      border-radius: 980px;
      text-decoration: none;
      background: #fff;
      color: #1a2533;
      padding: 11px 22px;
      font-size: 14px;
      font-weight: 600;
      transition: transform 0.2s ease, box-shadow 0.2s ease;
      box-shadow: 0 8px 20px rgba(0, 0, 0, 0.18);
    }

    .procurement-hero-cta:hover,
    .procurement-outro-link:hover {
      transform: translateY(-1px);
      box-shadow: 0 10px 24px rgba(0, 0, 0, 0.22);
    }

    .procurement-hero-cta svg,
    .procurement-outro-link svg {
      width: 15px;
      height: 15px;
    }

    .procurement-hero-secondary {
      display: inline-flex;
      align-items: center;
      border-radius: 980px;
      text-decoration: none;
      border: 1px solid rgba(255, 255, 255, 0.35);
      color: rgba(255, 255, 255, 0.9);
      padding: 11px 22px;
      font-size: 14px;
      font-weight: 500;
      transition: background 0.2s ease, border-color 0.2s ease;
    }

    .procurement-hero-secondary:hover {
      background: rgba(255, 255, 255, 0.1);
      border-color: rgba(255, 255, 255, 0.52);
    }

    .procurement-context,
    .procurement-practice,
    .procurement-ai-impact,
    .procurement-marc,
    .procurement-outro {
      max-width: 1080px;
      margin: 28px auto 0;
      padding: 0 24px;
    }

    .procurement-context-card {
      background: rgba(255, 255, 255, 0.45);
      backdrop-filter: blur(26px) saturate(1.2);
      -webkit-backdrop-filter: blur(26px) saturate(1.2);
      border: 1px solid rgba(255, 255, 255, 0.5);
      border-radius: 20px;
      padding: 34px;
      box-shadow:
        0 4px 24px rgba(0, 0, 0, 0.03),
        0 1px 0 rgba(255, 255, 255, 0.58) inset;
    }

    .procurement-context-card h2 {
      font-size: 30px;
      color: #1a2533;
      margin-bottom: 14px;
      letter-spacing: -0.7px;
    }

    .procurement-context-card p {
      font-size: 16px;
      line-height: 1.8;
      color: #4d5968;
    }

    .procurement-context-card p + p {
      margin-top: 14px;
    }

    .procurement-practice {
      margin-top: 72px;
    }

    .procurement-practice-header {
      text-align: center;
      margin-bottom: 34px;
    }

    .procurement-practice-label {
      font-size: 13px;
      font-weight: 600;
      text-transform: uppercase;
      letter-spacing: 0.1em;
      color: #3b7ddb;
      margin-bottom: 10px;
    }

    .procurement-practice-header h2 {
      font-size: 42px;
      color: #1a2533;
      letter-spacing: -1.1px;
      margin-bottom: 10px;
    }

    .procurement-practice-sub {
      max-width: 700px;
      margin: 0 auto;
      font-size: 16px;
      color: #5a6270;
      line-height: 1.7;
    }

    .procurement-pillar-grid {
      display: grid;
      grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: 20px;
    }

    .procurement-pillar {
      position: relative;
      background: #fff;
      border-radius: 20px;
      border: 1px solid rgba(0, 0, 0, 0.06);
      padding: 28px 24px;
      box-shadow: 0 10px 30px rgba(26, 37, 51, 0.06);
      overflow: hidden;
    }

    .procurement-pillar-index {
      font-size: 12px;
      font-weight: 700;
      letter-spacing: 0.08em;
      color: #3b7ddb;
      margin-bottom: 12px;
    }

    .procurement-pillar h3 {
      font-size: 22px;
      line-height: 1.25;
      letter-spacing: -0.45px;
      color: #1a2533;
      margin-bottom: 12px;
    }

    .procurement-pillar p {
      font-size: 14.5px;
      line-height: 1.78;
      color: #506074;
    }

    .procurement-ai-impact-card {
      background: linear-gradient(140deg, #16345f 0%, #254f82 62%, #30679d 100%);
      border-radius: 24px;
      border: 1px solid rgba(255, 255, 255, 0.14);
      box-shadow: 0 20px 44px rgba(26, 53, 90, 0.26);
      padding: 36px;
      color: #fff;
    }

    .procurement-ai-impact-card h2 {
      font-size: 34px;
      letter-spacing: -0.7px;
      margin-bottom: 18px;
      max-width: 640px;
    }

    .procurement-ai-impact-card ul {
      list-style: none;
      display: grid;
      gap: 12px;
      padding: 0;
    }

    .procurement-ai-impact-card li {
      position: relative;
      padding-left: 18px;
      font-size: 15px;
      line-height: 1.75;
      color: rgba(255, 255, 255, 0.88);
    }

    .procurement-ai-impact-card li::before {
      content: '';
      position: absolute;
      top: 11px;
      left: 0;
      width: 7px;
      height: 7px;
      border-radius: 999px;
      background: #9dd2f4;
      box-shadow: 0 0 0 4px rgba(157, 210, 244, 0.2);
    }

    .procurement-marc-card {
      display: grid;
      grid-template-columns: 84px minmax(0, 1fr) auto;
      align-items: center;
      gap: 18px;
      padding: 22px;
      border-radius: 18px;
      background: #fff;
      border: 1px solid rgba(26, 37, 51, 0.1);
      box-shadow: 0 12px 28px rgba(20, 35, 58, 0.06);
    }

    .procurement-marc-avatar {
      width: 84px;
      height: 84px;
      border-radius: 999px;
      flex-shrink: 0;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      overflow: hidden;
      background: #edf2f8;
      border: 1px solid rgba(26, 37, 51, 0.12);
    }

    .procurement-marc-avatar img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      display: block;
      border-radius: inherit;
    }

    .procurement-marc-initials {
      font-size: 20px;
      font-weight: 700;
      letter-spacing: 0.04em;
      color: #2a5f9c;
    }

    .procurement-marc-copy {
      min-width: 0;
    }

    .procurement-marc-label {
      font-size: 11px;
      font-weight: 700;
      text-transform: uppercase;
      letter-spacing: 0.1em;
      color: #4f6e91;
      margin-bottom: 4px;
    }

    .procurement-marc-copy h2 {
      font-size: 30px;
      line-height: 1.2;
      letter-spacing: -0.65px;
      color: #1a2533;
      margin-bottom: 4px;
    }

    .procurement-marc-role {
      font-size: 14px;
      color: #42566f;
      margin-bottom: 6px;
    }

    .procurement-marc-email {
      display: inline-flex;
      align-items: center;
      text-decoration: none;
      font-size: 13px;
      color: #2f6ab1;
      margin-bottom: 8px;
    }

    .procurement-marc-email:hover {
      text-decoration: underline;
    }

    .procurement-marc-description {
      font-size: 14px;
      line-height: 1.68;
      color: #5c6979;
      margin: 0;
      max-width: 650px;
    }

    .procurement-marc-link {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      text-decoration: none;
      white-space: nowrap;
      border-radius: 12px;
      background: #1a2533;
      color: #fff;
      padding: 12px 16px;
      font-size: 13px;
      font-weight: 600;
      box-shadow: 0 8px 18px rgba(15, 26, 40, 0.16);
      transition: transform 0.2s ease, box-shadow 0.2s ease;
    }

    .procurement-marc-link:hover {
      transform: translateY(-1px);
      box-shadow: 0 10px 22px rgba(15, 26, 40, 0.24);
    }

    .procurement-marc-link svg {
      width: 14px;
      height: 14px;
    }

    .procurement-outro {
      text-align: center;
      margin-top: 38px;
      margin-bottom: 8px;
    }

    .procurement-outro h2 {
      font-size: 36px;
      letter-spacing: -0.9px;
      color: #1a2533;
      margin-bottom: 10px;
    }

    .procurement-outro p {
      max-width: 700px;
      margin: 0 auto 18px;
      font-size: 16px;
      line-height: 1.75;
      color: #566174;
    }

    @media (max-width: 768px) {
      .portfolio-header h1 {
        font-size: 32px;
      }

      .services-category-grid {
        grid-template-columns: 1fr;
      }

      .services-category-card {
        min-height: 260px;
      }

      .portfolio-row {
        grid-template-columns: 1fr;
      }

      .portfolio-lines {
        display: none;
      }

      .service-reference-card {
        flex-direction: column;
        align-items: flex-start;
      }

      .service-reference-copy h2 {
        font-size: 24px;
      }

      .service-pages {
        margin-top: 52px;
        padding: 0 16px;
      }

      .service-pages-header h2 {
        font-size: 30px;
      }

      .service-pages-sub {
        font-size: 15px;
      }

      .service-pages-grid {
        grid-template-columns: 1fr;
      }

      .services-category-section {
        grid-template-columns: 1fr;
        padding: 18px;
      }

      .services-category-section-copy {
        position: static;
      }

      .service-domain-note {
        flex-direction: column;
        align-items: flex-start;
      }

      .procurement-hero {
        margin: 0;
        border-radius: 0;
        min-height: 520px;
        padding: 120px 0 56px;
      }

      .procurement-hero-inner {
        padding: 0 24px;
      }

      .procurement-hero h1 {
        font-size: 36px;
        letter-spacing: -1px;
      }

      .procurement-hero-sub {
        font-size: 16px;
      }

      .procurement-context,
      .procurement-practice,
      .procurement-ai-impact,
      .procurement-marc,
      .procurement-outro {
        padding: 0 16px;
      }

      .procurement-context-card {
        padding: 24px;
      }

      .procurement-context-card h2 {
        font-size: 26px;
      }

      .procurement-practice-header h2 {
        font-size: 30px;
      }

      .procurement-pillar-grid {
        grid-template-columns: 1fr;
      }

      .procurement-sub-offerings {
        margin-top: 48px;
      }

      .workshop-card-grid {
        grid-template-columns: 1fr;
      }

      .procurement-ai-impact-card {
        padding: 24px;
      }

      .procurement-ai-impact-card h2 {
        font-size: 28px;
      }

      .procurement-marc-card {
        grid-template-columns: 64px 1fr;
        padding: 18px;
        gap: 12px;
        align-items: flex-start;
      }

      .procurement-marc-avatar {
        width: 56px;
        height: 56px;
      }

      .procurement-marc-initials {
        font-size: 18px;
      }

      .procurement-marc-copy h2 {
        font-size: 24px;
      }

      .procurement-marc-email {
        font-size: 12.5px;
      }

      .procurement-marc-description {
        font-size: 14.5px;
      }

      .procurement-marc-link {
        grid-column: 1 / -1;
        justify-self: start;
      }

      .procurement-outro h2 {
        font-size: 30px;
      }
    }

    /* ── About page ── */
    .about-intro {
      max-width: 780px;
      margin: 80px auto 0;
      padding: 0 24px;
    }

    .about-label {
      font-size: 13px;
      font-weight: 600;
      text-transform: uppercase;
      letter-spacing: 0.08em;
      color: #8c6d3f;
      margin-bottom: 12px;
    }

    .about-intro h1 {
      font-size: 48px;
      font-weight: 500;
      letter-spacing: -1.5px;
      line-height: 1.1;
      color: #1a2533;
      margin-bottom: 32px;
    }

    .about-body {
      display: flex;
      flex-direction: column;
      gap: 16px;
    }

    .about-body p {
      font-size: 17px;
      line-height: 1.8;
      color: #5a6270;
    }

    /* Team section */
    .about-team {
      max-width: 1080px;
      margin: 80px auto 0;
      padding: 0 24px;
    }

    .about-team h2 {
      font-size: 32px;
      font-weight: 500;
      letter-spacing: -0.8px;
      color: #1a2533;
      margin-bottom: 40px;
    }

    .team-grid {
      display: grid;
      grid-template-columns: repeat(4, 1fr);
      gap: 32px;
    }

    .team-card {
      cursor: pointer;
      text-align: center;
      transition: transform 0.2s ease;
    }

    .team-card:hover {
      transform: translateY(-3px);
    }

    .team-photo {
      width: 100%;
      aspect-ratio: 1;
      border-radius: 16px;
      background-color: #e8ecf2;
      background-size: cover;
      background-position: center;
      margin-bottom: 16px;
      display: flex;
      align-items: center;
      justify-content: center;
      overflow: hidden;
    }

    .team-photo .team-initials {
      font-size: 32px;
      font-weight: 600;
      color: #8a919c;
      letter-spacing: 1px;
    }

    /* Hide initials when a real photo is loaded */
    .team-photo[style*="url"] .team-initials {
      display: none;
    }

    .team-card h3 {
      font-size: 17px;
      font-weight: 500;
      color: #1a2533;
      margin-bottom: 4px;
      letter-spacing: -0.2px;
    }

    .team-role {
      font-size: 14px;
      color: #5a6270;
    }

    /* Team modal */
    .team-modal {
      position: fixed;
      inset: 0;
      z-index: 2000;
      display: flex;
      align-items: center;
      justify-content: center;
      background: rgba(0, 0, 0, 0.6);
      backdrop-filter: blur(4px);
      opacity: 0;
      visibility: hidden;
      transition: opacity 0.3s ease, visibility 0.3s ease;
    }

    .team-modal.open {
      opacity: 1;
      visibility: visible;
    }

    .team-modal-inner {
      display: flex;
      max-width: 900px;
      width: 90%;
      max-height: 85vh;
      background: #fff;
      border-radius: 24px;
      overflow: hidden;
      box-shadow: 0 24px 80px rgba(0, 0, 0, 0.25);
      transform: scale(0.95) translateY(10px);
      transition: transform 0.3s ease;
    }

    .team-modal.open .team-modal-inner {
      transform: scale(1) translateY(0);
    }

    .team-modal-photo {
      width: 45%;
      min-height: 400px;
      background-color: #e8ecf2;
      background-size: cover;
      background-position: center;
      display: flex;
      align-items: center;
      justify-content: center;
      flex-shrink: 0;
    }

    .team-modal-photo .team-initials {
      font-size: 64px;
      font-weight: 600;
      color: #8a919c;
      letter-spacing: 2px;
    }

    .team-modal-photo[style*="url"] .team-initials {
      display: none;
    }

    .team-modal-content {
      flex: 1;
      padding: 40px;
      overflow-y: auto;
      position: relative;
    }

    .team-modal-close {
      position: absolute;
      top: 16px;
      right: 16px;
      width: 36px;
      height: 36px;
      border: none;
      background: none;
      cursor: pointer;
      display: flex;
      align-items: center;
      justify-content: center;
      border-radius: 8px;
      transition: background 0.2s ease;
    }

    .team-modal-close:hover {
      background: #f2f4f8;
    }

    .team-modal-close svg {
      width: 22px;
      height: 22px;
      color: #5a6270;
    }

    .team-modal-content h2 {
      font-size: 28px;
      font-weight: 500;
      color: #1a2533;
      letter-spacing: -0.5px;
      margin-bottom: 4px;
    }

    .team-modal-role {
      font-size: 15px;
      color: #5a6270;
      margin-bottom: 28px;
    }

    .team-modal-bio p {
      font-size: 15px;
      line-height: 1.8;
      color: #3a4a5c;
      margin-bottom: 16px;
    }

    .team-modal-linkedin {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      width: 32px;
      height: 32px;
      border-radius: 8px;
      background: #1a2533;
      margin-top: 8px;
      transition: background 0.2s ease;
    }

    .team-modal-linkedin:hover {
      background: #3b7ddb;
    }

    .team-modal-linkedin svg {
      width: 16px;
      height: 16px;
      fill: #fff;
    }

    @media (max-width: 768px) {
      .about-intro h1 {
        font-size: 32px;
      }

      .team-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 24px;
      }

      .team-modal-inner {
        flex-direction: column;
        max-height: 90vh;
      }

      .team-modal-photo {
        width: 100%;
        min-height: 250px;
      }

      .team-modal-content {
        padding: 28px;
      }
    }

    /* ── Customer stories overview ── */
    .stories-overview {
      max-width: 1280px;
      margin: 128px auto 0;
      padding: 0 24px;
    }

    .stories-overview-header {
      max-width: 760px;
      margin: 0 auto 44px;
      text-align: center;
    }

    .stories-overview-label {
      font-size: 13px;
      font-weight: 600;
      text-transform: uppercase;
      letter-spacing: 0.08em;
      color: #3b7ddb;
      margin-bottom: 12px;
    }

    .stories-overview-header h1 {
      font-size: 46px;
      font-weight: 500;
      letter-spacing: -1.2px;
      line-height: 1.1;
      color: #1a2533;
      margin-bottom: 16px;
    }

    .stories-overview-header p {
      font-size: 17px;
      color: #5a6270;
      line-height: 1.75;
    }

    .stories-grid {
      display: grid;
      grid-template-columns: minmax(0, 1.55fr) repeat(2, minmax(260px, 0.72fr));
      gap: 26px;
      align-items: stretch;
    }

    .story-card {
      display: flex;
      flex-direction: column;
      text-decoration: none;
      gap: 18px;
      padding: 10px 10px 18px;
      border-radius: 32px;
      background: rgba(255, 255, 255, 0.4);
      border: 1px solid rgba(255, 255, 255, 0.56);
      box-shadow:
        0 10px 28px rgba(26, 37, 51, 0.045),
        0 1px 0 rgba(255, 255, 255, 0.62) inset;
      backdrop-filter: blur(18px) saturate(1.16);
      -webkit-backdrop-filter: blur(18px) saturate(1.16);
      overflow: hidden;
      transition:
        transform 0.28s cubic-bezier(0.22, 1, 0.36, 1),
        box-shadow 0.28s ease,
        border-color 0.28s ease;
      color: inherit;
      will-change: transform;
    }

    .story-card:hover {
      transform: translateY(-3px);
      border-color: rgba(74, 138, 212, 0.18);
      box-shadow:
        0 14px 32px rgba(26, 37, 51, 0.07),
        0 1px 0 rgba(255, 255, 255, 0.72) inset;
    }

    .story-card-visual {
      position: relative;
      min-height: 420px;
      display: flex;
      flex-direction: column;
      justify-content: space-between;
      gap: 18px;
      padding: 28px;
      border-radius: 24px;
      background-image:
        linear-gradient(180deg, rgba(14, 22, 34, 0.04) 0%, rgba(14, 22, 34, 0.44) 100%),
        var(
          --story-card-bg-image,
          linear-gradient(135deg, rgba(59, 125, 219, 0.95) 0%, rgba(74, 138, 212, 0.92) 45%, rgba(91, 163, 217, 0.88) 100%)
        );
      background-size: cover;
      background-position: center;
      background-repeat: no-repeat;
      color: rgba(255, 255, 255, 0.9);
      overflow: hidden;
    }

    .story-card-visual::after {
      content: '';
      position: absolute;
      inset: 0;
      background:
        radial-gradient(circle at 78% 10%, rgba(255, 255, 255, 0.14) 0%, transparent 26%),
        linear-gradient(180deg, rgba(8, 18, 30, 0.04) 0%, rgba(8, 18, 30, 0.46) 100%);
      pointer-events: none;
    }

    .story-card-visual > * {
      position: relative;
      z-index: 1;
    }

    .story-card-visual-top {
      display: flex;
      align-items: flex-start;
      justify-content: flex-start;
    }

    .story-card-visual-bottom {
      display: flex;
      flex-direction: column;
      gap: 14px;
      max-width: min(82%, 560px);
    }

    .story-card-visual-brand {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      min-height: 52px;
      max-width: min(86%, 280px);
      padding: 10px 16px;
      border-radius: 16px;
      background: rgba(255, 255, 255, 0.88);
    }

    .story-card-visual-logo {
      display: block;
      width: auto;
      max-width: 100%;
      max-height: 28px;
      object-fit: contain;
    }

    .story-card-visual-logo-fallback {
      font-size: 12px;
      font-weight: 700;
      letter-spacing: 0.08em;
      text-transform: uppercase;
      color: #234f83;
      white-space: nowrap;
    }

    .story-card-body {
      display: flex;
      flex-direction: column;
      flex: 1;
      gap: 18px;
      padding: 0 8px 2px;
    }

    .story-card-meta {
      display: flex;
      align-items: center;
      justify-content: flex-start;
      gap: 10px;
      flex-wrap: wrap;
    }

    .story-card-sector {
      font-size: 13px;
      font-weight: 600;
      color: rgba(31, 41, 55, 0.82);
      background: rgba(230, 232, 238, 0.85);
      border-radius: 980px;
      padding: 10px 16px;
      white-space: nowrap;
    }

    .story-card h2 {
      font-size: 20px;
      font-weight: 500;
      letter-spacing: -0.4px;
      line-height: 1.24;
      color: #1a2533;
    }

    .story-card p {
      font-size: 15px;
      color: #5a6270;
      line-height: 1.75;
      flex: 1;
    }

    .story-card-link {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      font-size: 14px;
      font-weight: 600;
      color: #3b7ddb;
    }

    .story-card-arrow {
      width: 15px;
      height: 15px;
      transition: transform 0.2s ease;
    }

    .story-card:hover .story-card-arrow {
      transform: translateX(3px);
    }

    .story-card-featured .story-card-visual {
      min-height: 620px;
      padding: 28px 28px 30px;
      background-position: center;
    }

    .story-card-featured h2 {
      font-size: clamp(32px, 3vw, 42px);
      line-height: 1.1;
      color: #ffffff;
      max-width: 13ch;
    }

    .story-card-featured .story-card-sector {
      color: rgba(255, 255, 255, 0.95);
      background: rgba(255, 255, 255, 0.18);
      backdrop-filter: blur(12px);
      -webkit-backdrop-filter: blur(12px);
    }

    @media (max-width: 1024px) {
      .stories-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
      }

      .story-card-featured {
        grid-column: 1 / -1;
      }

      .story-card-featured .story-card-visual {
        min-height: 520px;
      }
    }

    @media (max-width: 768px) {
      .stories-overview {
        margin-top: 104px;
      }

      .stories-overview-header h1 {
        font-size: 32px;
      }

      .stories-overview-header p {
        font-size: 16px;
      }

      .stories-grid {
        grid-template-columns: 1fr;
      }

      .story-card-visual {
        min-height: 300px;
        padding: 22px;
      }

      .story-card-visual-brand {
        max-width: 92%;
        min-height: 44px;
      }

      .story-card-visual-logo {
        max-height: 27px;
      }

      .story-card h2 {
        font-size: 22px;
      }

      .story-card-featured .story-card-visual {
        min-height: 420px;
      }

      .story-card-featured h2 {
        font-size: 28px;
      }

      .story-card-body {
        padding: 0;
      }
    }

    /* ── Case story detail page ── */
    .case-story {
      max-width: 1320px;
      margin: 56px auto 0;
      padding: 0 24px;
    }

    .case-story-shell {
      padding: 12px 0 0;
    }

    .case-story-back {
      display: inline-flex;
      align-items: center;
      gap: 8px;
      text-decoration: none;
      font-size: 14.5px;
      font-weight: 500;
      color: #3b7ddb;
      margin-bottom: 26px;
      transition: opacity 0.2s ease;
    }

    .case-story-back:hover {
      opacity: 0.75;
    }

    .case-story-top {
      display: grid;
      grid-template-columns: minmax(0, 1fr) 270px;
      gap: 32px;
      align-items: start;
      margin-top: 22px;
    }

    .case-story-eyebrow {
      font-size: 13px;
      font-weight: 600;
      text-transform: uppercase;
      letter-spacing: 0.08em;
      color: #8892a1;
      margin-bottom: 12px;
    }

    .case-story-intro h1 {
      max-width: 15ch;
      font-size: clamp(40px, 5vw, 68px);
      font-weight: 500;
      letter-spacing: -2.2px;
      line-height: 0.98;
      color: #1a2533;
    }

    .case-story-intro p {
      margin-top: 20px;
      max-width: 760px;
      font-size: 20px;
      line-height: 1.65;
      color: #5a6270;
    }

    .case-story-overview {
      display: grid;
      gap: 14px;
      align-self: end;
    }

    .case-story-overview-card {
      display: grid;
      gap: 12px;
      padding: 22px;
      border-radius: 20px;
      background: rgba(255, 255, 255, 0.72);
      border: 1px solid rgba(219, 226, 236, 0.8);
    }

    .case-story-overview-logo {
      width: auto;
      max-width: 160px;
      max-height: 34px;
      object-fit: contain;
    }

    .case-story-overview-card p {
      font-size: 18px;
      font-weight: 600;
      color: #1a2533;
    }

    .case-story-overview-card span {
      font-size: 14px;
      color: #647083;
    }

    .case-story-share {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      min-height: 46px;
      padding: 0 18px;
      border: 0;
      border-radius: 999px;
      text-decoration: none;
      background: #111111;
      color: #ffffff;
      cursor: pointer;
      font: inherit;
      font-size: 14px;
      font-weight: 600;
      transition: transform 0.2s ease, opacity 0.2s ease;
    }

    .case-story-share:hover {
      transform: translateY(-1px);
      opacity: 0.92;
    }

    .case-story-share:focus-visible {
      outline: 3px solid rgba(59, 125, 219, 0.35);
      outline-offset: 3px;
    }

    .case-story-media {
      position: relative;
      margin-top: 32px;
      min-height: clamp(320px, 52vh, 620px);
      border-radius: 28px;
      overflow: hidden;
      background-image:
        linear-gradient(180deg, rgba(8, 18, 30, 0.04) 0%, rgba(8, 18, 30, 0.38) 100%),
        var(
          --case-story-bg-image,
          linear-gradient(136deg, rgba(59, 125, 219, 0.85) 0%, rgba(91, 163, 217, 0.8) 100%)
        );
      background-size: cover;
      background-position: center;
      background-repeat: no-repeat;
      box-shadow: inset 0 -90px 120px rgba(8, 22, 38, 0.2);
    }

    .case-story-media::after {
      content: '';
      position: absolute;
      inset: auto 0 0;
      height: 56%;
      background: linear-gradient(180deg, rgba(8, 22, 40, 0) 0%, rgba(8, 22, 40, 0.52) 100%);
      pointer-events: none;
    }

    .case-story-media-bar {
      position: absolute;
      top: 24px;
      left: 24px;
      z-index: 1;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      max-width: min(420px, calc(100% - 48px));
      min-height: 54px;
      padding: 12px 18px;
      border-radius: 16px;
      background: rgba(255, 255, 255, 0.9);
    }

    .case-story-media-logo {
      display: block;
      width: auto;
      max-width: 100%;
      max-height: 34px;
      object-fit: contain;
    }

    .case-story-media-logo-fallback {
      font-size: 13px;
      font-weight: 700;
      letter-spacing: 0.08em;
      text-transform: uppercase;
      color: #234f83;
      white-space: nowrap;
    }

    .case-story-body {
      display: grid;
      grid-template-columns: 280px minmax(0, 1fr);
      gap: 42px;
      margin-top: 38px;
      align-items: start;
    }

    .case-story-sidebar {
      position: sticky;
      top: 108px;
      display: grid;
      gap: 24px;
    }

    .case-story-sidebar-section {
      display: grid;
      gap: 10px;
    }

    .case-story-sidebar-label {
      font-size: 12px;
      font-weight: 700;
      letter-spacing: 0.12em;
      text-transform: uppercase;
      color: #8892a1;
    }

    .case-story-sidebar-copy {
      font-size: 15px;
      line-height: 1.75;
      color: #5a6270;
    }

    .case-story-highlights {
      display: grid;
      grid-template-columns: 1fr;
      gap: 10px;
    }

    .case-story-highlight {
      border-radius: 18px;
      background: rgba(255, 255, 255, 0.74);
      border: 1px solid rgba(219, 226, 236, 0.8);
      padding: 16px 18px;
    }

    .case-story-highlight-label {
      font-size: 11px;
      font-weight: 600;
      text-transform: uppercase;
      letter-spacing: 0.08em;
      color: #8a919c;
      margin-bottom: 8px;
    }

    .case-story-highlight-value {
      font-size: 15px;
      line-height: 1.45;
      color: #1a2533;
      font-weight: 600;
    }

    .case-story-content {
      display: grid;
      gap: 38px;
    }

    .case-story-article-section {
      display: grid;
      gap: 18px;
      padding-top: 12px;
      border-top: 1px solid rgba(203, 211, 222, 0.68);
    }

    .case-story-article-section h2 {
      font-size: 32px;
      font-weight: 500;
      letter-spacing: -0.8px;
      color: #1a2533;
    }

    .case-story-article-section > p {
      max-width: 72ch;
      font-size: 18px;
      line-height: 1.8;
      color: #4f5a6c;
    }

    .case-story-block-stack {
      display: grid;
      gap: 26px;
    }

    .case-story-block {
      padding: 0 0 26px;
      border-bottom: 1px solid rgba(218, 225, 235, 0.76);
    }

    .case-story-block h2 {
      font-size: 24px;
      font-weight: 500;
      color: #1a2533;
      letter-spacing: -0.35px;
      margin-bottom: 12px;
    }

    .case-story-block p {
      max-width: 70ch;
      font-size: 17px;
      line-height: 1.9;
      color: #5a6270;
    }

    .case-story-block p + p {
      margin-top: 10px;
    }

    .case-story-list {
      margin-top: 12px;
      padding-left: 20px;
      display: grid;
      gap: 8px;
      color: #5a6270;
      font-size: 16px;
      line-height: 1.8;
    }

    @media (max-width: 1024px) {
      .case-story-top {
        grid-template-columns: 1fr;
      }

      .case-story-overview {
        grid-template-columns: minmax(0, 1fr) auto;
        align-items: stretch;
      }

      .case-story-body {
        grid-template-columns: 1fr;
        gap: 28px;
      }

      .case-story-sidebar {
        position: static;
      }

      .case-story-highlights {
        grid-template-columns: repeat(2, minmax(0, 1fr));
      }
    }

    @media (max-width: 768px) {
      .case-story {
        margin-top: 64px;
      }

      .case-story-media {
        margin-top: 24px;
        min-height: 240px;
        border-radius: 18px;
      }

      .case-story-media-bar {
        top: 14px;
        left: 14px;
        min-height: 46px;
        padding: 10px 12px;
        max-width: calc(100% - 28px);
      }

      .case-story-media-logo {
        max-height: 28px;
      }

      .case-story-top {
        gap: 22px;
      }

      .case-story-intro h1 {
        font-size: 34px;
        letter-spacing: -1.2px;
      }

      .case-story-intro p {
        font-size: 17px;
      }

      .case-story-overview {
        grid-template-columns: 1fr;
      }

      .case-story-highlights {
        grid-template-columns: 1fr;
      }

      .case-story-article-section h2 {
        font-size: 26px;
      }

      .case-story-block {
        padding: 0 0 22px;
      }

      .case-story-block h2 {
        font-size: 21px;
      }
    }

    /* ── Vision page ── */
    .vision-hero {
      position: relative;
      max-width: 1280px;
      margin: 24px auto 0;
      padding: 0 24px;
      isolation: isolate;
    }

    .vision-hero-orb {
      position: absolute;
      border-radius: 50%;
      filter: blur(56px);
      z-index: 0;
      pointer-events: none;
      animation: vision-drift 18s ease-in-out infinite;
    }

    .vision-hero-orb-1 {
      width: 280px;
      height: 280px;
      top: -62px;
      left: 92px;
      background: rgba(127, 185, 236, 0.35);
    }

    .vision-hero-orb-2 {
      width: 320px;
      height: 320px;
      right: 68px;
      bottom: -110px;
      background: rgba(99, 159, 219, 0.24);
      animation-delay: -9s;
    }

    .vision-hero-grid {
      position: absolute;
      inset: 0 24px;
      border-radius: 30px;
      background-image:
        linear-gradient(rgba(90, 126, 169, 0.12) 1px, transparent 1px),
        linear-gradient(90deg, rgba(90, 126, 169, 0.12) 1px, transparent 1px);
      background-size: 34px 34px;
      opacity: 0.46;
      mask-image: radial-gradient(circle at 40% 34%, black 40%, transparent 100%);
      -webkit-mask-image: radial-gradient(circle at 40% 34%, black 40%, transparent 100%);
      z-index: 0;
      pointer-events: none;
    }

    .vision-hero-inner {
      position: relative;
      z-index: 1;
      border-radius: 30px;
      padding: 84px 72px 80px;
      background:
        linear-gradient(132deg, rgba(255, 255, 255, 0.96) 0%, rgba(236, 244, 253, 0.95) 63%, rgba(225, 239, 253, 0.95) 100%);
      border: 1px solid rgba(122, 161, 205, 0.24);
      box-shadow:
        0 22px 44px rgba(19, 53, 98, 0.12),
        0 1px 0 rgba(255, 255, 255, 0.78) inset;
      animation: vision-fade-up 0.85s ease both;
    }

    .vision-eyebrow {
      font-size: 12px;
      font-weight: var(--font-ui-weight);
      letter-spacing: var(--tracking-label);
      text-transform: uppercase;
      color: #2f67ad;
      margin-bottom: 14px;
    }

    .vision-hero h1 {
      max-width: 860px;
      font-size: 56px;
      line-height: var(--line-display);
      letter-spacing: var(--tracking-display-tight);
      color: #15273f;
      margin-bottom: 18px;
    }

    .vision-hero-lead {
      max-width: 760px;
      font-size: 18px;
      line-height: 1.82;
      color: #384f6d;
      margin-bottom: 14px;
    }

    .vision-hero-sub {
      max-width: 700px;
      font-size: 16px;
      line-height: 1.8;
      color: #4b6180;
    }

    .vision-story,
    .vision-consequences,
    .vision-outlook {
      max-width: 1280px;
      margin: 76px auto 0;
      padding: 0 24px;
    }

    .vision-story {
      display: grid;
      grid-template-columns: minmax(0, 1.15fr) minmax(0, 0.85fr);
      gap: 18px;
      align-items: start;
    }

    .vision-story-panel {
      border-radius: 22px;
      border: 1px solid rgba(101, 137, 179, 0.18);
      background: rgba(255, 255, 255, 0.64);
      backdrop-filter: blur(22px) saturate(1.2);
      -webkit-backdrop-filter: blur(22px) saturate(1.2);
      box-shadow:
        0 14px 30px rgba(29, 53, 86, 0.08),
        0 1px 0 rgba(255, 255, 255, 0.74) inset;
      animation: vision-fade-up 0.8s ease both;
    }

    .vision-story-copy {
      padding: 34px 34px 30px;
      animation-delay: 0.1s;
    }

    .vision-story-copy h2 {
      font-size: 34px;
      line-height: 1.13;
      letter-spacing: -0.85px;
      color: #172a43;
      margin-bottom: 14px;
    }

    .vision-story-copy p {
      font-size: 15.5px;
      line-height: 1.82;
      color: #4a5e79;
    }

    .vision-story-copy p + p {
      margin-top: 12px;
    }

    .vision-signal-grid {
      display: grid;
      gap: 12px;
    }

    .vision-signal-card {
      position: relative;
      overflow: hidden;
      padding: 24px 24px 22px;
      animation-delay: 0.18s;
    }

    .vision-signal-card:nth-child(2) {
      animation-delay: 0.24s;
    }

    .vision-signal-card:nth-child(3) {
      animation-delay: 0.3s;
    }


    .vision-signal-card h3 {
      font-size: 22px;
      letter-spacing: -0.4px;
      line-height: 1.24;
      color: #1a304c;
      margin-bottom: 10px;
    }

    .vision-signal-card p {
      font-size: 14.5px;
      line-height: 1.76;
      color: #536982;
    }

    .vision-consequences-head {
      max-width: 760px;
      margin-bottom: 24px;
      text-align: center;
      margin-left: auto;
      margin-right: auto;
    }

    .vision-consequences-head h2 {
      font-size: 42px;
      line-height: 1.1;
      letter-spacing: -1.15px;
      color: #162b47;
    }

    .vision-consequence-grid {
      display: grid;
      grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: 16px;
    }

    .vision-consequence-card {
      border-radius: 20px;
      border: 1px solid rgba(95, 133, 177, 0.17);
      background: rgba(255, 255, 255, 0.75);
      box-shadow:
        0 12px 26px rgba(24, 52, 88, 0.07),
        0 1px 0 rgba(255, 255, 255, 0.84) inset;
      padding: 24px 22px;
      transition: transform 0.22s ease, box-shadow 0.22s ease, border-color 0.22s ease;
      animation: vision-fade-up 0.8s ease both;
      animation-delay: 0.14s;
    }

    .vision-consequence-card:nth-child(2) {
      animation-delay: 0.2s;
    }

    .vision-consequence-card:nth-child(3) {
      animation-delay: 0.26s;
    }

    .vision-consequence-card:hover {
      transform: translateY(-3px);
      border-color: rgba(59, 125, 219, 0.35);
      box-shadow:
        0 16px 30px rgba(24, 52, 88, 0.12),
        0 1px 0 rgba(255, 255, 255, 0.9) inset;
    }

    .vision-consequence-index {
      font-size: 11px;
      font-weight: 700;
      letter-spacing: 0.12em;
      color: #316cad;
      margin-bottom: 10px;
    }

    .vision-consequence-card h3 {
      font-size: 22px;
      line-height: 1.24;
      letter-spacing: -0.36px;
      color: #1a304c;
      margin-bottom: 10px;
    }

    .vision-consequence-card p {
      font-size: 14.5px;
      line-height: 1.78;
      color: #4f637d;
    }

    .vision-outlook {
      margin-top: 58px;
    }

    .vision-outlook-card {
      position: relative;
      overflow: hidden;
      border-radius: 24px;
      padding: 42px;
      background:
        linear-gradient(137deg, rgba(240, 247, 255, 0.95) 0%, rgba(226, 239, 252, 0.95) 55%, rgba(219, 235, 250, 0.94) 100%);
      border: 1px solid rgba(91, 132, 179, 0.22);
      box-shadow:
        0 22px 40px rgba(24, 53, 90, 0.12),
        0 1px 0 rgba(255, 255, 255, 0.82) inset;
      animation: vision-fade-up 0.82s ease both;
      animation-delay: 0.16s;
    }

    .vision-outlook-card::after {
      content: '';
      position: absolute;
      inset: auto -6% -60% 42%;
      height: 330px;
      border-radius: 50%;
      background: radial-gradient(circle, rgba(117, 177, 230, 0.3) 0%, rgba(117, 177, 230, 0) 70%);
      pointer-events: none;
    }

    .vision-outlook-card h2 {
      max-width: 840px;
      font-size: 40px;
      line-height: 1.1;
      letter-spacing: -1.05px;
      color: #13263e;
      margin-bottom: 14px;
    }

    .vision-outlook-card p {
      max-width: 860px;
      font-size: 16px;
      line-height: 1.82;
      color: #4a607c;
      position: relative;
      z-index: 1;
    }

    .vision-outlook-card p + p {
      margin-top: 8px;
    }

    .vision-outlook-cta {
      margin-top: 22px;
      display: inline-flex;
      align-items: center;
      gap: 8px;
      text-decoration: none;
      border-radius: 980px;
      font-size: 14px;
      font-weight: 600;
      color: #fff;
      background: linear-gradient(132deg, #346fb6 0%, #5aa0d7 100%);
      padding: 12px 20px;
      box-shadow: 0 12px 22px rgba(46, 94, 156, 0.27);
      transition: transform 0.2s ease, box-shadow 0.2s ease;
      position: relative;
      z-index: 1;
    }

    .vision-outlook-cta:hover {
      transform: translateY(-1px);
      box-shadow: 0 15px 26px rgba(46, 94, 156, 0.33);
    }

    .vision-outlook-cta svg {
      width: 14px;
      height: 14px;
      transition: transform 0.2s ease;
    }

    .vision-outlook-cta:hover svg {
      transform: translateX(3px);
    }

    @keyframes vision-drift {
      0%,
      100% {
        transform: translate3d(0, 0, 0) scale(1);
      }
      35% {
        transform: translate3d(10px, -12px, 0) scale(1.05);
      }
      70% {
        transform: translate3d(-12px, 8px, 0) scale(0.96);
      }
    }

    @keyframes vision-fade-up {
      from {
        opacity: 0;
        transform: translate3d(0, 14px, 0);
      }
      to {
        opacity: 1;
        transform: translate3d(0, 0, 0);
      }
    }

    @keyframes vision-shimmer {
      0% {
        background-position: 0% 50%;
      }
      100% {
        background-position: 220% 50%;
      }
    }

    @media (max-width: 1080px) {
      .vision-hero-inner {
        padding: 72px 46px 66px;
      }

      .vision-hero h1 {
        font-size: 46px;
        letter-spacing: -1.45px;
      }

      .vision-story {
        grid-template-columns: 1fr;
      }

      .vision-consequence-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
      }

      .vision-consequences-head h2,
      .vision-outlook-card h2 {
        font-size: 34px;
        letter-spacing: -0.85px;
      }
    }

    @media (max-width: 768px) {
      .vision-hero {
        margin-top: 16px;
        padding: 0 16px;
      }

      .vision-hero-grid {
        inset: 0 16px;
        border-radius: 22px;
      }

      .vision-hero-inner {
        border-radius: 22px;
        padding: 48px 24px 42px;
      }

      .vision-hero h1 {
        font-size: 34px;
        line-height: 1.1;
        letter-spacing: -0.95px;
      }

      .vision-hero-lead,
      .vision-hero-sub {
        font-size: 15.5px;
      }

      .vision-story,
      .vision-consequences,
      .vision-outlook {
        margin-top: 56px;
        padding: 0 16px;
      }

      .vision-story-copy {
        padding: 24px 22px;
      }

      .vision-story-copy h2 {
        font-size: 28px;
      }

      .vision-signal-card h3,
      .vision-consequence-card h3 {
        font-size: 20px;
      }

      .vision-consequence-grid {
        grid-template-columns: 1fr;
      }

      .vision-consequences-head h2,
      .vision-outlook-card h2 {
        font-size: 30px;
      }

      .vision-outlook {
        margin-top: 42px;
      }

      .vision-outlook-card {
        border-radius: 20px;
        padding: 28px 24px;
      }

      .vision-outlook-card p {
        font-size: 15px;
      }

      .vision-outlook-cta {
        width: 100%;
        justify-content: center;
      }
    }

    @media (prefers-reduced-motion: reduce) {
      .vision-hero-orb,
      .vision-story-panel,
      .vision-consequence-card,
      .vision-outlook-card,
      .vision-signal-card::before {
        animation: none;
      }

      .vision-outlook-cta,
      .vision-consequence-card {
        transition: none;
      }

      .home-services-reveal::before,
      .home-services-reveal-sweep,
      .home-services-reveal-sweep::after,
      .home-service-node,
      .home-service-node::before,
      .home-service-track-link svg {
        animation: none;
        transition: none;
      }

      .home-service-node {
        opacity: 1;
        transform: none;
      }
    }

/* ── Services intro header ── */
.services-intro {
  max-width: 780px;
  margin: 80px auto 0;
  padding: 0 24px;
  text-align: center;
}

.services-intro-label {
  font-size: 12.5px;
  font-weight: var(--font-ui-weight);
  text-transform: uppercase;
  letter-spacing: var(--tracking-label);
  color: #3b7ddb;
  margin-bottom: 12px;
}

.services-intro h1 {
  font-size: clamp(32px, 5vw, 52px);
  font-weight: var(--font-display-weight);
  letter-spacing: var(--tracking-display-tight);
  line-height: var(--line-display);
  color: #1a2533;
  margin-bottom: 16px;
}

.services-intro-sub {
  font-size: 17px;
  line-height: 1.75;
  color: #5a6270;
  max-width: 580px;
  margin: 0 auto;
}

/* ── Per-category detail sections ── */
.service-category-sections {
  margin-top: 0;
}

.service-category-section {
  max-width: 1080px;
  margin: 80px auto 0;
  padding: 0 24px;
}

.service-category-section + .service-category-section {
  margin-top: 60px;
  padding-top: 64px;
  border-top: 1px solid rgba(200, 215, 240, 0.7);
}

.service-category-header {
  margin-bottom: 32px;
}

.service-category-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  font-size: 11.5px;
  font-weight: var(--font-ui-weight);
  text-transform: uppercase;
  letter-spacing: var(--tracking-label);
  color: #3b7ddb;
  margin-bottom: 12px;
}

.service-category-eyebrow::before {
  content: '';
  display: inline-block;
  width: 6px;
  height: 6px;
  background: #3b7ddb;
  border-radius: 50%;
  flex-shrink: 0;
}

.service-category-header h2 {
  font-size: clamp(26px, 3.8vw, 42px);
  font-weight: var(--font-display-weight);
  letter-spacing: var(--tracking-display);
  color: #1a2533;
  margin-bottom: 12px;
  line-height: var(--line-display-relaxed);
}

.service-category-description {
  font-size: 16px;
  line-height: 1.75;
  color: #5a6270;
  max-width: 640px;
}

/* ── Service detail block ── */
.service-detail-block {
  background: rgba(255, 255, 255, 0.92);
  border: 1px solid rgba(200, 215, 240, 0.65);
  border-radius: 20px;
  padding: 0;
  margin-bottom: 16px;
  overflow: hidden;
  box-shadow:
    0 2px 4px rgba(26, 37, 51, 0.04),
    0 12px 40px rgba(26, 37, 51, 0.07),
    inset 0 1px 0 rgba(255, 255, 255, 0.9);
}

.service-detail-block-top {
  padding: 32px 40px 28px;
  background: linear-gradient(140deg, rgba(59, 125, 219, 0.07) 0%, rgba(100, 160, 240, 0.02) 55%, transparent 100%);
  border-bottom: 1px solid rgba(59, 125, 219, 0.09);
}

.service-detail-category {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: #3b7ddb;
  margin-bottom: 8px;
}

.service-detail-block-top h3 {
  font-size: clamp(22px, 3vw, 32px);
  font-weight: 500;
  letter-spacing: -0.6px;
  color: #1a2533;
  margin-bottom: 10px;
  line-height: 1.16;
}

.service-detail-intro {
  font-size: 15px;
  line-height: 1.75;
  color: #526074;
  max-width: 740px;
  margin: 0;
}

/* ── Pillar grid ── */
.service-pillars-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 12px;
  padding: 28px 40px 24px;
}

.service-pillar-tile {
  padding: 18px 20px;
  background: #ffffff;
  border: 1px solid rgba(59, 125, 219, 0.13);
  border-radius: 14px;
  display: flex;
  flex-direction: column;
  gap: 6px;
  box-shadow: 0 2px 8px rgba(26, 37, 51, 0.05);
}

.service-pillar-index {
  font-size: 10.5px;
  font-weight: 700;
  letter-spacing: 0.1em;
  color: #3b7ddb;
  font-variant-numeric: tabular-nums;
}

.service-pillar-tile strong {
  font-size: 13.5px;
  font-weight: 600;
  color: #1a2533;
  line-height: 1.3;
}

.service-pillar-tile p {
  font-size: 13px;
  line-height: 1.65;
  color: #526074;
  margin: 0;
}

/* ── Advanced Prompt Training follow-up note ── */
.service-followup-note {
  font-size: 13.5px;
  line-height: 1.7;
  color: #3a4a5c;
  background: rgba(59, 125, 219, 0.05);
  border: 1px solid rgba(59, 125, 219, 0.12);
  border-radius: 12px;
  padding: 14px 18px;
  margin: 0 40px 0;
}

.service-followup-note strong {
  font-weight: 600;
  color: #1a2533;
}

/* ── Impact list + CTA footer ── */
.service-detail-footer {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 24px;
  padding: 20px 40px 28px;
  border-top: 1px solid rgba(0, 0, 0, 0.06);
  margin-top: 24px;
  flex-wrap: wrap;
}

.service-impact-list {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 7px;
  flex: 1;
  min-width: 0;
}

.service-impact-list li {
  font-size: 14px;
  line-height: 1.5;
  color: #3a4a5c;
  padding-left: 22px;
  position: relative;
}

.service-impact-list li::before {
  content: '✓';
  position: absolute;
  left: 0;
  color: #3b7ddb;
  font-weight: 700;
  font-size: 13px;
}

.service-detail-cta {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  white-space: nowrap;
  font-size: 13px;
  font-weight: 600;
  color: #ffffff;
  background: #2f6ab1;
  text-decoration: none;
  flex-shrink: 0;
  padding: 9px 16px;
  border-radius: 8px;
  transition: background 0.2s ease, transform 0.15s ease;
  align-self: flex-end;
}

.service-detail-cta:hover {
  background: #2460a0;
}

.service-detail-cta svg {
  width: 14px;
  height: 14px;
  transition: transform 0.2s ease;
}

.service-detail-cta:hover svg {
  transform: translateX(3px);
}

@media (max-width: 860px) {
  .service-detail-block-top {
    padding: 24px 28px 22px;
  }

  .service-pillars-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    padding: 22px 28px 18px;
  }

  .service-followup-note {
    margin: 0 28px 0;
  }

  .service-detail-footer {
    padding: 18px 28px 24px;
  }
}

@media (max-width: 600px) {
  .service-detail-block-top {
    padding: 20px 20px 18px;
  }

  .service-pillars-grid {
    grid-template-columns: 1fr;
    padding: 18px 20px 16px;
  }

  .service-followup-note {
    margin: 0 20px 0;
  }

  .service-detail-footer {
    flex-direction: column;
    padding: 16px 20px 22px;
  }

  .service-detail-cta {
    align-self: flex-start;
  }

  .service-category-section {
    padding: 0 16px;
  }
}

/* ── Procurement note ── */
.services-procurement-note {
  max-width: 1080px;
  margin: 64px auto 80px;
  padding: 0 24px;
}

.services-procurement-note-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 32px;
  padding: 28px 36px;
  background: rgba(255, 255, 255, 0.7);
  border: 1px solid rgba(59, 125, 219, 0.12);
  border-radius: 16px;
  box-shadow: 0 2px 12px rgba(26, 37, 51, 0.04);
  flex-wrap: wrap;
}

.services-procurement-note-label {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: #3b7ddb;
  margin-bottom: 4px;
}

.services-procurement-note-copy h2 {
  font-size: 20px;
  font-weight: 600;
  letter-spacing: -0.3px;
  color: #1a2533;
  margin-bottom: 4px;
}

.services-procurement-note-copy p {
  font-size: 14px;
  line-height: 1.65;
  color: #526074;
  max-width: 560px;
}

.services-procurement-note-link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 13.5px;
  font-weight: 600;
  color: #fff;
  background: #2f6ab1;
  text-decoration: none;
  padding: 11px 20px;
  border-radius: 9px;
  white-space: nowrap;
  flex-shrink: 0;
  transition: background 0.2s ease;
}

.services-procurement-note-link:hover {
  background: #2460a0;
}

.services-procurement-note-link svg {
  width: 14px;
  height: 14px;
  transition: transform 0.2s ease;
}

.services-procurement-note-link:hover svg {
  transform: translateX(3px);
}

@media (max-width: 600px) {
  .services-procurement-note-inner {
    flex-direction: column;
    align-items: flex-start;
    padding: 22px 24px;
  }
}

/* ── Workshop offering pages ── */
.workshop-hero,
.workshop-detail-hero {
  position: relative;
  overflow: hidden;
  margin: 24px 24px 0;
  border-radius: 32px;
  background:
    radial-gradient(circle at 82% 14%, rgba(127, 197, 239, 0.42), transparent 28%),
    radial-gradient(circle at 10% 82%, rgba(59, 125, 219, 0.36), transparent 30%),
    linear-gradient(145deg, #132c54 0%, #214779 70%, #2d6199 100%);
  color: #fff;
  isolation: isolate;
}

.workshop-hero {
  min-height: 620px;
  padding: 96px 0;
}

.workshop-hero-inner,
.workshop-detail-hero-inner {
  position: relative;
  z-index: 1;
  max-width: 1120px;
  margin: 0 auto;
  padding: 0 56px;
}

.workshop-hero-inner {
  max-width: 1000px;
}

.workshop-hero-label,
.workshop-card-category,
.workshop-section-heading p,
.workshop-process-copy p,
.workshop-final-cta p,
.workshop-detail-card > span,
.workshop-detail-context-card p,
.workshop-outcomes-panel p,
.workshop-related-copy p {
  font-size: 12px;
  font-weight: var(--font-ui-weight);
  text-transform: uppercase;
  letter-spacing: var(--tracking-label);
}

.workshop-hero-label {
  color: rgba(255, 255, 255, 0.72);
  margin-bottom: 14px;
}

.workshop-hero h1,
.workshop-detail-copy h1 {
  max-width: 860px;
  font-size: 58px;
  line-height: var(--line-display);
  letter-spacing: var(--tracking-display-tight);
  color: #fff;
  margin-bottom: 22px;
}

.workshop-hero-sub,
.workshop-detail-copy > p {
  max-width: 760px;
  font-size: 17px;
  line-height: 1.8;
  color: rgba(255, 255, 255, 0.84);
  margin-bottom: 32px;
}

.workshop-hero-actions {
  display: flex;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
}

.workshop-hero-cta,
.workshop-final-cta a {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  border-radius: 980px;
  text-decoration: none;
  background: #fff;
  color: #1a2533;
  padding: 12px 24px;
  font-size: 14px;
  font-weight: 600;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.18);
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.workshop-hero-cta:hover,
.workshop-final-cta a:hover {
  transform: translateY(-1px);
  box-shadow: 0 12px 28px rgba(0, 0, 0, 0.22);
}

.workshop-hero-cta svg,
.workshop-final-cta a svg,
.workshop-card-link svg,
.workshop-related-links svg {
  width: 15px;
  height: 15px;
  transition: transform 0.2s ease;
}

.workshop-hero-cta:hover svg,
.workshop-final-cta a:hover svg,
.workshop-card:hover .workshop-card-link svg,
.workshop-related-links a:hover svg {
  transform: translateX(3px);
}

.workshop-hero-secondary {
  display: inline-flex;
  align-items: center;
  border-radius: 980px;
  text-decoration: none;
  border: 1px solid rgba(255, 255, 255, 0.34);
  color: rgba(255, 255, 255, 0.9);
  padding: 11px 22px;
  font-size: 14px;
  font-weight: 600;
  transition: background 0.2s ease, border-color 0.2s ease;
}

.workshop-hero-secondary:hover {
  background: rgba(255, 255, 255, 0.1);
  border-color: rgba(255, 255, 255, 0.52);
}

.workshop-hero-map {
  position: absolute;
  inset: 0;
  z-index: 0;
  opacity: 0.7;
  pointer-events: none;
}

.workshop-map-node {
  position: absolute;
  width: 150px;
  height: 150px;
  border-radius: 28px;
  border: 1px solid rgba(255, 255, 255, 0.18);
  background: rgba(255, 255, 255, 0.1);
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.2) inset;
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
}

.workshop-map-node::after {
  content: "";
  position: absolute;
  inset: 28px;
  border-radius: 20px;
  border: 1px solid rgba(157, 210, 244, 0.42);
  background:
    linear-gradient(rgba(255, 255, 255, 0.16) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255, 255, 255, 0.16) 1px, transparent 1px);
  background-size: 18px 18px;
}

.workshop-map-node-1 {
  right: 13%;
  top: 16%;
  transform: rotate(7deg);
}

.workshop-map-node-2 {
  right: 27%;
  bottom: 20%;
  transform: rotate(-5deg);
}

.workshop-map-node-3 {
  right: 4%;
  bottom: 10%;
  transform: rotate(12deg);
}

.workshop-map-line {
  position: absolute;
  height: 1px;
  transform-origin: left center;
  background: linear-gradient(90deg, transparent, rgba(157, 210, 244, 0.54), transparent);
}

.workshop-map-line-1 {
  right: 20%;
  top: 46%;
  width: 240px;
  transform: rotate(28deg);
}

.workshop-map-line-2 {
  right: 10%;
  top: 62%;
  width: 260px;
  transform: rotate(-24deg);
}

.workshop-offerings,
.workshop-process,
.workshop-detail-context,
.workshop-detail-modules,
.workshop-detail-outcomes,
.workshop-related,
.workshop-final-cta {
  max-width: 1120px;
  margin: 72px auto 0;
  padding: 0 24px;
}

.workshop-section-heading {
  max-width: 760px;
  margin-bottom: 34px;
}

.workshop-section-heading p,
.workshop-process-copy p,
.workshop-detail-context-card p,
.workshop-related-copy p {
  color: #3b7ddb;
  margin-bottom: 10px;
}

.workshop-section-heading h2,
.workshop-process-copy h2,
.workshop-related-copy h2 {
  font-size: 42px;
  line-height: 1.12;
  letter-spacing: -1.1px;
  color: #1a2533;
}

.workshop-overview-groups {
  display: grid;
  gap: 28px;
}

.workshop-overview-group {
  display: grid;
  grid-template-columns: 0.42fr 1fr;
  gap: 24px;
  align-items: start;
}

.workshop-overview-group-copy {
  position: sticky;
  top: 84px;
  padding: 28px;
  border-radius: 22px;
  background: rgba(255, 255, 255, 0.42);
  border: 1px solid rgba(255, 255, 255, 0.54);
  box-shadow:
    0 4px 24px rgba(0, 0, 0, 0.03),
    0 1px 0 rgba(255, 255, 255, 0.62) inset;
  backdrop-filter: blur(24px) saturate(1.3);
  -webkit-backdrop-filter: blur(24px) saturate(1.3);
}

.workshop-overview-group-copy h3 {
  font-size: 26px;
  line-height: 1.18;
  letter-spacing: -0.6px;
  color: #1a2533;
  margin-bottom: 12px;
}

.workshop-overview-group-copy p,
.workshop-card p,
.workshop-process-step p,
.workshop-module p,
.workshop-detail-context-card span,
.workshop-final-cta span {
  font-size: 15px;
  line-height: 1.75;
  color: #5a6270;
}

.procurement-sub-offerings {
  max-width: 1080px;
  margin: 72px auto 0;
  padding: 0 24px;
}

.workshop-card-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 20px;
}

.workshop-card {
  display: flex;
  flex-direction: column;
  min-height: 300px;
  text-decoration: none;
  color: inherit;
  border-radius: 22px;
  padding: 28px;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.88) 0%, rgba(246, 250, 255, 0.82) 100%);
  border: 1px solid rgba(255, 255, 255, 0.62);
  box-shadow:
    0 10px 28px rgba(26, 37, 51, 0.06),
    0 1px 0 rgba(255, 255, 255, 0.72) inset;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.workshop-card:hover {
  transform: translateY(-2px);
  box-shadow:
    0 16px 36px rgba(26, 37, 51, 0.1),
    0 1px 0 rgba(255, 255, 255, 0.82) inset;
}

.workshop-card-category {
  color: #3b7ddb;
  margin-bottom: 12px;
}

.workshop-card h4 {
  font-size: 27px;
  line-height: 1.18;
  letter-spacing: -0.65px;
  color: #1a2533;
  margin-bottom: 12px;
}

.workshop-card-meta {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-top: 20px;
}

.workshop-card-meta span {
  display: inline-flex;
  align-items: center;
  border-radius: 980px;
  background: rgba(59, 125, 219, 0.1);
  color: #2f6ab1;
  padding: 6px 10px;
  font-size: 12px;
  font-weight: 700;
}

.workshop-card-link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-top: auto;
  padding-top: 24px;
  color: #2f6ab1;
  font-size: 14px;
  font-weight: 700;
}

.workshop-process-panel,
.workshop-detail-context-card {
  border-radius: 28px;
  background: rgba(255, 255, 255, 0.48);
  border: 1px solid rgba(255, 255, 255, 0.58);
  box-shadow:
    0 10px 34px rgba(26, 37, 51, 0.06),
    0 1px 0 rgba(255, 255, 255, 0.64) inset;
  padding: 36px;
  backdrop-filter: blur(24px) saturate(1.25);
  -webkit-backdrop-filter: blur(24px) saturate(1.25);
}

.workshop-process-panel {
  display: grid;
  grid-template-columns: 0.42fr 1fr;
  gap: 34px;
}

.workshop-process-steps {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
}

.workshop-process-step,
.workshop-module {
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.56);
  border: 1px solid rgba(59, 125, 219, 0.1);
  padding: 24px;
}

.workshop-process-step span,
.workshop-module span {
  display: inline-flex;
  color: #3b7ddb;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.1em;
  margin-bottom: 12px;
}

.workshop-process-step h3,
.workshop-module h3 {
  font-size: 21px;
  line-height: 1.25;
  letter-spacing: -0.35px;
  color: #1a2533;
  margin-bottom: 10px;
}

.workshop-detail-hero {
  padding: 88px 0;
}

.workshop-detail-hero-inner {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 360px;
  gap: 48px;
  align-items: end;
}

.workshop-detail-card {
  border-radius: 24px;
  padding: 28px;
  background: rgba(255, 255, 255, 0.12);
  border: 1px solid rgba(255, 255, 255, 0.18);
  box-shadow: 0 18px 36px rgba(0, 0, 0, 0.12);
  backdrop-filter: blur(24px) saturate(1.3);
  -webkit-backdrop-filter: blur(24px) saturate(1.3);
}

.workshop-detail-card > span {
  display: inline-flex;
  color: rgba(255, 255, 255, 0.76);
  margin-bottom: 22px;
}

.workshop-detail-card dl {
  display: grid;
  gap: 18px;
}

.workshop-detail-card div {
  padding-bottom: 18px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.15);
}

.workshop-detail-card div:last-child {
  padding-bottom: 0;
  border-bottom: 0;
}

.workshop-detail-card dt {
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: rgba(255, 255, 255, 0.58);
  margin-bottom: 6px;
}

.workshop-detail-card dd {
  font-size: 15px;
  line-height: 1.6;
  color: rgba(255, 255, 255, 0.88);
}

.workshop-detail-context {
  margin-top: 30px;
}

.workshop-detail-context-card {
  max-width: none;
}

.workshop-detail-context-card h2 {
  font-size: 34px;
  line-height: 1.16;
  letter-spacing: -0.8px;
  color: #1a2533;
  margin-bottom: 12px;
}

.workshop-module-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

.workshop-outcomes-panel {
  display: grid;
  grid-template-columns: 0.45fr 1fr;
  gap: 36px;
  align-items: start;
  border-radius: 28px;
  padding: 38px;
  color: #fff;
  background: linear-gradient(145deg, #132c54 0%, #214779 72%, #2d6199 100%);
  border: 1px solid rgba(255, 255, 255, 0.15);
  box-shadow: 0 18px 36px rgba(19, 44, 84, 0.22);
}

.workshop-outcomes-panel p,
.workshop-final-cta p {
  color: rgba(255, 255, 255, 0.66);
  margin-bottom: 10px;
}

.workshop-outcomes-panel h2,
.workshop-final-cta h2 {
  font-size: 36px;
  line-height: 1.14;
  letter-spacing: -0.85px;
  color: #fff;
}

.workshop-outcomes-panel ul {
  display: grid;
  gap: 14px;
  list-style: none;
}

.workshop-outcomes-panel li {
  position: relative;
  padding-left: 20px;
  font-size: 15px;
  line-height: 1.75;
  color: rgba(255, 255, 255, 0.88);
}

.workshop-outcomes-panel li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 11px;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: #9dd2f4;
  box-shadow: 0 0 0 4px rgba(157, 210, 244, 0.18);
}

.workshop-related {
  display: flex;
  justify-content: space-between;
  gap: 28px;
  align-items: flex-start;
}

.workshop-related-copy {
  max-width: 520px;
}

.workshop-related-links {
  display: grid;
  gap: 10px;
  min-width: 300px;
}

.workshop-related-links a {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  text-decoration: none;
  color: #1a2533;
  padding: 14px 16px;
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.58);
  border: 1px solid rgba(255, 255, 255, 0.62);
  font-size: 14px;
  font-weight: 700;
  box-shadow: 0 6px 18px rgba(26, 37, 51, 0.05);
}

.workshop-final-cta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 28px;
  margin-bottom: 80px;
  border-radius: 28px;
  padding: 36px;
  background: linear-gradient(145deg, #132c54 0%, #214779 72%, #2d6199 100%);
  border: 1px solid rgba(255, 255, 255, 0.15);
  box-shadow: 0 18px 36px rgba(19, 44, 84, 0.22);
}

.workshop-final-cta div {
  max-width: 720px;
}

.workshop-final-cta span {
  display: inline-flex;
  margin-top: 10px;
  color: rgba(255, 255, 255, 0.78);
}

.workshop-final-cta a {
  flex-shrink: 0;
}

@media (max-width: 980px) {
  .workshop-overview-group,
  .workshop-process-panel,
  .workshop-detail-hero-inner,
  .workshop-outcomes-panel,
  .workshop-related,
  .workshop-final-cta {
    grid-template-columns: 1fr;
  }

  .workshop-overview-group {
    display: block;
  }

  .workshop-overview-group-copy {
    position: static;
    margin-bottom: 18px;
  }

  .workshop-detail-hero-inner,
  .workshop-related,
  .workshop-final-cta {
    display: flex;
    flex-direction: column;
    align-items: stretch;
  }

  .workshop-detail-card,
  .workshop-related-links {
    width: 100%;
  }

  .workshop-module-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 720px) {
  .workshop-hero,
  .workshop-detail-hero {
    margin: 16px 16px 0;
    border-radius: 24px;
    padding: 70px 0;
  }

  .workshop-hero-inner,
  .workshop-detail-hero-inner {
    padding: 0 24px;
  }

  .workshop-hero h1,
  .workshop-detail-copy h1 {
    font-size: 36px;
    letter-spacing: -1px;
  }

  .workshop-hero-sub,
  .workshop-detail-copy > p {
    font-size: 16px;
  }

  .workshop-map-node,
  .workshop-map-line {
    display: none;
  }

  .workshop-offerings,
  .workshop-process,
  .workshop-detail-context,
  .workshop-detail-modules,
  .workshop-detail-outcomes,
  .workshop-related,
  .workshop-final-cta {
    margin-top: 54px;
    padding: 0 16px;
  }

  .workshop-section-heading h2,
  .workshop-process-copy h2,
  .workshop-related-copy h2,
  .workshop-outcomes-panel h2,
  .workshop-final-cta h2 {
    font-size: 30px;
  }

  .workshop-card,
  .workshop-process-panel,
  .workshop-detail-context-card,
  .workshop-outcomes-panel,
  .workshop-final-cta {
    padding: 24px;
    border-radius: 22px;
  }

  .workshop-process-steps {
    grid-template-columns: 1fr;
  }

  .workshop-final-cta {
    margin-bottom: 58px;
  }
}

/* Subtle micro-interactions */
.micro-reveal {
  opacity: 0;
  translate: var(--micro-reveal-x, 0) 22px;
  scale: 0.985;
  filter: blur(8px);
}

.micro-reveal.is-micro-visible {
  opacity: 1;
  translate: 0 0;
  scale: 1;
  filter: blur(0);
}

.micro-spotlight {
  --micro-x: 50%;
  --micro-y: 50%;
  --micro-depth-x: 0px;
  --micro-depth-y: 0px;
  position: relative;
  isolation: isolate;
  overflow: hidden;
}

.micro-spotlight > * {
  position: relative;
  z-index: 1;
  transform: translate3d(var(--micro-depth-x), var(--micro-depth-y), 0);
  will-change: transform;
}

.micro-spotlight::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  opacity: 0;
  background:
    radial-gradient(
      circle at var(--micro-x) var(--micro-y),
      rgba(255, 255, 255, 0.38) 0%,
      rgba(91, 163, 217, 0.14) 28%,
      rgba(91, 163, 217, 0) 58%
    );
  transition: opacity 0.22s ease;
}

.micro-spotlight.is-micro-hovering::after,
.micro-spotlight:focus-within::after {
  opacity: 1;
}

.is-pressing {
  scale: 0.985;
}

.hero-journey-tab,
.testimonial-dot,
.testimonial-arrow,
.language-toggle,
.contact-icon,
.cookie-banner-accept,
.cookie-banner-decline {
  -webkit-tap-highlight-color: transparent;
}

.hero-journey-tab.is-pressing,
.testimonial-dot.is-pressing,
.testimonial-arrow.is-pressing,
.language-toggle.is-pressing,
.contact-icon.is-pressing,
.cookie-banner-accept.is-pressing,
.cookie-banner-decline.is-pressing {
  scale: 0.94;
}

.hero-cta,
.nav-cta,
.procurement-hero-cta,
.procurement-outro-link,
.service-reference-link,
.service-domain-note a,
.home-contact-reimagined-cta,
.careers-hero-cta,
.careers-open-cta,
.workshop-hero-cta,
.workshop-detail-cta,
.workshop-final-cta-link {
  position: relative;
  overflow: hidden;
}

.hero-cta::before,
.nav-cta::before,
.procurement-hero-cta::before,
.procurement-outro-link::before,
.service-reference-link::before,
.service-domain-note a::before,
.home-contact-reimagined-cta::before,
.careers-hero-cta::before,
.careers-open-cta::before,
.workshop-hero-cta::before,
.workshop-detail-cta::before,
.workshop-final-cta-link::before {
  content: "";
  position: absolute;
  inset: -40% auto -40% -34%;
  width: 32%;
  pointer-events: none;
  background: linear-gradient(100deg, transparent 0%, rgba(255, 255, 255, 0.42) 50%, transparent 100%);
  transform: translateX(-120%) rotate(8deg);
  transition: transform 0.42s cubic-bezier(0.22, 1, 0.36, 1);
}

.micro-magnetic-cta {
  --micro-cta-x: 50%;
  --micro-cta-y: 50%;
  --micro-cta-shift-x: 0px;
  --micro-cta-shift-y: 0px;
  position: relative;
  overflow: hidden;
  isolation: isolate;
  translate: var(--micro-cta-shift-x) var(--micro-cta-shift-y);
  will-change: translate;
}

.micro-magnetic-cta::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  opacity: 0;
  background:
    radial-gradient(
      circle at var(--micro-cta-x) var(--micro-cta-y),
      rgba(255, 255, 255, 0.32) 0%,
      rgba(255, 255, 255, 0.14) 26%,
      rgba(255, 255, 255, 0) 62%
    );
  transition: opacity 0.2s ease;
}

.micro-magnetic-cta.is-micro-hovering::after,
.micro-magnetic-cta:focus-visible::after {
  opacity: 1;
}

.hero-cta:hover::before,
.nav-cta:hover::before,
.procurement-hero-cta:hover::before,
.procurement-outro-link:hover::before,
.service-reference-link:hover::before,
.service-domain-note a:hover::before,
.home-contact-reimagined-cta:hover::before,
.careers-hero-cta:hover::before,
.careers-open-cta:hover::before,
.workshop-hero-cta:hover::before,
.workshop-detail-cta:hover::before,
.workshop-final-cta-link:hover::before {
  transform: translateX(560%) rotate(8deg);
}

.clients-track-wrapper:hover .clients-track,
.clients-track-wrapper:focus-within .clients-track {
  animation-play-state: paused;
}

.clients-track img {
  transform-origin: center;
}

.clients-track img:hover {
  transform: translateY(-3px) scale(1.055);
  filter: saturate(1.08) contrast(1.04);
}

.testimonial-arrow {
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.62) inset;
}

.testimonial-arrow svg {
  transition: transform 0.18s ease;
}

.testimonial-prev:hover svg {
  transform: translateX(-2px);
}

.testimonial-next:hover svg {
  transform: translateX(2px);
}

.testimonial-dot:hover {
  transform: translateY(-1px);
  background: rgba(47, 106, 177, 0.42);
}

.service-tab {
  position: relative;
  overflow: hidden;
}

.service-tab::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: 4px;
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: currentColor;
  opacity: 0;
  transform: translateX(-50%) scale(0.7);
  transition: opacity 0.18s ease, transform 0.18s ease;
}

.service-tab:hover::after,
.service-tab.active::after {
  opacity: 0.38;
  transform: translateX(-50%) scale(1);
}

.services-preview-feature-visual::before {
  content: "";
  position: absolute;
  inset: 0;
  opacity: 0;
  background:
    linear-gradient(115deg, transparent 22%, rgba(255, 255, 255, 0.28) 48%, transparent 72%);
  transform: translateX(-46%);
  transition: opacity 0.2s ease, transform 0.5s cubic-bezier(0.22, 1, 0.36, 1);
}

.services-preview-feature-card:hover .services-preview-feature-visual::before {
  opacity: 1;
  transform: translateX(46%);
}

.services-preview-stage {
  transition: transform 0.24s ease, box-shadow 0.24s ease, border-color 0.24s ease;
}

.services-preview-feature-card:hover .services-preview-stage {
  transform: translateY(-2px);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.08),
    0 28px 46px rgba(17, 30, 50, 0.26);
}

.story-card-visual,
.case-story-media {
  transition: transform 0.32s cubic-bezier(0.22, 1, 0.36, 1);
  will-change: transform;
}

.team-photo {
  transition: filter 0.24s ease, scale 0.28s ease, background-position 0.28s ease;
}

.team-card:hover .team-photo {
  scale: 1.012;
  filter: saturate(1.04) contrast(1.015);
}

.case-story-media:hover {
  transform: scale(1.006);
}

.story-card-link {
  transition: color 0.2s ease, transform 0.2s ease;
}

.home-contact-reimagined-channels a strong {
  transition: transform 0.2s ease, color 0.2s ease;
}

.home-contact-reimagined-channels a:hover strong {
  transform: translateX(2px);
  color: #2f6ab1;
}

.contact-icon:hover svg {
  transform: translateY(-1px);
}

.contact-icon svg {
  transition: transform 0.18s ease;
}

.nav-dropdown-menu {
  transform-origin: 50% 0;
}

.nav-dropdown:hover .nav-dropdown-menu {
  animation: nav-menu-soft-open 0.22s cubic-bezier(0.22, 1, 0.36, 1) both;
}

@keyframes nav-menu-soft-open {
  from {
    scale: 0.985;
  }

  to {
    scale: 1;
  }
}

@media (prefers-reduced-motion: no-preference) {
  .micro-reveal {
    transition:
      opacity 0.72s cubic-bezier(0.22, 1, 0.36, 1) var(--micro-delay, 0ms),
      translate 0.72s cubic-bezier(0.22, 1, 0.36, 1) var(--micro-delay, 0ms),
      scale 0.72s cubic-bezier(0.22, 1, 0.36, 1) var(--micro-delay, 0ms),
      filter 0.58s ease var(--micro-delay, 0ms);
  }

  .home-contact-reimagined-glow,
  .testimonials-blob {
    animation: micro-atmosphere-drift 16s ease-in-out infinite alternate;
  }

  .testimonials-blob-2 {
    animation-delay: -7s;
  }

  .footer-logo a:hover .footer-mark-svg,
  .nav-logo:hover .logo-mark-svg {
    animation: micro-logo-settle 0.42s cubic-bezier(0.22, 1, 0.36, 1);
  }
}

@keyframes micro-atmosphere-drift {
  from {
    translate: -8px -6px;
  }

  to {
    translate: 8px 6px;
  }
}

@keyframes micro-logo-settle {
  0% {
    scale: 1;
  }

  46% {
    scale: 1.055;
  }

  100% {
    scale: 1;
  }
}

/* Error boundary and 404 */
.error-boundary {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: clamp(92px, 12vw, 140px) var(--page-pad, 24px);
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.94), rgba(244, 248, 246, 0.96)),
    radial-gradient(circle at 18% 18%, rgba(119, 178, 85, 0.16), transparent 34%),
    radial-gradient(circle at 82% 12%, rgba(47, 106, 177, 0.13), transparent 30%);
}

.error-boundary-inner {
  width: min(1080px, 100%);
  margin: 0 auto;
  color: #16231f;
}

.error-boundary-inner h1 {
  margin: 0 0 20px;
  color: #101b18;
  font-size: clamp(46px, 8vw, 92px);
  font-weight: var(--font-display-weight, 500);
  line-height: 0.96;
  letter-spacing: 0;
}

.error-boundary-inner p {
  max-width: 620px;
  margin: 0 0 32px;
  color: rgba(22, 35, 31, 0.68);
  font-size: clamp(17px, 2vw, 20px);
  line-height: 1.65;
}

.error-boundary-inner a {
  color: #2f6ab1;
}

.error-boundary-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}

.btn-primary,
.btn-secondary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 46px;
  border-radius: 999px;
  padding: 12px 22px;
  font-size: 14px;
  font-weight: 650;
  line-height: 1;
  text-decoration: none;
  transition:
    transform 0.2s ease,
    border-color 0.2s ease,
    background 0.2s ease,
    color 0.2s ease;
}

.btn-primary {
  color: #ffffff;
  background: #17231f;
  border: 1px solid #17231f;
  box-shadow: 0 14px 32px rgba(18, 27, 25, 0.18);
}

.btn-primary:hover {
  transform: translateY(-1px);
  background: #2f6ab1;
  border-color: #2f6ab1;
}

.btn-secondary {
  color: #17231f;
  background: rgba(255, 255, 255, 0.72);
  border: 1px solid rgba(18, 27, 25, 0.14);
}

.btn-secondary:hover {
  transform: translateY(-1px);
  background: #ffffff;
  border-color: rgba(47, 106, 177, 0.28);
}

button.btn-primary {
  cursor: pointer;
  font-family: inherit;
}

.error-boundary-links {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  color: rgba(22, 35, 31, 0.56);
  font-size: 13px;
  line-height: 1.2;
}

.error-boundary-links span {
  margin-right: 2px;
}

.error-boundary-links a {
  padding: 8px 11px;
  color: #17231f;
  background: rgba(255, 255, 255, 0.56);
  border: 1px solid rgba(18, 27, 25, 0.1);
  border-radius: 999px;
  text-decoration: none;
  transition:
    background 0.18s ease,
    border-color 0.18s ease,
    color 0.18s ease;
}

.error-boundary-links a:hover {
  color: #2f6ab1;
  background: #ffffff;
  border-color: rgba(47, 106, 177, 0.24);
}

.not-found-shell {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(300px, 0.78fr);
  gap: clamp(32px, 6vw, 84px);
  align-items: center;
}

.not-found-copy {
  min-width: 0;
}

.not-found-kicker {
  margin: 0 0 18px;
  color: rgba(22, 35, 31, 0.58);
  font-family: var(--font-mono);
  font-size: 13px;
  font-weight: 500;
  line-height: 1.2;
  text-transform: uppercase;
  letter-spacing: var(--tracking-label, 0.06em);
}

.not-found-visual {
  position: relative;
  min-height: 430px;
  overflow: hidden;
  border: 1px solid rgba(18, 27, 25, 0.12);
  border-radius: 8px;
  background:
    linear-gradient(135deg, rgba(22, 35, 31, 0.95), rgba(21, 43, 56, 0.95)),
    repeating-linear-gradient(90deg, rgba(255, 255, 255, 0.05) 0 1px, transparent 1px 52px),
    repeating-linear-gradient(0deg, rgba(255, 255, 255, 0.04) 0 1px, transparent 1px 52px);
  box-shadow: 0 28px 70px rgba(18, 27, 25, 0.18);
}

.not-found-visual::before {
  content: "";
  position: absolute;
  inset: 32px;
  border: 1px solid rgba(255, 255, 255, 0.16);
  border-radius: 999px;
}

.not-found-visual::after {
  content: "404";
  position: absolute;
  right: 28px;
  bottom: 18px;
  color: rgba(255, 255, 255, 0.08);
  font-size: 112px;
  font-weight: 700;
  line-height: 1;
}

.not-found-signal,
.not-found-console {
  position: absolute;
  z-index: 2;
  border: 1px solid rgba(255, 255, 255, 0.16);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.08);
  backdrop-filter: blur(18px);
}

.not-found-signal {
  top: 28px;
  left: 28px;
  display: grid;
  gap: 8px;
  min-width: 168px;
  padding: 16px;
}

.not-found-signal span,
.not-found-console span {
  color: rgba(255, 255, 255, 0.58);
  font-family: var(--font-mono);
  font-size: 11px;
  line-height: 1.2;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.not-found-signal strong {
  color: #ffffff;
  font-size: 44px;
  font-weight: 600;
  line-height: 1;
}

.not-found-orbit {
  position: absolute;
  inset: 66px 42px 64px;
}

.not-found-node {
  position: absolute;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 72px;
  min-height: 42px;
  padding: 0 14px;
  color: #17231f;
  background: #ffffff;
  border-radius: 999px;
  font-size: 13px;
  font-weight: 700;
  box-shadow: 0 18px 36px rgba(0, 0, 0, 0.2);
}

.not-found-node-home {
  left: 8%;
  bottom: 18%;
}

.not-found-node-services {
  right: 5%;
  top: 18%;
  background: #d9f3c7;
}

.not-found-node-missing {
  left: 50%;
  top: 50%;
  min-width: 84px;
  min-height: 84px;
  translate: -50% -50%;
  color: #ffffff;
  background: #2f6ab1;
  border: 10px solid rgba(255, 255, 255, 0.16);
  font-size: 40px;
}

.not-found-console {
  right: 28px;
  bottom: 28px;
  display: grid;
  gap: 12px;
  width: min(230px, calc(100% - 56px));
  padding: 16px;
}

.not-found-console div {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}

.not-found-console strong {
  color: #ffffff;
  font-size: 13px;
  font-weight: 650;
}

.not-found-shortcuts {
  grid-column: 1 / -1;
  padding-top: 6px;
}

@media (max-width: 760px) {
  .error-boundary {
    align-items: flex-start;
    padding-top: 96px;
  }

  .error-boundary-inner h1 {
    font-size: clamp(42px, 14vw, 64px);
  }

  .not-found-shell {
    grid-template-columns: 1fr;
  }

  .not-found-visual {
    min-height: 330px;
  }

  .not-found-visual::after {
    font-size: 78px;
  }

  .not-found-signal {
    top: 20px;
    left: 20px;
  }

  .not-found-orbit {
    inset: 74px 24px 72px;
  }

  .not-found-console {
    right: 20px;
    bottom: 20px;
  }

  .not-found-shortcuts {
    padding-top: 0;
  }
}

@media (prefers-reduced-motion: reduce) {
  .micro-reveal,
  .micro-reveal.is-micro-visible {
    opacity: 1;
    translate: none;
    scale: 1;
    filter: none;
    transition: none;
  }

  .micro-spotlight::after,
  .hero-cta::before,
  .nav-cta::before,
  .procurement-hero-cta::before,
  .procurement-outro-link::before,
  .service-reference-link::before,
  .service-domain-note a::before,
  .home-contact-reimagined-cta::before,
  .careers-hero-cta::before,
  .careers-open-cta::before,
  .workshop-hero-cta::before,
  .workshop-detail-cta::before,
  .workshop-final-cta-link::before {
    display: none;
  }

  .home-contact-reimagined-glow,
  .testimonials-blob {
    animation: none;
  }
}

/* ── Contact modal overlay ── */
.contact-modal-overlay {
  position: fixed;
  inset: 0;
  z-index: 1000;
  background: rgba(10, 20, 40, 0.55);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
  animation: contact-modal-fade-in 0.18s ease;
}

@keyframes contact-modal-fade-in {
  from { opacity: 0; }
  to   { opacity: 1; }
}

/* ── Card ── */
.contact-modal-card {
  position: relative;
  background: #fff;
  border-radius: 24px;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06), 0 24px 64px rgba(0, 0, 0, 0.18);
  padding: 52px 48px;
  width: 100%;
  max-width: 580px;
  animation: contact-modal-slide-in 0.22s cubic-bezier(0.22, 1, 0.36, 1);
}

@keyframes contact-modal-slide-in {
  from { opacity: 0; transform: translateY(12px) scale(0.98); }
  to   { opacity: 1; transform: translateY(0) scale(1); }
}

/* ── Close button ── */
.contact-modal-close {
  position: absolute;
  top: 20px;
  right: 20px;
  width: 36px;
  height: 36px;
  border: none;
  background: #f3f4f7;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  color: #5a6270;
  transition: background 0.15s ease, color 0.15s ease;
  flex-shrink: 0;
}

.contact-modal-close svg {
  width: 16px;
  height: 16px;
}

.contact-modal-close:hover {
  background: #e8eaf0;
  color: #1a2533;
}

/* ── Header ── */
.contact-modal-eyebrow {
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: #3b7ddb;
  margin-bottom: 12px;
}

.contact-modal-title {
  font-size: clamp(22px, 3.5vw, 28px);
  font-weight: 500;
  letter-spacing: -0.5px;
  color: #1a2533;
  line-height: 1.2;
  margin-bottom: 12px;
}

.contact-modal-sub {
  font-size: 15px;
  line-height: 1.65;
  color: #5a6270;
  margin-bottom: 32px;
}

/* ── Form ── */
.contact-modal-form {
  display: flex;
  flex-direction: column;
  gap: 18px;
}

.contact-modal-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}

.contact-modal-field {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.contact-modal-field label {
  font-size: 13px;
  font-weight: 500;
  color: #3a4250;
}

.contact-modal-optional {
  font-weight: 400;
  color: #9aa3b0;
}

.contact-modal-field input,
.contact-modal-field textarea {
  border: 1.5px solid #dde2ea;
  border-radius: 10px;
  padding: 12px 14px;
  font-size: 14px;
  font-family: inherit;
  color: #1a2533;
  background: #f7f8fb;
  outline: none;
  transition: border-color 0.15s ease, background 0.15s ease;
  resize: none;
}

.contact-modal-field input:focus,
.contact-modal-field textarea:focus {
  border-color: #3b7ddb;
  background: #fff;
}

.contact-modal-field input::placeholder,
.contact-modal-field textarea::placeholder {
  color: #adb5c2;
}

.contact-modal-field--error input,
.contact-modal-field--error textarea {
  border-color: #e05252;
  background: #fff8f8;
}

.contact-modal-error {
  font-size: 12px;
  color: #e05252;
  line-height: 1.4;
}

/* ── Submit button ── */
.contact-modal-submit {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  background: #3b7ddb;
  color: #fff;
  border: none;
  border-radius: 980px;
  padding: 14px 28px;
  font-size: 15px;
  font-weight: 500;
  font-family: inherit;
  cursor: pointer;
  transition: background 0.18s ease, transform 0.18s ease, box-shadow 0.18s ease;
  box-shadow: 0 4px 14px rgba(59, 125, 219, 0.28);
  align-self: flex-start;
  margin-top: 4px;
}

.contact-modal-submit svg {
  width: 15px;
  height: 15px;
}

.contact-modal-submit:hover:not(:disabled) {
  background: #2d6bc4;
  transform: translateY(-1px);
  box-shadow: 0 8px 20px rgba(59, 125, 219, 0.35);
}

.contact-modal-submit:disabled {
  opacity: 0.65;
  cursor: not-allowed;
}

/* ── Success state ── */
.contact-modal-success {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 12px;
  padding: 8px 0;
}

.contact-modal-success-icon {
  width: 52px;
  height: 52px;
  border-radius: 50%;
  background: #eaf2ff;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #3b7ddb;
  margin-bottom: 8px;
}

.contact-modal-success-icon svg {
  width: 24px;
  height: 24px;
}

.contact-modal-success h2 {
  font-size: 24px;
  font-weight: 500;
  letter-spacing: -0.4px;
  color: #1a2533;
}

.contact-modal-success p {
  font-size: 15px;
  line-height: 1.65;
  color: #5a6270;
  margin-bottom: 8px;
}

/* ── Responsive ── */
@media (max-width: 560px) {
  .contact-modal-card {
    padding: 36px 24px;
    border-radius: 20px;
  }

  .contact-modal-row {
    grid-template-columns: 1fr;
  }
}

/* ── Cookie Consent Banner ── */
.cookie-banner {
  position: fixed;
  bottom: 24px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 9000;
  width: calc(100% - 48px);
  max-width: 680px;
  background: rgba(255, 255, 255, 0.88);
  border: 1px solid rgba(255, 255, 255, 0.92);
  border-radius: 20px;
  box-shadow:
    0 24px 64px rgba(19, 44, 84, 0.13),
    0 4px 16px rgba(0, 0, 0, 0.06),
    0 1px 0 rgba(255, 255, 255, 0.9) inset;
  backdrop-filter: blur(24px) saturate(1.5);
  -webkit-backdrop-filter: blur(24px) saturate(1.5);
  padding: 18px 20px;
  animation: cookie-slide-in 0.45s cubic-bezier(0.22, 1, 0.36, 1);
}

@keyframes cookie-slide-in {
  from { opacity: 0; transform: translateX(-50%) translateY(22px); }
  to   { opacity: 1; transform: translateX(-50%) translateY(0); }
}

.cookie-banner-inner {
  display: flex;
  align-items: center;
  gap: 20px;
  flex-wrap: wrap;
}

.cookie-banner-body {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  flex: 1;
  min-width: 220px;
}

.cookie-banner-icon {
  flex-shrink: 0;
  margin-top: 1px;
}

.cookie-banner-text {
  font-size: 13.5px;
  line-height: 1.6;
  color: #1a2533;
  margin: 0;
}

.cookie-banner-link {
  color: #3b7ddb;
  font-weight: 500;
  text-decoration: none;
  border-bottom: 1px solid rgba(59, 125, 219, 0.3);
  transition: border-color 0.15s ease;
}

.cookie-banner-link:hover {
  border-bottom-color: #3b7ddb;
}

.cookie-banner-actions {
  display: flex;
  gap: 8px;
  flex-shrink: 0;
  align-items: center;
}

.cookie-banner-accept,
.cookie-banner-decline {
  padding: 9px 20px;
  border-radius: 980px;
  font-size: 13.5px;
  font-weight: 600;
  cursor: pointer;
  border: none;
  white-space: nowrap;
  font-family: inherit;
  transition: box-shadow 0.2s ease, transform 0.18s cubic-bezier(0.34, 1.56, 0.64, 1);
}

.cookie-banner-accept {
  background: linear-gradient(135deg, #4a8ad4 0%, #5ba3d9 100%);
  color: #fff;
  box-shadow: 0 4px 14px rgba(74, 138, 212, 0.28);
}

.cookie-banner-accept:hover {
  transform: translateY(-1px);
  box-shadow: 0 6px 20px rgba(74, 138, 212, 0.38);
}

.cookie-banner-accept:active {
  transform: scale(0.97);
  box-shadow: 0 2px 8px rgba(74, 138, 212, 0.2);
  transition-duration: 0.06s;
}

.cookie-banner-decline {
  background: transparent;
  color: #5a6270;
  border: 1px solid rgba(26, 37, 51, 0.14);
}

.cookie-banner-decline:hover {
  background: rgba(26, 37, 51, 0.05);
  border-color: rgba(26, 37, 51, 0.22);
  transform: translateY(-1px);
}

.cookie-banner-decline:active {
  transform: scale(0.97);
  transition-duration: 0.06s;
}

@media (max-width: 600px) {
  .cookie-banner {
    bottom: 0;
    left: 0;
    right: 0;
    width: 100%;
    transform: none;
    border-radius: 20px 20px 0 0;
    max-width: none;
    padding: 20px 20px calc(20px + env(safe-area-inset-bottom));
  }

  @keyframes cookie-slide-in {
    from { opacity: 0; transform: translateY(24px); }
    to   { opacity: 1; transform: translateY(0); }
  }

  .cookie-banner-inner {
    flex-direction: column;
    align-items: flex-start;
    gap: 14px;
  }

  .cookie-banner-actions {
    width: 100%;
    flex-direction: row-reverse;
    justify-content: flex-end;
  }
}

/* ── Privacy Policy Page ── */
.prose-page {
  max-width: 720px;
  margin: 80px auto 120px;
  padding: 0 24px;
}

.prose-page h1 {
  font-size: clamp(28px, 4vw, 42px);
  font-weight: 700;
  letter-spacing: -0.03em;
  margin-bottom: 8px;
}

.prose-meta {
  font-size: 14px;
  color: #888;
  margin-bottom: 48px;
}

.prose-page h2 {
  font-size: 20px;
  font-weight: 650;
  margin-top: 48px;
  margin-bottom: 12px;
  letter-spacing: -0.01em;
}

.prose-page h3 {
  font-size: 16px;
  font-weight: 600;
  margin-top: 28px;
  margin-bottom: 8px;
  color: #222;
}

.prose-page p,
.prose-page li {
  font-size: 15px;
  line-height: 1.7;
  color: #444;
  margin-bottom: 12px;
}

.prose-page ul {
  padding-left: 20px;
  margin-bottom: 16px;
}

.prose-page a {
  color: #3b7ddb;
  text-decoration: underline;
  text-underline-offset: 2px;
}

.prose-page code {
  font-size: 13px;
  background: #f2f2f5;
  padding: 2px 6px;
  border-radius: 4px;
  color: #333;
}

/* ── Footer privacy link ── */
.footer-bottom {
  display: flex;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
}

.footer-privacy-link {
  font-size: 13px;
  color: inherit;
  opacity: 0.6;
  text-decoration: underline;
  text-underline-offset: 2px;
}

.footer-privacy-link:hover {
  opacity: 1;
}
