@font-face {
  font-family: "SohneMeetMax";
  src: url("assets/Sohne Font Meet Max.otf") format("opentype");
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
}

:root {
  --bg: #f8f7f4;
  --surface: color-mix(in srgb, var(--bg) 86%, #ffffff 14%);
  --surface-strong: color-mix(in srgb, var(--bg) 74%, #ffffff 26%);
  --media-radius-lg: 0px;
  --media-radius-md: 0px;
  --media-radius-sm: 0px;
  --text: #111111;
  --muted: #6a6966;
  --hairline: rgba(17, 17, 17, 0.12);
  --shadow: 0 20px 60px rgba(0, 0, 0, 0.18);
  --pastel-blue: radial-gradient(1100px 460px at 55% 10%, rgba(90, 80, 70, 0.06), transparent 66%),
    radial-gradient(900px 420px at 45% 92%, rgba(90, 80, 70, 0.045), transparent 62%),
    linear-gradient(
      180deg,
      color-mix(in srgb, var(--bg) 72%, #cfcac2 28%) 0%,
      var(--bg) 52%,
      color-mix(in srgb, var(--bg) 78%, #d7d1c9 22%) 100%
    );
  --radius-lg: 24px;
  --radius-md: 14px;
  --container: 1720px;
  --page-gutter: clamp(16px, 2vw, 42px);
  --section-min-height: 100svh;
  --banner-min-height: clamp(380px, 66svh, 520px);
  --meet-max-banner-min-height: clamp(360px, 56svh, 440px);
  --header-offset: 78px;
  --title-font: "Montserrat", ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji",
    "Segoe UI Emoji";
  --meet-max-font: "SohneMeetMax", "Söhne", "Sohne", "Manrope", "Neue Haas Grotesk Display Pro", "Helvetica Now Display", "Montserrat", ui-sans-serif,
    system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial, "Apple Color Emoji", "Segoe UI Emoji";
  --serif: var(--title-font);
  --sans: "DM Sans", ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji",
    "Segoe UI Emoji";
  --section-title-size: clamp(18px, 2vw, 28px);
  --section-title-line-height: 1.15;
  --body-copy-size: clamp(17px, 1.1vw, 19px);
  --body-copy-line: 1.6;
  --site-hero-size: clamp(58px, 8.2vw, 132px);
  --site-hero-line: 0.92;
  --page-hero-size: var(--site-hero-size);
  --page-hero-line: var(--site-hero-line);
  --site-heading-size: clamp(26px, 3.2vw, 48px);
  --site-heading-line: 1.05;
  --site-subtitle-size: clamp(16px, 1.35vw, 20px);
  --site-subtitle-line: 1.35;
  --site-button-size: 16px;
  --site-button-line: 1.1;
  --site-button-pad-y: 12px;
  --site-button-pad-x: 22px;
  --site-button-radius: 12px;
  --title-subtitle-gap: 12px;
  --section-heading-color: var(--text);
  --section-subtitle-color: var(--muted);
  --card-title-size: clamp(18px, 1.35vw, 22px);
  --card-title-line: 1.2;
  --feature-frame-ratio: 16 / 9;
}

.solutions-page,
.security-page {
  --page-hero-size: clamp(36px, 4.4vw, 70px);
  --page-hero-line: 1.05;
}

.home-page .intro-text {
  font-family: var(--serif);
  font-size: clamp(24px, 3vw, 44px) !important;
  line-height: var(--site-heading-line) !important;
  font-weight: 700;
  letter-spacing: -0.02em;
}

.home-page .intro-text strong {
  font-weight: inherit;
}

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

html,
body {
  height: 100%;
}

body {
  margin: 0;
  font-family: var(--sans);
  font-size: var(--body-copy-size);
  color: var(--text);
  background: var(--bg);
  line-height: var(--body-copy-line);
  overflow-x: clip;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-family: var(--title-font);
}

.hero-title,
.security-hero-title,
.solutions-hero-title,
.system-hero-title,
.contact-title {
  font-family: var(--serif) !important;
  font-weight: 700 !important;
  letter-spacing: -0.02em !important;
  font-size: var(--page-hero-size) !important;
  line-height: var(--page-hero-line) !important;
}

.journey-title,
.security-title,
.security-standards-title,
.security-architecture-marquee-title,
.security-architecture-title,
.system-brings-title,
.system-banner-title,
.solutions-spotlight-title,
.solutions-usage-title,
.solutions-stack-title,
.solutions-litigation-title,
.features-cta-title,
.vision-title,
.system-title {
  margin: 0 !important;
  font-family: var(--serif) !important;
  font-weight: 700 !important;
  letter-spacing: -0.02em !important;
  font-size: var(--site-heading-size) !important;
  line-height: var(--site-heading-line) !important;
  color: var(--section-heading-color) !important;
}

.feature-text,
.security-body,
.security-hero-text,
.security-standards-copy p,
.security-pillar-text,
.journey-panel-text,
.system-brings-text,
.why-max-page .system-brings-column-text,
.system-context-text,
.system-scale-text,
.overview-capabilities-banner .system-scale-text,
.contact-card-text,
.solutions-hero-text,
.solutions-spotlight-text,
.solutions-benefit-text,
.solutions-usage-panel-text,
.solutions-stack-card-text,
.solutions-litigation-text,
.mega-desc,
.vision-cite,
.vision-paragraph,
.security-standard-link {
  font-size: var(--body-copy-size) !important;
  line-height: var(--body-copy-line) !important;
}

.hero-subtitle,
.solutions-hero-subtitle,
.security-subtitle,
.security-architecture-subtitle,
.security-architecture-marquee-subtitle,
.system-brings-subtitle,
.contact-subtitle,
.features-cta-subtitle,
.solutions-stack-subtitle,
.journey-subtitle,
.security-standards-subtitle,
.system-kicker,
.system-context-text--kicker {
  font-weight: 600 !important;
  letter-spacing: -0.01em !important;
  font-size: var(--site-subtitle-size) !important;
  line-height: var(--site-subtitle-line) !important;
  margin: 0 !important;
  color: var(--section-subtitle-color) !important;
}

.system-brings-subtitle.is-title {
  font-family: var(--serif) !important;
  font-weight: 700 !important;
  letter-spacing: -0.02em !important;
  font-size: var(--site-heading-size) !important;
  line-height: var(--site-heading-line) !important;
  color: var(--section-heading-color) !important;
}

.system-brings-subtitle.is-context-title {
  font-family: var(--serif) !important;
  font-weight: 700 !important;
  letter-spacing: -0.02em !important;
  font-size: var(--site-heading-size) !important;
  line-height: var(--site-heading-line) !important;
  color: var(--section-heading-color) !important;
}

.system-brings-column-title,
.journey-step,
.vision-quote {
  font-weight: 600 !important;
  letter-spacing: -0.01em !important;
  font-size: var(--site-subtitle-size) !important;
  line-height: var(--site-subtitle-line) !important;
}

.feature-title,
.journey-panel-title,
.system-brings-card-title,
.system-brings-card-overlay--with-foot .system-brings-card-title,
.overview-capability-title,
.solutions-stack-card-title,
.solutions-benefit-title,
.solutions-usage-panel-title,
.contact-card-title,
.contact-side .contact-card-title,
.security-pillar-title {
  font-family: var(--title-font) !important;
  font-weight: 700 !important;
  letter-spacing: -0.01em !important;
  font-size: var(--card-title-size) !important;
  line-height: var(--card-title-line) !important;
}

.vision-quote strong {
  font-weight: inherit;
}

.button,
.security-cta,
.security-architecture-marquee-cta {
  font-size: var(--site-button-size) !important;
  line-height: var(--site-button-line) !important;
  padding: var(--site-button-pad-y) var(--site-button-pad-x) !important;
}

main > section {
  min-height: 100vh;
  min-height: var(--section-min-height);
  box-sizing: border-box;
}


img {
  max-width: 100%;
  display: block;
}

a {
  color: inherit;
  text-decoration: none;
}

a:focus-visible {
  outline: 3px solid color-mix(in srgb, var(--text) 22%, transparent);
  outline-offset: 3px;
  border-radius: 10px;
}

.stretched-link {
  position: absolute;
  inset: 0;
  z-index: 5;
}

.is-clickable {
  position: relative;
  cursor: pointer;
}

button {
  font: inherit;
}

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border-width: 0;
}

.skip-link {
  position: absolute;
  left: 12px;
  top: 12px;
  transform: translateY(-140%);
  background: #ffffff;
  border: 1px solid var(--hairline);
  padding: 10px 12px;
  border-radius: 10px;
  z-index: 1000;
}

.skip-link:focus {
  transform: translateY(0);
}

.container {
  width: min(var(--container), calc(100% - (var(--page-gutter) * 2)));
  margin-inline: auto;
  margin-left: auto;
  margin-right: auto;
}

.site-header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  width: 100%;
  z-index: 1000;
  background: var(--bg);
  backdrop-filter: none;
  border-bottom: none;
  transition: transform 200ms ease, opacity 200ms ease;
}

main {
  padding-top: var(--header-offset);
}

.site-header[data-open="true"] {
  border-bottom-color: transparent;
}

.header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-block: 14px;
  gap: 16px;
  position: relative;
  z-index: 3;
}

.header-actions {
  display: none;
  align-items: center;
  gap: 18px;
}

.brand {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  min-width: 160px;
}

.brand-mark {
  display: none !important;
  width: 12px;
  height: 12px;
  border: 2px solid var(--text);
  border-radius: 3px;
}

.brand-name {
  font-family: var(--serif);
  letter-spacing: 0.08em;
  font-size: 20px;
}

.site-header .brand-name {
  font-size: 21px;
  font-weight: 700;
  letter-spacing: 0.01em;
}

.home-page .site-header .brand {
  gap: 0;
}

.home-page .site-header .brand-mark {
  display: none;
}

.home-page .site-header .brand-name {
  font-size: 21px;
  font-weight: 700;
  letter-spacing: 0.01em;
}

.nav {
  display: none;
}

.nav-list {
  display: flex;
  gap: 22px;
  align-items: center;
  margin: 0;
  padding: 0;
  list-style: none !important;
  padding-left: 0;
}

.nav-item {
  list-style: none !important;
  display: block;
}

.nav-item::marker {
  content: "";
}

.nav-link {
  background: none;
  border: none;
  padding: 10px 6px;
  border-radius: 0;
  color: var(--text);
  cursor: pointer;
  border-bottom: 2px solid transparent;
}

.nav-link:hover,
.nav-link:focus-visible {
  color: var(--text);
  outline: none;
  background: none;
  border-bottom-color: var(--text);
}

.nav-link[aria-expanded="true"] {
  border-bottom-color: var(--text);
}

.nav-plus {
  width: 8px;
  height: 8px;
  margin-left: 6px;
  border-right: 1.5px solid currentColor;
  border-bottom: 1.5px solid currentColor;
  transform: translateY(-1px) rotate(45deg);
  display: inline-block;
}

.nav-toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  border-radius: 12px;
  border: 1px solid var(--hairline);
  background: #ffffff;
  cursor: pointer;
}

.nav-toggle:focus-visible {
  outline: 3px solid color-mix(in srgb, var(--text) 25%, transparent);
  outline-offset: 2px;
}

.nav-toggle-lines {
  width: 18px;
  height: 12px;
  position: relative;
}

.nav-toggle-lines::before,
.nav-toggle-lines::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  height: 2px;
  background: var(--text);
  border-radius: 2px;
}

.nav-toggle-lines::before {
  top: 0;
}

.nav-toggle-lines::after {
  bottom: 0;
}

.mega-wrap {
  position: relative;
  z-index: 2;
}

.mega-layer {
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  height: calc(100vh - var(--header-offset));
  background: rgba(0, 0, 0, 0.25);
  opacity: 0;
  pointer-events: none;
  transition: opacity 180ms ease;
  z-index: 1;
}

.site-header[data-open="true"] .mega-layer {
  opacity: 1;
  pointer-events: auto;
}

.mega {
  --mega-item-pad: 6px;
  --mega-item-gap: 3px;
  --mega-title-h: 24px;
  --mega-desc-lines: 2;
  --mega-desc-line-h: 1.3;
  --mega-row-h: 84px;
  display: block;
  position: absolute;
  left: 0;
  right: 0;
  top: 100%;
  padding-block: 0;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transform: translateY(-8px);
  transition: opacity 180ms ease, transform 180ms ease, visibility 0ms linear 180ms;
  z-index: 2;
}

.site-header[data-open="true"] .mega[data-active="true"] {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translateY(0);
  transition: opacity 180ms ease, transform 180ms ease, visibility 0ms;
}

.mega-inner {
  background: var(--bg);
  border-radius: 0;
  border: none;
  box-shadow: none;
  padding: 32px 0 40px;
  padding-inline: clamp(24px, 4vw, 56px);
}

.mega .container.mega-inner {
  width: 100%;
  max-width: none;
  margin-inline: 0;
}

.mega-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 36px;
  align-items: start;
}

#mega-system .mega-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

#mega-system .mega-col:not(.mega-media) {
  grid-column: 1 / span 2;
}

#mega-system .mega-media {
  grid-column: 3;
  width: min(360px, 100%);
  justify-self: end;
  align-self: start;
}

#mega-system .mega-media-link {
  display: block;
  width: 100%;
  max-width: 360px;
}

#mega-system .mega-media-block {
  width: 100%;
  max-width: 360px;
  aspect-ratio: 4 / 3;
  height: auto !important;
  max-height: 270px;
  background: #ffffff;
}

#mega-system .mega-media-video {
  width: calc(100% + 2px);
  height: calc(100% + 2px);
  margin: -1px;
  object-fit: cover;
  object-position: center;
  background: #ffffff;
}

#mega-system .mega-links {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  column-gap: clamp(24px, 4vw, 44px);
  row-gap: 0;
  grid-auto-rows: var(--mega-row-h);
}

#mega-solutions .mega-grid {
  --mega-solutions-gap: clamp(28px, 4vw, 56px);
  --mega-solutions-row: var(--mega-row-h);
  grid-template-columns: minmax(0, 2fr) minmax(0, 1fr) minmax(0, 360px);
  column-gap: var(--mega-solutions-gap);
}

#mega-solutions .mega-media {
  justify-self: stretch;
  width: 100%;
}

#mega-solutions .mega-media-video {
  object-position: 42% 58%;
}

#mega-solutions .mega-links-columns {
  grid-auto-flow: column;
  grid-template-rows: repeat(4, var(--mega-solutions-row));
  gap: 0 var(--mega-solutions-gap);
}

#mega-solutions .mega-links {
  display: contents;
}

#mega-solutions .mega-link {
  list-style: none;
}

#mega-solutions .mega-col:nth-child(2) .mega-links {
  display: grid;
  grid-auto-rows: var(--mega-solutions-row);
  gap: 0;
  align-content: start;
}

#mega-solutions .mega-col:nth-child(2) .mega-link a {
  height: 100%;
  padding-block: var(--mega-item-pad);
}

.mega-grid-login {
  grid-template-columns: 1fr;
}

.mega-kicker {
  margin: 0 0 16px;
  font-size: 12px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--muted);
}

.mega-links {
  margin: 0;
  padding: 0;
  display: grid;
  gap: 0;
  list-style: none;
  align-content: start;
  grid-auto-rows: var(--mega-row-h);
}

.mega-links-columns {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: clamp(18px, 3vw, 44px);
}

.mega-link a {
  display: grid;
  height: 100%;
  gap: var(--mega-item-gap);
  padding-block: var(--mega-item-pad);
  grid-template-rows: var(--mega-title-h) auto;
  align-content: start;
  border-radius: 0;
  overflow: hidden;
  transform: translate3d(0, 0, 0);
  transition: transform 180ms ease;
}

.mega-link a:hover,
.mega-link a:focus-visible {
  outline: none;
  background: none;
  transform: translate3d(4px, 0, 0);
}

.mega-title {
  font-weight: 600;
  font-size: 18px;
  display: inline-flex;
  align-items: flex-start;
  gap: 8px;
  line-height: 1.12;
  min-height: var(--mega-title-h);
  height: var(--mega-title-h);
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
}

.mega-title::after {
  content: "↗";
  opacity: 0;
  transform: translate3d(-6px, 0, 0);
  transition: opacity 180ms ease, transform 180ms ease;
}

.mega-link a:hover .mega-title::after,
.mega-link a:focus-visible .mega-title::after {
  opacity: 1;
  transform: translate3d(0, 0, 0);
}

.mega-desc {
  color: var(--muted);
  font-size: var(--body-copy-size);
  line-height: var(--body-copy-line);
  min-height: calc(1em * var(--body-copy-line) * var(--mega-desc-lines));
  max-height: calc(1em * var(--body-copy-line) * var(--mega-desc-lines));
  display: -webkit-box;
  -webkit-line-clamp: var(--mega-desc-lines);
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.nowrap {
  white-space: nowrap;
}

@media (max-width: 760px) {
  .intro-text .nowrap {
    white-space: normal;
  }
}

.mega-media {
  min-width: 0;
  width: min(360px, 100%);
  justify-self: end;
}

.mega-media-link {
  display: block;
}

.mega-media-block {
  border-radius: var(--media-radius-md);
  border: 1px solid var(--hairline);
  background: color-mix(in srgb, var(--text) 6%, var(--bg));
  aspect-ratio: 4 / 3;
  width: 100%;
  overflow: hidden;
}

.mega-media-block[aria-label="Overview visual"] {
  box-shadow: 0 34px 80px -52px rgba(0, 0, 0, 0.48), 0 16px 34px -26px rgba(0, 0, 0, 0.3);
}

@media (max-width: 980px) {
  .mega-media-block[aria-label="Overview visual"] {
    box-shadow: 0 22px 52px -34px rgba(0, 0, 0, 0.42), 0 10px 24px -18px rgba(0, 0, 0, 0.26);
  }
}

.mega-media-video,
.system-overview-loop-video {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}


.mega-cards {
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
}

.mega-card {
  display: grid;
  gap: 10px;
  padding: 10px;
  border-radius: 16px;
  border: 1px solid var(--hairline);
  background: var(--bg);
  transition: transform 160ms ease, box-shadow 160ms ease;
}

.mega-card:hover,
.mega-card:focus-visible {
  outline: none;
  transform: translateY(-2px);
  box-shadow: 0 12px 30px rgba(0, 0, 0, 0.14);
}

.mega-card img {
  border-radius: var(--media-radius-sm);
  aspect-ratio: var(--feature-frame-ratio);
  object-fit: cover;
}

.mega-card-title {
  font-weight: 600;
  line-height: 1.25;
}

.mega-card-cta {
  color: var(--muted);
  font-size: 14px;
}

.mega-login-cta {
  height: 100%;
  border-radius: 18px;
  background: color-mix(in srgb, #111111 5%, #ffffff);
  padding: 18px;
  display: grid;
  gap: 10px;
  align-content: start;
}

.mega-login-title {
  margin: 0;
  font-weight: 700;
}

.mega-login-desc {
  margin: 0;
  color: var(--muted);
}

.hero {
  padding-top: 20px;
  padding-bottom: 76px;
  display: grid;
  gap: 0;
  align-items: start;
}

.hero-inner {
  display: grid;
  gap: 42px;
  align-content: start;
}

.home-page main > section.hero {
  min-height: var(--meet-max-banner-min-height);
  padding-top: 40px;
  padding-bottom: 40px;
  align-content: center;
}

.hero-media {
  min-height: auto;
  padding: 0;
}

.video-band {
  background: radial-gradient(1200px 520px at 35% 15%, rgba(255, 255, 255, 0.11), transparent 62%),
    radial-gradient(900px 620px at 65% 85%, rgba(255, 255, 255, 0.06), transparent 68%),
    linear-gradient(135deg, #151515 0%, #3a3a3a 55%, #1a1a1a 100%);
  padding-inline: var(--page-gutter);
  padding-block: clamp(18px, 3vw, 28px);
  min-height: var(--section-min-height);
  display: flex;
  align-items: stretch;
}

.home-page .video-band {
  min-height: 100svh;
  background: transparent !important;
  padding-inline: 0 !important;
  padding-block: 0 !important;
}

.video-band .video-shell {
  width: 100%;
  background: transparent;
  margin-inline: 0;
  min-height: calc(var(--section-min-height) - (clamp(18px, 3vw, 28px) * 2));
}

.home-page .video-band .video-shell {
  min-height: 100svh;
  background: transparent !important;
  box-shadow: none !important;
}

.video-band .video-shell::before {
  content: none;
}

.video-band .video-placeholder {
  background: transparent;
}

.video-band .video-placeholder-inner {
  width: min(520px, 100%);
}

.hero-heading {
  display: grid;
  gap: var(--title-subtitle-gap);
  justify-items: start;
  text-align: left;
  align-content: start;
}

.home-page .hero-heading {
  margin-left: 0;
  gap: var(--title-subtitle-gap);
  padding-left: 0;
}

.home-page .hero-subtitle {
  font-family: var(--serif);
  transform: none !important;
  justify-self: start;
  align-self: start;
  text-align: left;
  width: 100%;
  margin-left: 0 !important;
  padding-left: 0 !important;
}

.home-page .hero-title {
  padding-left: 0;
  transform: none;
  font-family: "Montserrat", var(--meet-max-font) !important;
  font-weight: 700 !important;
  letter-spacing: -0.015em !important;
  font-synthesis: none;
}

.hero-cta {
  padding: 12px 18px;
  font-size: 15px;
}

.intro {
  padding-top: 72px;
  padding-bottom: 72px;
  min-height: auto;
}

.home-page .intro {
  min-height: calc(var(--section-min-height) - var(--header-offset));
  padding-block: clamp(44px, 8svh, 92px);
  display: flex;
  justify-content: center;
  align-items: stretch;
}

.home-page .intro-inner {
  min-height: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: clamp(10px, 1.4svh, 18px);
}

.home-page .intro-copy {
  flex: 0 0 auto;
  align-content: start;
  padding-top: 0;
}

.home-page .ticker {
  margin-top: clamp(68px, 7.4svh, 108px);
  margin-bottom: 0;
  align-self: stretch;
}

.intro-inner {
  display: grid;
  gap: 38px;
  justify-items: center;
}

.ticker {
  position: relative;
  padding-block: 10px;
  background: transparent;
  overflow: hidden;
  margin-bottom: 36px;
  justify-self: stretch;
}

.ticker-viewport {
  width: 100%;
  overflow: hidden;
}

.ticker-marquee {
  display: flex;
  width: max-content;
  will-change: transform;
  animation: ticker-ltr 40s linear infinite;
}

.ticker-track {
  margin: 0;
  padding: 0;
  display: flex;
  gap: 0;
  align-items: center;
  white-space: nowrap;
  flex-shrink: 0;
  list-style: none;
}

.ticker-item {
  position: relative;
  font-size: 13px;
  line-height: 1;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: color-mix(in srgb, var(--text) 82%, transparent);
  display: inline-flex;
  align-items: center;
}

.ticker-item::before {
  content: "•";
  margin-inline: 20px;
  color: color-mix(in srgb, var(--text) 65%, transparent);
}

.ticker-marquee .ticker-track:first-child .ticker-item:first-child::before {
  content: none;
  margin: 0;
}


.ticker-fade {
  pointer-events: none;
  position: absolute;
  inset: 0;
  background: linear-gradient(
    90deg,
    color-mix(in srgb, var(--bg) 92%, transparent) 0%,
    transparent 14%,
    transparent 86%,
    color-mix(in srgb, var(--bg) 92%, transparent) 100%
  );
}

@keyframes ticker-ltr {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(-50%);
  }
}

@keyframes security-architecture-marquee {
  0%,
  16% {
    transform: translate3d(0, var(--marquee-start), 0);
  }
  16% {
    animation-timing-function: cubic-bezier(0.33, 0, 0.15, 1);
  }
  25%,
  41% {
    transform: translate3d(0, calc(var(--marquee-start) - var(--marquee-step)), 0);
  }
  41% {
    animation-timing-function: cubic-bezier(0.33, 0, 0.15, 1);
  }
  50%,
  66% {
    transform: translate3d(0, calc(var(--marquee-start) - (var(--marquee-step) * 2)), 0);
  }
  66% {
    animation-timing-function: cubic-bezier(0.33, 0, 0.15, 1);
  }
  75%,
  91% {
    transform: translate3d(0, calc(var(--marquee-start) - (var(--marquee-step) * 3)), 0);
  }
  91% {
    animation-timing-function: cubic-bezier(0.33, 0, 0.15, 1);
  }
  100% {
    transform: translate3d(0, calc(var(--marquee-start) - var(--marquee-shift)), 0);
  }
}

.intro-copy {
  display: grid;
  justify-items: center;
  text-align: center;
  width: 100%;
}

.intro-text {
  margin: 0;
  width: min(62ch, 100%);
  margin-inline: auto;
  font-family: var(--serif);
  font-size: clamp(20px, 2vw, 30px);
  line-height: 1.3;
  letter-spacing: -0.01em;
  color: color-mix(in srgb, var(--text) 92%, transparent);
  text-align: center;
  text-wrap: balance;
}

.intro-subtext {
  margin: 14px 0 0;
  width: min(78ch, 100%);
  margin-inline: auto;
  font-size: var(--site-subtitle-size);
  line-height: var(--site-subtitle-line);
  font-weight: 600;
  letter-spacing: -0.01em;
  color: var(--section-subtitle-color);
  text-align: center;
  text-wrap: balance;
}

.features {
  padding-block: 56px 84px;
  position: relative;
}

.home-page .features {
  min-height: 100vh;
  min-height: 100svh;
  box-sizing: border-box;
  padding-top: 0;
  background-color: var(--bg);
  background-image: radial-gradient(900px 420px at 55% 10%, rgba(90, 80, 70, 0.015), transparent 66%),
    radial-gradient(760px 360px at 45% 92%, rgba(90, 80, 70, 0.011), transparent 62%),
    linear-gradient(
      180deg,
      color-mix(in srgb, var(--bg) 72%, #cfcac2 28%) 0%,
      var(--bg) 52%,
      color-mix(in srgb, var(--bg) 78%, #d7d1c9 22%) 100%
    );
}

.features-grid {
  display: grid;
  grid-template-columns: repeat(1, minmax(0, 1fr));
  gap: 34px;
}

.home-page .features .features-grid {
  --home-features-gap: clamp(22px, 3vw, 34px);
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--home-features-gap);
  width: 100%;
  margin-inline: 0;
}

.home-page .features .feature {
  display: flex;
  flex-direction: column;
  gap: 10px;
  height: 100%;
  background: transparent;
  border: 0;
  padding: 0;
  overflow: visible;
}

.home-page .features .feature-kicker {
  display: block;
  margin: 0;
}

.home-page .features .feature-title {
  padding: 0;
}

.home-page .features .feature-text {
  padding: 0;
}

.home-page .features .feature-media {
  width: 100%;
  aspect-ratio: 4 / 5;
  min-height: 340px;
  border: none !important;
  outline: none !important;
  background: transparent;
  display: grid;
  place-items: center;
  box-shadow: 0 20px 50px -30px rgba(0, 0, 0, 0.28), 0 8px 20px -16px rgba(0, 0, 0, 0.16) !important;
}

.home-page .features .feature-media::before {
  content: none;
}

.home-page .features .feature-media::after {
  display: none;
}

.home-feature-video {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  object-position: 50% 50%;
}

.home-feature-video--drafting-crop {
  object-fit: cover;
  object-position: 10% 46%;
  transform: scale(1.24);
  transform-origin: center;
  -webkit-clip-path: inset(0 0 36px 0);
  clip-path: inset(0 0 36px 0);
}

.home-feature-video--reasoning-center {
  object-position: 46% 50%;
  transform: scale(1.08);
  transform-origin: center;
  -webkit-clip-path: inset(0 0 0 26px);
  clip-path: inset(0 0 0 26px);
}

.home-feature-video--review-crop {
  object-position: 10% 50%;
  -webkit-clip-path: inset(0 0 3px 0);
  clip-path: inset(0 0 3px 0);
}

.home-feature-video--knowledge-crop {
  object-fit: cover;
  object-position: 54% 66%;
  transform: scale(1.68);
  transform-origin: center;
  -webkit-clip-path: inset(2px 2px 42px 2px);
  clip-path: inset(2px 2px 42px 2px);
}

@media (max-width: 900px) {
  .home-feature-video--reasoning-center {
    transform: scale(1.12);
    object-position: 45% 50%;
    -webkit-clip-path: inset(0 0 0 22px);
    clip-path: inset(0 0 0 22px);
  }

  .home-feature-video--drafting-crop {
    transform: scale(1.34);
    object-position: 8% 46%;
    -webkit-clip-path: inset(0 0 36px 0);
    clip-path: inset(0 0 36px 0);
  }

  .home-feature-video--knowledge-crop {
    transform: scale(1.78);
    object-position: 56% 63%;
    -webkit-clip-path: inset(2px 2px 42px 2px);
    clip-path: inset(2px 2px 42px 2px);
  }
}

.home-page .features .feature-media--reasoning {
  --home-card-bg: #bdb2a8;
  background: var(--home-card-bg);
  background-image: url("images/MARRON FOND REASONING VIDEO.png");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}

.home-page .features .feature-media-doc {
  width: 82%;
  height: 80%;
  display: grid;
  align-content: center;
  justify-items: center;
  position: relative;
}

.home-page .features .feature-media-doc-card {
  width: 100%;
  height: 100%;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.78);
  border: 1px solid rgba(17, 17, 17, 0.08);
  box-shadow: 0 30px 80px -70px rgba(0, 0, 0, 0.35);
  padding: 28px 26px;
  display: grid;
  gap: 14px;
}

.home-page .features .feature-media-doc-title {
  font-weight: 600;
  font-size: 14px;
  color: rgba(17, 17, 17, 0.62);
  justify-self: start;
}

.home-page .features .feature-media-doc-rule {
  height: 2px;
  width: 100%;
  background: rgba(17, 17, 17, 0.08);
  border-radius: 999px;
}

.home-page .features .feature-media-doc-lines {
  display: grid;
  gap: 10px;
}

.home-page .features .feature-media-doc-lines span {
  display: block;
  height: 3px;
  border-radius: 999px;
  background: rgba(17, 17, 17, 0.1);
  width: 100%;
}

.home-page .features .feature-media-doc-lines span:nth-child(2),
.home-page .features .feature-media-doc-lines span:nth-child(5) {
  width: 88%;
}

.home-page .features .feature-media-doc-lines span:nth-child(3) {
  width: 92%;
}

.home-page .features .feature-media-doc-bullets {
  display: grid;
  gap: 10px;
  margin-top: 6px;
}

.home-page .features .feature-media-doc-bullets span {
  display: block;
  height: 3px;
  border-radius: 999px;
  background: rgba(17, 17, 17, 0.1);
  width: 80%;
}

.home-page .features .feature-media-doc-icon {
  position: absolute;
  left: -12px;
  bottom: -14px;
  width: 32px;
  height: 32px;
  border-radius: 8px;
  background: linear-gradient(135deg, #6aa0ff, #2f6cff);
  color: #ffffff;
  display: grid;
  place-items: center;
  font-weight: 800;
  font-size: 13px;
  box-shadow: 0 22px 40px -30px rgba(0, 0, 0, 0.55);
}

.home-page .features .feature-media--drafting {
  --home-drafting-frame-bg: #e5d5bc;
  position: relative;
  overflow: hidden;
  background: var(--home-drafting-frame-bg) !important;
  background-image: url("images/JAUNE FOND DRAFTING VIDEO.png") !important;
  background-size: cover !important;
  background-position: center !important;
  background-repeat: no-repeat !important;
}

.home-page .features .feature-media--drafting .home-feature-video {
  position: relative;
  z-index: 1;
  background: var(--home-drafting-frame-bg) !important;
}

.home-page .features .feature-media--drafting::after {
  content: none !important;
  display: none !important;
}

.home-page .features .feature-media-files {
  width: 78%;
  height: 68%;
  display: grid;
  place-items: center;
}

.home-page .features .feature-media-files-card {
  width: 100%;
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.28);
  border: 1px solid rgba(17, 17, 17, 0.08);
  padding: 18px 18px 16px;
  display: grid;
  gap: 12px;
}

.home-page .features .feature-media-files-title {
  font-weight: 600;
  font-size: 12px;
  color: rgba(17, 17, 17, 0.72);
}

.home-page .features .feature-media-files-row {
  display: grid;
  grid-template-columns: 10px 1fr;
  gap: 10px;
  align-items: center;
  padding: 10px 12px;
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.26);
}

.home-page .features .feature-media-files-dot {
  width: 10px;
  height: 10px;
  border-radius: 3px;
  background: rgba(30, 110, 255, 0.9);
}

.home-page .features .feature-media-files-name {
  font-size: 11px;
  color: rgba(17, 17, 17, 0.7);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.home-page .features .feature-media--review {
  background: transparent;
  background-image: url("images/TERRACOTA FOND REVIEW VIDEO.png");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}

.home-page .features .feature-media-review-chip {
  width: min(78%, 360px);
  padding: 16px 18px;
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.55);
  border: 1px solid rgba(17, 17, 17, 0.12);
  backdrop-filter: blur(10px);
  box-shadow: 0 26px 60px -52px rgba(0, 0, 0, 0.5);
  display: grid;
  gap: 10px;
  justify-items: start;
}

.home-page .features .feature-media-review-step {
  font-weight: 600;
  font-size: 12px;
  color: rgba(17, 17, 17, 0.7);
}

.home-page .features .feature-media-review-action {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.72);
  border: 1px solid rgba(17, 17, 17, 0.1);
  color: rgba(17, 17, 17, 0.82);
  font-weight: 600;
  font-size: 13px;
}

.home-page .features .feature-media--knowledge {
  background: transparent;
  background-image: url("images/VERT KNOWLEDGE FOND VIDEO.png");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}

.home-page .features .feature-media-sources {
  display: grid;
  gap: 12px;
  justify-items: center;
  align-content: center;
}

.home-page .features .feature-media-sources-title {
  font-weight: 600;
  color: rgba(17, 17, 17, 0.8);
}

.home-page .features .feature-media-sources-pill {
  padding: 12px 20px;
  border-radius: 14px;
  border: 1px solid rgba(17, 17, 17, 0.14);
  background: rgba(255, 255, 255, 0.8);
  font-weight: 600;
  color: rgba(17, 17, 17, 0.8);
}

.home-page .features .feature-media-sources-pill.is-muted {
  background: rgba(255, 255, 255, 0.26);
  border-color: rgba(255, 255, 255, 0.2);
  color: rgba(17, 17, 17, 0.45);
}

.feature {
  display: grid;
  gap: 14px;
}

.feature-media {
  border-radius: 0;
  border: 1px solid var(--hairline);
  background: linear-gradient(135deg, rgba(17, 17, 17, 0.12), rgba(17, 17, 17, 0.03));
  aspect-ratio: 5 / 6;
  position: relative;
  overflow: hidden;
}

.features .feature-media {
  aspect-ratio: 4 / 5;
  min-height: 320px;
  background: linear-gradient(180deg, rgba(17, 17, 17, 0.1), rgba(17, 17, 17, 0.03));
}

.features .feature-media::after {
  display: none;
}

.feature-media::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(900px 420px at 50% 20%, rgba(255, 255, 255, 0.65), transparent 55%),
    radial-gradient(900px 420px at 30% 80%, rgba(255, 255, 255, 0.25), transparent 60%);
  opacity: 0.28;
}

.feature-media::after {
  content: "";
  position: absolute;
  inset: 0;
  background: repeating-linear-gradient(90deg, rgba(255, 255, 255, 0.06) 0 1px, transparent 1px 10px);
  opacity: 0.08;
  mix-blend-mode: overlay;
}

.feature-title {
  margin: 0;
  font-size: 18px;
  font-weight: 700;
  letter-spacing: -0.01em;
}

.feature-kicker {
  margin: 0;
  font-size: 12px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--muted);
}

.feature-text {
  margin: 0;
  color: var(--muted);
  font-size: var(--body-copy-size);
  line-height: var(--body-copy-line);
}


.journey {
  padding-block: clamp(64px, 8vw, 110px);
  background: transparent;
}

.journey-inner {
  display: grid;
  gap: 32px;
}

.journey-left {
  display: grid;
  gap: var(--title-subtitle-gap);
  justify-items: start;
}

.journey-title {
  margin: 0;
  font-family: var(--serif);
  font-weight: 700;
  font-size: clamp(34px, 3.6vw, 52px);
  line-height: 1.05;
  letter-spacing: -0.02em;
}

.why-max-page .journey-title {
  font-size: var(--site-heading-size) !important;
  line-height: var(--site-heading-line) !important;
}

.why-max-page .journey-button {
  display: none !important;
}

.journey-subtitle {
  margin: 0;
  color: color-mix(in srgb, var(--text) 70%, transparent);
  font-size: 14px;
}

.journey-button {
  justify-self: start;
  align-self: start;
}

.journey-left .journey-button {
  justify-self: start !important;
}

.security {
  --section-heading-color: #ffffff;
  --security-dark-bg: #0b0b0b;
  --section-subtitle-color: color-mix(in srgb, #ffffff 72%, transparent);
  --security-dark-bg-image: radial-gradient(1000px 520px at 55% 12%, rgba(255, 255, 255, 0.08), transparent 64%),
    radial-gradient(900px 480px at 40% 100%, rgba(255, 255, 255, 0.06), transparent 62%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.02), rgba(0, 0, 0, 0.06));
  color: #f4f4f4;
  padding-block: clamp(84px, 10vw, 140px);
  background-color: var(--security-dark-bg);
  background-image: var(--security-dark-bg-image);
}

.security-inner {
  display: grid;
  grid-template-rows: auto 1fr;
  gap: clamp(44px, 7vw, 84px);
  align-items: start;
}

.security-title {
  margin: 0;
  font-family: var(--title-font);
  font-weight: 500;
  font-size: clamp(30px, 3.2vw, 44px);
  letter-spacing: -0.02em;
  line-height: 1.12;
  color: #f7f7f7;
}

.security-kicker {
  margin: 0;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-size: 12px;
  color: color-mix(in srgb, #ffffff 70%, transparent);
}

.security-subtitle {
  margin: 0;
  font-size: clamp(16px, 1.35vw, 20px);
  line-height: 1.55;
  color: color-mix(in srgb, #ffffff 72%, transparent);
}

.security-body {
  margin: 0;
  font-size: clamp(15px, 1.15vw, 18px);
  line-height: 1.6;
  color: color-mix(in srgb, #ffffff 66%, transparent);
}

.security-top {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1.2fr);
  gap: clamp(28px, 5vw, 84px);
  align-items: start;
}

.security-left {
  max-width: 560px;
  justify-self: start;
  text-align: left;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}

.security-left .security-cta {
  margin-top: 18px;
}

.security-right {
  max-width: 720px;
  width: min(720px, 100%);
  justify-self: end;
  text-align: left;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 18px;
}

@media (min-width: 981px) {
  .home-page .security-top {
    grid-template-columns: minmax(0, 1.14fr) minmax(0, 0.86fr);
    gap: clamp(18px, 2.4vw, 34px);
  }

  .home-page .security-right {
    max-width: none;
    width: 100%;
    justify-self: end;
  }

  .home-page .security-right .security-body {
    max-width: none;
    width: min(760px, 100%);
    align-self: stretch;
    margin-left: auto;
    transform: none;
  }
}

.security-cta {
  justify-self: start;
  display: inline-flex;
  align-items: center;
  padding: 10px 14px;
  border-radius: 10px;
  border: 1px solid color-mix(in srgb, #ffffff 32%, transparent);
  color: #ffffff;
  font-size: 14px;
  letter-spacing: -0.01em;
  background: transparent;
  transition: border-color 180ms ease, background-color 180ms ease, transform 180ms ease;
  will-change: transform;
}

.security-cta:hover {
  border-color: color-mix(in srgb, #ffffff 48%, transparent);
  background-color: rgba(255, 255, 255, 0.05);
  transform: translateY(-1px);
}

.security-cta:focus-visible {
  outline: 3px solid color-mix(in srgb, #ffffff 22%, transparent);
  outline-offset: 3px;
}

.security-standards-row {
  --security-standard-icon-size: clamp(112px, 8vw, 150px);
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: clamp(16px, 3vw, 44px);
  align-items: end;
  width: min(980px, 100%);
  margin-top: clamp(26px, 4vw, 58px);
  margin-inline: auto;
}

.security-standard {
  display: grid;
  justify-items: center;
  text-align: center;
  gap: 12px;
  min-height: 170px;
  text-decoration: none;
  color: inherit;
  padding-block: 6px;
  transition: filter 180ms ease;
}

.security-standard-icon {
  width: var(--security-standard-icon-size);
  height: var(--security-standard-icon-size);
  color: rgba(255, 255, 255, 0.2);
  display: grid;
  place-items: center;
  transition: color 180ms ease, filter 180ms ease;
}

.security-standard-icon svg {
  width: var(--security-standard-icon-size);
  height: var(--security-standard-icon-size);
}

.security-standard-label {
  font-size: 18px;
  letter-spacing: -0.01em;
  color: color-mix(in srgb, #ffffff 82%, transparent);
  transition: color 180ms ease, text-shadow 180ms ease;
}

.security-standard-status {
  font-size: 17px;
  font-weight: 600;
  color: color-mix(in srgb, #ffffff 78%, transparent);
  line-height: 1.1;
}

.security-standard-link {
  font-size: 14px;
  color: color-mix(in srgb, #ffffff 55%, transparent);
  display: inline-flex;
  gap: 8px;
  align-items: center;
  transition: color 180ms ease, text-shadow 180ms ease;
}

.home-page .security-standard-link {
  font-size: 17px;
  font-weight: 600;
  letter-spacing: 0;
}

.security-standard:hover,
.security-standard:focus-visible {
  filter: brightness(1.05);
}

.security-standard:hover .security-standard-label,
.security-standard:focus-visible .security-standard-label {
  color: #ffffff;
  text-shadow: 0 0 12px rgba(255, 255, 255, 0.18);
}

.security-standard:hover .security-standard-link {
  color: #ffffff;
  text-shadow: 0 0 10px rgba(255, 255, 255, 0.22);
}

.security-standard:hover .security-standard-icon {
  color: rgba(255, 255, 255, 0.52);
  filter: drop-shadow(0 0 8px rgba(255, 255, 255, 0.22));
}

@media (max-width: 980px) {
  .system-brings-subtitle {
    white-space: normal;
  }

  .security-top {
    grid-template-columns: 1fr;
  }

  .security-right {
    justify-self: stretch;
    text-align: left;
    align-items: flex-start;
  }

  .security-standards-row {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

.security-page {
  --security-dark-bg: #000000;
  background-color: var(--security-dark-bg);
  background-image: none;
  color: #f5f5f5;
}

.security-page .site-header {
  background-color: var(--security-dark-bg);
  background-image: none;
  border-bottom-color: transparent;
  backdrop-filter: none;
}

.security-page .nav-link {
  color: color-mix(in srgb, #ffffff 78%, transparent);
  border-bottom-color: transparent;
}

.security-page .nav-link:hover,
.security-page .nav-link:focus-visible,
.security-page .nav-link[aria-expanded="true"] {
  color: #ffffff;
  border-bottom-color: #ffffff;
}

.security-page .brand-mark {
  border-color: #ffffff;
}

.security-page .brand-name {
  color: #ffffff;
}

.security-page .site-footer .brand-name {
  color: #ffffff;
}

.security-page .site-footer .brand-mark {
  border-color: #ffffff;
}

.security-page .site-footer {
  background-color: var(--security-dark-bg);
  background-image: none;
  color: #f5f5f5;
}

.security-page .footer-link {
  color: color-mix(in srgb, #ffffff 72%, transparent);
}

.security-page .footer-link:hover,
.security-page .footer-link:focus-visible {
  color: #ffffff;
}

.security-page .footer-col-title {
  color: #ffffff;
}

.security-page .header-cta {
  background: #ffffff;
  color: #111111;
}

.security-page .mega {
  color: #111111;
}

.security-page .mega-kicker {
  color: var(--muted);
}

.security-page .mega-title {
  color: #111111;
}

.security-page .mega-desc {
  color: var(--muted);
}

.security-hero {
  padding-block: clamp(72px, 10vw, 140px);
  background: transparent;
  min-height: 100vh;
  display: grid;
  align-items: center;
}

.security-hero-inner {
  display: grid;
  gap: 36px;
  align-items: start;
}

.security-hero-left {
  display: grid;
  gap: 18px;
  align-self: start;
}

.security-hero-kicker {
  margin: 0;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-size: 12px;
  color: color-mix(in srgb, #ffffff 70%, transparent);
}

.security-hero-title {
  margin: 0;
  font-family: var(--serif);
  font-weight: 700;
  color: #ffffff;
}

.security-hero-text {
  margin: 0;
  max-width: 48ch;
  font-size: 15px;
  line-height: 1.6;
  color: color-mix(in srgb, #ffffff 65%, transparent);
}

.security-hero-cta {
  justify-self: start;
}

.security-hero-right {
  min-height: auto;
}

.security-hero-visual {
  position: relative;
  width: 100%;
  height: auto;
  min-height: auto;
  aspect-ratio: var(--feature-frame-ratio);
  border-radius: var(--media-radius-lg);
  background:
    radial-gradient(120% 80% at 20% 30%, rgba(255, 255, 255, 0.18), transparent 60%),
    linear-gradient(120deg, #5c5a57 0%, #80624c 35%, #b79a7e 65%, #d8c4ab 100%);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.12);
  overflow: hidden;
}

.security-hero-image {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  z-index: 0;
}

.security-hero-visual::after {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(60% 40% at 80% 20%, rgba(0, 0, 0, 0.25), transparent 60%);
  z-index: 1;
}

.security-hero-pill {
  position: absolute;
  right: 12%;
  top: 45%;
  display: inline-flex;
  gap: 12px;
  padding: 10px 14px;
  border-radius: 18px;
  background: rgba(0, 0, 0, 0.35);
  border: 1px solid rgba(255, 255, 255, 0.2);
  backdrop-filter: blur(8px);
  z-index: 2;
}

.security-hero-pill-icon {
  width: 44px;
  height: 44px;
  border-radius: 14px;
  display: grid;
  place-items: center;
  background: rgba(255, 255, 255, 0.06);
  color: rgba(255, 255, 255, 0.6);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.security-hero-pill-icon.is-active {
  background: rgba(255, 255, 255, 0.18);
  color: #ffffff;
}

.security-standards {
  padding-block: clamp(64px, 8vw, 120px);
  background: var(--bg);
  color: var(--text);
  min-height: 100vh;
  display: grid;
  align-items: stretch;
}

.security-page .security-standards {
  background: transparent;
  color: #f5f5f5;
  min-height: auto;
  padding-block: clamp(28px, 4vw, 56px);
}

.security-page .security-standards-inner {
  align-content: start;
  gap: clamp(28px, 4vw, 44px);
}

.security-page .security-standards-title,
.security-page .security-standards-subtitle {
  color: #ffffff !important;
}

.security-page .security-standards-subtitle {
  font-family: var(--serif) !important;
  font-weight: 700 !important;
  letter-spacing: -0.02em !important;
  font-size: var(--site-heading-size) !important;
  line-height: var(--site-heading-line) !important;
  text-shadow: 0 1px 0 rgba(0, 0, 0, 0.2);
}

.security-page .security-standards-icon {
  border-color: rgba(255, 255, 255, 0.22);
  color: rgba(255, 255, 255, 0.78);
}

.security-page .security-standards-label {
  margin: 0;
  font-size: 18px;
  font-weight: 600;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.92);
}

.security-page .security-standards-statusline {
  margin: 0;
  font-size: 14px;
  line-height: 1.1;
  font-weight: 600;
  color: rgba(255, 255, 255, 0.78);
}

.security-page .security-standards-link {
  color: color-mix(in srgb, #ffffff 70%, transparent);
  font-size: 15px;
  font-weight: 500;
  letter-spacing: 0;
}

.security-page .security-standards-link:hover,
.security-page .security-standards-link:focus-visible {
  color: #ffffff;
}

.security-page .security-architecture-marquee-title {
  color: #ffffff !important;
}

.security-page .security-title {
  color: #ffffff !important;
}

.security-page .security-architecture-marquee-subtitle {
  color: color-mix(in srgb, #ffffff 86%, transparent) !important;
}

.security-page .security-standards-copy p {
  color: color-mix(in srgb, #ffffff 72%, transparent);
}

.security-standards-inner {
  display: grid;
  gap: 48px;
  min-height: 100%;
  align-content: center;
}

.security-standards-title {
  margin: 0;
  font-family: var(--serif);
  font-weight: 700;
  font-size: clamp(24px, 2.8vw, 40px);
  text-align: center;
}

.security-standards-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 26px;
  justify-items: center;
}

.security-standards-card {
  display: grid;
  gap: 10px;
  justify-items: center;
  text-align: center;
  transition: filter 180ms ease;
}

.security-standards-icon {
  width: 72px;
  height: 72px;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--text) 20%, transparent);
  display: grid;
  place-items: center;
  color: color-mix(in srgb, var(--text) 80%, transparent);
  transition: color 180ms ease, border-color 180ms ease, filter 180ms ease;
}

.security-standards-icon svg {
  width: 46px;
  height: 46px;
}

.security-standards-icon-image {
  width: 46px;
  height: 46px;
  object-fit: contain;
  display: block;
}

.security-standards-icon--soc2 {
  border: none !important;
  background: transparent !important;
  position: relative;
  isolation: isolate;
  border-radius: 999px;
}

.security-standard-icon.security-standards-icon--soc2::before,
.security-standard-icon.security-standards-icon--soc2::after,
.security-standards-icon.security-standards-icon--soc2::before,
.security-standards-icon.security-standards-icon--soc2::after {
  content: "";
  position: absolute;
  inset: 0;
  margin: auto;
  border-radius: 999px;
  pointer-events: none;
  transition: border-color 180ms ease, opacity 180ms ease;
  z-index: 0;
}

.security-standard-icon.security-standards-icon--soc2::before,
.security-standards-icon.security-standards-icon--soc2::before {
  content: none !important;
  display: none !important;
  border: 0 !important;
}

.security-standard-icon.security-standards-icon--soc2::after,
.security-standards-icon.security-standards-icon--soc2::after {
  content: none !important;
  display: none !important;
  border: 0 !important;
}

.security-standards-icon--soc2 .security-standards-icon-image {
  width: 64% !important;
  height: auto !important;
  max-width: none !important;
  max-height: none !important;
  object-fit: contain !important;
  transition: transform 180ms ease, filter 180ms ease !important;
  position: relative;
  z-index: 2;
  filter:
    brightness(0) saturate(0) invert(1)
    contrast(1.04)
    drop-shadow(0 0 0.35px rgba(255, 255, 255, 0.75));
}

.security-standards-icon--soc2 svg {
  width: 100% !important;
  height: 100% !important;
  color: #ffffff;
  filter: drop-shadow(0 0 0.5px rgba(255, 255, 255, 0.28));
  transition: transform 180ms ease, filter 180ms ease !important;
  position: relative;
  z-index: 2;
}

.teaser-controls {
  display: none;
}

.security-standards-icon--soc2 svg path {
  fill: none !important;
  stroke: currentColor !important;
  vector-effect: non-scaling-stroke;
}

/* Home security row: scale SOC2 badge to visually match CCPA/GDPR icon footprint */
.home-page .security-standard .security-standards-icon--soc2 .security-standards-icon-image {
  width: calc(var(--security-standard-icon-size) * 0.64) !important;
  height: auto !important;
  max-width: none !important;
  max-height: calc(var(--security-standard-icon-size) * 0.64) !important;
}

.security-page .security-standards-icon.security-standards-icon--soc2 {
  width: 72px !important;
  height: 72px !important;
  min-width: 72px !important;
  min-height: 72px !important;
  border: none !important;
  background: transparent !important;
  box-shadow: none !important;
  color: inherit !important;
}

.security-standard:hover .security-standards-icon--soc2 .security-standards-icon-image,
.security-standard:focus-visible .security-standards-icon--soc2 .security-standards-icon-image,
.security-standards-card:hover .security-standards-icon--soc2 .security-standards-icon-image,
.security-standards-card:focus-within .security-standards-icon--soc2 .security-standards-icon-image {
  filter:
    brightness(0) saturate(0) invert(1)
    contrast(1.12)
    drop-shadow(0 0 0.7px rgba(255, 255, 255, 0.9)) !important;
  transform: scale(1.06);
}

.security-standard:hover .security-standards-icon--soc2 svg,
.security-standard:focus-visible .security-standards-icon--soc2 svg,
.security-standards-card:hover .security-standards-icon--soc2 svg,
.security-standards-card:focus-within .security-standards-icon--soc2 svg {
  filter: drop-shadow(0 0 0.9px rgba(255, 255, 255, 0.38)) !important;
  transform: scale(1.03);
}

.security-standard:hover .security-standards-icon--soc2::before,
.security-standard:focus-visible .security-standards-icon--soc2::before,
.security-standards-card:hover .security-standards-icon--soc2::before,
.security-standards-card:focus-within .security-standards-icon--soc2::before {
  border-color: rgba(255, 255, 255, 0.52);
  box-shadow: 0 0 8px rgba(255, 255, 255, 0.18);
}

.security-standard:hover .security-standards-icon--soc2::after,
.security-standard:focus-visible .security-standards-icon--soc2::after,
.security-standards-card:hover .security-standards-icon--soc2::after,
.security-standards-card:focus-within .security-standards-icon--soc2::after {
  content: none !important;
  display: none !important;
}

.security-standards-label {
  margin: 0;
  font-size: 12px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--text);
  transition: color 180ms ease, text-shadow 180ms ease;
}

.security-standards-link {
  display: inline-flex;
  align-items: center;
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.01em;
  color: color-mix(in srgb, var(--text) 70%, transparent);
  text-decoration: none;
  transition: color 180ms ease, text-shadow 180ms ease;
}

.security-standards-card:hover .security-standards-icon,
.security-standards-card:focus-within .security-standards-icon {
  border-color: rgba(255, 255, 255, 0.52);
  color: #ffffff;
  filter: drop-shadow(0 0 8px rgba(255, 255, 255, 0.18));
}

.security-standards-card:hover .security-standards-label,
.security-standards-card:focus-within .security-standards-label {
  color: #ffffff;
  text-shadow: 0 0 10px rgba(255, 255, 255, 0.14);
}

.security-standards-link:hover,
.security-standards-link:focus-visible {
  color: var(--text);
}

.security-architecture-marquee {
  --security-architecture-marquee-bg: var(--bg);
  background: var(--security-architecture-marquee-bg);
  color: var(--text);
  padding-block: clamp(56px, 7vw, 96px);
  display: grid;
  align-items: center;
  min-height: auto;
}

.security-architecture-marquee-inner {
  --marquee-window-height: clamp(320px, 48vh, 500px);
  --marquee-gap-inline: clamp(16px, 2vw, 30px);
  --marquee-title-line: calc(var(--section-title-size) * 1.1);
  --marquee-focus-index: 2;
  display: grid;
  grid-template-columns: minmax(0, 0.8fr) minmax(0, 2fr);
  gap: clamp(28px, 6vw, 90px);
  align-items: center;
}

.security-architecture-marquee-copy {
  max-width: 44ch;
  height: var(--marquee-window-height);
  display: grid;
  align-content: flex-start;
  justify-items: start;
  gap: var(--title-subtitle-gap);
  padding-top: calc((var(--marquee-window-height) - var(--marquee-title-line)) / 2);
}

.security-architecture-marquee-title {
  margin: 0;
  font-family: var(--sans);
  font-weight: 700;
  font-size: var(--section-title-size);
  line-height: 1.1;
}

.security-architecture-marquee-subtitle {
  margin: 0;
  font-weight: 600;
  color: color-mix(in srgb, var(--text) 70%, transparent);
}

.security-architecture-marquee-words {
  justify-self: stretch;
  width: 100%;
  min-width: 0;
  height: var(--marquee-window-height);
  display: block;
}

.security-architecture-marquee-window {
  position: relative;
  height: var(--marquee-window-height);
  overflow: hidden;
  -webkit-mask-image: linear-gradient(
    90deg,
    transparent 0%,
    rgba(0, 0, 0, 0.18) 4%,
    #000 10%,
    #000 90%,
    rgba(0, 0, 0, 0.18) 96%,
    transparent 100%
  );
  mask-image: linear-gradient(
    90deg,
    transparent 0%,
    rgba(0, 0, 0, 0.18) 4%,
    #000 10%,
    #000 90%,
    rgba(0, 0, 0, 0.18) 96%,
    transparent 100%
  );
}

.security-architecture-marquee-track {
  position: absolute;
  left: 0;
  right: 0;
  top: 50%;
  display: flex;
  align-items: center;
  gap: var(--marquee-gap-inline);
  margin: 0;
  width: max-content;
  transform: translate3d(0, -50%, 0);
  padding: 0;
  list-style: none;
  will-change: transform;
}

.security-architecture-marquee-track::before {
  content: none;
}

.security-architecture-marquee-track::after {
  content: none;
}

.security-architecture-marquee-item {
  margin: 0;
  position: relative;
  z-index: 0;
  font-family: var(--title-font);
  font-weight: 500;
  font-size: clamp(18px, 1.9vw, 32px);
  line-height: 1.15;
  letter-spacing: -0.02em;
  text-align: center;
  white-space: nowrap;
  flex: 0 0 var(--marquee-item-width);
  width: var(--marquee-item-width);
  min-width: var(--marquee-item-width);
  padding-inline: clamp(6px, 0.8vw, 12px);
  height: auto;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  text-overflow: ellipsis;
  text-transform: none;
  color: #aeb4bf;
  opacity: 0.7;
  transition:
    opacity 110ms linear,
    color 110ms linear,
    font-weight 110ms linear,
    filter 110ms linear;
}

.security-architecture-marquee-item.is-active {
  color: #ffffff;
  opacity: 1;
  font-weight: 600;
  filter: none;
}

.security-architecture-marquee-item.is-side {
  color: #9ea5b1;
  opacity: 0.6;
}

.security-architecture-marquee-item.is-near {
  color: #c2c8d2;
  opacity: 0.78;
}

.security-architecture-marquee-item.is-far {
  color: #8b929f;
  opacity: 0.42;
  filter: blur(0.2px);
}

.security-architecture-marquee-item.is-buffer {
  opacity: 0;
  visibility: hidden;
}

.security-architecture-marquee-item.is-focused {
  color: #ffffff;
  opacity: 1 !important;
}

.security-architecture-marquee-cta {
  justify-self: end;
  align-self: center;
  display: inline-flex;
  align-items: center;
  padding: 8px 10px;
  border-radius: var(--site-button-radius);
  border: 1px solid color-mix(in srgb, var(--text) 28%, transparent);
  background: transparent;
  color: var(--text);
  font-size: 13px;
  line-height: 1;
  text-decoration: none;
  white-space: nowrap;
  transition: border-color 180ms ease, background-color 180ms ease, transform 180ms ease;
  will-change: transform;
}

.security-architecture-marquee-cta:hover,
.security-architecture-marquee-cta:focus-visible {
  outline: none;
  border-color: color-mix(in srgb, var(--text) 44%, transparent);
  background: color-mix(in srgb, var(--text) 4%, transparent);
  transform: translateY(-1px);
}

@media (max-width: 960px) {
  .security-architecture-marquee-inner {
    grid-template-columns: 1fr;
  }

  .security-architecture-marquee-words {
    width: 100%;
    grid-template-columns: 1fr;
    row-gap: 18px;
  }

  .security-architecture-marquee-cta {
    justify-self: start;
  }
}

.security-architecture {
  background: #0d0d0d;
  color: #f5f5f5;
  padding-block: clamp(36px, 6vw, 72px);
  min-height: auto;
  display: grid;
  align-items: start;
}

.security-page .security-architecture {
  background: transparent;
  color: #f5f5f5;
}

.security-page .security-architecture-marquee {
  background-color: var(--security-dark-bg);
  background-image: none;
  color: #f5f5f5;
  --text: #f5f5f5;
  --muted: color-mix(in srgb, #ffffff 72%, transparent);
  padding-top: clamp(28px, 5vw, 60px);
  padding-bottom: clamp(10px, 1.8vw, 22px);
}

.security-page .security-architecture-marquee-inner {
  --marquee-gap-inline: clamp(4px, 0.8vw, 10px);
  min-height: var(--marquee-window-height);
  grid-template-columns: minmax(320px, 0.72fr) minmax(0, 2.28fr);
  gap: clamp(16px, 2vw, 32px);
}

.security-page .security-architecture-marquee-copy {
  min-height: var(--marquee-window-height);
  padding-top: 0;
  align-content: center;
  padding-right: clamp(10px, 1.6vw, 24px);
}

.security-page .security-architecture-marquee-words {
  width: 100%;
  justify-self: stretch;
  margin-left: 0;
  padding-left: 0;
}

.security-page .security-architecture-marquee-window {
  -webkit-mask-image: linear-gradient(90deg, transparent 0%, #000 6%, #000 94%, transparent 100%);
  mask-image: linear-gradient(90deg, transparent 0%, #000 6%, #000 94%, transparent 100%);
}

.security-page .security-architecture-marquee-item {
  font-size: clamp(14px, 1.18vw, 20px);
}

.security-page .security-pillars {
  padding-top: clamp(18px, 2.4vw, 34px);
}

.security-page .security-architecture-marquee-cta {
  justify-self: start !important;
  align-self: flex-start;
  margin-left: 0;
  margin-top: clamp(18px, 2vw, 26px);
  border-color: rgba(255, 255, 255, 0.18);
  background: rgba(255, 255, 255, 0.08);
  color: #ffffff;
  padding: 8px 10px;
  border-radius: var(--site-button-radius);
  font-size: 13px;
}

.security-architecture-inner {
  display: grid;
  gap: 28px;
  align-content: start;
}

.security-architecture-title {
  margin: 0;
  font-family: var(--serif);
  font-weight: 700;
  font-size: var(--section-title-size);
  color: #f5f5f5;
}

.security-architecture-subtitle {
  margin: 0;
  font-weight: 600;
  color: color-mix(in srgb, #ffffff 70%, transparent);
}

.security-architecture-flow {
  margin-top: clamp(60px, 10vh, 180px);
  display: flex;
  align-items: center;
  gap: 18px;
  flex-wrap: wrap;
}

.security-architecture-card {
  border: 2px solid rgba(255, 255, 255, 0.5);
  min-height: 180px;
  display: grid;
  place-items: center;
  font-weight: 600;
  text-align: center;
  padding: 16px;
  color: #f5f5f5;
  flex: 1 1 0;
  min-width: 180px;
}

.security-architecture-arrow {
  color: #f5f5f5;
  font-size: 20px;
  line-height: 1;
  flex: 0 0 auto;
}

.security-architecture-copy {
  background: transparent;
  color: #f3f3f3;
  padding-block: clamp(48px, 7vw, 96px);
}

.security-architecture-copy .security-architecture-title {
  color: #ffffff;
}

.security-architecture-copy .security-architecture-subtitle {
  color: color-mix(in srgb, #ffffff 70%, transparent);
}

.security-pillars {
  background: transparent;
  color: #f5f5f5;
  padding-block: clamp(64px, 8vw, 120px);
  padding-bottom: clamp(140px, 18vw, 240px);
}

.security-pillars-grid {
  display: grid;
  column-gap: 72px;
  row-gap: 140px;
  grid-auto-rows: 1fr;
}

.security-pillar {
  position: relative;
  border: 1px solid rgba(255, 255, 255, 0.7);
  padding: 22px 52px 34px 22px;
  background:
    radial-gradient(
      140% 100% at 20% 10%,
      rgba(255, 255, 255, 0.06) 0%,
      rgba(255, 255, 255, 0.025) 42%,
      transparent 78%
    ),
    rgba(0, 0, 0, 0.14);
  min-height: 320px;
  height: 100%;
  display: grid;
  grid-template-rows: 24px auto auto 1fr;
  gap: 12px;
  align-items: start;
  justify-items: start;
  transition: transform 220ms ease, border-color 220ms ease, box-shadow 220ms ease, background 220ms ease;
  will-change: transform;
}

.security-pillar:hover,
.security-pillar:focus-within {
  transform: translateY(-6px);
  border-color: rgba(255, 255, 255, 0.9);
  box-shadow: 0 24px 60px rgba(0, 0, 0, 0.35);
  background:
    radial-gradient(
      140% 100% at 20% 10%,
      rgba(255, 255, 255, 0.08) 0%,
      rgba(255, 255, 255, 0.03) 42%,
      transparent 78%
    ),
    rgba(0, 0, 0, 0.2);
}

.security-pillar:hover .security-pillar-arrow,
.security-pillar:focus-within .security-pillar-arrow {
  transform: translateX(4px);
  transition: transform 220ms ease;
}

@media (prefers-reduced-motion: reduce) {
  .security-pillar,
  .security-pillar:hover,
  .security-pillar:focus-within,
  .security-pillar:hover .security-pillar-arrow,
  .security-pillar:focus-within .security-pillar-arrow {
    transition: none;
    transform: none;
  }
}

/* Drafting card hard-lock: keep video, remove synthetic overlays. */
.home-page .features .feature-media--drafting {
  background-color: #e5d5bc !important;
  background-image: none !important;
}

.home-page .features .feature-media--drafting .home-feature-video {
  display: block !important;
  background: transparent !important;
  background-image: none !important;
}

.home-page .features .feature-media--drafting::before,
.home-page .features .feature-media--drafting::after {
  content: none !important;
  display: none !important;
  background: none !important;
}

.security-pillar-arrow {
  font-size: 26px;
  line-height: 1;
  color: rgba(255, 255, 255, 0.9);
  grid-row: 1;
}

.security-pillar-title {
  margin: 0;
  font-family: var(--serif);
  font-weight: 700;
  font-size: clamp(24px, 3vw, 36px);
  line-height: 1.2;
  min-height: 2.6em;
  grid-row: 2;
  align-self: start;
  padding-top: 0;
}

.security-pillar-text {
  margin: 0;
  color: color-mix(in srgb, #ffffff 78%, transparent);
  line-height: 1.6;
}

.security-pillar-lead {
  min-height: 3.2em;
  grid-row: 3;
  align-self: start;
  padding-top: 0;
}

.security-pillar-body {
  display: grid;
  gap: 16px;
  grid-row: 4;
}

.security-pillar-list {
  margin: 0;
  padding-left: 22px;
  display: grid;
  gap: 8px;
  color: color-mix(in srgb, #ffffff 78%, transparent);
}

.security-pillar-number {
  position: absolute;
  right: 22px;
  bottom: 18px;
  font-size: clamp(42px, 6vw, 72px);
  font-weight: 700;
  color: rgba(255, 255, 255, 0.9);
}

.security-standards-bottom {
  display: grid;
  grid-template-columns: 1fr;
  gap: 24px;
  align-items: start;
}

.solutions-hero {
  padding-block: clamp(36px, 6vw, 72px);
  background: var(--bg);
  min-height: auto;
}

body:is(
    .transactional-page,
    .banking-page,
    .litigation-page,
    .tax-page,
    .employment-page,
    .data-ip-page,
    .innovation-page,
    .firm-knowledge-page,
    .collaboration-page,
    .inhouse-page,
    .faq-page,
    .overview-page
  )
  main
  > section.solutions-hero {
  min-height: var(--meet-max-banner-min-height);
  display: grid;
  align-items: center;
}

.overview-page main > section.system-brings,
.overview-page main > section.system-scale--overview {
  height: auto;
  min-height: auto;
}

.overview-page main > section.system-brings {
  padding-block: clamp(48px, 7vw, 96px);
  display: block;
}

.overview-page main > section.system-brings > .system-brings-inner {
  height: auto;
  align-content: start;
}

.overview-page main > section.overview-capabilities {
  min-height: auto;
}

.overview-capabilities {
  background: var(--bg);
  color: var(--text);
  padding-block: clamp(40px, 7vw, 96px);
  min-height: auto;
  display: grid;
  align-items: start;
}

.overview-capabilities-inner {
  display: grid;
  gap: clamp(22px, 4vw, 44px);
  align-content: start;
}

.overview-capabilities-banner {
  display: grid;
  gap: 12px;
  justify-items: start;
  text-align: left;
  width: 100%;
  max-width: none;
  margin-inline: 0;
}

.overview-capabilities-banner .features-cta-title {
  margin: 0;
}

.overview-capabilities-banner .features-cta-subtitle {
  margin: 0;
  max-width: none;
  transform: translateX(4px);
}

.overview-page .overview-capabilities .features-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: clamp(22px, 3vw, 34px);
  align-items: start;
}

.overview-page .overview-capabilities .feature {
  display: grid;
  gap: 14px;
  align-content: start;
}

.overview-page .overview-capabilities .feature-media {
  width: 100%;
  aspect-ratio: 4 / 5;
  min-height: 340px;
  border: none !important;
  outline: none !important;
  display: grid;
  place-items: center;
  position: relative;
  overflow: hidden;
  box-shadow: none !important;
}

.overview-page .overview-capabilities .feature-media--reasoning {
  --home-card-bg: #bdb2a8;
  background: var(--home-card-bg) !important;
  background-image: url("images/MARRON FOND REASONING VIDEO.png") !important;
  background-size: cover !important;
  background-position: center !important;
  background-repeat: no-repeat !important;
}

.overview-page .overview-capabilities .feature-media--drafting {
  --home-card-bg: #e5d5bc;
  background: var(--home-card-bg) !important;
  background-image: url("images/JAUNE FOND DRAFTING VIDEO.png") !important;
  background-size: cover !important;
  background-position: center !important;
  background-repeat: no-repeat !important;
}

.overview-page .overview-capabilities .feature-media--review {
  --home-card-bg: #d8ae9f;
  background: var(--home-card-bg) !important;
  background-image: url("images/TERRACOTA FOND REVIEW VIDEO.png") !important;
  background-size: cover !important;
  background-position: center !important;
  background-repeat: no-repeat !important;
}

.overview-page .overview-capabilities .feature-media--knowledge {
  --home-card-bg: #b7bca6;
  background: var(--home-card-bg) !important;
  background-image: url("images/NOUVEAU FOND VERT KNOWLEDGE.png") !important;
  background-size: cover !important;
  background-position: center !important;
  background-repeat: no-repeat !important;
}

.overview-page .overview-capabilities .feature-media .home-feature-video {
  position: relative;
  inset: auto !important;
  width: 100% !important;
  height: auto !important;
  aspect-ratio: 16 / 9 !important;
  display: block !important;
  object-fit: contain !important;
  object-position: 50% 50% !important;
  background: var(--home-card-bg) !important;
  z-index: 1;
}

.overview-page .overview-capabilities .feature-media--knowledge .home-feature-video {
  position: relative !important;
  inset: auto !important;
  width: 100% !important;
  height: auto !important;
  aspect-ratio: 16 / 9 !important;
  object-fit: contain !important;
  object-position: 50% 50% !important;
}

.overview-page .overview-capabilities .home-feature-video--reasoning-center,
.overview-page .overview-capabilities .home-feature-video--drafting-crop {
  width: 100% !important;
  max-width: none !important;
  margin-left: 0 !important;
  transform: none !important;
  transform-origin: center !important;
  object-position: 50% 50% !important;
  -webkit-clip-path: none !important;
  clip-path: none !important;
}

.overview-page .overview-capabilities .feature-media--knowledge .home-feature-video--knowledge-crop {
  object-fit: contain !important;
  width: 100% !important;
  height: auto !important;
  aspect-ratio: 16 / 9 !important;
  max-width: none !important;
  margin-left: 0 !important;
  transform: none !important;
  transform-origin: center !important;
  object-position: 50% 50% !important;
  filter: none !important;
  -webkit-mask-image: none !important;
  mask-image: none !important;
  -webkit-clip-path: none !important;
  clip-path: none !important;
  animation: none !important;
}

.overview-page .overview-capabilities .feature-media--reasoning::before,
.overview-page .overview-capabilities .feature-media--drafting::before,
.overview-page .overview-capabilities .feature-media--review::before,
.overview-page .overview-capabilities .feature-media--knowledge::before {
  content: none !important;
  display: none !important;
}

.overview-page .overview-capabilities .feature-media--reasoning::after,
.overview-page .overview-capabilities .feature-media--drafting::after,
.overview-page .overview-capabilities .feature-media--review::after,
.overview-page .overview-capabilities .feature-media--knowledge::after {
  content: none !important;
  display: none !important;
}

.overview-capabilities-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: clamp(22px, 3vw, 34px);
  align-items: start;
}

.overview-capability {
  display: flex;
  flex-direction: column;
  gap: 10px;
  height: 100%;
}

.overview-capability-frame {
  width: 100%;
  aspect-ratio: 4 / 5;
  min-height: 340px;
  border: 1px solid var(--hairline);
  background: linear-gradient(180deg, rgba(17, 17, 17, 0.1), rgba(17, 17, 17, 0.03));
}

.overview-page .overview-capability-frame {
  border: none !important;
  position: relative;
  overflow: hidden;
  box-shadow: none !important;
}

.overview-page .overview-capability-frame--reasoning {
  --overview-card-bg: #c8bcb5;
  background: var(--overview-card-bg) !important;
}

.overview-page .overview-capability-frame--drafting {
  --overview-card-bg: #e5d5bc;
  background: var(--overview-card-bg) !important;
}

.overview-page .overview-capability-frame--review {
  --overview-card-bg: #dcb5a8;
  background: var(--overview-card-bg) !important;
}

.overview-page .overview-capability-frame--knowledge {
  --overview-card-bg: #c4c8b5;
  background: var(--overview-card-bg) !important;
}

.overview-page .overview-capability-frame .home-feature-video {
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  aspect-ratio: auto !important;
  display: block !important;
  object-fit: cover !important;
  object-position: 50% 50% !important;
  background: transparent !important;
}

.overview-page .overview-capability-kicker {
  display: none;
}

.overview-capability-kicker {
  margin: 0;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-size: 12px;
  color: var(--muted);
}

.overview-capability-title {
  margin: 0;
  font-family: var(--serif);
  font-weight: 700;
  font-size: clamp(22px, 2.1vw, 28px);
  line-height: 1.15;
  letter-spacing: -0.02em;
}

.overview-capability-text {
  margin: 0;
  color: color-mix(in srgb, var(--text) 70%, transparent);
  line-height: 1.6;
}

@media (max-width: 1100px) {
  .overview-capabilities-grid,
  .overview-page .overview-capabilities .features-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 620px) {
  .overview-capabilities-grid,
  .overview-page .overview-capabilities .features-grid {
    grid-template-columns: 1fr;
  }
}

.solutions-hero.solutions-hero--center {
  display: flex;
  align-items: center;
  justify-content: center;
}

.solutions-hero.solutions-hero--center .solutions-hero-inner {
  width: 100%;
  transform: translateY(clamp(30px, 4vw, 56px));
  justify-items: center;
  text-align: center;
}

.solutions-hero-inner {
  display: grid;
  gap: 18px;
  justify-items: start;
  text-align: left;
}

.solutions-page main > section.solutions-hero .solutions-hero-inner {
  justify-items: center;
  text-align: center;
}

.solutions-hero-kicker {
  margin: 0;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-size: 12px;
  color: color-mix(in srgb, var(--text) 70%, transparent);
}

.solutions-hero-title {
  margin: 0;
  font-family: var(--serif);
  font-weight: 700;
}

.solutions-hero-subtitle {
  margin: 0;
  font-weight: 600;
  font-size: 18px;
  color: var(--text);
}

.whymax-overview-mobile-hero-media {
  display: none;
}

.banking-page .solutions-intro .solutions-hero-subtitle {
  font-family: var(--serif);
  font-weight: 700;
  font-size: clamp(30px, 3vw, 46px);
  line-height: 1.1;
  letter-spacing: -0.02em;
}

.solutions-hero-text {
  margin: 0;
  max-width: 48ch;
  color: color-mix(in srgb, var(--text) 70%, transparent);
  line-height: 1.6;
}

.solutions-intro {
  padding-block: clamp(56px, 7vw, 110px);
}

.solutions-intro-inner {
  display: grid;
  gap: clamp(22px, 4vw, 44px);
}

.solutions-intro-top {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 48px;
  align-items: start;
}

.solutions-intro-copy {
  max-width: 520px;
  display: grid;
  gap: 18px;
  align-content: start;
  justify-items: start;
  text-align: left;
}

.solutions-intro-detail {
  display: grid;
  gap: 18px;
  max-width: none;
}

.transactional-page .solutions-intro--video-overlay {
  padding-top: 0;
  padding-bottom: clamp(44px, 5vw, 72px);
}

.transactional-page .solutions-intro--video-overlay .solutions-intro-inner {
  max-width: none;
  width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  padding-left: 0;
  padding-right: 0;
}

.transactional-page .solutions-spotlight-media--hero {
  width: 100%;
}

.transactional-page .solutions-spotlight-frame--hero {
  position: relative;
  width: 100%;
  min-height: clamp(360px, 48vw, 680px);
  padding: 0 !important;
  border-radius: 0 !important;
  overflow: hidden;
  border: 0 !important;
  outline: 0 !important;
  box-shadow: none !important;
}

.transactional-page .solutions-spotlight-frame--hero::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(
    90deg,
    rgba(8, 10, 14, 0.8) 0%,
    rgba(8, 10, 14, 0.62) 24%,
    rgba(8, 10, 14, 0.4) 46%,
    rgba(8, 10, 14, 0.2) 66%,
    rgba(8, 10, 14, 0.06) 82%,
    rgba(8, 10, 14, 0) 100%
  );
  pointer-events: none;
}

.transactional-page .solutions-spotlight-frame--hero .solutions-spotlight-video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  margin-bottom: -1px;
}

.transactional-page .solutions-intro-copy--overlay {
  position: absolute;
  left: clamp(24px, 6vw, 88px);
  top: 50%;
  transform: translateY(-50%);
  z-index: 2;
  max-width: min(560px, 46vw);
  color: #ffffff;
  gap: 16px;
}

.transactional-page .solutions-intro-copy--overlay .solutions-hero-subtitle,
.transactional-page .solutions-intro-copy--overlay .solutions-hero-text {
  color: #ffffff;
  max-width: 48ch;
}

.transactional-page .solutions-intro-copy--overlay .solutions-hero-subtitle {
  color: #ffffff !important;
}

@media (max-width: 960px) {
  .transactional-page .solutions-intro--video-overlay .solutions-intro-inner {
    width: 100%;
    margin-left: 0;
    margin-right: 0;
  }

  .transactional-page .solutions-spotlight-frame--hero {
    border-radius: var(--media-radius-lg) !important;
    min-height: clamp(320px, 82vw, 520px);
  }

  .transactional-page .solutions-intro-copy--overlay {
    left: 22px;
    right: 22px;
    max-width: none;
    top: auto;
    bottom: 26px;
    transform: none;
  }

  .transactional-page .solutions-spotlight-frame--hero::after {
    background: linear-gradient(180deg, rgba(10, 10, 10, 0.08) 0%, rgba(10, 10, 10, 0.52) 100%);
  }
}

/* Solutions pages: top detail copy should end on the same visual measure as first block below */
.solutions-page:not(.solutions-overview-page) .solutions-spotlight .solutions-intro-detail {
  max-width: min(100%, 56ch);
}

.solutions-page:not(.solutions-overview-page) .solutions-spotlight .solutions-intro-detail .solutions-spotlight-text {
  width: min(100%, 56ch);
}

@media (max-width: 960px) {
  .solutions-intro-top {
    grid-template-columns: 1fr;
  }
}

.system-hero {
  padding-block: clamp(48px, 7vw, 96px);
  background: var(--bg);
}

.system-hero-inner {
  display: grid;
  grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.1fr);
  gap: clamp(24px, 6vw, 72px);
  align-items: center;
}

.system-hero--center .system-hero-inner {
  grid-template-columns: 1fr;
  justify-items: center;
  text-align: center;
}

.system-hero--center {
  min-height: var(--section-min-height);
  display: flex;
  align-items: center;
  padding-block: clamp(72px, 10vw, 140px);
}

.system-hero--center .system-hero-left {
  max-width: 720px;
}

.hero-line {
  display: block;
}

.system-hero-left {
  max-width: 540px;
}

.system-hero-kicker {
  margin: 0 0 16px;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-size: 12px;
  color: color-mix(in srgb, var(--text) 70%, transparent);
}

.system-hero-title {
  margin: 0;
  font-family: var(--serif);
  font-weight: 700;
}

.system-hero-right {
  display: flex;
  justify-content: center;
}

.system-hero-media {
  position: relative;
  width: min(720px, 100%);
  min-height: clamp(320px, 42vw, 520px);
  background: linear-gradient(135deg, #e7e3de 0%, #d3cec8 100%);
  border-radius: var(--media-radius-lg);
  overflow: hidden;
  box-shadow: 0 30px 60px -40px rgba(0, 0, 0, 0.45);
}

.system-hero-card {
  position: absolute;
  background: var(--surface);
  border-radius: var(--media-radius-sm);
  box-shadow: 0 18px 40px -28px rgba(0, 0, 0, 0.5);
}

.system-hero-card--large {
  width: 56%;
  height: 70%;
  left: 8%;
  top: 14%;
  background: var(--surface);
}

.system-hero-card--small {
  width: 42%;
  height: 78%;
  right: 10%;
  top: 10%;
  background: var(--surface-strong);
}

.system-hero-image {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.drafting-system-page .system-hero-media,
.knowledge-page .system-hero-media,
.review-page .system-hero-media,
.reasoning-page .system-hero-media {
  display: grid;
  place-items: center;
  line-height: 0;
  padding: 0;
  background: #ffffff !important;
  background-image: none !important;
  width: min(720px, 100%);
  min-height: clamp(320px, 42vw, 520px);
  border-radius: 16px;
  overflow: hidden;
  box-shadow: 0 34px 80px -56px rgba(0, 0, 0, 0.55);
}

.drafting-system-page .system-hero-media::before,
.knowledge-page .system-hero-media::before,
.review-page .system-hero-media::before,
.reasoning-page .system-hero-media::before {
  content: none !important;
  display: none !important;
}

.drafting-system-page .system-hero-image,
.knowledge-page .system-hero-image,
.review-page .system-hero-image,
.reasoning-page .system-hero-image {
  position: static;
  inset: auto;
  object-fit: cover;
  object-position: 50% 50%;
  width: 100%;
  height: 100%;
  display: block;
  align-self: stretch;
  justify-self: center;
  position: relative;
  z-index: 1;
  border-radius: 16px;
  box-shadow: 0 34px 80px -56px rgba(0, 0, 0, 0.55);
}

.drafting-system-page .system-hero-video,
.knowledge-page .system-hero-video,
.review-page .system-hero-video,
.reasoning-page .system-hero-video {
  width: 100%;
  height: 100%;
  display: block;
  vertical-align: top;
  object-fit: contain;
  object-position: 50% 50%;
  border-radius: 0;
  box-shadow: none;
  background: #ffffff;
  transform: translateZ(0);
  backface-visibility: hidden;
}

.drafting-system-page .system-hero-video,
.knowledge-page .system-hero-video,
.review-page .system-hero-video {
  height: calc(100% + 2px);
  margin-bottom: -2px;
}

.reasoning-page .system-hero-inner,
.drafting-system-page .system-hero-inner,
.review-page .system-hero-inner,
.knowledge-page .system-hero-inner {
  grid-template-columns: minmax(240px, 0.82fr) minmax(0, 1.48fr);
}

.reasoning-page .system-hero-right,
.drafting-system-page .system-hero-right,
.review-page .system-hero-right,
.knowledge-page .system-hero-right {
  width: 100%;
}

.reasoning-page .system-hero-media,
.drafting-system-page .system-hero-media,
.review-page .system-hero-media,
.knowledge-page .system-hero-media {
  width: 100%;
  max-width: none;
  min-height: auto;
  aspect-ratio: 16 / 9;
}

.operational-efficiency-page .system-hero-inner,
.strategic-legal-advice-page .system-hero-inner,
.confidence-trust-page .system-hero-inner,
.consistency-quality-page .system-hero-inner,
.zero-fracture-workflow-page .system-hero-inner {
  grid-template-columns: minmax(260px, 0.9fr) minmax(0, 1.4fr);
}

.operational-efficiency-page .system-hero-right,
.strategic-legal-advice-page .system-hero-right,
.confidence-trust-page .system-hero-right,
.consistency-quality-page .system-hero-right,
.zero-fracture-workflow-page .system-hero-right {
  width: 100%;
}

.operational-efficiency-page .system-hero-media,
.strategic-legal-advice-page .system-hero-media,
.confidence-trust-page .system-hero-media,
.consistency-quality-page .system-hero-media,
.zero-fracture-workflow-page .system-hero-media {
  width: 100%;
  max-width: none;
  min-height: auto;
  aspect-ratio: var(--feature-frame-ratio);
}

.operational-efficiency-page .system-hero-video {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  background: #000000;
}

.strategic-legal-advice-page .system-hero-video {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: contain;
  object-position: center;
  background: #000000;
}

.confidence-trust-page .system-hero-video {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: contain;
  object-position: center;
  background: #000000;
}

.consistency-quality-page .system-hero-video {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: contain;
  object-position: center;
  background: #000000;
}

.confidence-trust-page .system-hero-media {
  aspect-ratio: 16 / 9 !important;
  overflow: hidden !important;
  background: #000000 !important;
}

.confidence-trust-page .system-hero-media .system-hero-video {
  width: 100% !important;
  height: 100% !important;
  object-fit: contain !important;
  object-position: 50% 50% !important;
  transform: none !important;
}

.operational-efficiency-page .system-hero-media.is-whymax-sequence {
  position: relative;
  overflow: hidden;
}

.operational-efficiency-page .system-hero-media.is-whymax-sequence .whymax-sequence-video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  opacity: 0;
  transform: scale(1.015);
  transition: opacity 560ms ease, transform 560ms ease;
  will-change: opacity, transform;
}

.operational-efficiency-page .system-hero-media.is-whymax-sequence .whymax-sequence-video.is-visible {
  opacity: 1;
  transform: scale(1);
}

.operational-efficiency-page .system-hero-media.is-whymax-fade .system-hero-video {
  opacity: 0;
  transition: opacity 320ms cubic-bezier(0.4, 0, 0.2, 1);
  will-change: opacity;
}

.operational-efficiency-page .system-hero-media.is-whymax-fade .system-hero-video.is-fade-visible {
  opacity: 1;
}

.operational-efficiency-page .system-hero-media.is-whymax-fade .system-hero-video.is-fade-out {
  opacity: 0;
}

.strategic-legal-advice-page .system-hero-media.is-whymax-fade .system-hero-video {
  opacity: 0;
  transition: opacity 320ms cubic-bezier(0.4, 0, 0.2, 1);
  will-change: opacity;
}

.strategic-legal-advice-page .system-hero-media.is-whymax-fade .system-hero-video.is-fade-visible {
  opacity: 1;
}

.strategic-legal-advice-page .system-hero-media.is-whymax-fade .system-hero-video.is-fade-out {
  opacity: 0;
}

:is(.confidence-trust-page) .system-hero-media.is-whymax-fade .system-hero-video {
  opacity: 0;
  transition: opacity 320ms cubic-bezier(0.4, 0, 0.2, 1);
  will-change: opacity;
}

:is(.confidence-trust-page) .system-hero-media.is-whymax-fade .system-hero-video.is-fade-visible {
  opacity: 1;
}

:is(.confidence-trust-page) .system-hero-media.is-whymax-fade .system-hero-video.is-fade-out {
  opacity: 0;
}

:is(.operational-efficiency-page, .strategic-legal-advice-page) .system-hero-media.is-whymax-fade {
  background: #000000 !important;
}

:is(.confidence-trust-page) .system-hero-media.is-whymax-fade {
  background: #000000 !important;
}

:is(.zero-fracture-workflow-page) .system-hero-media.is-whymax-fade .system-hero-video {
  opacity: 0;
  transition: opacity 320ms cubic-bezier(0.4, 0, 0.2, 1);
  will-change: opacity;
}

:is(.zero-fracture-workflow-page) .system-hero-media.is-whymax-fade .system-hero-video.is-fade-visible {
  opacity: 1;
}

:is(.zero-fracture-workflow-page) .system-hero-media.is-whymax-fade .system-hero-video.is-fade-out {
  opacity: 0;
}

:is(.zero-fracture-workflow-page) .system-hero-media.is-whymax-fade {
  background: #000000 !important;
}

:is(.consistency-quality-page) .system-hero-media.is-whymax-fade .system-hero-video {
  opacity: 0;
  transition: opacity 320ms cubic-bezier(0.4, 0, 0.2, 1);
  will-change: opacity;
}

:is(.consistency-quality-page) .system-hero-media.is-whymax-fade .system-hero-video.is-fade-visible {
  opacity: 1;
}

:is(.consistency-quality-page) .system-hero-media.is-whymax-fade .system-hero-video.is-fade-out {
  opacity: 0;
}

:is(.consistency-quality-page) .system-hero-media.is-whymax-fade {
  background: #000000 !important;
}

.operational-efficiency-page .system-hero.system-hero--center .system-hero-inner,
.strategic-legal-advice-page .system-hero.system-hero--center .system-hero-inner,
.confidence-trust-page .system-hero.system-hero--center .system-hero-inner,
.consistency-quality-page .system-hero.system-hero--center .system-hero-inner,
.zero-fracture-workflow-page .system-hero.system-hero--center .system-hero-inner {
  grid-template-columns: 1fr;
  justify-items: center;
  text-align: center;
}

@media (min-width: 981px) {
  .zero-fracture-workflow-page .system-hero.system-hero--center .system-hero-left {
    max-width: none;
  }
}

@media (min-width: 981px) {
  .transactional-page .solutions-intro-top,
  .banking-page .solutions-intro-top,
  .litigation-page .solutions-intro-top,
  .tax-page .solutions-intro-top,
  .employment-page .solutions-intro-top,
  .data-ip-page .solutions-intro-top,
  .innovation-page .solutions-intro-top,
  .firm-knowledge-page .solutions-intro-top,
  .collaboration-page .solutions-intro-top,
  .inhouse-page .solutions-intro-top {
    grid-template-columns: minmax(260px, 0.9fr) minmax(0, 1.4fr);
    gap: clamp(28px, 5vw, 64px);
  }

  .transactional-page .solutions-spotlight-media,
  .banking-page .solutions-spotlight-media,
  .litigation-page .solutions-spotlight-media,
  .tax-page .solutions-spotlight-media,
  .employment-page .solutions-spotlight-media,
  .data-ip-page .solutions-spotlight-media,
  .innovation-page .solutions-spotlight-media,
  .firm-knowledge-page .solutions-spotlight-media,
  .collaboration-page .solutions-spotlight-media,
  .inhouse-page .solutions-spotlight-media {
    width: 100%;
  }

  .transactional-page .solutions-spotlight-frame,
  .banking-page .solutions-spotlight-frame,
  .litigation-page .solutions-spotlight-frame,
  .tax-page .solutions-spotlight-frame,
  .employment-page .solutions-spotlight-frame,
  .data-ip-page .solutions-spotlight-frame,
  .innovation-page .solutions-spotlight-frame,
  .firm-knowledge-page .solutions-spotlight-frame,
  .collaboration-page .solutions-spotlight-frame,
  .inhouse-page .solutions-spotlight-frame {
    width: 100%;
    max-width: none;
    min-height: auto;
    aspect-ratio: var(--feature-frame-ratio);
  }
}

.system-brings {
  padding-block: clamp(40px, 7vw, 96px);
  background: var(--bg);
}

.why-max-page .system-brings {
  background-color: var(--bg);
  background-image: var(--pastel-blue);
  min-height: clamp(520px, 62svh, 760px);
  padding-block: clamp(68px, 9vw, 136px);
  display: grid;
  align-items: center;
}

.why-max-page:not(.why-max-overview-page) .system-hero,
.why-max-page:not(.why-max-overview-page) .system-brings,
.why-max-page:not(.why-max-overview-page) .journey {
  min-height: auto;
  padding-block: clamp(56px, 8vw, 118px);
}

.why-max-page:not(.why-max-overview-page) .system-hero,
.why-max-page:not(.why-max-overview-page) .system-brings {
  margin-bottom: clamp(28px, 4vw, 56px);
}

.why-max-overview-page .system-brings {
  background-image: none;
  min-height: auto;
  padding-block: clamp(48px, 7vw, 96px);
  display: block;
}

.why-max-page .system-brings-inner {
  gap: clamp(30px, 4vw, 52px);
}

.consistency-quality-page .system-brings-inner {
  gap: clamp(34px, 5vw, 56px);
}

.consistency-quality-page .system-brings {
  padding-block: clamp(56px, 8vw, 118px);
}

.system-brings-inner {
  display: grid;
  gap: clamp(24px, 5vw, 48px);
}

.reasoning-page .system-brings,
.drafting-system-page .system-brings,
.review-page .system-brings,
.knowledge-page .system-brings {
  min-height: 0;
  height: auto;
  box-sizing: border-box;
  display: grid;
  align-items: start;
  background-color: var(--bg);
  background-image: none;
}

/* Reasoning: center "Clarity Before Commitment" block and isolate it in viewport */
.reasoning-page .system-brings {
  min-height: calc(100svh - var(--header-offset)) !important;
  padding-top: clamp(84px, 10svh, 140px) !important;
  padding-bottom: clamp(110px, 14svh, 180px) !important;
  display: grid !important;
  align-content: center !important;
}

.reasoning-page .system-brings-inner {
  gap: clamp(32px, 4.8vw, 62px) !important;
}

.reasoning-page .system-practice-heading {
  margin-top: clamp(280px, 32svh, 460px) !important;
  padding-top: clamp(24px, 3svh, 44px) !important;
  padding-bottom: clamp(24px, 3svh, 44px) !important;
}

.reasoning-page .system-brings-card,
.drafting-system-page .system-brings-card,
.review-page .system-brings-card,
.knowledge-page .system-brings-card {
  background: #eceeea;
}

.reasoning-page .system-hero {
  background-color: #bdafa6;
  background-image: none;
}

.drafting-system-page .system-hero {
  background-color: #e3d1b5;
  background-image: none;
}

.review-page .system-hero {
  background-color: #d6aa9b;
  background-image: none;
}

.knowledge-page .system-hero {
  background-color: #bdc0aa;
  background-image: none;
}

.system-brings-header {
  max-width: 640px;
}

@media (min-width: 980px) {
  .system-brings-header {
    max-width: none;
  }
}

.system-brings-kicker {
  margin: 0 0 12px;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-size: 12px;
  color: color-mix(in srgb, var(--text) 70%, transparent);
}

.system-brings-title {
  margin: 0 0 8px;
  font-family: var(--serif);
  font-weight: 700;
  font-size: clamp(30px, 3.8vw, 56px);
}

.system-brings-subtitle {
  margin: 0 0 14px;
  font-family: var(--serif);
  font-weight: 700;
  font-size: clamp(22px, 2.7vw, 38px);
  color: var(--section-heading-color) !important;
  white-space: nowrap;
}

.consistency-quality-page .system-brings-subtitle {
  font-size: var(--site-heading-size) !important;
  line-height: var(--site-heading-line) !important;
  letter-spacing: -0.02em !important;
}

.consistency-quality-page .system-brings-text {
  font-size: var(--site-subtitle-size) !important;
  line-height: var(--site-subtitle-line) !important;
  font-weight: 600 !important;
  letter-spacing: -0.01em !important;
  color: var(--section-subtitle-color) !important;
}

.consistency-quality-page .journey-panel-title {
  font-size: var(--site-subtitle-size) !important;
  line-height: var(--site-subtitle-line) !important;
  font-weight: 600 !important;
  letter-spacing: -0.01em !important;
}

.system-brings-text {
  margin: 0;
  color: color-mix(in srgb, var(--text) 70%, transparent);
  line-height: 1.6;
}

@media (min-width: 980px) {
  .solutions-page.drafting-system-page .system-brings-text {
    white-space: nowrap;
    font-size: clamp(14px, 1.1vw, 16px);
  }
}

.system-brings-grid {
  display: grid;
  gap: clamp(24px, 3.4vw, 36px);
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.why-max-page .system-brings-grid {
  gap: 0;
  align-items: stretch;
}

.why-max-overview-page .system-brings-grid {
  gap: clamp(18px, 3vw, 28px);
}

.why-max-overview-page .system-brings-card-body {
  display: grid;
  grid-template-rows: auto 1fr;
  align-content: stretch;
  min-height: 100%;
}

.why-max-overview-page .whymax-icon {
  --whymax-icon-shift-y: -1cm;
  align-self: end;
  justify-self: center;
  width: min(260px, 100%);
  height: 132px;
  margin-top: clamp(14px, 2vw, 22px);
  margin-left: 0;
  margin-right: 0;
  margin-inline: auto;
  position: relative;
  transform: translateY(var(--whymax-icon-shift-y));
}

/* Card 1: puzzle corners assembling at center */
.why-max-overview-page .whymax-icon--puzzle {
  width: 220px;
}

.why-max-overview-page .whymax-puzzle-piece {
  --tx: 0px;
  --ty: 0px;
  --tx-end: 0px;
  --ty-end: 0px;
  --rot: 0deg;
  width: 74px;
  height: 74px;
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(calc(-50% + var(--tx)), calc(-50% + var(--ty))) rotate(var(--rot));
  filter: drop-shadow(0 10px 16px rgba(0, 0, 0, 0.16));
  animation: whymax-puzzle-assemble 6s ease-in-out infinite;
}

.why-max-overview-page .whymax-puzzle-piece svg {
  width: 100%;
  height: 100%;
  display: block;
}

.why-max-overview-page .whymax-puzzle-piece path {
  fill: rgba(255, 255, 255, 0.95);
  stroke: rgba(17, 17, 17, 0.2);
  stroke-width: 2;
}

.why-max-overview-page .whymax-puzzle-piece--tl {
  --tx: -58px;
  --ty: -58px;
  --tx-end: -30px;
  --ty-end: -30px;
  --rot: 0deg;
}

.why-max-overview-page .whymax-puzzle-piece--tr {
  --tx: 58px;
  --ty: -58px;
  --tx-end: 30px;
  --ty-end: -30px;
  --rot: 0deg;
}

.why-max-overview-page .whymax-puzzle-piece--bl {
  --tx: -58px;
  --ty: 58px;
  --tx-end: -30px;
  --ty-end: 30px;
  --rot: 0deg;
}

.why-max-overview-page .whymax-puzzle-piece--br {
  --tx: 58px;
  --ty: 58px;
  --tx-end: 30px;
  --ty-end: 30px;
  --rot: 0deg;
}

@media (min-width: 980px) {
  .why-max-overview-page .whymax-puzzle-piece--tl {
    --tx: -48px;
    --ty: -48px;
    --tx-end: -30px;
    --ty-end: -30px;
  }

  .why-max-overview-page .whymax-puzzle-piece--tr {
    --tx: 48px;
    --ty: -48px;
    --tx-end: 30px;
    --ty-end: -30px;
  }

  .why-max-overview-page .whymax-puzzle-piece--bl {
    --tx: -48px;
    --ty: 48px;
    --tx-end: -30px;
    --ty-end: 30px;
  }

  .why-max-overview-page .whymax-puzzle-piece--br {
    --tx: 48px;
    --ty: 48px;
    --tx-end: 30px;
    --ty-end: 30px;
  }
}

/* Card 2: magnetic lines alignment */
.why-max-overview-page .whymax-icon--magnet {
  width: 230px;
  display: grid;
  align-content: center;
  gap: 10px;
}

.why-max-overview-page .whymax-magnet-line {
  height: 6px;
  border-radius: 999px;
  background: rgba(17, 17, 17, 0.22);
  transform-origin: left center;
}

.why-max-overview-page .whymax-magnet-line:nth-child(1) {
  width: 62%;
  animation: whymax-magnet-master 4.6s ease-in-out infinite;
}

.why-max-overview-page .whymax-magnet-line:nth-child(2) {
  width: 88%;
  animation: whymax-magnet-follow-1 4.6s ease-in-out infinite;
}

.why-max-overview-page .whymax-magnet-line:nth-child(3) {
  width: 74%;
  animation: whymax-magnet-follow-2 4.6s ease-in-out infinite;
}

.why-max-overview-page .whymax-magnet-line:nth-child(4) {
  width: 92%;
  animation: whymax-magnet-follow-3 4.6s ease-in-out infinite;
}

.why-max-overview-page .whymax-magnet-line:nth-child(5) {
  width: 70%;
  animation: whymax-magnet-follow-4 4.6s ease-in-out infinite;
}

.why-max-overview-page .whymax-magnet-line:nth-child(6) {
  width: 84%;
  animation: whymax-magnet-follow-5 4.6s ease-in-out infinite;
}

/* Card 3: connected network dots */
.why-max-overview-page .whymax-icon--network {
  width: 280px;
  height: 140px;
  display: grid;
  place-items: center;
  position: relative;
}

.why-max-overview-page .whymax-network-scene {
  position: relative;
  width: 100%;
  height: 100%;
}

.why-max-overview-page .whymax-network-bg,
.why-max-overview-page .whymax-network-route {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
}

.why-max-overview-page .whymax-network-bg path {
  display: none;
}

.why-max-overview-page .whymax-network-route path {
  fill: none;
  stroke: rgba(17, 17, 17, 0.46);
  stroke-width: 2.1;
  stroke-linecap: round;
  stroke-dasharray: 2 4;
}

.why-max-overview-page .whymax-network-dot {
  position: absolute;
  border-radius: 50%;
}

.why-max-overview-page .whymax-network-dot--ambient {
  background: rgba(38, 62, 77, 0.28);
}

.why-max-overview-page .whymax-network-dot--focus {
  border: 2px solid rgba(255, 255, 255, 0.92);
  box-shadow: 0 8px 18px -12px rgba(0, 0, 0, 0.35);
  animation: whymax-node-pulse 3.4s ease-in-out infinite;
  display: grid;
  place-items: center;
}

.why-max-overview-page .whymax-network-dot.n1 {
  width: 10px;
  height: 10px;
  left: 18px;
  top: 20px;
}

.why-max-overview-page .whymax-network-dot.n2 {
  width: 8px;
  height: 8px;
  left: 130px;
  top: 14px;
}

.why-max-overview-page .whymax-network-dot.n3 {
  width: 9px;
  height: 9px;
  right: 30px;
  top: 18px;
}

.why-max-overview-page .whymax-network-dot.n4 {
  width: 11px;
  height: 11px;
  left: 74px;
  bottom: 20px;
}

.why-max-overview-page .whymax-network-dot.n5 {
  width: 8px;
  height: 8px;
  right: 56px;
  bottom: 24px;
}

.why-max-overview-page .whymax-network-dot.n6 {
  width: 18px;
  height: 18px;
  left: 28px;
  top: 78px;
  background: #a9c8d4;
}

.why-max-overview-page .whymax-network-dot.n7 {
  width: 46px;
  height: 46px;
  left: 71px;
  top: 92px;
  background: #c2d7df;
  animation-delay: 0.2s;
}

.why-max-overview-page .whymax-network-dot.n8 {
  width: 42px;
  height: 42px;
  left: 135px;
  top: 14px;
  background: #9fb9c4;
  animation-delay: 0.45s;
}

.why-max-overview-page .whymax-network-dot.n9 {
  width: 20px;
  height: 20px;
  left: 206px;
  top: 22px;
  background: #deecef;
  animation-delay: 0.65s;
}

.why-max-overview-page .whymax-network-dot.n10 {
  width: 44px;
  height: 44px;
  left: 246px;
  top: 36px;
  background: #9cbfcc;
  animation-delay: 0.9s;
}

.why-max-overview-page .whymax-network-glyph {
  line-height: 1;
  font-weight: 700;
  color: #111111;
}

.why-max-overview-page .whymax-network-glyph--profile {
  width: 16px;
  height: 16px;
  position: relative;
}

.why-max-overview-page .whymax-network-glyph--profile::before {
  content: "";
  position: absolute;
  left: 50%;
  top: 1px;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: #111111;
  transform: translateX(-50%);
}

.why-max-overview-page .whymax-network-glyph--profile::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 6px;
  width: 10px;
  height: 7px;
  border-radius: 7px 7px 4px 4px;
  background: #111111;
  transform: translateX(-50%);
}

.why-max-overview-page .whymax-network-glyph--scale {
  width: auto;
  height: auto;
  position: static;
  font-size: 22px;
  line-height: 1;
  font-weight: 700;
  color: #111111;
  transform: translateY(-1px);
}

.why-max-overview-page .whymax-network-glyph--scale::before {
  content: none;
}

.why-max-overview-page .whymax-network-glyph--scale::after {
  content: none;
}

.why-max-overview-page .whymax-network-glyph--lock {
  width: 16px;
  height: 16px;
  position: relative;
  font-size: 0;
  color: transparent;
}

.why-max-overview-page .whymax-network-glyph--lock::before {
  content: "";
  position: absolute;
  left: 50%;
  top: 0;
  width: 9px;
  height: 7px;
  border: 2px solid #111111;
  border-bottom: none;
  border-radius: 7px 7px 0 0;
  transform: translateX(-50%);
}

.why-max-overview-page .whymax-network-glyph--lock::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: 0;
  width: 11px;
  height: 9px;
  border-radius: 2px;
  background: #111111;
  transform: translateX(-50%);
}

@keyframes whymax-puzzle-assemble {
  0%,
  18%,
  100% {
    transform: translate(calc(-50% + var(--tx)), calc(-50% + var(--ty))) rotate(var(--rot));
  }
  42%,
  72% {
    transform: translate(calc(-50% + var(--tx-end)), calc(-50% + var(--ty-end))) rotate(var(--rot));
  }
}

@keyframes whymax-magnet-master {
  0%,
  100% {
    width: 62%;
  }
  38%,
  64% {
    width: 76%;
  }
}

@keyframes whymax-magnet-follow-1 {
  0%,
  100% {
    width: 88%;
  }
  38%,
  64% {
    width: 97%;
  }
}

@keyframes whymax-magnet-follow-2 {
  0%,
  100% {
    width: 74%;
  }
  38%,
  64% {
    width: 86%;
  }
}

@keyframes whymax-magnet-follow-3 {
  0%,
  100% {
    width: 92%;
  }
  38%,
  64% {
    width: 99%;
  }
}

@keyframes whymax-magnet-follow-4 {
  0%,
  100% {
    width: 70%;
  }
  38%,
  64% {
    width: 81%;
  }
}

@keyframes whymax-magnet-follow-5 {
  0%,
  100% {
    width: 84%;
  }
  38%,
  64% {
    width: 94%;
  }
}

@keyframes whymax-magnet-master-mobile {
  0%,
  100% {
    width: 62%;
  }
  38%,
  64% {
    width: 76%;
  }
}

@keyframes whymax-magnet-follow-1-mobile {
  0%,
  100% {
    width: 88%;
  }
  38%,
  64% {
    width: 97%;
  }
}

@keyframes whymax-magnet-follow-2-mobile {
  0%,
  100% {
    width: 74%;
  }
  38%,
  64% {
    width: 86%;
  }
}

@keyframes whymax-magnet-follow-3-mobile {
  0%,
  100% {
    width: 92%;
  }
  38%,
  64% {
    width: 99%;
  }
}

@keyframes whymax-magnet-follow-4-mobile {
  0%,
  100% {
    width: 70%;
  }
  38%,
  64% {
    width: 81%;
  }
}

@keyframes whymax-magnet-follow-5-mobile {
  0%,
  100% {
    width: 84%;
  }
  38%,
  64% {
    width: 94%;
  }
}

@keyframes whymax-node-pulse {
  0%,
  100% {
    transform: scale(1);
    filter: brightness(1);
  }
  50% {
    transform: scale(1.06);
    filter: brightness(1.07);
  }
}

.why-max-page .system-brings-column {
  padding: clamp(16px, 2.4vw, 24px);
  border-left: 1px solid rgba(17, 17, 17, 0.22);
  background: transparent;
  display: grid;
  gap: 14px;
  align-content: start;
  height: 100%;
}

.why-max-page .system-brings-column-title {
  margin: 0;
  font-size: clamp(18px, 1.6vw, 22px);
  font-weight: 600;
  letter-spacing: -0.01em;
  color: color-mix(in srgb, var(--text) 92%, transparent);
}

.why-max-page .system-brings-column-text {
  margin: 0;
  color: color-mix(in srgb, var(--text) 72%, transparent);
  line-height: 1.6;
  font-size: clamp(15px, 1.15vw, 17px);
  max-width: 46ch;
}

.why-max-page .system-brings-header {
  max-width: none;
}

.why-max-page .system-brings-header {
  text-align: left;
  margin-inline: 0;
  width: 100%;
}

.why-max-page .system-brings-subtitle,
.why-max-page .system-brings-text {
  margin-left: 0;
  margin-right: 0;
}

.why-max-page .system-brings-subtitle {
  font-family: var(--serif) !important;
  font-weight: 700 !important;
  font-size: var(--site-heading-size) !important;
  line-height: var(--site-heading-line) !important;
  letter-spacing: -0.02em !important;
  color: var(--section-heading-color) !important;
}

.why-max-page .system-brings-text {
  font-size: var(--site-subtitle-size) !important;
  line-height: var(--site-subtitle-line) !important;
  font-weight: 600 !important;
  letter-spacing: -0.01em !important;
  color: var(--section-subtitle-color) !important;
}

/* Sitewide paragraph scale */
.feature-text,
.security-body,
.security-pillar-text,
.journey-panel-text,
.system-brings-text,
.why-max-page .system-brings-column-text,
.system-context-text,
.system-scale-text,
.overview-capabilities-banner .system-scale-text,
.contact-card-text,
.solutions-hero-text,
.solutions-spotlight-text,
.solutions-benefit-text,
.solutions-usage-panel-text,
.solutions-stack-card-text,
.solutions-litigation-text,
.mega-desc,
.vision-paragraph,
.system-brings-card-text {
  font-size: var(--body-copy-size) !important;
  line-height: var(--body-copy-line) !important;
}

@media (max-width: 980px) {
  .why-max-page .system-brings-grid {
    grid-template-columns: 1fr;
  }

  .why-max-page .system-brings-column {
    border-left: none;
    border-top: 1px solid rgba(17, 17, 17, 0.22);
  }

  .why-max-page .system-brings-column:first-child {
    border-top: none;
  }
}

.system-brings-card {
  border-radius: 0;
  padding: 0;
  min-height: clamp(360px, 42vw, 520px);
  background: color-mix(in srgb, var(--bg) 92%, #ffffff 8%);
  position: relative;
  overflow: hidden;
  box-shadow: none;
  border: 1px solid color-mix(in srgb, var(--text) 6%, transparent);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.6), 0 18px 52px -64px rgba(0, 0, 0, 0.35);
}

.system-brings-card-media {
  position: absolute;
  inset: 0;
  background: transparent;
  display: grid;
  place-items: center;
}

.system-brings-card-image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.system-brings-card-photo {
  width: 100%;
  height: 100%;
  border-radius: 0;
  background: linear-gradient(135deg, #e6e1db 0%, #d8d2cb 100%);
  box-shadow: none;
}

.system-brings-card-photo--files {
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(circle at 50% 56%, rgba(255, 255, 255, 0.46), rgba(255, 255, 255, 0) 52%),
    linear-gradient(180deg, #efeeec 0%, #e5e3e0 100%);
}

.reasoning-files-visual {
  position: absolute;
  inset: 0;
}

.reasoning-files-backdrop {
  position: absolute;
  left: 14%;
  top: 20%;
  width: 72%;
  height: 68%;
  border-radius: 24px;
  background: rgba(255, 255, 255, 0.22);
  box-shadow: 0 34px 80px rgba(0, 0, 0, 0.08);
  filter: blur(4px);
}

.reasoning-files-folder-shadow {
  position: absolute;
  left: 27%;
  top: 23%;
  width: 46%;
  height: 48%;
  border-radius: 22px;
  background: rgba(0, 0, 0, 0.11);
  filter: blur(18px);
}

.reasoning-files-folder {
  position: absolute;
  left: 32%;
  top: 17%;
  width: 43%;
  height: 46%;
  border-radius: 22px;
  background: linear-gradient(180deg, rgba(205, 205, 207, 0.95), rgba(194, 194, 196, 0.92));
  box-shadow: inset 0 0 0 2px rgba(255, 255, 255, 0.28);
}

.reasoning-files-folder-tab {
  position: absolute;
  left: 32%;
  top: 17%;
  width: 18%;
  height: 10%;
  border-radius: 22px 22px 0 0;
  background: linear-gradient(180deg, rgba(198, 198, 200, 0.96), rgba(186, 186, 188, 0.94));
  clip-path: polygon(0 100%, 0 0, 70% 0, 100% 100%);
}

.reasoning-files-panel {
  position: absolute;
  left: 32%;
  top: 24%;
  width: 43%;
  height: 39%;
  border-radius: 20px;
  background: linear-gradient(180deg, rgba(250, 250, 250, 0.36), rgba(255, 255, 255, 0.18));
  box-shadow: inset 0 0 0 2px rgba(255, 255, 255, 0.3);
}

.reasoning-files-row {
  position: absolute;
  left: 41%;
  width: 24%;
  height: 3.3%;
  border-radius: 999px;
  background:
    linear-gradient(90deg, rgba(141, 175, 224, 0.9) 0 8%, transparent 8% 14%, rgba(120, 120, 124, 0.82) 14% 100%);
  opacity: 0.92;
}

.reasoning-files-row::before {
  content: "";
  position: absolute;
  left: -18%;
  top: 50%;
  width: 10%;
  height: 140%;
  border-radius: 3px;
  transform: translateY(-50%);
  background: rgba(154, 188, 235, 0.95);
  box-shadow: inset 0 -2px 0 rgba(255, 255, 255, 0.35);
}

.reasoning-files-row--1 {
  top: 28%;
}

.reasoning-files-row--2 {
  top: 35.5%;
}

.reasoning-files-row--2::before {
  background: rgba(226, 110, 110, 0.92);
}

.reasoning-files-row--3 {
  top: 43%;
}

.reasoning-files-row--4 {
  top: 50.5%;
}

.reasoning-files-row--4::before {
  background: rgba(100, 188, 138, 0.92);
}

.reasoning-files-row--5 {
  top: 58%;
  opacity: 0.5;
}

.system-brings-card--stacked {
  min-height: clamp(420px, 42vw, 560px);
  display: block;
  background: #e6e6e6;
}

.system-brings-card--handle-matters {
  background-color: #e6e6e6;
  background-image: none;
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center bottom;
}

.system-brings-card-overlay--stacked {
  position: relative;
  inset: auto;
  background: linear-gradient(
    180deg,
    rgba(230, 230, 230, 0.98) 0%,
    rgba(230, 230, 230, 0.98) 42%,
    rgba(230, 230, 230, 0.7) 58%,
    rgba(230, 230, 230, 0.12) 76%,
    rgba(230, 230, 230, 0) 100%
  );
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  gap: 14px;
  min-height: 100%;
  padding-bottom: 0;
}

.reasoning-page .system-brings-card--handle-matters {
  background-position: center bottom;
  background-size: contain;
}

.reasoning-page .system-brings-card--handle-matters .system-brings-card-overlay--stacked {
  background: linear-gradient(
    180deg,
    rgba(230, 230, 230, 0.94) 0%,
    rgba(230, 230, 230, 0.88) 24%,
    rgba(230, 230, 230, 0.42) 46%,
    rgba(230, 230, 230, 0.08) 64%,
    rgba(230, 230, 230, 0) 82%
  );
}

.system-brings-card-overlay {
  position: absolute;
  inset: 0;
  padding: clamp(22px, 3vw, 32px);
  background: linear-gradient(
    180deg,
    color-mix(in srgb, var(--bg) 88%, transparent) 0%,
    color-mix(in srgb, var(--bg) 96%, transparent) 100%
  );
  color: #111111;
  display: grid;
  grid-template-rows: auto 1fr auto;
  gap: 14px;
}

.system-brings-card-overlay:not(.system-brings-card-overlay--with-foot) {
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  gap: 14px;
}

.reasoning-page .system-brings-card-overlay:not(.system-brings-card-overlay--with-foot),
.drafting-system-page .system-brings-card-overlay:not(.system-brings-card-overlay--with-foot),
.review-page .system-brings-card-overlay:not(.system-brings-card-overlay--with-foot),
.knowledge-page .system-brings-card-overlay:not(.system-brings-card-overlay--with-foot) {
  justify-content: flex-start;
}

.system-brings-card-overlay:not(.system-brings-card-overlay--with-foot) .system-brings-card-body {
  align-content: start;
}

@media (min-width: 981px) {
  .system-brings-card-overlay:not(.system-brings-card-overlay--with-foot) .system-brings-card-title {
    min-height: 2.3em;
  }

  .system-brings-card-overlay:not(.system-brings-card-overlay--with-foot) .system-brings-card-body {
    min-height: calc(6 * 1.6em);
  }
}

.system-brings-card-overlay--with-foot {
  grid-template-rows: minmax(clamp(46px, 5vw, 64px), auto) 1fr minmax(clamp(96px, 10vw, 132px), auto);
  gap: 12px;
}

.system-brings-card-overlay--with-foot .system-brings-card-title {
  align-self: end;
}

.system-brings-card-overlay--with-foot .system-brings-card-foot {
  align-self: start;
}

.solutions-overview-page .system-brings-card-overlay--with-foot {
  grid-template-rows: auto 1fr auto;
  gap: 14px;
}

.overview-page .system-brings-card-overlay--with-foot {
  display: flex;
  flex-direction: column;
  align-content: flex-start;
  align-items: stretch;
  gap: 12px;
}

.overview-page .system-brings-card-overlay--with-foot .system-brings-card-title,
.overview-page .system-brings-card-body,
.overview-page .system-brings-card-foot {
  align-self: flex-start;
  text-align: left;
}

.overview-page .system-brings-card-body,
.overview-page .system-brings-card-foot {
  width: 100%;
  max-width: none;
}

/* Overview pages: remove decorative icons from cards. */
.overview-page :is(.overview-icon, .whymax-icon, .solutions-overview-icon) {
  display: none !important;
}

/* Overview pages: tighten card height now that icons are removed. */
.overview-page .system-brings-card {
  min-height: clamp(300px, 30vw, 390px);
}

.overview-page .system-brings-card-overlay--with-foot {
  gap: 10px;
}

.overview-page .system-brings-card-title {
  min-height: 0;
  height: auto;
  display: block;
  -webkit-line-clamp: unset;
}

.overview-page .system-brings-card-foot {
  min-height: 0;
}

.overview-page .system-brings-card-body {
  align-content: start;
  place-self: stretch;
}

.solutions-overview-page .system-brings-card {
  background: linear-gradient(
    180deg,
    color-mix(in srgb, var(--bg) 72%, #cfcac2 28%) 0%,
    color-mix(in srgb, var(--bg) 78%, #d7d1c9 22%) 100%
  );
  box-shadow: 0 22px 70px -46px rgba(0, 0, 0, 0.35), 0 10px 26px -20px rgba(0, 0, 0, 0.18);
  border-color: color-mix(in srgb, var(--text) 8%, transparent);
}

.overview-page .system-brings-card {
  background: linear-gradient(
    180deg,
    color-mix(in srgb, var(--bg) 72%, #cfcac2 28%) 0%,
    color-mix(in srgb, var(--bg) 78%, #d7d1c9 22%) 100%
  );
  box-shadow: 0 22px 70px -46px rgba(0, 0, 0, 0.35), 0 10px 26px -20px rgba(0, 0, 0, 0.18);
  border-color: color-mix(in srgb, var(--text) 8%, transparent);
}

.solutions-overview-page .system-brings-card-overlay {
  background: linear-gradient(
    180deg,
    color-mix(in srgb, var(--bg) 72%, #cfcac2 28%) 0%,
    color-mix(in srgb, var(--bg) 78%, #d7d1c9 22%) 100%
  );
}

.overview-page .system-brings-card-overlay {
  background: linear-gradient(
    180deg,
    color-mix(in srgb, var(--bg) 72%, #cfcac2 28%) 0%,
    color-mix(in srgb, var(--bg) 78%, #d7d1c9 22%) 100%
  );
}

.solutions-overview-page .system-brings-card-overlay--with-foot .system-brings-card-title {
  align-self: start;
}

.solutions-overview-page .system-brings-card-body {
  grid-template-rows: auto 1fr;
}

.solutions-overview-page .solutions-overview-icon {
  width: min(280px, 100%);
  height: 74px;
  justify-self: center;
  align-self: end;
  margin-top: clamp(10px, 1.6vw, 18px);
  margin-bottom: clamp(18px, 2.6vw, 34px);
  position: relative;
  perspective: 900px;
}

.solutions-overview-page .solutions-overview-flip-word {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  padding: 0 14px;
  color: rgba(17, 17, 17, 0.9);
  font-size: clamp(20px, 1.45vw, 24px);
  font-weight: 700;
  letter-spacing: -0.01em;
  white-space: nowrap;
  backface-visibility: hidden;
  opacity: 0;
  transform: rotateX(90deg);
  animation: solutions-overview-word-flip 18s linear infinite;
  animation-delay: calc(var(--i) * 3s);
}

.solutions-overview-page .solutions-overview-icon--pyramid {
  width: min(280px, 100%);
  height: 120px;
  margin-top: clamp(10px, 1.6vw, 18px);
  margin-bottom: clamp(14px, 2.2vw, 28px);
  position: relative;
  display: grid;
  place-items: center;
}

.solutions-overview-page .solutions-overview-icon--compass {
  width: min(280px, 100%);
  height: 120px;
  margin-top: clamp(10px, 1.6vw, 18px);
  margin-bottom: clamp(14px, 2.2vw, 28px);
  position: relative;
  display: grid;
  place-items: center;
  transform: translateY(0);
}

.solutions-overview-page .solutions-compass-rose {
  width: 108px;
  height: 108px;
  overflow: visible;
  filter: drop-shadow(0 10px 22px rgba(0, 0, 0, 0.14));
  transform-origin: 50% 50%;
  animation: solutions-compass-rose-rotate 7.5s ease-in-out infinite;
}

.solutions-overview-page .solutions-compass-rose-ring {
  fill: none;
  stroke: #111111;
  stroke-width: 3.4;
}

.solutions-overview-page .solutions-compass-rose-label {
  fill: #111111;
  font-family: var(--sans);
  font-size: 11px;
  font-weight: 700;
  text-anchor: middle;
  dominant-baseline: middle;
}

.solutions-overview-page .solutions-compass-rose-main {
  fill: #111111;
}

.solutions-overview-page .solutions-compass-rose-sub {
  fill: rgba(17, 17, 17, 0.48);
}

.solutions-overview-page .solutions-compass-rose-center {
  fill: #111111;
  animation: solutions-compass-rose-pulse 3.2s ease-in-out infinite;
}

.solutions-overview-page .solutions-pyramid-layer {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  height: 16px;
  border-radius: 999px;
  border: 1px solid rgba(17, 17, 17, 0.18);
  box-shadow: 0 8px 18px -16px rgba(0, 0, 0, 0.28);
}

.solutions-overview-page .solutions-pyramid-layer.is-top {
  width: 52px;
  top: 18px;
  background: #9aa8b7;
}

.solutions-overview-page .solutions-pyramid-layer.is-mid {
  width: 98px;
  top: 42px;
  background: #8393a4;
}

.solutions-overview-page .solutions-pyramid-layer.is-low {
  width: 150px;
  top: 66px;
  background: #6f8195;
}

.solutions-overview-page .solutions-pyramid-layer.is-base {
  width: 210px;
  top: 90px;
  background: #5f7388;
}

.solutions-overview-page .solutions-overview-icon--context {
  width: min(280px, 100%);
  height: 120px;
  margin-top: clamp(10px, 1.6vw, 18px);
  margin-bottom: clamp(14px, 2.2vw, 28px);
  position: relative;
  display: grid;
  place-items: center;
  transform: translateY(0);
}

.solutions-overview-page .solutions-context-links {
  display: none;
}

.solutions-overview-page .solutions-context-node {
  position: absolute;
  border-radius: 50%;
  display: grid;
  place-items: center;
}

.solutions-overview-page .solutions-context-node--center {
  width: 24px;
  height: 24px;
  left: 128px;
  top: 48px;
  background: #627180;
  box-shadow: 0 10px 20px -14px rgba(0, 0, 0, 0.45);
}

.solutions-overview-page .solutions-context-node--pressure {
  width: 38px;
  height: 38px;
  left: 34px;
  top: 12px;
  background: #7f8fa1;
  border: 2px solid rgba(255, 255, 255, 0.92);
  box-shadow: 0 10px 20px -14px rgba(0, 0, 0, 0.45);
}

.solutions-overview-page .solutions-context-node--decision {
  width: 30px;
  height: 30px;
  left: 72px;
  top: 84px;
  background: #5f7fa5;
  border: 2px solid rgba(255, 255, 255, 0.92);
  box-shadow: 0 10px 20px -14px rgba(0, 0, 0, 0.45);
}

.solutions-overview-page .solutions-context-glyph {
  position: relative;
  color: #2e3a45;
  opacity: 0.98;
}

.solutions-overview-page .solutions-context-glyph--profile {
  width: 15px;
  height: 15px;
}

.solutions-overview-page .solutions-context-glyph--profile::before {
  content: "";
  position: absolute;
  left: 50%;
  top: 0;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: currentColor;
  transform: translateX(-50%);
}

.solutions-overview-page .solutions-context-glyph--profile::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: 0;
  width: 11px;
  height: 6px;
  border-radius: 8px 8px 5px 5px;
  background: currentColor;
  transform: translateX(-50%);
}

.solutions-overview-page .solutions-context-glyph--computer {
  width: 76px;
  height: 56px;
  position: relative;
  animation: solutions-computer-float 3.8s ease-in-out infinite;
}

.solutions-overview-page .solutions-context-glyph--computer::before {
  content: "";
  position: absolute;
  left: 50%;
  top: 0;
  width: 62px;
  height: 40px;
  border: 6px solid #1f2a36;
  border-radius: 3px;
  transform: translateX(-50%);
}

.solutions-overview-page .solutions-context-glyph--computer::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: 0;
  width: 30px;
  height: 8px;
  border-radius: 3px;
  background: #1f2a36;
  transform: translateX(-50%);
}

.solutions-overview-page .solutions-context-glyph--lock {
  font-size: 12px;
  line-height: 1;
  font-weight: 700;
}

.solutions-overview-page .solutions-context-glyph--lock::before {
  content: "🔒";
}

.solutions-overview-page .solutions-context-node--accountability {
  width: 32px;
  height: 32px;
  left: 210px;
  top: 20px;
  background: #8b9ba8;
}

.solutions-overview-page .solutions-context-node--computer-main {
  position: static;
  width: auto;
  height: auto;
  background: transparent;
  border: none;
  box-shadow: none;
}

.solutions-overview-page .solutions-context-check {
  position: absolute;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: #ffffff;
  border: 2px solid #7c8794;
  box-shadow: 0 4px 10px -8px rgba(0, 0, 0, 0.4);
  animation: whymax-node-pulse 3.2s ease-in-out infinite;
}

.solutions-overview-page .solutions-context-check--c1 {
  left: 94px;
  top: 45px;
  animation-delay: 0.15s;
}

.solutions-overview-page .solutions-context-check--c2 {
  left: 110px;
  top: 74px;
  animation-delay: 0.4s;
}

.solutions-overview-page .solutions-context-check--c3 {
  left: 182px;
  top: 44px;
  animation-delay: 0.7s;
}

.solutions-overview-page .solutions-overview-icon--adoption {
  width: min(280px, 100%);
  height: 120px;
  margin-top: clamp(10px, 1.6vw, 18px);
  margin-bottom: clamp(14px, 2.2vw, 28px);
  position: relative;
  transform: scale(1.32);
  transform-origin: center center;
}

.solutions-overview-page .solutions-adoption-node {
  position: absolute;
  border-radius: 8px;
  border: 1px solid rgba(17, 17, 17, 0.18);
  background: rgba(255, 255, 255, 0.72);
  box-shadow: 0 10px 20px -18px rgba(0, 0, 0, 0.35);
  animation: solutions-adoption-node-breathe 4.2s ease-in-out infinite;
}

.solutions-overview-page .solutions-adoption-rail {
  position: absolute;
  left: 54px;
  top: 58px;
  width: 172px;
  height: 2px;
  background: rgba(17, 17, 17, 0.28);
}

.solutions-overview-page .solutions-adoption-stem {
  position: absolute;
  width: 2px;
  height: 24px;
  top: 58px;
  background: rgba(17, 17, 17, 0.28);
}

.solutions-overview-page .solutions-adoption-stem--left {
  left: 70px;
}

.solutions-overview-page .solutions-adoption-stem--mid {
  left: 140px;
}

.solutions-overview-page .solutions-adoption-stem--right {
  left: 210px;
}

.solutions-overview-page .solutions-adoption-node--role,
.solutions-overview-page .solutions-adoption-node--mandate,
.solutions-overview-page .solutions-adoption-node--governance {
  width: 60px;
  height: 20px;
  top: 84px;
}

.solutions-overview-page .solutions-adoption-node--role {
  left: 40px;
}

.solutions-overview-page .solutions-adoption-node--mandate {
  left: 110px;
}

.solutions-overview-page .solutions-adoption-node--governance {
  left: 180px;
}

.solutions-overview-page .solutions-adoption-check {
  position: absolute;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  border: 1.5px solid #6f7b88;
  background: #ffffff;
  top: 70px;
  box-shadow: 0 4px 10px -8px rgba(0, 0, 0, 0.4);
  animation: solutions-adoption-check-pulse 2.8s ease-in-out infinite;
}

.solutions-overview-page .solutions-adoption-check::before {
  content: "";
  position: absolute;
  left: 2px;
  top: 2px;
  width: 4px;
  height: 2px;
  border-left: 1.5px solid #6f7b88;
  border-bottom: 1.5px solid #6f7b88;
  transform: rotate(-45deg);
}

.solutions-overview-page .solutions-adoption-check--left {
  left: 66px;
  animation-delay: 0s;
}

.solutions-overview-page .solutions-adoption-check--mid {
  left: 136px;
  animation-delay: 0.2s;
}

.solutions-overview-page .solutions-adoption-check--right {
  left: 206px;
  animation-delay: 0.4s;
}

@keyframes solutions-overview-word-flip {
  0% {
    opacity: 0;
    transform: rotateX(90deg);
  }
  4% {
    opacity: 1;
    transform: rotateX(0deg);
  }
  14% {
    opacity: 1;
    transform: rotateX(0deg);
  }
  18% {
    opacity: 0;
    transform: rotateX(-90deg);
  }
  100% {
    opacity: 0;
    transform: rotateX(-90deg);
  }
}

@keyframes solutions-compass-sweep {
  0%,
  100% {
    transform: translateY(-10px) rotate(12deg);
  }
  50% {
    transform: translateY(-10px) rotate(34deg);
  }
}

@keyframes solutions-compass-breathe {
  0%,
  100% {
    transform: scale(1);
  }
  50% {
    transform: scale(1.03);
  }
}

@keyframes solutions-computer-float {
  0%,
  100% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(-4px);
  }
}

@keyframes solutions-adoption-node-breathe {
  0%,
  100% {
    transform: scale(1);
  }
  50% {
    transform: scale(1.03);
  }
}

@keyframes solutions-adoption-check-pulse {
  0%,
  100% {
    transform: scale(1);
    box-shadow: 0 4px 10px -8px rgba(0, 0, 0, 0.4);
  }
  50% {
    transform: scale(1.12);
    box-shadow: 0 7px 14px -8px rgba(0, 0, 0, 0.5);
  }
}

@keyframes solutions-compass-rose-rotate {
  0%,
  100% {
    transform: rotate(-6deg);
  }
  50% {
    transform: rotate(6deg);
  }
}

@keyframes solutions-compass-rose-pulse {
  0%,
  100% {
    opacity: 1;
  }
  50% {
    opacity: 0.72;
  }
}

@media (prefers-reduced-motion: reduce) {
  .solutions-overview-page .solutions-compass-rose,
  .solutions-overview-page .solutions-compass-rose-center,
  .solutions-overview-page .solutions-context-glyph--computer,
  .solutions-overview-page .solutions-adoption-node,
  .solutions-overview-page .solutions-adoption-check {
    animation: none !important;
  }
}

.overview-page .system-brings-card-overlay--with-foot .system-brings-card-title {
  align-self: start;
}

.solutions-overview-page .system-brings-card-body {
  align-content: start;
  place-self: stretch;
}

.overview-page .system-brings-card-body {
  display: grid;
  min-height: 0;
  align-content: start;
  place-self: auto;
  row-gap: 0;
}

.solutions-overview-page .system-brings-card-foot {
  align-self: end;
}

.overview-page .system-brings-card-foot {
  align-self: flex-start;
  margin-top: 0;
  min-height: 0;
}

.overview-page .system-brings-card-text {
  line-height: 1.42;
}

.overview-page .overview-icon {
  margin-top: 0;
  width: 100%;
  display: grid;
  justify-items: center;
  align-self: end;
  padding-bottom: 10px;
  transform: scale(0.82);
  transform-origin: center top;
}

.overview-page .overview-icon--features-ring {
  min-height: 150px;
}

.overview-page .overview-icon--cycle {
  min-height: 150px;
  display: grid;
  place-items: center;
}

.overview-page .overview-icon-cycle-image {
  width: clamp(94px, 7vw, 124px);
  height: auto;
  filter: drop-shadow(0 8px 16px rgba(0, 0, 0, 0.14));
  animation: overview-cycle-gentle-rotate 7s ease-in-out infinite;
  transform-origin: 50% 50%;
}

.overview-page .overview-icon-cycle-outline {
  width: clamp(138px, 10vw, 184px);
  height: auto;
  filter: drop-shadow(0 8px 16px rgba(0, 0, 0, 0.14));
}

.overview-page .overview-cycle-outline-outer {
  fill: none;
  stroke: #111111;
  stroke-width: 8;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.overview-page .overview-cycle-outline-inner {
  fill: none;
  stroke: #111111;
  stroke-width: 7;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.overview-page .overview-cycle-outline-head {
  fill: #ffffff;
  stroke: #111111;
  stroke-width: 7;
  stroke-linejoin: miter;
}

.overview-page .overview-icon-features-ring {
  width: 220px;
  height: 170px;
  position: relative;
  margin-inline: auto;
  transform: translateY(-6px);
}

.overview-page .overview-icon-pill {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  transform-origin: 0 0;
  padding: 7px 14px;
  border-radius: 999px;
  border: 1px solid rgba(17, 17, 17, 0.16);
  background: rgba(255, 255, 255, 0.88);
  color: rgba(17, 17, 17, 0.86);
  font-size: 14px;
  font-weight: 600;
  letter-spacing: 0.01em;
  white-space: nowrap;
  box-shadow: 0 8px 20px -16px rgba(0, 0, 0, 0.25);
  will-change: transform;
}

@media (min-width: 980px) {
  .overview-page .system-brings-grid .overview-icon {
    margin-top: auto !important;
    min-height: 112px;
    align-self: end;
  }

  .overview-page .system-brings-grid .overview-icon--ms-orbit,
  .overview-page .system-brings-grid .overview-icon--bullet-growth {
    margin-top: auto !important;
  }

  .overview-page .overview-icon--features-ring,
  .overview-page .overview-icon--ms-orbit,
  .overview-page .overview-icon--bullet-growth {
    min-height: 112px;
  }

  .overview-page .overview-icon-features-ring.is-fade-sequence {
    transform: none;
  }

  .overview-page .overview-icon-features-ring.is-fade-sequence .overview-icon-pill {
    padding: 0;
    border: 0;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
    font-size: clamp(24px, 1.8vw, 34px);
    font-weight: 600;
    letter-spacing: -0.01em;
    opacity: 0;
    transform: translate(-50%, -50%) !important;
    animation: overview-pill-fade-sequence 12s ease-in-out infinite;
    animation-delay: calc(var(--overview-pill-index, 0) * 3s);
  }
}

/* General icon line rule for system overview card sections */
:is(.overview-page, .why-max-overview-page, .solutions-overview-page)
  .system-brings-card-overlay--with-foot
  :is(.overview-icon, .whymax-icon, .solutions-overview-icon) {
  margin-top: auto !important;
  margin-left: auto;
  margin-right: auto;
  align-self: end;
}

/* Match icon vertical anchoring across Why Max / Solutions overview cards */
:is(.why-max-overview-page, .solutions-overview-page) .system-brings-card-overlay--with-foot {
  display: flex;
  flex-direction: column;
  align-content: flex-start;
  align-items: stretch;
  gap: 12px;
}

:is(.why-max-overview-page, .solutions-overview-page)
  .system-brings-card-overlay--with-foot
  .system-brings-card-title,
:is(.why-max-overview-page, .solutions-overview-page) .system-brings-card-body {
  align-self: flex-start;
  text-align: left;
}

:is(.why-max-overview-page, .solutions-overview-page) .system-brings-card-body {
  width: 100%;
  max-width: none;
  align-content: start;
  place-self: stretch;
}

@media (min-width: 980px) {
  :is(.overview-page, .why-max-overview-page, .solutions-overview-page)
    .system-brings-card-overlay--with-foot
    :is(.overview-icon, .whymax-icon, .solutions-overview-icon) {
    width: 152px !important;
    height: 152px !important;
    min-height: 152px !important;
    min-width: 152px !important;
  }

  .overview-page .overview-icon {
    transform: none !important;
    padding-bottom: 0 !important;
  }

  .overview-page .overview-icon-cycle-image {
    width: calc(116px - 1cm) !important;
  }

  .overview-page .overview-icon-ms-orbit {
    width: 152px !important;
    height: 152px !important;
    transform: scale(0.6) !important;
    transform-origin: center center !important;
  }

  .overview-page .overview-icon-bullet-growth {
    transform: scale(1.2) !important;
    transform-origin: center center !important;
  }

  .why-max-overview-page .whymax-icon--puzzle {
    transform: scale(0.68) !important;
    transform-origin: center center;
  }

  .why-max-overview-page .whymax-icon--magnet {
    transform: scale(0.7) !important;
    transform-origin: center center;
  }

  .why-max-overview-page .whymax-icon--network {
    width: 280px !important;
    height: 140px !important;
    min-width: 280px !important;
    min-height: 140px !important;
    overflow: visible !important;
    transform: translateX(-2cm) scale(0.96) !important;
    transform-origin: center center;
  }

  .why-max-overview-page .whymax-icon--network .whymax-network-scene {
    width: 280px !important;
    height: 140px !important;
  }

  .solutions-overview-page .solutions-overview-icon--adoption {
    transform: translateX(-2cm) scale(1.12) !important;
    transform-origin: center center;
  }

  .solutions-overview-page .solutions-compass-rose {
    width: 122px !important;
    height: 122px !important;
  }

  .solutions-overview-page .solutions-context-glyph--computer {
    transform: scale(1.12);
    transform-origin: center center;
  }
}

@keyframes overview-cycle-gentle-rotate {
  0%,
  100% {
    transform: rotate(-4deg);
  }
  50% {
    transform: rotate(4deg);
  }
}

@media (prefers-reduced-motion: reduce) {
  .overview-page .overview-icon-cycle-image {
    animation: none !important;
  }
}

@keyframes overview-pill-fade-sequence {
  0% {
    opacity: 0;
  }
  8% {
    opacity: 1;
  }
  22% {
    opacity: 1;
  }
  30% {
    opacity: 0;
  }
  100% {
    opacity: 0;
  }
}

.overview-page .overview-icon--ms-orbit {
  min-height: 96px;
}

.overview-page .overview-icon-ms-orbit {
  --overview-ms-orbit-shift: calc(20px - 2cm);
  width: 380px;
  height: 132px;
  position: relative;
  perspective: 900px;
  transform-style: preserve-3d;
  transform: translateX(var(--overview-ms-orbit-shift));
}

.overview-page .overview-icon-ms-badge {
  position: absolute;
  left: 50%;
  top: 50%;
  width: 68px;
  height: 68px;
  margin: -34px 0 0 -34px;
  border-radius: 16px;
  border: 1px solid rgba(255, 255, 255, 0.35);
  color: #fff;
  display: grid;
  place-items: center;
  font-size: 36px;
  font-weight: 700;
  box-shadow: 0 10px 24px -16px rgba(0, 0, 0, 0.5);
  animation: none;
  will-change: transform, opacity, filter;
}

@media (min-width: 980px) {
  .overview-page .system-brings-card-overlay--with-foot .overview-icon {
    justify-self: center !important;
    justify-items: center !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }

  .overview-page .overview-icon-features-ring,
  .overview-page .overview-icon-ms-orbit,
  .overview-page .overview-icon-bullet-growth {
    justify-self: center !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }

  .overview-page .overview-icon-ms-orbit {
    --overview-ms-orbit-shift: 0px;
  }

  .overview-page .overview-icon--ms-orbit {
    min-height: 90px;
  }

  .overview-page .overview-icon-ms-orbit {
    width: 320px;
    height: 112px;
    transform: translateX(var(--overview-ms-orbit-shift)) scale(0.84);
    transform-origin: center top;
  }

  .overview-page .overview-icon-ms-badge {
    width: 56px;
    height: 56px;
    margin: -28px 0 0 -28px;
    font-size: 30px;
    border-radius: 14px;
  }

  .overview-page .overview-icon-features-ring,
  .overview-page .overview-icon-bullet-growth {
    transform: none !important;
  }

  .overview-page .overview-icon-bullet-growth {
    min-height: 112px;
    align-content: center;
  }
}

.overview-page .overview-icon-ms-word {
  background: #185abd;
}

.overview-page .overview-icon-ms-outlook {
  background: #0a5ec4;
}

.overview-page .overview-icon-ms-teams {
  background: #6264a7;
}

.overview-page .overview-icon-ms-sharepoint {
  background: #0b7d66;
}

.overview-page .overview-icon--bullet-growth {
  min-height: 92px;
}

.overview-page .overview-icon-bullet-growth {
  display: grid;
  gap: 10px;
}

.overview-page .overview-icon-bullet-row {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  gap: 10px;
  min-height: 12px;
}

.overview-page .overview-icon-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #111111;
  display: inline-block;
}

.overview-page .overview-icon-bullet-row--three {
  animation: overview-bullets-three 4.5s ease-in-out infinite;
}

.overview-page .overview-icon-bullet-row--six {
  animation: overview-bullets-six 4.5s ease-in-out infinite;
}

@keyframes overview-ms-front {
  0% {
    transform: translate(-50%, -50%) rotateY(70deg) translateX(-126px) scale(0.68);
    opacity: 1;
    z-index: 1;
  }
  20% {
    transform: translate(-50%, -50%) rotateY(24deg) translateX(-62px) scale(0.84);
    opacity: 1;
    z-index: 2;
  }
  40% {
    transform: translate(-50%, -50%) rotateY(0deg) translateX(0) scale(1.2);
    opacity: 1;
    z-index: 4;
  }
  60% {
    transform: translate(-50%, -50%) rotateY(-24deg) translateX(62px) scale(0.84);
    opacity: 1;
    z-index: 2;
  }
  80% {
    transform: translate(-50%, -50%) rotateY(-70deg) translateX(126px) scale(0.68);
    opacity: 1;
    z-index: 1;
  }
  100% {
    transform: translate(-50%, -50%) rotateY(70deg) translateX(-126px) scale(0.68);
    opacity: 1;
    z-index: 1;
  }
}

@keyframes overview-bullets-three {
  0%,
  26% {
    opacity: 0;
    transform: translateY(-2px);
  }
  34%,
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes overview-bullets-six {
  0%,
  58% {
    opacity: 0;
    transform: translateY(-2px);
  }
  68%,
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}

@media (prefers-reduced-motion: reduce) {
  .overview-page .overview-icon-features-ring,
  .overview-page .overview-icon-pill,
  .overview-page .overview-icon-ms-badge,
  .overview-page .overview-icon-bullet-row--three,
  .overview-page .overview-icon-bullet-row--six {
    animation: none !important;
  }

  .why-max-overview-page .whymax-puzzle-piece,
  .why-max-overview-page .whymax-magnet-line,
  .why-max-overview-page .whymax-network-dot--focus {
    animation: none !important;
  }
}

.system-brings-card-body {
  display: grid;
  grid-template-rows: auto auto auto;
  row-gap: 10px;
  align-content: center;
  place-self: center;
  width: 100%;
}

.system-brings-card-foot {
  margin-top: 0;
  min-height: calc(1.5em * 3);
  -webkit-line-clamp: 3;
}

.system-brings-card-title {
  margin: 0;
  font-size: clamp(18px, 1.4vw, 20px);
  font-weight: 600;
  color: #111111;
  line-height: 1.25;
  min-height: calc(1.25em * 2);
  height: calc(1.25em * 2);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.system-brings-card-text {
  margin: 0;
  color: rgba(17, 17, 17, 0.72);
  line-height: 1.5;
  font-size: clamp(15px, 1.15vw, 16px);
  display: block;
  overflow: visible;
}

.system-brings-card-kicker {
  margin: 0;
  font-weight: 600;
  font-size: clamp(14px, 1.05vw, 15px);
  color: rgba(17, 17, 17, 0.72);
}

.overview-page .system-brings-card-kicker {
  white-space: nowrap;
}

.system-brings-card-body .system-brings-card-kicker {
  min-height: 1.5em;
}

.system-brings-card-body .system-brings-card-text {
  min-height: 0;
}

.overview-page .system-brings-card-body .system-brings-card-text {
  min-height: 0;
  max-width: 32ch;
}

.system-brings-card-list {
  margin: 10px 0;
  padding-left: 18px;
  color: rgba(17, 17, 17, 0.72);
  line-height: 1.5;
  font-size: clamp(14px, 1.05vw, 15px);
  min-height: calc((1.5em * 3) + 8px);
}

.system-brings-card-list li + li {
  margin-top: 4px;
}

.system-context {
  padding-block: clamp(48px, 8vw, 110px);
  background: var(--bg);
}

.system-banner {
  padding-block: 72px;
  background: #0d0d0d;
  color: #f5f5f5;
  min-height: auto;
}

.system-banner-inner {
  display: grid;
  gap: 16px;
  align-content: start;
  justify-items: start;
  text-align: left;
}

.system-banner-kicker {
  margin: 0;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-size: 12px;
  color: color-mix(in srgb, #ffffff 70%, transparent);
}

.system-banner-title {
  margin: 0;
  font-family: var(--serif);
  font-weight: 700;
  font-size: clamp(28px, 3.2vw, 46px);
  line-height: 1.05;
  color: #f5f5f5;
}

.system-banner-subtitle {
  margin: 0;
  font-size: 16px;
  color: color-mix(in srgb, #ffffff 72%, transparent);
}

.system-banner--light {
  background: var(--bg);
  color: var(--text);
}

.system-banner--light .system-banner-kicker,
.system-banner--light .system-banner-title {
  color: var(--text);
}

.system-banner--light .system-banner-subtitle {
  color: color-mix(in srgb, var(--text) 70%, transparent);
}

.system-banner--hero {
  padding-block: 72px;
}

.system-banner--compact {
  padding-block: 72px;
}

.why-max-overview-page .system-banner[aria-label="Why it matters"] {
  padding-block: clamp(54px, 7vw, 96px);
}

.why-matters-card {
  width: 100%;
  margin-inline: auto;
  padding: clamp(28px, 5vw, 56px);
  background: color-mix(in srgb, var(--bg) 86%, #d7d1c9 14%);
  border: 1px solid color-mix(in srgb, var(--text) 8%, transparent);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.6), 0 22px 60px -70px rgba(0, 0, 0, 0.45);
  display: grid;
  gap: 14px;
  justify-items: center;
  text-align: center;
}

.why-matters-card .system-context-text {
  margin: 0;
  max-width: none;
  color: color-mix(in srgb, var(--text) 72%, transparent);
  font-size: var(--body-copy-size);
  line-height: var(--body-copy-line);
}

@media (min-width: 980px) {
  .why-matters-card {
    padding: clamp(42px, 4.8vw, 72px) clamp(28px, 5vw, 56px);
  }
}

.why-matters-card {
  transition: transform 220ms ease, box-shadow 220ms ease, border-color 220ms ease, background-color 220ms ease;
  will-change: transform;
}

@media (hover: hover) and (pointer: fine) {
  .why-matters-card:hover {
    transform: translateY(-4px);
    border-color: color-mix(in srgb, var(--text) 14%, transparent);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.7), 0 34px 90px -80px rgba(0, 0, 0, 0.55);
  }
}

.system-banner--hero .system-banner-inner,
.system-banner--compact .system-banner-inner {
  justify-items: start;
  text-align: left;
}

.system-banner--center .system-banner-inner {
  justify-items: center;
  text-align: center;
}

.system-banner--center .system-context-text {
  max-width: 72ch;
  margin-inline: auto;
}

.system-context-text--fullbleed {
  position: relative;
  left: 50%;
  transform: translateX(-50%);
  width: 100dvw;
  padding-inline: clamp(24px, 4vw, 56px);
  max-width: none !important;
  text-align: center;
  animation: banner-copy-reveal 720ms cubic-bezier(0.2, 0, 0.2, 1) both;
}

.why-max-overview-page .system-context-text--fullbleed {
  position: static;
  left: auto;
  transform: none;
  width: 100%;
  padding-inline: 0;
  margin-inline: 0;
  animation-name: banner-copy-reveal-y;
}

.fullbleed-copy {
  position: relative;
  left: 50%;
  transform: translateX(-50%);
  width: 100dvw;
  padding-inline: clamp(24px, 4vw, 56px);
  max-width: none !important;
}

@keyframes banner-copy-reveal {
  from {
    opacity: 0;
    transform: translateX(-50%) translateY(10px);
    filter: blur(0.6px);
  }
  to {
    opacity: 1;
    transform: translateX(-50%) translateY(0);
    filter: blur(0);
  }
}

@keyframes banner-copy-reveal-y {
  from {
    opacity: 0;
    transform: translateY(10px);
    filter: blur(0.6px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
    filter: blur(0);
  }
}

@media (prefers-reduced-motion: reduce) {
  .system-context-text--fullbleed {
    animation: none;
    filter: none;
  }
}

.system-context-inner {
  display: grid;
  --system-split-gap: clamp(28px, 6vw, 72px);
  grid-template-columns: minmax(260px, 0.9fr) minmax(0, 1.4fr);
  gap: var(--system-split-gap);
  justify-content: space-between;
  align-items: start;
}

.system-practice-heading {
  margin-top: 0;
  padding-top: clamp(8px, 1.2vw, 16px);
  padding-bottom: clamp(44px, 6vw, 88px);
  min-height: auto !important;
}

.drafting-system-page .system-practice-heading {
  min-height: auto;
  display: block;
  align-items: initial;
}

.system-practice-heading .system-brings-subtitle {
  margin-bottom: 0;
  white-space: normal;
}

.system-practice-heading + .system-context {
  padding-top: clamp(12px, 1.6vw, 24px);
}

.system-context-left {
  max-width: 100%;
  min-height: clamp(180px, 22vw, 260px);
}

.system-context-title {
  margin: 0 0 12px;
  font-family: var(--serif);
  font-weight: 700;
  font-size: var(--section-title-size);
  line-height: var(--section-title-line-height);
}

.system-context-text {
  margin: 0;
  color: color-mix(in srgb, var(--text) 70%, transparent);
  line-height: 1.6;
}

.reasoning-page .system-brings-header > .system-brings-text,
.drafting-system-page .system-brings-header > .system-brings-text,
.review-page .system-brings-header > .system-brings-text,
.knowledge-page .system-brings-header > .system-brings-text {
  font-size: var(--site-subtitle-size) !important;
  line-height: var(--site-subtitle-line) !important;
  font-weight: 600 !important;
  color: var(--section-subtitle-color) !important;
}

.reasoning-page .system-practice-heading,
.drafting-system-page .system-practice-heading,
.review-page .system-practice-heading,
.knowledge-page .system-practice-heading {
  margin-top: clamp(-36px, -3vw, -20px);
  padding-top: 0;
  padding-bottom: clamp(6px, 0.8vw, 12px);
}

.reasoning-page .system-practice-heading,
.drafting-system-page .system-practice-heading,
.review-page .system-practice-heading,
.knowledge-page .system-practice-heading {
  padding-top: clamp(32px, 4vw, 56px);
  padding-bottom: clamp(32px, 4vw, 56px);
}

.reasoning-page .system-practice-heading,
.drafting-system-page .system-practice-heading,
.review-page .system-practice-heading,
.knowledge-page .system-practice-heading {
  margin-top: clamp(40px, 7vw, 96px);
}

.reasoning-page .system-practice-heading + .system-context,
.drafting-system-page .system-practice-heading + .system-context,
.review-page .system-practice-heading + .system-context,
.knowledge-page .system-practice-heading + .system-context {
  padding-top: 0;
}

.reasoning-page .system-practice-heading + .system-context,
.drafting-system-page .system-practice-heading + .system-context,
.review-page .system-practice-heading + .system-context,
.knowledge-page .system-practice-heading + .system-context {
  padding-top: clamp(44px, 4.8vw, 80px);
}

.reasoning-page .system-context,
.drafting-system-page .system-context,
.review-page .system-context,
.knowledge-page .system-context {
  min-height: 100svh;
  padding-block: 0;
}

.reasoning-page .system-context,
.drafting-system-page .system-context,
.review-page .system-context,
.knowledge-page .system-context {
  min-height: clamp(460px, 62svh, 680px);
}

.reasoning-page .system-scale,
.drafting-system-page .system-scale,
.review-page .system-scale,
.knowledge-page .system-scale {
  min-height: 100svh;
  padding-block: 0;
}

.reasoning-page .system-scale,
.drafting-system-page .system-scale,
.review-page .system-scale,
.knowledge-page .system-scale {
  min-height: clamp(460px, 62svh, 680px);
}

.reasoning-page .system-context + .system-scale,
.reasoning-page .system-scale + .system-scale,
.drafting-system-page .system-context + .system-scale,
.drafting-system-page .system-scale + .system-scale,
.review-page .system-context + .system-scale,
.review-page .system-scale + .system-scale,
.knowledge-page .system-context + .system-scale,
.knowledge-page .system-scale + .system-scale {
  margin-top: var(--system-how-gap-y, clamp(84px, 5.8vw, 128px));
  padding-top: 0;
}

.reasoning-page main > .system-scale:last-of-type,
.drafting-system-page main > .system-scale:last-of-type,
.review-page main > .system-scale:last-of-type,
.knowledge-page main > .system-scale:last-of-type {
  margin-bottom: clamp(120px, 12vw, 220px);
}

.reasoning-page .system-context-inner,
.drafting-system-page .system-context-inner,
.review-page .system-context-inner,
.knowledge-page .system-context-inner,
.reasoning-page .system-scale-inner,
.drafting-system-page .system-scale-inner,
.review-page .system-scale-inner,
.knowledge-page .system-scale-inner {
  --system-how-gap-x: clamp(96px, 6.4vw, 140px);
  --system-how-gap-y: clamp(130px, 9vw, 210px);
  --system-split-gap: var(--system-how-gap-x);
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  column-gap: var(--system-how-gap-x);
  row-gap: clamp(28px, 3vw, 40px);
  justify-content: initial;
  align-items: start;
}

.reasoning-page .system-scale--reverse .system-scale-inner,
.drafting-system-page .system-scale--reverse .system-scale-inner,
.review-page .system-scale--reverse .system-scale-inner,
.knowledge-page .system-scale--reverse .system-scale-inner {
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
}

.reasoning-page .system-context-left,
.drafting-system-page .system-context-left,
.review-page .system-context-left,
.knowledge-page .system-context-left,
.reasoning-page .system-scale-copy,
.drafting-system-page .system-scale-copy,
.review-page .system-scale-copy,
.knowledge-page .system-scale-copy {
  min-height: 0;
  width: min(100%, 36rem);
  max-width: 36rem;
  margin-left: 0;
  margin-right: 0;
  text-align: left;
}

.reasoning-page .system-context-left,
.drafting-system-page .system-context-left,
.review-page .system-context-left,
.knowledge-page .system-context-left,
.reasoning-page .system-scale--reverse .system-scale-copy,
.drafting-system-page .system-scale--reverse .system-scale-copy,
.review-page .system-scale--reverse .system-scale-copy,
.knowledge-page .system-scale--reverse .system-scale-copy {
  justify-self: end;
}

.reasoning-page .system-scale-copy,
.drafting-system-page .system-scale-copy,
.review-page .system-scale-copy,
.knowledge-page .system-scale-copy {
  justify-self: start;
}

.reasoning-page .system-context-title,
.reasoning-page .system-scale-title,
.drafting-system-page .system-context-title,
.drafting-system-page .system-scale-title,
.review-page .system-context-title,
.review-page .system-scale-title,
.knowledge-page .system-context-title,
.knowledge-page .system-scale-title {
  margin: 0 0 12px;
  font-size: clamp(18px, 1.4vw, 20px) !important;
  line-height: 1.25 !important;
  font-weight: 600 !important;
}

.reasoning-page .system-context-text,
.reasoning-page .system-scale-text,
.drafting-system-page .system-context-text,
.drafting-system-page .system-scale-text,
.review-page .system-context-text,
.review-page .system-scale-text,
.knowledge-page .system-context-text,
.knowledge-page .system-scale-text {
  margin: 0;
}

.reasoning-page .system-brings-card-title,
.drafting-system-page .system-brings-card-title,
.review-page .system-brings-card-title,
.knowledge-page .system-brings-card-title {
  font-size: clamp(18px, 1.4vw, 20px) !important;
  line-height: 1.25 !important;
  font-weight: 600 !important;
  min-height: 0 !important;
  height: auto !important;
  display: block !important;
  -webkit-line-clamp: initial !important;
  -webkit-box-orient: initial !important;
  overflow: visible !important;
}

.reasoning-page .system-brings-card-text,
.drafting-system-page .system-brings-card-text,
.review-page .system-brings-card-text,
.knowledge-page .system-brings-card-text,
.reasoning-page .system-context-text,
.drafting-system-page .system-context-text,
.review-page .system-context-text,
.knowledge-page .system-context-text {
  font-size: var(--body-copy-size) !important;
  line-height: var(--body-copy-line) !important;
}

.reasoning-page .system-brings-card-text {
  font-size: clamp(15px, 1.15vw, 17px) !important;
  line-height: 1.6 !important;
}

.reasoning-page .system-brings-card,
.drafting-system-page .system-brings-card,
.review-page .system-brings-card,
.knowledge-page .system-brings-card {
  background-color: #ebebeb;
  min-height: 0;
  height: auto;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.55),
    0 26px 70px -42px rgba(0, 0, 0, 0.28);
}

.reasoning-page .system-brings-grid,
.drafting-system-page .system-brings-grid,
.review-page .system-brings-grid,
.knowledge-page .system-brings-grid {
  align-items: start;
}

.reasoning-page .system-brings-card-photo,
.drafting-system-page .system-brings-card-photo,
.review-page .system-brings-card-photo,
.knowledge-page .system-brings-card-photo {
  background: #ebebeb;
}

.reasoning-page .system-brings-card-overlay,
.drafting-system-page .system-brings-card-overlay,
.review-page .system-brings-card-overlay,
.knowledge-page .system-brings-card-overlay {
  position: relative;
  inset: auto;
  background: linear-gradient(
    180deg,
    rgba(235, 235, 235, 0.98) 0%,
    rgba(235, 235, 235, 0.98) 52%,
    rgba(235, 235, 235, 0.9) 100%
  );
}

.reasoning-page .system-brings-card-body,
.drafting-system-page .system-brings-card-body,
.review-page .system-brings-card-body,
.knowledge-page .system-brings-card-body {
  align-content: start;
  place-self: stretch;
}

.reasoning-page .system-brings-card--handle-matters {
  background-color: #ebebeb;
  background-image:
    linear-gradient(to right, #ebebeb 0, #ebebeb 18px, rgba(235, 235, 235, 0) 54px),
    linear-gradient(to bottom, #ebebeb 0, #ebebeb 18px, rgba(235, 235, 235, 0) 54px);
  background-repeat: no-repeat;
  background-size: 100% 100%, 100% 100%;
  background-position: 0 0, 0 0;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.55), -10px 18px 44px -34px rgba(0, 0, 0, 0.16);
}

.reasoning-page .system-brings-card--stacked {
  min-height: clamp(360px, 42vw, 520px);
}

.reasoning-page .system-brings-card--handle-matters .system-brings-card-overlay--stacked {
  background: transparent;
}

.reasoning-page .system-brings-card--complete-context .system-brings-card-photo {
  background-color: #ebebeb;
  background-image:
    linear-gradient(to right, #ebebeb 0, #ebebeb 18px, rgba(235, 235, 235, 0) 54px),
    linear-gradient(to bottom, #ebebeb 0, #ebebeb 18px, rgba(235, 235, 235, 0) 54px);
  background-repeat: no-repeat;
  background-size: 100% 100%, 100% 100%;
  background-position: 0 0, 0 0;
}

.reasoning-page .system-brings-card--complete-context .system-brings-card-overlay {
  background: linear-gradient(
    180deg,
    #ebebeb 0%,
    #ebebeb 46%,
    rgba(235, 235, 235, 0.92) 54%,
    rgba(235, 235, 235, 0.16) 66%,
    rgba(235, 235, 235, 0) 76%
  );
}

.system-context-right {
  display: block;
}

.system-context-media {
  width: 100%;
  max-width: 100%;
  min-height: auto;
  aspect-ratio: var(--feature-frame-ratio);
  border-radius: var(--media-radius-md);
  border: 1px solid var(--hairline);
  background: linear-gradient(135deg, rgba(17, 17, 17, 0.12), rgba(17, 17, 17, 0.03));
  box-shadow: none;
}

.reasoning-page .system-context-media--handle-matters {
  background-color: #b1a49c;
  background-image: none;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.55), -10px 18px 44px -34px rgba(0, 0, 0, 0.16);
}

.reasoning-page .system-context-media--handle-matters .system-context-video {
  object-position: 56% 58%;
  transform: scale(1.22);
  transform-origin: center;
}

.drafting-system-page .system-context-media--structure-instruments {
  background-color: #e2d0b4;
  background-image: none;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.55), 0 18px 44px -34px rgba(0, 0, 0, 0.16);
}

.drafting-system-page .system-scale-media--embed-positions {
  background-color: #e2d0b4;
  background-image: none;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.55), 0 18px 44px -34px rgba(0, 0, 0, 0.16);
}

section[aria-label="Embed legal positions into operative language"] .system-scale-media--embed-positions .system-scale-video {
  object-fit: contain !important;
  object-position: 50% 50% !important;
}

.drafting-system-page .system-scale-media--support-output {
  background-color: #e2d0b4;
  background-image: none;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.55), 0 18px 44px -34px rgba(0, 0, 0, 0.16);
}

.review-page .system-context-media--stabilize-review {
  background-color: #ebebeb;
  background-image: none;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.55), 0 18px 44px -34px rgba(0, 0, 0, 0.16);
}

.review-page .system-scale-media--reconcile-input {
  background-color: #ebebeb;
  background-image: none;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.55), 0 18px 44px -34px rgba(0, 0, 0, 0.16);
}

.knowledge-page .system-context-media--reuse-structures {
  background-color: #ebebeb;
  background-image: none;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.55), 0 18px 44px -34px rgba(0, 0, 0, 0.16);
}

.knowledge-page .system-scale-media--apply-approaches {
  background-color: #ebebeb;
  background-image: none;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.55), 0 18px 44px -34px rgba(0, 0, 0, 0.16);
}

.knowledge-page .system-scale-media--connect-source-knowledge {
  background-color: #ebebeb;
  background-image: none;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.55), 0 18px 44px -34px rgba(0, 0, 0, 0.16);
}

.knowledge-page .system-scale-media--apply-approaches .system-scale-video,
.knowledge-page .system-scale-media--connect-source-knowledge .system-scale-video {
  object-position: 50% 50%;
}

.system-context-video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.system-scale {
  padding-block: clamp(48px, 8vw, 110px);
  background: var(--bg);
}

.system-scale-inner {
  display: grid;
  --system-split-gap: clamp(28px, 6vw, 72px);
  grid-template-columns: minmax(0, 1.4fr) minmax(260px, 0.9fr);
  gap: var(--system-split-gap);
  justify-content: space-between;
  align-items: stretch;
}

.system-scale--reverse .system-scale-inner {
  grid-template-columns: minmax(260px, 0.9fr) minmax(0, 1.4fr);
}

.system-scale--reverse .system-scale-media {
  order: 2;
}

.system-scale--reverse .system-scale-copy {
  order: 1;
}

.system-scale--align-bottom .system-scale-inner {
  align-items: stretch;
  min-height: clamp(420px, 60vh, 640px);
}

.system-scale-copy--split {
  display: flex;
  flex-direction: column;
  min-height: clamp(420px, 60vh, 640px);
}

.system-scale-bottom {
  margin-top: auto;
}

.system-scale-cta {
  margin-top: clamp(26px, 3vw, 44px);
  display: flex;
  justify-content: center;
}

.system-scale-media {
  width: 100%;
  max-width: 100%;
  min-height: auto;
  aspect-ratio: var(--feature-frame-ratio);
  border-radius: var(--media-radius-md);
  border: 1px solid var(--hairline);
  background: linear-gradient(135deg, rgba(17, 17, 17, 0.12), rgba(17, 17, 17, 0.03));
  box-shadow: none;
}

.reasoning-page .system-scale-media--complete-context {
  background-color: #b1a49c;
  background-image: none;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.55), 0 18px 44px -34px rgba(0, 0, 0, 0.16);
}

.reasoning-page .system-scale-media--complete-context .system-scale-video {
  object-position: 61% 50%;
}

.reasoning-page .system-scale-media--develop-analysis {
  background-color: #b1a49c;
  background-image: none;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.55), 0 18px 44px -34px rgba(0, 0, 0, 0.16);
}

.reasoning-page .system-scale-media--assess-robustness {
  background-color: #b1a49c;
  background-image: none;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.55), 0 18px 44px -34px rgba(0, 0, 0, 0.16);
}

.system-scale-video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.system-scale-copy {
  max-width: 100%;
  min-height: clamp(180px, 22vw, 260px);
  display: flex;
  flex-direction: column;
  height: 100%;
  align-self: stretch;
}

.system-scale--align-bottom .system-scale-media {
  min-height: auto;
}

.system-scale--align-bottom .system-scale-copy {
  min-height: auto;
  height: 100%;
}

.system-scale-copy--full {
  grid-column: 1 / -1;
  max-width: none;
  height: 100%;
  width: 100%;
}

.system-scale--overview .system-scale-inner {
  grid-template-columns: minmax(0, 1fr);
}

.system-scale--overview .system-scale-copy {
  max-width: none;
  width: 100%;
  min-height: auto;
  justify-content: center;
  gap: clamp(16px, 2.6vw, 28px);
  text-align: left;
  align-items: flex-start;
}

.system-scale--overview {
  min-height: 100vh;
  padding-block: clamp(48px, 8vw, 110px);
  display: flex;
  align-items: center;
}

@media (min-width: 981px) {
  .reasoning-page .system-context-inner,
  .reasoning-page .system-scale-inner,
  .drafting-system-page .system-context-inner,
  .drafting-system-page .system-scale-inner,
  .review-page .system-context-inner,
  .review-page .system-scale-inner,
  .knowledge-page .system-context-inner,
  .knowledge-page .system-scale-inner,
  .reasoning-page .system-scale--reverse .system-scale-inner,
  .drafting-system-page .system-scale--reverse .system-scale-inner,
  .review-page .system-scale--reverse .system-scale-inner,
  .knowledge-page .system-scale--reverse .system-scale-inner {
    --system-how-gap-x: clamp(96px, 6.4vw, 140px);
    --system-how-gap-y: clamp(130px, 9vw, 210px);
    --system-split-gap: var(--system-how-gap-x);
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    column-gap: var(--system-how-gap-x);
  }

  .reasoning-page .system-context-left,
  .drafting-system-page .system-context-left,
  .review-page .system-context-left,
  .knowledge-page .system-context-left,
  .reasoning-page .system-scale-copy,
  .drafting-system-page .system-scale-copy,
  .review-page .system-scale-copy,
  .knowledge-page .system-scale-copy {
    width: min(100%, 36rem) !important;
    max-width: 36rem !important;
    justify-self: start !important;
    margin: 0 !important;
    text-align: left !important;
  }

  .reasoning-page .system-context-title,
  .reasoning-page .system-context-text,
  .reasoning-page .system-scale-title,
  .reasoning-page .system-scale-text,
  .drafting-system-page .system-context-title,
  .drafting-system-page .system-context-text,
  .drafting-system-page .system-scale-title,
  .drafting-system-page .system-scale-text,
  .review-page .system-context-title,
  .review-page .system-context-text,
  .review-page .system-scale-title,
  .review-page .system-scale-text,
  .knowledge-page .system-context-title,
  .knowledge-page .system-context-text,
  .knowledge-page .system-scale-title,
  .knowledge-page .system-scale-text {
    width: 100% !important;
    max-width: 36rem !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
  }
}

@media (min-width: 981px) {
  :is(.reasoning-page, .drafting-system-page, .review-page, .knowledge-page) {
    --system-how-gap-x: clamp(96px, 6.4vw, 140px);
    --system-how-gap-y: clamp(190px, 13vw, 320px);
    --system-first-how-offset: var(--system-how-gap-y);
  }

  .reasoning-page {
    --system-first-how-offset: clamp(150px, 10vw, 260px);
  }

  :is(.reasoning-page, .drafting-system-page, .review-page, .knowledge-page) .system-context-inner,
  :is(.reasoning-page, .drafting-system-page, .review-page, .knowledge-page) .system-scale-inner {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) !important;
    column-gap: var(--system-how-gap-x) !important;
    row-gap: clamp(28px, 3vw, 40px) !important;
    align-items: start !important;
    justify-content: initial !important;
  }

  :is(.reasoning-page, .drafting-system-page, .review-page, .knowledge-page) .system-context,
  :is(.reasoning-page, .drafting-system-page, .review-page, .knowledge-page) .system-scale {
    min-height: auto !important;
    padding-block: 0 !important;
  }

  :is(.reasoning-page, .drafting-system-page, .review-page, .knowledge-page) .system-practice-heading + .system-context,
  :is(.reasoning-page, .drafting-system-page, .review-page, .knowledge-page) .system-practice-heading + .system-scale {
    margin-top: var(--system-first-how-offset) !important;
    padding-top: 0 !important;
  }

  :is(.reasoning-page, .drafting-system-page, .review-page, .knowledge-page) .system-context + .system-scale,
  :is(.reasoning-page, .drafting-system-page, .review-page, .knowledge-page) .system-scale + .system-scale {
    margin-top: var(--system-how-gap-y) !important;
    padding-top: 0 !important;
  }

  :is(.reasoning-page, .drafting-system-page, .review-page, .knowledge-page) .system-context-left,
  :is(.reasoning-page, .drafting-system-page, .review-page, .knowledge-page) .system-scale-copy {
    width: 100% !important;
    max-width: none !important;
    justify-self: start !important;
    margin: 0 !important;
    padding-inline: 0 !important;
    text-align: left !important;
  }

  :is(.reasoning-page, .drafting-system-page, .review-page, .knowledge-page) .system-context-title,
  :is(.reasoning-page, .drafting-system-page, .review-page, .knowledge-page) .system-context-text,
  :is(.reasoning-page, .drafting-system-page, .review-page, .knowledge-page) .system-scale-title,
  :is(.reasoning-page, .drafting-system-page, .review-page, .knowledge-page) .system-scale-text {
    width: 100% !important;
    max-width: none !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
  }

  :is(.reasoning-page, .drafting-system-page, .review-page, .knowledge-page) .system-context-media,
  :is(.reasoning-page, .drafting-system-page, .review-page, .knowledge-page) .system-scale-media {
    aspect-ratio: var(--feature-frame-ratio) !important;
    min-height: clamp(340px, 28vw, 500px) !important;
  }
}

@media (min-width: 981px) {
  .knowledge-page {
    --system-how-gap-y: clamp(190px, 13vw, 320px);
  }

  .reasoning-page .system-practice-heading + .system-context {
    margin-top: clamp(24px, 2.4vw, 56px) !important;
  }

  :is(.reasoning-page, .drafting-system-page, .review-page, .knowledge-page) main .system-context-inner {
    grid-template-columns: minmax(260px, 0.9fr) minmax(0, 1.4fr) !important;
    gap: clamp(28px, 5vw, 64px) !important;
  }

  :is(.reasoning-page, .drafting-system-page, .review-page, .knowledge-page) main .system-scale-inner {
    grid-template-columns: minmax(0, 1.4fr) minmax(260px, 0.9fr) !important;
    gap: clamp(28px, 5vw, 64px) !important;
  }

  :is(.reasoning-page, .drafting-system-page, .review-page, .knowledge-page) main .system-scale--reverse .system-scale-inner {
    grid-template-columns: minmax(260px, 0.9fr) minmax(0, 1.4fr) !important;
  }

  :is(.reasoning-page, .drafting-system-page, .review-page, .knowledge-page) main .system-context-left,
  :is(.reasoning-page, .drafting-system-page, .review-page, .knowledge-page) main .system-scale-copy {
    width: min(100%, 36rem) !important;
    max-width: 36rem !important;
  }

  :is(.reasoning-page, .drafting-system-page, .review-page, .knowledge-page) main .system-context-media,
  :is(.reasoning-page, .drafting-system-page, .review-page, .knowledge-page) main .system-scale-media {
    min-height: clamp(380px, 30vw, 540px) !important;
  }
}

.system-scale--overview .system-scale-inner {
  width: 100%;
}

.system-scale--overview.system-scale--align-bottom .system-scale-inner {
  min-height: clamp(420px, 60vh, 640px);
}

.system-scale--overview .system-scale-bottom {
  margin-top: 0;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}

.system-scale-title {
  margin: 0 0 12px;
  font-family: var(--serif);
  font-weight: 700;
  font-size: var(--section-title-size);
  line-height: var(--section-title-line-height);
}

.system-scale-text {
  margin: 0;
  color: color-mix(in srgb, var(--text) 70%, transparent);
  line-height: 1.6;
}

.system-context-text--kicker {
  margin-bottom: 8px;
  font-weight: 600;
  color: color-mix(in srgb, var(--text) 85%, transparent);
}

.system-list {
  margin: 12px 0;
  padding-left: 18px;
  color: color-mix(in srgb, var(--text) 70%, transparent);
  line-height: 1.6;
}

.system-list li + li {
  margin-top: 6px;
}

.contact-section {
  padding-block: clamp(28px, 4vw, 56px) clamp(44px, 6vw, 80px);
  background:
    radial-gradient(1200px 440px at 18% 14%, rgba(175, 170, 162, 0.16), rgba(175, 170, 162, 0) 62%),
    linear-gradient(180deg, color-mix(in srgb, #ffffff 86%, #efede8), var(--bg) 42%);
}

.contact-page {
  min-height: 100vh;
  min-height: 100svh;
  display: flex;
  flex-direction: column;
}

.contact-page main {
  flex: 1;
  display: flex;
  position: relative;
  background: var(--bg);
}

.contact-page main::before {
  content: none;
}

.contact-page main > section.contact-section {
  flex: 1;
  height: 100%;
  min-height: 100%;
  max-height: none;
  overflow: visible;
  padding-top: var(--header-offset);
  padding-bottom: 0;
  background: var(--bg);
  display: flex;
  align-items: stretch;
  position: relative;
  z-index: 1;
}

.contact-page main > section.contact-section > .container {
  flex: 0 1 auto;
  width: min(var(--container), calc(100% - (var(--page-gutter) * 2))) !important;
  max-width: var(--container) !important;
  margin-inline: auto !important;
  margin-left: auto !important;
  margin-right: auto !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
  height: 100%;
  display: flex;
  align-items: stretch;
  background: transparent;
}

.contact-page .contact-grid {
  margin-top: 0;
  height: 100%;
  padding-block: 0;
  align-content: stretch;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
}

.contact-header {
  max-width: 760px;
}

.contact-header[aria-hidden="true"] {
  display: none;
}

.contact-kicker {
  margin: 0 0 10px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: color-mix(in srgb, var(--text) 70%, transparent);
}

.contact-title {
  margin: 0 0 14px;
  font-family: var(--serif);
  font-weight: 700;
  font-size: clamp(34px, 4.4vw, 56px);
  line-height: 1.05;
}

.contact-subtitle {
  margin: 0;
  color: color-mix(in srgb, var(--text) 70%, transparent);
  line-height: 1.65;
  max-width: 58ch;
}

.contact-grid {
  margin-top: clamp(8px, 1.2vw, 18px);
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: clamp(24px, 3.2vw, 48px);
  align-items: start;
}

.contact-pane {
  min-width: 0;
}

.contact-pane--form {
  grid-column: 2;
  height: 100%;
  border-radius: 26px;
  padding: clamp(24px, 2.9vw, 40px);
  background: transparent;
  border: none;
  box-shadow: none;
  display: flex;
  align-items: flex-start;
}

.contact-form-intro {
  width: 100%;
  max-width: none;
  margin: 0 0 clamp(18px, 2vw, 24px);
  background: transparent;
  border: none;
  padding: 0;
}

.contact-pane--form .contact-form-intro .contact-kicker {
  font-size: clamp(12px, 0.9vw, 14px);
  line-height: 1.2;
  margin: 0 0 8px;
  color: color-mix(in srgb, var(--text) 78%, transparent);
}

.contact-pane--form .contact-form-intro .contact-title {
  font-size: clamp(26px, 2.55vw, 42px) !important;
  line-height: 1.02 !important;
  letter-spacing: -0.018em !important;
  margin: 0 0 12px;
  color: var(--text) !important;
}

.contact-pane--form .contact-form-intro .contact-subtitle {
  font-size: clamp(15px, 1.04vw, 18px);
  line-height: 1.52;
  max-width: 58ch;
  margin: 0 0 18px !important;
  display: block;
  color: #646974;
}

.contact-pane--form .contact-form-intro .button {
  margin-top: 2px;
  position: relative;
  z-index: 1;
}

.contact-pane--form .contact-card {
  width: 100%;
  margin-left: auto;
  margin-right: auto;
  box-shadow: 0 26px 52px -34px rgba(0, 0, 0, 0.38);
}

.contact-card {
  border-radius: 20px;
  border: 1px solid color-mix(in srgb, #111111 10%, transparent);
  background: color-mix(in srgb, #ffffff 76%, #f7f6f4 24%);
  padding: clamp(18px, 2vw, 26px);
  box-shadow: 0 24px 42px -38px rgba(0, 0, 0, 0.36);
}

.contact-side {
  grid-column: 1;
  background: transparent;
  border: none;
  box-shadow: none;
  padding: clamp(22px, 2.2vw, 30px);
  border-radius: 26px;
  align-self: center;
  justify-self: stretch;
  width: 100%;
  max-width: none;
}

.contact-side-intro {
  margin: 0 0 clamp(16px, 1.8vw, 22px);
  text-align: left;
}

/* Contact page: align intro typography between left and right panels. */
.contact-page .contact-form-intro,
.contact-page .contact-side-intro {
  display: grid;
  align-content: start;
  gap: clamp(8px, 0.9vw, 12px);
}

.contact-page .contact-form-intro .contact-kicker,
.contact-page .contact-side-intro .contact-pricing-kicker {
  margin: 0;
  font-size: clamp(12px, 0.9vw, 14px);
  line-height: 1.2;
  letter-spacing: 0.08em;
  color: color-mix(in srgb, var(--text) 70%, transparent) !important;
}

.contact-page .contact-form-intro .contact-kicker {
  font-size: clamp(32px, 2.7vw, 48px) !important;
  line-height: 1.06 !important;
  letter-spacing: 0.02em !important;
  font-family: var(--sans) !important;
  font-weight: 800 !important;
  color: #111111 !important;
  text-transform: uppercase !important;
  white-space: nowrap;
  text-align: center;
  width: max-content;
  margin-left: auto;
  margin-right: auto;
  min-height: 2.2em;
  transform: none;
}

.contact-page .contact-side-intro .contact-pricing-kicker {
  font-size: clamp(32px, 2.7vw, 48px) !important;
  line-height: 1.06 !important;
  letter-spacing: 0.02em !important;
  font-family: var(--sans) !important;
  font-weight: 800 !important;
  color: #111111 !important;
  text-transform: uppercase !important;
  white-space: nowrap;
  text-align: center;
  width: max-content;
  margin-left: auto;
  margin-right: auto;
  min-height: 2.2em;
  transform: none;
}

.contact-page .contact-form-intro .contact-title {
  margin: 3cm 0 0 !important;
  font-size: calc(var(--page-hero-size) / 2.6) !important;
  line-height: var(--page-hero-line) !important;
  letter-spacing: -0.02em !important;
}

.contact-page .contact-side-intro .contact-pricing-sub {
  margin: 3cm 0 0 !important;
  font-size: calc(var(--page-hero-size) / 2.6) !important;
  line-height: var(--page-hero-line) !important;
  letter-spacing: -0.02em !important;
  font-family: var(--serif) !important;
  font-weight: 700 !important;
  color: var(--text) !important;
}

.contact-page .contact-form-intro .contact-title {
  margin-top: 0 !important;
  font-family: var(--sans) !important;
  font-weight: 700 !important;
  font-size: clamp(22px, 2vw, 34px) !important;
  line-height: var(--page-hero-line) !important;
  letter-spacing: -0.02em !important;
  color: #111111 !important;
}

.contact-page .contact-side-intro .contact-pricing-sub {
  margin-top: 0 !important;
  font-family: var(--sans) !important;
  font-weight: 700 !important;
  font-size: clamp(22px, 2vw, 34px) !important;
  line-height: var(--page-hero-line) !important;
  letter-spacing: -0.02em !important;
  color: #111111 !important;
}

.contact-page .contact-form-intro .contact-subtitle {
  margin: 0 !important;
  font-size: var(--site-subtitle-size) !important;
  line-height: var(--site-subtitle-line) !important;
  max-width: 58ch;
  color: #646974 !important;
}

.contact-page .contact-side-intro .contact-pricing-copy {
  margin: 0 !important;
  font-size: var(--site-subtitle-size) !important;
  line-height: var(--site-subtitle-line) !important;
  max-width: 58ch;
  color: #646974 !important;
}

.contact-side-intro .contact-pricing-kicker {
  font-size: clamp(12px, 0.9vw, 14px);
  line-height: 1.2;
  margin: 0 0 8px;
}

.contact-side-intro .contact-pricing-sub {
  margin: 0 0 10px;
  font-size: clamp(34px, 3vw, 54px);
  line-height: 0.96;
  letter-spacing: -0.02em;
  color: #303239;
}

.contact-side-intro .contact-pricing-copy {
  margin: 0;
  padding-top: 0;
  border-top: none;
  font-size: clamp(15px, 1.04vw, 17px);
  line-height: 1.5;
  color: #646974;
}

.contact-pricing-card {
  width: 100%;
  max-width: none;
  border-radius: 0;
  background: #ffffff;
  border: 1px solid #d8dbe0;
  padding: clamp(28px, 3vw, 40px);
  margin: 0 0 clamp(24px, 3vw, 36px);
  text-align: left;
  box-shadow: 0 14px 34px -30px rgba(17, 20, 27, 0.3);
}

.contact-pricing-kicker {
  margin: 0 0 8px;
  color: #8f969d;
  font-size: clamp(13px, 1vw, 16px);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.03em;
}

.contact-pricing-top {
  margin: 0;
  color: #707785;
  display: flex;
  align-items: flex-end;
  flex-wrap: wrap;
  gap: 8px 12px;
  line-height: 1;
  letter-spacing: 0;
}

.contact-pricing-currency {
  font-size: clamp(34px, 2.7vw, 44px);
  line-height: 1;
  font-weight: 500;
}

.contact-pricing-top strong {
  color: #1f2530;
  font-weight: 800;
  font-size: clamp(44px, 4.3vw, 66px);
  line-height: 0.9;
  letter-spacing: -0.03em;
}

.contact-pricing-period {
  color: #666d79;
  font-size: clamp(18px, 1.35vw, 24px);
  line-height: 1.15;
  font-weight: 600;
}

.contact-pricing-copy {
  margin: clamp(18px, 2vw, 24px) 0 0;
  padding-top: clamp(18px, 2vw, 24px);
  border-top: 1px solid #dddddd;
  color: #8f969d;
  font-size: clamp(16px, 1.4vw, 22px);
  line-height: 1.35;
  font-weight: 600;
}

.contact-pricing-line {
  margin: 18px 0 0;
  color: #20242c;
  font-size: clamp(22px, 1.65vw, 30px);
  line-height: 1.18;
  font-weight: 700;
}

.contact-pricing-line--lead {
  margin-top: clamp(14px, 1.6vw, 20px);
  font-size: clamp(19px, 1.4vw, 24px);
  font-weight: 500;
}

.contact-pricing-note {
  margin: 16px 0 0;
  color: #808690;
  font-size: clamp(13px, 0.92vw, 15px);
  line-height: 1.5;
  font-weight: 500;
}

.contact-pricing-cta {
  margin: clamp(22px, 2.4vw, 30px) 0 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: auto;
  min-height: 0;
  padding: var(--site-button-pad-y) var(--site-button-pad-x);
  border-radius: var(--site-button-radius);
  background: #111111;
  color: #ffffff;
  text-decoration: none;
  font-size: var(--site-button-size);
  font-weight: 600;
  letter-spacing: 0;
  line-height: var(--site-button-line);
  transition: transform 160ms ease, box-shadow 160ms ease, filter 160ms ease;
}

.contact-pricing-cta:hover,
.contact-pricing-cta:focus-visible {
  transform: translateY(-1px);
  box-shadow: 0 12px 24px -18px rgba(0, 0, 0, 0.55);
  filter: brightness(1.04);
}

.contact-pricing-features {
  list-style: none;
  margin: clamp(18px, 2vw, 24px) 0 0;
  padding: 0;
  display: grid;
  gap: 10px;
}

.contact-pricing-feature {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  color: #242833;
  font-size: clamp(22px, 1.5vw, 28px);
  line-height: 1.35;
  font-weight: 700;
}

.contact-pricing-feature::before {
  content: "✦";
  font-size: 0.9em;
  line-height: 1.5;
  color: #242833;
  flex: 0 0 auto;
}

.contact-pricing-benefits {
  list-style: none;
  margin: clamp(18px, 2vw, 24px) 0 0;
  padding: 0;
  display: grid;
  gap: 10px;
}

.contact-pricing-benefits li {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  color: #20242c;
  font-size: clamp(14px, 0.95vw, 16px);
  line-height: 1.4;
  font-weight: 500;
}

.contact-pricing-benefits li::before {
  content: "✔";
  color: #1f7a2e;
  font-weight: 700;
  flex: 0 0 auto;
  line-height: 1.3;
}

.contact-side .contact-card-title {
  font-family: var(--serif);
  font-weight: 700;
  font-size: var(--page-hero-size);
  line-height: var(--page-hero-line);
  margin-bottom: clamp(10px, 2vw, 16px);
  text-transform: uppercase;
  letter-spacing: -0.02em;
}

.contact-page .contact-side .contact-card-title {
  font-family: "Montserrat", var(--meet-max-font) !important;
  font-weight: 700 !important;
  font-size: clamp(36px, 4.6vw, 74px) !important;
  line-height: 0.95 !important;
  letter-spacing: -0.015em !important;
  font-synthesis: none !important;
}

.contact-side .contact-card-text {
  font-family: var(--sans) !important;
  font-weight: 600 !important;
  letter-spacing: -0.01em !important;
  font-size: var(--site-subtitle-size) !important;
  line-height: var(--site-subtitle-line) !important;
  color: var(--section-subtitle-color) !important;
  text-wrap: balance;
}

.contact-card-title {
  margin: 0 0 10px;
  font-size: 18px;
  font-weight: 600;
}

.contact-card-text {
  margin: 0;
  color: color-mix(in srgb, var(--text) 70%, transparent);
  line-height: 1.7;
}

.contact-form {
  display: grid;
  gap: 12px;
}

.contact-row {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.contact-row--single {
  grid-template-columns: minmax(0, 1fr);
}

.contact-field {
  display: grid;
  gap: 7px;
}

.contact-label {
  font-weight: 700;
  font-size: 0.93rem;
  letter-spacing: -0.01em;
}

.contact-input,
.contact-textarea,
.contact-select {
  width: 100%;
  min-height: 52px;
  padding: 12px 14px;
  border-radius: 14px;
  border: 1px solid color-mix(in srgb, var(--text) 14%, transparent);
  background: color-mix(in srgb, #ffffff 90%, #f4f3f0 10%);
  color: var(--text);
  font: inherit;
  transition: border-color 150ms ease, box-shadow 150ms ease, background-color 150ms ease;
}

.contact-textarea {
  min-height: 140px;
  resize: vertical;
}

.contact-select {
  appearance: auto;
}

.contact-form input[type="number"] {
  -moz-appearance: textfield;
  min-height: 44px;
  height: 44px;
  padding-top: 8px;
  padding-bottom: 8px;
}

.contact-form #contact-lawyers {
  width: 100%;
  min-height: 38px;
  height: 38px;
  padding: 6px 10px;
}

.contact-page .contact-form .contact-input,
.contact-page .contact-form .contact-select {
  min-height: 38px !important;
  height: 38px !important;
  padding-top: 6px !important;
  padding-bottom: 6px !important;
}

.contact-form input[type="number"]::-webkit-outer-spin-button,
.contact-form input[type="number"]::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

.contact-input:focus,
.contact-textarea:focus,
.contact-select:focus {
  border-color: color-mix(in srgb, var(--text) 40%, transparent);
  background: #ffffff;
  outline: 2px solid color-mix(in srgb, var(--text) 18%, transparent);
  outline-offset: 1px;
  box-shadow: 0 0 0 4px color-mix(in srgb, #000000 6%, transparent);
}

.contact-actions {
  margin-top: 6px;
  display: flex;
  justify-content: flex-start;
}

.contact-page .contact-pane--form .contact-actions {
  justify-content: center;
}

.contact-privacy {
  margin: 10px 0 0;
  color: color-mix(in srgb, var(--text) 70%, transparent);
  line-height: 1.55;
  font-size: clamp(12px, 1vw, 14px);
}

.contact-privacy a {
  text-decoration: underline;
  text-underline-offset: 2px;
}

/* Subscribe page: unify all button sizes/shapes. */
.contact-page .button,
.contact-page .contact-pricing-cta,
.contact-page .mobile-drawer-btn {
  min-height: 0 !important;
  height: auto !important;
  padding: var(--site-button-pad-y) var(--site-button-pad-x) !important;
  border-radius: var(--site-button-radius) !important;
  font-size: var(--site-button-size) !important;
  line-height: var(--site-button-line) !important;
  font-weight: 600 !important;
  letter-spacing: 0 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
}

.contact-page .contact-actions .button {
  width: auto !important;
}

.contact-page .contact-pricing-card .contact-pricing-cta {
  width: auto !important;
  padding: var(--site-button-pad-y) var(--site-button-pad-x) !important;
  border-radius: var(--site-button-radius) !important;
  font-size: var(--site-button-size) !important;
  line-height: var(--site-button-line) !important;
  font-weight: 600 !important;
}

/* Contact page: square corners instead of rounded cards/fields. */
.contact-page .contact-pane--form,
.contact-page .contact-side,
.contact-page .contact-card,
.contact-page .contact-input,
.contact-page .contact-textarea,
.contact-page .contact-select {
  border-radius: 0 !important;
}

@media (max-width: 980px) {
  .contact-page main > section.contact-section {
    overflow: visible;
    background: var(--bg);
  }

  .contact-page main > section.contact-section > .container {
    width: min(var(--container), calc(100% - (var(--page-gutter) * 2))) !important;
    max-width: var(--container) !important;
    margin-inline: auto !important;
    margin-left: auto !important;
    margin-right: auto !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
    background: transparent;
  }

  .contact-page .contact-grid {
    display: flex;
    flex-direction: column;
    gap: 18px;
    height: auto;
    padding-inline: 0;
    min-width: 0;
  }

  .contact-pane--form,
  .contact-side {
    grid-column: auto;
    width: 100%;
    max-width: 100%;
    min-width: 0;
  }

  .contact-side {
    display: block;
    order: 1;
    align-self: stretch;
    justify-self: stretch;
    padding: clamp(14px, 4vw, 20px);
    border-radius: 18px;
  }

  .contact-pane--form {
    order: 2;
    height: auto;
    padding: 12px;
    border-radius: 0;
    background-image: url("images/PHOTO OFFICIELLE BANKING.png");
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    border: none;
    flex-direction: column;
  }

  .contact-page .contact-form-intro {
    background: #ffffff !important;
    border: none !important;
    padding: clamp(14px, 4vw, 24px) clamp(12px, 4vw, 22px) !important;
    margin: clamp(10px, 3vw, 18px) 0 clamp(16px, 4.5vw, 28px) !important;
  }

  .contact-card {
    border-radius: 16px;
    padding: clamp(14px, 4vw, 20px);
  }

  .contact-page .contact-pane--form .contact-card {
    background: #ffffff !important;
    background-image: none !important;
    border: 1px solid rgba(17, 17, 17, 0.12) !important;
  }

  .contact-pricing-card {
    width: min(100%, 94%);
    max-width: none;
    border-radius: 18px;
    padding: clamp(16px, 4.5vw, 24px);
    margin: 0 auto 18px;
  }

  .contact-page .contact-side-intro .contact-pricing-kicker,
  .contact-page .contact-form-intro .contact-kicker {
    font-size: clamp(20px, 8vw, 34px) !important;
    line-height: 1.14 !important;
    white-space: normal !important;
    width: 100% !important;
    text-align: center !important;
    font-family: var(--sans) !important;
    font-weight: 800 !important;
    letter-spacing: 0.02em !important;
    text-wrap: balance !important;
  }

  .contact-pricing-top {
    font-size: clamp(24px, 8.5vw, 38px);
  }

  .contact-pricing-sub {
    font-size: clamp(18px, 6vw, 28px);
  }

  .contact-pricing-copy {
    font-size: clamp(13px, 3.7vw, 18px);
  }

  .contact-page .contact-side-intro .contact-pricing-copy .contact-pricing-copy-line {
    display: block;
  }

  .contact-page .contact-form-intro .contact-subtitle .contact-subtitle-line {
    display: block;
  }

  .contact-pricing-cta {
    min-height: 0;
    width: auto;
    font-size: var(--site-button-size);
  }

  .contact-page .contact-side .contact-pricing-top {
    justify-content: center;
    text-align: center;
  }

  .contact-page .contact-side .contact-pricing-period,
  .contact-page .contact-side .contact-pricing-line--lead {
    text-align: center;
  }

  .contact-page .contact-side .contact-pricing-cta {
    display: flex !important;
    width: fit-content !important;
    margin-top: 14px !important;
    margin-left: auto !important;
    margin-right: auto !important;
    justify-content: center !important;
  }

  .contact-page .contact-side .contact-card-title {
    font-size: clamp(36px, 11vw, 58px) !important;
    line-height: 0.95 !important;
    margin-bottom: 10px;
  }

  .contact-page .contact-form-intro,
  .contact-page .contact-side-intro,
  .contact-page .contact-form-intro .contact-title,
  .contact-page .contact-form-intro .contact-subtitle,
  .contact-page .contact-side-intro .contact-pricing-sub,
  .contact-page .contact-side-intro .contact-pricing-copy {
    text-align: center !important;
  }

  .contact-side .contact-card-text {
    font-size: clamp(15px, 4.4vw, 20px) !important;
    line-height: 1.42 !important;
  }

  .contact-side .contact-card-text br {
    display: none;
  }

  .contact-row {
    grid-template-columns: 1fr;
  }

  .contact-actions {
    justify-content: stretch;
  }

  .contact-actions .button {
    width: 100%;
  }
}

@media (min-width: 981px) {
  .contact-page {
    --contact-col-pad: 0px;
    --contact-panel-width: min(100%, 920px);
  }

  .contact-page main > section.contact-section > .container {
    width: min(var(--container), calc(100% - (var(--page-gutter) * 3.2))) !important;
  }

  .contact-page .contact-grid {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    gap: clamp(28px, 3vw, 48px);
    align-items: stretch;
  }

  .contact-page .contact-pane--form {
    flex: initial;
    grid-column: 2 !important;
    grid-row: 1 !important;
    align-items: flex-start;
    padding: var(--contact-col-pad);
    margin-top: 0;
    flex-direction: column;
    align-items: center;
    align-self: stretch;
    background: transparent;
  }

  .contact-page .contact-side {
    flex: initial;
    grid-column: 1 !important;
    grid-row: 1 !important;
    padding: var(--contact-col-pad);
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
    align-self: flex-start;
    margin-top: 0 !important;
    position: static;
    top: auto;
    display: flex !important;
    flex-direction: column;
    align-items: center;
  }

  .contact-page .contact-side-intro {
    margin-top: 0;
    width: var(--contact-panel-width);
    margin-left: auto;
    margin-right: auto;
  }

  .contact-page .contact-side .contact-pricing-card {
    margin-top: 0;
    width: var(--contact-panel-width) !important;
    max-width: var(--contact-panel-width) !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }

  .contact-page .contact-side .contact-pricing-card,
  .contact-page .contact-pane--form .contact-card {
    height: clamp(700px, 46vw, 820px);
    min-height: clamp(700px, 46vw, 820px);
  }

  .contact-page .contact-pane--form .contact-card {
    width: var(--contact-panel-width);
    max-width: var(--contact-panel-width);
    margin-left: auto;
    margin-right: auto;
  }

  .contact-page .contact-form-intro {
    width: var(--contact-panel-width);
    margin-left: auto !important;
    margin-right: auto !important;
    background: transparent !important;
  }

  /* Keep both intro blocks at the same height so the two cards align horizontally. */
  .contact-page .contact-form-intro,
  .contact-page .contact-side-intro {
    height: clamp(250px, 19vw, 320px);
    min-height: clamp(250px, 19vw, 320px);
    margin-bottom: clamp(18px, 2vw, 24px);
    display: flex;
    flex-direction: column;
    padding-top: 1cm;
  }

  .contact-page .contact-form-intro {
    height: auto;
    min-height: 0;
    margin-top: 1cm;
    margin-bottom: 8px;
  }

  .contact-page .contact-side-intro {
    height: auto;
    min-height: 0;
    margin-top: 1cm;
    margin-bottom: 8px;
  }

  .contact-page .contact-form-intro .contact-title,
  .contact-page .contact-side-intro .contact-pricing-sub {
    margin-top: 0 !important;
  }

  .contact-page .contact-form-intro .contact-subtitle,
  .contact-page .contact-side-intro .contact-pricing-copy {
    margin-top: 0 !important;
  }

  /* Contact desktop: enforce identical size and vertical alignment for both cards. */
  .contact-page {
    --contact-panel-width: min(100%, 920px);
    --contact-intro-height: clamp(170px, 11vw, 220px);
    --contact-card-height: clamp(700px, 46vw, 820px);
  }

  .contact-page .contact-pane--form,
  .contact-page .contact-side {
    display: flex !important;
    flex-direction: column;
    align-items: center !important;
    justify-content: flex-start !important;
  }

  .contact-page .contact-pane--form {
    align-self: stretch !important;
  }

  .contact-page .contact-side {
    align-self: stretch !important;
  }

  .contact-page .contact-form-intro,
  .contact-page .contact-side-intro {
    width: var(--contact-panel-width) !important;
    height: var(--contact-intro-height) !important;
    min-height: var(--contact-intro-height) !important;
    padding-top: 0 !important;
    margin-top: 0 !important;
    margin-bottom: clamp(16px, 1.6vw, 22px) !important;
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
  }

  .contact-page .contact-side .contact-pricing-card {
    width: var(--contact-panel-width) !important;
    max-width: var(--contact-panel-width) !important;
    height: 100% !important;
    min-height: 0 !important;
    margin-left: auto !important;
    margin-right: auto !important;
    box-sizing: border-box;
    flex: 1 1 auto;
  }

  .contact-page .contact-pane--form .contact-card {
    width: var(--contact-panel-width) !important;
    max-width: var(--contact-panel-width) !important;
    height: 100% !important;
    min-height: 0 !important;
    margin-left: auto !important;
    margin-right: auto !important;
    box-sizing: border-box;
    flex: 1 1 auto;
  }

  .contact-page .contact-pane--form .contact-card {
    background-image: url("images/PHOTO OFFICIELLE BANKING.png") !important;
    background-size: cover !important;
    background-position: center !important;
    background-repeat: no-repeat !important;
  }

  .contact-page .contact-pane--form .contact-form {
    background: #ffffff !important;
    padding: clamp(20px, 2vw, 28px) !important;
  }

  .contact-page .contact-pane--form .contact-card {
    transform: translateX(0.5cm);
  }

  .contact-page .contact-form-intro {
    background: transparent !important;
    transform: translateX(0);
    text-align: center;
    align-items: center;
  }

  .contact-page .contact-form-intro .contact-subtitle {
    margin-left: auto;
    margin-right: auto;
  }

  .contact-page .contact-side .contact-pricing-card {
    transform: translateX(-0.2cm);
    height: 100% !important;
    min-height: 0 !important;
  }

  .contact-page .contact-side-intro {
    transform: translateX(0);
    text-align: center;
    align-items: center;
  }

  .contact-page .contact-side-intro .contact-pricing-copy {
    margin-left: auto;
    margin-right: auto;
  }
}

.solutions-page .solutions-intro,
.solutions-intro {
  background-color: var(--bg);
  background-image: var(--pastel-blue);
  color: var(--text);
  padding-block: clamp(56px, 7vw, 110px);
}

.solutions-page .solutions-intro {
  display: grid;
  align-items: center;
}

.solutions-page .solutions-spotlight,
.solutions-spotlight {
  background: #1b1b1b;
  color: #f5f5f5;
  padding-block: clamp(56px, 7vw, 110px);
}

@media (min-width: 1100px) {

  .solutions-page .solutions-spotlight .solutions-benefit-text {
    text-wrap: pretty;
  }

  .solutions-page .solutions-spotlight .solutions-benefits-grid {
    width: 100%;
    max-width: none;
    margin-inline: 0;
  }

  .solutions-page .solutions-spotlight .solutions-benefit {
    padding-block: clamp(16px, 2.4vw, 24px);
    padding-inline: clamp(14px, 1.8vw, 24px);
  }
}

.solutions-page main > section.solutions-intro {
  overflow: hidden;
}

.solutions-intro .solutions-hero-subtitle {
  color: var(--section-heading-color) !important;
  margin: 0;
  font-family: var(--serif) !important;
  font-weight: 700 !important;
  font-size: clamp(28px, 3.2vw, 46px) !important;
  line-height: 1.1 !important;
  letter-spacing: -0.02em !important;
  text-align: left;
  width: 100%;
}

.solutions-intro .solutions-hero-text {
  color: color-mix(in srgb, var(--text) 70%, transparent);
  max-width: 60ch;
}

.solutions-spotlight-inner {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 48px;
  align-items: start;
}

.solutions-spotlight-inner.solutions-spotlight-merged {
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(12px, 2vw, 22px);
}

.solutions-spotlight-top {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 48px;
  align-items: start;
}

@media (min-width: 981px) {
  .solutions-page:not(.solutions-overview-page) .solutions-spotlight-top {
    grid-template-columns: minmax(0, 1.15fr) minmax(0, 0.85fr);
  }

  .solutions-page:not(.solutions-overview-page) .solutions-spotlight-top .solutions-intro-detail {
    grid-column: 1;
    grid-row: 1;
  }

  .solutions-page:not(.solutions-overview-page) .solutions-spotlight-top .solutions-spotlight-left {
    grid-column: 2;
    grid-row: 1;
    justify-self: end;
    align-items: flex-end;
    text-align: right;
  }

  .solutions-page:not(.solutions-overview-page) .solutions-spotlight-top .solutions-spotlight-title {
    text-align: right;
  }
}

.solutions-spotlight-benefits {
  padding-top: clamp(20px, 2.6vw, 38px);
}

@media (min-width: 981px) {
  .solutions-spotlight-benefits {
    padding-top: clamp(96px, 6.8vw, 148px);
  }
}

.solutions-spotlight-inner.solutions-spotlight-merged .solutions-spotlight-left {
  min-height: auto;
}

.solutions-spotlight-kicker {
  margin: 0 0 14px;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-size: 12px;
  color: color-mix(in srgb, #ffffff 70%, transparent);
}

.solutions-spotlight-title {
  margin: 0;
  font-family: var(--serif);
  font-weight: 700;
  font-size: clamp(34px, 4.4vw, 64px);
  line-height: 1.05;
  color: #ffffff;
}

.solutions-page .solutions-spotlight .solutions-spotlight-title {
  color: #ffffff !important;
}

.solutions-spotlight-left {
  max-width: 520px;
  display: flex;
  flex-direction: column;
  min-height: clamp(260px, 32vw, 420px);
}

.solutions-spotlight-copy {
  margin-top: auto;
}

.solutions-spotlight-text {
  margin: 0 0 18px;
  color: color-mix(in srgb, #ffffff 75%, transparent);
  line-height: 1.6;
}

.solutions-spotlight-subtitle {
  margin: 0 0 12px;
  font-weight: 600;
  color: #ffffff;
}

.solutions-spotlight-button {
  background: #ffffff;
  color: #111111;
}

.solutions-spotlight-media {
  margin-top: 0;
}

.solutions-spotlight-frame {
  background: #d7d0db;
  border-radius: var(--media-radius-lg);
  padding: clamp(24px, 6vw, 60px);
  min-height: clamp(260px, 32vw, 420px);
  display: grid;
  gap: 24px;
  place-items: center;
}

.solutions-spotlight-card {
  background: #ffffff;
  color: #111111;
  padding: 18px 26px;
  border-radius: var(--media-radius-md);
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.15);
  width: min(520px, 100%);
  text-align: center;
  font-weight: 600;
}

.solutions-spotlight-video {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}

.solutions-spotlight-frame:has(.solutions-spotlight-video) {
  padding: 0 !important;
  overflow: hidden;
  box-shadow: 0 40px 90px -38px rgba(0, 0, 0, 0.46), 0 18px 38px -24px rgba(0, 0, 0, 0.3) !important;
}

.litigation-page .solutions-spotlight-frame {
  padding: 0;
  overflow: hidden;
  box-shadow: 0 26px 70px -34px rgba(0, 0, 0, 0.34), 0 10px 28px -18px rgba(0, 0, 0, 0.2) !important;
}

.transactional-page .solutions-spotlight-frame {
  padding: 0;
  overflow: hidden;
}

@media (max-width: 960px) {
  .reasoning-page main > .system-scale:last-of-type {
    margin-bottom: 28px !important;
  }

  .drafting-system-page main > .system-scale:last-of-type,
  .review-page main > .system-scale:last-of-type,
  .knowledge-page main > .system-scale:last-of-type {
    margin-bottom: 28px !important;
  }

  .reasoning-page .system-hero {
    padding-top: 28px !important;
    padding-bottom: 44px !important;
  }

  .drafting-system-page .system-hero,
  .review-page .system-hero,
  .knowledge-page .system-hero {
    padding-top: 28px !important;
    padding-bottom: 44px !important;
  }

  .reasoning-page .system-hero-media {
    background: transparent !important;
    border: none !important;
    box-shadow: var(--global-frame-shadow) !important;
    aspect-ratio: 16 / 9 !important;
    overflow: hidden !important;
  }

  .drafting-system-page .system-hero-media {
    background: transparent !important;
    border: none !important;
    box-shadow: var(--global-frame-shadow) !important;
    aspect-ratio: 16 / 9 !important;
    overflow: hidden !important;
  }

  .review-page .system-hero-media,
  .knowledge-page .system-hero-media {
    background: transparent !important;
    border: none !important;
    box-shadow: var(--global-frame-shadow) !important;
    aspect-ratio: 16 / 9 !important;
    overflow: hidden !important;
  }

  .reasoning-page .system-hero-video {
    width: calc(100% + 8px) !important;
    height: calc(100% + 8px) !important;
    margin: -4px !important;
    object-fit: contain !important;
    object-position: 50% 50% !important;
    background: transparent !important;
    -webkit-clip-path: inset(2px);
    clip-path: inset(2px);
  }

  /* Mobile reasoning: remove brown frame treatment around videos (match desktop rendering). */
  .reasoning-page .system-context-media--handle-matters,
  .reasoning-page .system-scale-media--complete-context,
  .reasoning-page .system-scale-media--develop-analysis,
  .reasoning-page .system-scale-media--assess-robustness {
    background: transparent !important;
    background-image: none !important;
    border: none !important;
    box-shadow: none !important;
  }

  .drafting-system-page .system-hero-video {
    width: calc(100% + 8px) !important;
    height: calc(100% + 8px) !important;
    margin: -4px !important;
    object-fit: contain !important;
    object-position: 50% 50% !important;
    background: transparent !important;
    -webkit-clip-path: inset(2px);
    clip-path: inset(2px);
  }

  .review-page .system-hero-video,
  .knowledge-page .system-hero-video {
    width: calc(100% + 8px) !important;
    height: calc(100% + 8px) !important;
    margin: -4px !important;
    object-fit: contain !important;
    object-position: 50% 50% !important;
    background: transparent !important;
    -webkit-clip-path: inset(2px);
    clip-path: inset(2px);
  }

  .reasoning-page .system-brings-card-overlay,
  .drafting-system-page .system-brings-card-overlay,
  .review-page .system-brings-card-overlay,
  .knowledge-page .system-brings-card-overlay {
    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important;
    gap: clamp(12px, 2.8vw, 18px) !important;
    padding: clamp(20px, 5.2vw, 28px) !important;
  }

  .reasoning-page .system-brings-card-body,
  .drafting-system-page .system-brings-card-body,
  .review-page .system-brings-card-body,
  .knowledge-page .system-brings-card-body {
    display: block !important;
    align-content: initial !important;
    place-self: auto !important;
  }

  .reasoning-page .system-hero-inner,
  .drafting-system-page .system-hero-inner,
  .review-page .system-hero-inner,
  .knowledge-page .system-hero-inner {
    grid-template-columns: 1fr !important;
    row-gap: clamp(18px, 4.8vw, 28px);
    align-items: start;
  }

  .reasoning-page .system-hero-right,
  .drafting-system-page .system-hero-right,
  .review-page .system-hero-right,
  .knowledge-page .system-hero-right {
    grid-column: 1;
    width: 100%;
  }

  .reasoning-page .system-hero-right {
    display: flex;
    justify-content: flex-start;
    margin-top: 10px;
  }

  .drafting-system-page .system-hero-right {
    display: flex;
    justify-content: flex-start;
    margin-top: 10px;
  }

  .review-page .system-hero-right,
  .knowledge-page .system-hero-right {
    display: flex;
    justify-content: flex-start;
    margin-top: 10px;
  }

  .reasoning-page .system-hero-media {
    width: min(100%, calc(100vw - 64px)) !important;
    margin-left: 0 !important;
    margin-right: auto !important;
  }

  .drafting-system-page .system-hero-media {
    width: min(100%, calc(100vw - 64px)) !important;
    margin-left: 0 !important;
    margin-right: auto !important;
  }

  .review-page .system-hero-media,
  .knowledge-page .system-hero-media {
    width: min(100%, calc(100vw - 64px)) !important;
    margin-left: 0 !important;
    margin-right: auto !important;
  }

  .solutions-spotlight-inner {
    grid-template-columns: 1fr;
  }

  .solutions-spotlight-top {
    grid-template-columns: 1fr;
  }

  .solutions-spotlight-media {
    margin-top: clamp(24px, 6vw, 48px);
  }

  .system-hero-inner {
    grid-template-columns: 1fr;
  }

  .system-hero-right {
    width: 100%;
  }

  .system-hero-media {
    min-height: clamp(240px, 56vw, 420px);
  }

  .system-brings-grid {
    grid-template-columns: 1fr;
  }

  .system-context-inner {
    grid-template-columns: 1fr;
  }

  .system-context-right {
    justify-content: flex-start;
  }

  .system-context-media {
    min-height: auto;
  }

  .system-scale-inner {
    grid-template-columns: 1fr;
  }

  .system-scale-media {
    min-height: auto;
  }

  .reasoning-page .system-brings-card--handle-matters {
    background-size: 84% auto;
    background-position: center calc(100% + 72px);
  }
}

.solutions-benefits {
  background: #141414;
  color: #f5f5f5;
  padding-block: clamp(56px, 9vw, 120px);
  min-height: 100vh;
  display: grid;
  align-items: center;
}

.solutions-benefits-inner {
  display: grid;
  gap: 32px;
  min-height: auto;
  align-items: center;
}

.solutions-benefits-kicker {
  margin: 0;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-size: 12px;
  color: color-mix(in srgb, #ffffff 70%, transparent);
}

.solutions-benefits-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0;
  align-items: stretch;
}

.solutions-benefit {
  padding: clamp(26px, 3.4vw, 46px);
  display: grid;
  gap: 14px;
  border-left: 1px solid rgba(255, 255, 255, 0.18);
  height: 100%;
  align-content: start;
  justify-items: center;
}

.transactional-page .solutions-benefit {
  padding: clamp(22px, 2.8vw, 38px);
}

.solutions-benefit-icon {
  font-size: 26px;
  color: rgba(255, 255, 255, 0.85);
}

.solutions-benefit-title {
  margin: 0;
  font-size: clamp(22px, 3vw, 32px);
  font-weight: 600;
  color: #ffffff;
  letter-spacing: -0.02em;
  line-height: 1.1;
  width: min(100%, 46ch);
}

@media (min-width: 981px) {
  .solutions-benefit-title {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    height: 1.1em;
  }

  .solutions-page .solutions-spotlight .solutions-benefit {
    grid-template-rows: auto auto;
  }

  .solutions-page .solutions-spotlight .solutions-benefit-title {
    white-space: normal;
    overflow: visible;
    text-overflow: clip;
    height: auto;
  }
}

.solutions-benefit-text {
  margin: 0;
  color: color-mix(in srgb, #ffffff 75%, transparent);
  line-height: 1.6;
  width: min(100%, 46ch);
}

.solutions-page .solutions-spotlight .solutions-benefit-title,
.solutions-page .solutions-spotlight .solutions-benefit-text {
  text-align: left;
}

@media (max-width: 980px) {
  .solutions-benefits-grid {
    grid-template-columns: 1fr;
  }

  .solutions-benefit {
    border-left: none;
    border-top: 1px solid rgba(255, 255, 255, 0.18);
    padding-top: 26px;
  }

  .solutions-benefit:first-child {
    border-top: none;
  }
}

.solutions-usage {
  background: var(--bg);
  color: var(--text);
  padding-block: clamp(72px, 10vw, 140px);
}

.solutions-usage-top {
  display: grid;
  grid-template-columns: minmax(0, 0.7fr) minmax(0, 1.3fr);
  gap: 24px 40px;
  align-items: start;
}

.transactional-page .solutions-usage-top {
  grid-template-columns: minmax(0, 0.82fr) minmax(0, 1.18fr);
}

.firm-knowledge-page .solutions-usage-top {
  grid-template-columns: minmax(0, 0.78fr) minmax(0, 1.22fr);
}

.banking-page .solutions-usage-top {
  grid-template-columns: minmax(0, 0.78fr) minmax(0, 1.22fr);
  gap: 24px 28px;
}


.banking-page .solutions-usage-title {
  font-size: clamp(24px, 3vw, 44px);
}

.banking-page .solutions-usage-title {
  font-size: clamp(28px, 3.6vw, 52px);
}
.solutions-usage-title {
  margin: 0;
  font-family: var(--serif);
  font-weight: 700;
  font-size: clamp(30px, 4vw, 56px);
  line-height: 1.05;
}

.title-nowrap {
  white-space: nowrap;
}

.title-break {
  display: block;
  white-space: normal;
}

@media (min-width: 981px) {
  .solutions-page:not(.solutions-overview-page) .solutions-spotlight-title {
    max-width: 16ch;
    margin-left: auto;
  }

  .litigation-page .solutions-spotlight-title,
  .firm-knowledge-page .solutions-spotlight-title {
    max-width: 10ch;
  }
}

.solutions-usage-tags {
  display: flex;
  flex-wrap: nowrap;
  gap: 10px;
  justify-content: flex-end;
  align-items: center;
  overflow-x: visible;
  margin-top: clamp(6px, 1.2vw, 14px);
  padding-bottom: 6px;
  white-space: nowrap;
  padding-left: 0;
  padding-right: 24px;
  width: 100%;
}

.transactional-page .solutions-usage-tags {
  padding-right: 0;
}

.banking-page .solutions-usage-tags {
  padding-right: 0;
}

.firm-knowledge-page .solutions-usage-tags {
  padding-right: 0;
}

.collaboration-page .solutions-usage-tags {
  padding-right: 0;
}

.solutions-usage-tag {
  flex: 0 0 auto;
  padding: 7px 12px;
  border-radius: 999px;
  border: 1px solid color-mix(in srgb, var(--text) 25%, transparent);
  font-size: 13px;
  color: color-mix(in srgb, var(--text) 80%, transparent);
  background: transparent;
  cursor: pointer;
  white-space: nowrap;
}


.solutions-usage-tag.is-active {
  border-color: color-mix(in srgb, var(--text) 55%, transparent);
  color: var(--text);
  background: color-mix(in srgb, var(--text) 8%, transparent);
}

.solutions-usage-body {
  margin-top: clamp(28px, 6vw, 60px);
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(0, 0.8fr);
  gap: 32px;
  align-items: stretch;
}

.solutions-page .solutions-usage-body {
  align-items: end;
}

.solutions-usage-visual {
  background: #d7d0db;
  border-radius: var(--media-radius-md);
  min-height: clamp(280px, 36vw, 480px);
  box-shadow: inset 0 0 0 1px rgba(0, 0, 0, 0.1);
  position: relative;
  overflow: hidden;
}

.solutions-usage-visual-doc {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  object-position: center;
  border: 0;
}

.solutions-usage-visual-doc[hidden] {
  display: none !important;
}

.solutions-usage-panel {
  background: var(--surface);
  border-radius: 16px;
  padding: clamp(24px, 4vw, 48px);
  display: grid;
  gap: 12px;
  align-content: center;
}

.solutions-page .solutions-usage-panel {
  height: 100%;
  min-height: clamp(280px, 36vw, 480px);
  align-self: end;
  align-content: end;
  justify-content: end;
  padding-top: 0;
  padding-bottom: 0;
}

.solutions-usage-panel[hidden] {
  display: none !important;
}

.collaboration-page .solutions-usage-panel {
  background: transparent !important;
  padding-left: 0;
  padding-right: 0;
}

@media (min-width: 981px) {
  .firm-knowledge-page .solutions-usage-body {
    grid-template-columns: minmax(0, 1.4fr) minmax(260px, 0.9fr);
    gap: clamp(28px, 5vw, 64px);
    align-items: stretch;
  }

  .firm-knowledge-page .solutions-usage-visual {
    aspect-ratio: var(--feature-frame-ratio);
    min-height: auto;
    height: auto;
  }

  .firm-knowledge-page .solutions-usage-panel {
    min-height: 0;
    height: auto;
    align-self: stretch;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
  }
}

.solutions-usage-panel-title {
  margin: 0;
  font-family: var(--serif);
  font-weight: 700;
  font-size: clamp(22px, 3vw, 32px);
}

.solutions-usage-panel-text {
  margin: 0;
  color: color-mix(in srgb, var(--text) 70%, transparent);
  line-height: 1.6;
}

@media (max-width: 980px) {
  .solutions-usage-top {
    grid-template-columns: 1fr;
  }

  .solutions-usage-tags {
    justify-content: flex-start;
  }

  .solutions-usage-body {
    grid-template-columns: 1fr;
  }
}

.solutions-stack {
  background-color: var(--bg);
  background-image: none;
  color: var(--text);
  padding-block: clamp(28px, 6vw, 80px);
}

.solutions-stack-inner {
  display: grid;
  gap: 20px;
  padding-top: 0;
}

.transactional-page .solutions-stack-inner {
  justify-items: center;
}

.solutions-stack-title {
  margin: 0;
  text-align: center;
  font-family: var(--serif);
  font-weight: 700;
  font-size: var(--section-title-size);
  line-height: var(--section-title-line-height);
}

.transactional-page .solutions-stack-title,
.transactional-page .solutions-stack-subtitle {
  width: 100%;
  justify-self: center;
  text-align: center;
}

.transactional-page .solutions-stack-grid {
  width: 100%;
  justify-self: center;
  gap: clamp(18px, 2.4vw, 32px);
}

.solutions-stack-subtitle {
  margin: 0;
  text-align: center;
  color: color-mix(in srgb, var(--text) 70%, transparent);
  line-height: 1.6;
}

.solutions-stack-grid {
  margin-top: 28px;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 22px;
}

.solutions-stack-card {
  background: var(--surface);
  border: 1px solid var(--hairline);
  border-radius: var(--media-radius-lg);
  padding: 28px;
  display: grid;
  gap: 12px;
  min-height: 220px;
  align-content: start;
  transition: transform 160ms ease, box-shadow 160ms ease, border-color 160ms ease;
  will-change: transform;
}

.solutions-stack-card:focus-within {
  outline: none;
  transform: translateY(-4px);
  box-shadow: 0 12px 30px rgba(0, 0, 0, 0.12);
  border-color: color-mix(in srgb, var(--text) 14%, transparent);
}

.solutions-stack-card:hover,
.solutions-stack-card:active {
  transform: translateY(-4px);
  box-shadow: 0 12px 30px rgba(0, 0, 0, 0.12);
  border-color: color-mix(in srgb, var(--text) 14%, transparent);
}

@media (prefers-reduced-motion: reduce) {
  .solutions-stack-card {
    transition: none;
  }

  .solutions-stack-card:hover,
  .solutions-stack-card:focus-within {
    transform: none;
  }
}

.solutions-stack-card-title {
  margin: 0;
  font-size: 20px;
  font-weight: 600;
  min-height: 28px;
}

.solutions-stack-card-text {
  margin: 0;
  color: color-mix(in srgb, var(--text) 70%, transparent);
  line-height: 1.6;
  min-height: 88px;
}

@media (max-width: 980px) {
  .solutions-stack-grid {
    grid-template-columns: 1fr;
  }
}

.solutions-litigation {
  background: var(--bg);
  color: var(--text);
  padding-block: clamp(48px, 7vw, 90px);
  min-height: auto;
}


.solutions-litigation-inner {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(0, 0.8fr);
  gap: 48px;
  align-items: start;
}

.solutions-litigation-left {
  align-self: start;
  display: grid;
  justify-items: start;
}

.solutions-litigation-title {
  margin: 0;
  font-family: var(--serif);
  font-weight: 700;
  font-size: var(--section-title-size);
  line-height: var(--section-title-line-height);
  text-align: left;
}

.solutions-litigation-text {
  margin: 0 0 18px;
  color: color-mix(in srgb, var(--text) 70%, transparent);
  line-height: 1.6;
}

.solutions-litigation-right {
  display: grid;
  gap: 24px;
  justify-items: start;
  max-width: 420px;
  margin-left: 0;
  align-content: start;
  padding-top: 8px;
}

.solutions-litigation-button {
  justify-self: start;
  margin-top: -14px;
  background: #111111;
  color: #ffffff;
  align-self: end;
}

.solutions-page .solutions-litigation-button.button-invert {
  background: #111111;
  color: #ffffff;
  border-color: transparent;
}

.solutions-page .solutions-litigation-button.button-invert:hover,
.solutions-page .solutions-litigation-button.button-invert:focus-visible {
  background: #0a0a0a;
  color: #ffffff;
}

@media (max-width: 980px) {
  .solutions-litigation-inner {
    grid-template-columns: 1fr;
  }
}

.security-standards-content {
  display: grid;
  grid-template-columns: minmax(240px, 0.7fr) minmax(0, 1.3fr);
  gap: 32px;
  align-items: start;
}

.security-standards-left {
  display: grid;
  gap: 26px;
  align-items: start;
}

.security-page .security-standards-left {
  gap: clamp(34px, 4vw, 48px);
}

@media (min-width: 981px) {
  .security-page .security-standards-left .security-standards-grid {
    width: 100%;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    justify-content: initial;
    justify-items: center;
    column-gap: clamp(18px, 2.4vw, 40px);
  }
}

.security-page .security-standards-left .security-standards-card {
  width: 100%;
  justify-items: center;
  text-align: center;
}

.security-standards-left .security-standards-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  justify-items: center;
}

.security-standards-left .security-standards-card {
  justify-items: center;
  text-align: center;
}

.security-standards-status {
  display: grid;
  gap: 8px;
  justify-items: center;
  width: min(980px, 100%);
  margin: 14px auto 0;
}

.security-standards-status-item {
  margin: 0;
  color: color-mix(in srgb, var(--text) 78%, transparent);
  font-size: 14px;
  line-height: 1.45;
  font-weight: 500;
}

.security-standards-status-item::before {
  content: "→ ";
}

.security-page .security-standards-status {
  justify-items: start;
  gap: 10px;
  margin-top: 16px;
}

.security-page .security-standards-status-item {
  color: #ffffff;
  font-size: 15px;
}

.home-page .security .security-standards-status {
  justify-items: center;
  margin-top: 16px;
}

.home-page .security .security-standards-status-item {
  color: #ffffff;
  font-size: 15px;
  font-weight: 600;
}

.security-standards-subtitle {
  margin: 0;
  font-family: var(--serif);
  font-weight: 400;
  font-size: var(--section-title-size);
  line-height: var(--section-title-line-height);
  color: var(--text);
  white-space: nowrap;
}

.security-standards-copy {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: clamp(18px, 3vh, 34px);
  max-width: 560px;
  margin-left: 220px;
  min-height: clamp(360px, 46vh, 560px);
}

.security-page .security-standards-copy {
  max-width: 760px;
  width: min(760px, 100%);
  margin-left: auto;
  min-height: auto;
  justify-content: flex-start;
  gap: clamp(10px, 1.6vw, 18px);
}

.security-standards-copy p {
  margin: 0;
  color: color-mix(in srgb, var(--text) 65%, transparent);
  line-height: 1.75;
  font-size: 15px;
}

@media (max-width: 980px) {
  .security-standards-content {
    grid-template-columns: 1fr;
    align-items: start;
  }

  .security-standards-subtitle {
    white-space: normal;
  }

  .security-standards-left .security-standards-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    justify-items: center;
  }

  .security-standards-left .security-standards-card {
    justify-items: center;
    text-align: center;
  }

  .security-standards-copy {
    margin-left: 0;
    max-width: none;
    min-height: auto;
    justify-content: flex-start;
  }
}

.security-standards-cta {
  justify-self: start;
}

.journey-list {
  margin: 10px 0 0;
  padding: 0 0 0 16px;
  display: grid;
  gap: 12px;
  list-style: none;
  border-left: 1px solid var(--hairline);
}

.journey-step {
  position: relative;
  color: color-mix(in srgb, var(--text) 40%, transparent);
  font-size: 14px;
  letter-spacing: 0.02em;
}

.journey-step::before {
  content: "";
  position: absolute;
  left: -20px;
  top: 0.4em;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: color-mix(in srgb, var(--text) 28%, transparent);
}

.journey-step.is-active {
  color: var(--text);
}

.journey-step.is-active::before {
  background: var(--text);
}

.journey-step.is-current {
  font-weight: 600;
}

.journey-right {
  display: grid;
  gap: 0;
}

.journey-panel {
  display: grid;
  gap: 16px;
  padding: clamp(28px, 4vw, 52px) 0;
  border-top: 1px solid var(--hairline);
  min-height: 60vh;
  align-content: center;
}

.journey-panel:first-child {
  border-top: none;
}

.journey-panel-title {
  margin: 0;
  font-size: 18px;
  font-family: var(--title-font);
  font-weight: 700;
  letter-spacing: -0.01em;
}

.journey-panel-text {
  margin: 0;
  color: var(--muted);
  max-width: 520px;
  line-height: 1.6;
}

.journey-panel-media {
  border-radius: var(--media-radius-md);
  border: 1px solid var(--hairline);
  background: linear-gradient(135deg, rgba(17, 17, 17, 0.12), rgba(17, 17, 17, 0.03));
  aspect-ratio: var(--feature-frame-ratio);
  overflow: hidden;
}

.journey-panel-media img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}

.strategic-legal-advice-page .journey-panel-media img.partner-decisions-shift {
  object-position: 56% center;
}

.features-cta {
  margin-top: 18px;
  margin-bottom: 26px;
  padding-top: 38px;
  display: grid;
  grid-template-columns: 1fr;
  gap: 18px;
  align-items: start;
  position: relative;
}

.features-cta-left {
  display: grid;
  gap: var(--title-subtitle-gap);
  justify-items: start;
}

.features-cta::before {
  content: "";
  position: absolute;
  left: 50%;
  top: 0;
  width: 100vw;
  transform: translateX(-50%);
  border-top: 1px solid var(--hairline);
}

.home-page .features-cta::before {
  display: none;
}

.home-page .features-cta {
  margin: 0;
  padding-block: clamp(34px, 4vw, 56px);
  align-items: center;
}

.features-cta-title {
  margin: 0;
  font-family: var(--serif);
  font-weight: 700;
  letter-spacing: -0.02em;
  font-size: clamp(30px, 3.4vw, 54px);
  line-height: 1.02;
}

.features-cta-right {
  display: grid;
  gap: 10px;
  justify-items: start;
}

.home-page .features-cta-right {
  justify-self: start !important;
  justify-items: start !important;
  text-align: left !important;
  width: 100%;
}

.features-cta-subtitle {
  margin: 0;
  font-weight: 600;
  font-size: var(--site-subtitle-size);
  line-height: var(--site-subtitle-line);
  letter-spacing: -0.01em;
  color: color-mix(in srgb, var(--text) 86%, transparent);
}

.features-cta-button {
  margin-top: 0;
}

.home-page .features-cta-button {
  justify-self: start !important;
}

.vision {
  background-color: var(--bg);
  background-image: var(--pastel-blue);
  padding-block: 72px;
}

.home-page .vision {
  height: auto;
  min-height: 0;
  display: block;
  padding-block: clamp(34px, 4vw, 56px);
  background-color: var(--bg);
  background-image: none;
}

.vision-inner {
  display: grid;
  grid-template-columns: 1fr;
  gap: 46px;
  align-items: start;
}

.home-page .vision-inner {
  gap: clamp(28px, 4.2vw, 56px);
}

.vision-left {
  max-width: 52ch;
}

.home-page .vision-left {
  max-width: none;
  display: grid;
  justify-items: center;
  width: 100%;
}

.home-page .vision-title {
  text-align: center;
  white-space: nowrap;
  transform: none;
}

.vision-body {
  display: grid;
  gap: 10px;
}

.vision-paragraph-block {
  display: grid;
  gap: 8px;
  align-content: start;
}

.home-page .vision-body .vision-paragraph {
  margin: 0;
  line-height: 1.45;
  overflow-wrap: anywhere;
}

.home-page .vision-blocks .vision-paragraph {
  margin: 0;
  line-height: 1.45;
  overflow-wrap: anywhere;
}

.home-page .vision-quote-item {
  text-align: center;
}

.home-page .vision-quote-item .vision-quote,
.home-page .vision-quote-item .vision-cite {
  text-align: center;
}

.home-page .vision-cite {
  display: none !important;
}

.home-page .vision-body .vision-paragraph + .vision-paragraph {
  margin-top: 2px;
}

.vision-title {
  margin: 0 0 var(--title-subtitle-gap);
  font-family: var(--serif);
  font-weight: 700;
  font-size: clamp(34px, 3.6vw, 52px);
  letter-spacing: -0.02em;
  line-height: 1.05;
}

.vision-figure {
  margin: 0;
  display: grid;
  gap: 14px;
  width: min(380px, 100%);
  align-self: start;
}

.vision-portrait {
  aspect-ratio: 4 / 5;
  width: 100%;
  height: auto;
  background: linear-gradient(135deg, rgba(17, 17, 17, 0.14), rgba(17, 17, 17, 0.04));
  border: 1px solid color-mix(in srgb, var(--text) 12%, transparent);
}

.vision-caption {
  display: grid;
  gap: 2px;
}

.vision-name {
  margin: 0;
  font-weight: 700;
}

.vision-role {
  margin: 0;
  color: var(--muted);
  font-size: 14px;
}

.vision-right {
  display: grid;
  grid-template-columns: 1fr;
  gap: 26px;
  align-items: start;
  justify-items: stretch;
  width: 100%;
  margin-top: 6px;
}

.home-page .vision-right {
  gap: 18px;
}

.vision-copy {
  max-width: 100%;
  width: 100%;
}

.vision-paragraph {
  margin: 0 0 16px;
  font-size: 15px;
  line-height: 1.6;
  color: color-mix(in srgb, var(--text) 88%, transparent);
  max-width: 100%;
  width: 100%;
}

.vision-quote {
  margin: 12px 0 0;
  font-family: var(--sans);
  font-size: 18px;
  color: color-mix(in srgb, var(--text) 92%, transparent);
  width: 100%;
}

.home-page .vision-quote {
  margin-top: 10px;
  font-size: 16px;
  line-height: 1.25;
  width: auto;
  max-width: 58ch;
  margin-inline: auto;
  text-wrap: balance;
}

.vision-quotes {
  position: relative;
  display: grid;
  place-items: center;
  text-align: center;
  width: 100%;
  min-height: clamp(110px, 10vw, 170px);
  padding-block: 10px 0;
}

.home-page .vision-quotes {
  transform: none;
  min-height: clamp(78px, 7vw, 112px);
}

@media (min-width: 980px) {
  .home-page .vision-quotes {
    min-height: clamp(58px, 4.2vw, 86px);
    padding-block: 2px 0;
  }
}

.vision-quote-item {
  margin: 0 auto;
  width: min(72ch, 100%);
  opacity: 0;
  transform: none;
  transition: opacity 520ms ease;
  position: absolute;
  inset: 0;
  display: grid;
  grid-template-rows: auto auto;
  row-gap: 2px;
  align-content: stretch;
  justify-items: center;
  pointer-events: none;
}

.vision-quote-item.is-active {
  opacity: 1;
  transform: none;
  pointer-events: auto;
}

.vision-quote-item.is-exiting {
  opacity: 0;
  transform: none;
}

.vision-quote-item .vision-quote {
  margin-top: 0;
  align-self: start;
}

.vision-quote-item .vision-cite {
  margin-top: 10px;
  text-align: center;
}

.home-page .vision-quote-item .vision-cite {
  margin-top: clamp(8px, 1.1vw, 14px);
}

@media (prefers-reduced-motion: reduce) {
  .vision-quote-item {
    transition: none;
    transform: none;
  }

  .vision-quote-item.is-exiting {
    transform: none;
  }
}

.vision-cite {
  margin: 0;
  font-size: 13px;
  color: var(--muted);
  width: 100%;
  text-align: center;
}

.home-page .vision-cite {
  font-size: 12px;
  width: min(58ch, 100%);
  max-width: 58ch;
  margin-inline: auto;
}

@media (min-width: 980px) {
  .home-page .vision-quote {
    max-width: none;
  }

  .home-page .vision-quote strong {
    white-space: nowrap;
    font-size: clamp(14px, 1.15vw, 22px);
  }

  .home-page .vision-quote-item .vision-cite {
    margin-top: clamp(8px, 1.1vw, 14px);
  }
}

.vision-paragraph:last-child {
  margin-bottom: 0;
}

.vision-paragraph strong {
  font-weight: 700;
  color: var(--text);
}

.vision-wide {
  margin-top: 0;
  align-self: start;
  aspect-ratio: 16 / 6;
  background: linear-gradient(135deg, rgba(17, 17, 17, 0.12), rgba(17, 17, 17, 0.03));
  border: 1px solid color-mix(in srgb, var(--text) 12%, transparent);
}

.home-page .vision-wide {
  aspect-ratio: 16 / 4.2;
  min-height: clamp(300px, 26vw, 430px);
  height: auto;
  background-color: #ffffff;
  background-image: url("images/Max bleu.png");
  background-repeat: no-repeat;
  background-position: center center;
  background-size: 42%;
  transition: background-color 180ms ease;
  box-shadow: 0 24px 52px -36px rgba(0, 0, 0, 0.4);
}

.home-page .vision-wide:hover {
  background-color: #2a2a2a;
  background-image: url("images/Max blanc-fond noir.png");
  background-repeat: no-repeat;
  background-position: center center;
  background-size: 42%;
}

@media (min-width: 980px) {
  .home-page .vision-wide {
    animation: none !important;
    background-color: #ffffff;
    background-image: url("images/Max bleu.png");
  }
}

@keyframes home-vision-mobile-swap {
  0%,
  49.999% {
    background-color: #ffffff;
    background-image: url("images/Max bleu.png");
  }
  50%,
  100% {
    background-color: #2a2a2a;
    background-image: url("images/Max blanc-fond noir.png");
  }
}

.system {
  padding-block: 84px 94px;
  background-color: var(--bg);
  background-image: radial-gradient(900px 420px at 55% 10%, rgba(90, 80, 70, 0.015), transparent 66%),
    radial-gradient(760px 360px at 45% 92%, rgba(90, 80, 70, 0.011), transparent 62%),
    linear-gradient(
      180deg,
      color-mix(in srgb, var(--bg) 72%, #cfcac2 28%) 0%,
      var(--bg) 52%,
      color-mix(in srgb, var(--bg) 78%, #d7d1c9 22%) 100%
    );
  --system-carousel-gap: clamp(22px, 2.6vw, 44px);
}

.home-page .system {
  --system-carousel-gap: clamp(32px, 3.2vw, 76px);
  background-color: var(--bg) !important;
  background-image: var(--pastel-blue) !important;
}


.solutions-overview-page .system {
  --system-carousel-gap: clamp(32px, 3.2vw, 76px);
}

.system-head {
  display: grid;
  grid-template-columns: 1fr;
  gap: 18px;
  align-items: start;
  margin-bottom: 120px;
}

.home-page .system-head {
  margin-bottom: 26px;
}

.system-head-left {
  display: grid;
  gap: var(--title-subtitle-gap);
  justify-items: start;
  text-align: left;
}

.system-title {
  margin: 0;
  font-family: var(--serif);
  font-weight: 700;
  letter-spacing: -0.02em;
  font-size: clamp(34px, 4.4vw, 68px);
  line-height: 0.98;
  justify-self: start;
  text-align: left;
}

/* Optical alignment tweak for the home System header. */
.home-page .system-head .system-title {
  transform: translateX(-2px);
}

.system-head-right {
  display: grid;
  gap: 10px;
  justify-items: start;
}

.system-kicker {
  margin: 0;
  font-weight: 600;
  font-size: 16px;
  letter-spacing: -0.01em;
  color: color-mix(in srgb, var(--text) 86%, transparent);
  justify-self: start;
  text-align: left;
}

/* Keep exact left alignment with the title (no optical offset). */
.home-page .system-head .system-kicker {
  transform: none;
}

.home-page .system-head-right {
  justify-items: start !important;
  text-align: left !important;
}

.home-page .system-button {
  justify-self: start !important;
  margin-left: 0 !important;
}

.hero-heading,
.features-cta-left,
.journey-left,
.system-head-left {
  gap: var(--title-subtitle-gap) !important;
}

.system-brings-header {
  display: grid;
  gap: var(--title-subtitle-gap);
}

.system-brings-title,
.system-brings-subtitle,
.system-brings-text {
  margin: 0 !important;
}

.hero-subtitle,
.features-cta-subtitle,
.journey-subtitle,
.system-kicker {
  margin: 0 !important;
  font-size: var(--site-subtitle-size) !important;
  line-height: var(--site-subtitle-line) !important;
  font-weight: 600 !important;
  letter-spacing: -0.01em !important;
  color: var(--section-subtitle-color) !important;
}

.system-button {
  margin-top: 0;
}

.solutions-overview-page .system-head {
  margin-bottom: clamp(10px, 1.6vw, 18px);
}

.system-scenarios {
  display: grid;
  gap: 12px;
  max-width: 78ch;
}

.solutions-overview-page .system-scenarios {
  max-width: none;
  width: 100%;
}

.solutions-overview-page .system-scenarios-text {
  max-width: none;
}

.system-scenarios-title {
  margin: 0;
  font-family: var(--serif);
  font-weight: 700;
  letter-spacing: -0.02em;
  font-size: clamp(22px, 2.2vw, 32px);
  line-height: 1.12;
}

.system-scenarios-subtitle {
  margin: 0 0 6px;
  font-weight: 600;
  color: color-mix(in srgb, var(--text) 78%, transparent);
  font-size: 16px;
  letter-spacing: -0.01em;
}

.system-scenarios-text {
  margin: 0;
  color: color-mix(in srgb, var(--text) 72%, transparent);
  font-size: var(--body-copy-size);
  line-height: var(--body-copy-line);
}

.solutions-overview-page .system-carousel {
  margin-top: clamp(14px, 2.4vw, 26px);
}

.solutions-overview-page main > section.system {
  padding-bottom: clamp(130px, 12vw, 200px);
  margin-bottom: clamp(18px, 3vw, 44px);
  background-image: none;
  background-color: var(--bg);
}

.overview-page main > section.overview-capabilities {
  padding-bottom: clamp(130px, 12vw, 200px);
  margin-bottom: clamp(18px, 3vw, 44px);
}

.why-max-overview-page main > section.journey {
  padding-bottom: clamp(130px, 12vw, 200px);
  margin-bottom: clamp(18px, 3vw, 44px);
}

.system-carousel {
  position: relative;
  overflow: hidden;
  margin-top: 56px;
  -webkit-mask-image: none;
  mask-image: none;
}

.home-page .system-carousel {
  -webkit-mask-image: none;
  mask-image: none;
}

@media (min-width: 980px) {
  .solutions-overview-page .system-carousel {
    -webkit-mask-image: none !important;
    mask-image: none !important;
  }
}

.system-track {
  display: flex;
  gap: 0;
  width: max-content;
  will-change: transform;
  animation: system-ltr var(--system-carousel-duration, 50s) linear infinite;
}

.system-carousel.is-card-hover .system-track {
  animation-play-state: paused;
}

.system-carousel.is-card-hover:not(:hover) .system-track {
  animation-play-state: running;
}

.system-row {
  display: flex;
  gap: var(--system-carousel-gap);
  flex-shrink: 0;
  padding-right: var(--system-carousel-gap);
}

.system .feature {
  min-width: clamp(190px, 14vw, 260px);
  width: clamp(190px, 14vw, 260px);
  min-height: 420px;
  grid-template-rows: auto auto 1fr;
  align-content: start;
  position: relative;
}

.home-page .system .feature {
  min-width: clamp(240px, 18vw, 300px);
  width: clamp(240px, 18vw, 300px);
  min-height: 450px;
  justify-items: start;
  gap: 10px;
}

.solutions-overview-page .system .feature {
  min-width: clamp(240px, 18vw, 300px);
  width: clamp(240px, 18vw, 300px);
  min-height: 450px;
  justify-items: start;
  gap: 10px;
}

.solutions-overview-page .system .feature .feature-title {
  text-transform: capitalize;
  letter-spacing: 0;
}

.home-page .system .feature-media {
  min-height: clamp(320px, 24vw, 360px);
}

.solutions-overview-page .system .feature-media {
  min-height: clamp(320px, 24vw, 360px);
}

.home-page .system .feature-media::after {
  display: none;
}

.home-page .system .feature-media::before {
  display: none;
}

.solutions-overview-page .system .feature-media::after {
  display: none;
}

.solutions-overview-page .system .feature-media::before,
.overview-page .system .feature-media::before,
.overview-page .system .feature-media::after {
  display: none !important;
  content: none !important;
  background: none !important;
}

.system .feature .feature-title {
  text-transform: uppercase;
  letter-spacing: 0.05em;
  font-size: var(--site-subtitle-size) !important;
  line-height: var(--site-subtitle-line) !important;
  min-height: calc(2 * 1em * var(--site-subtitle-line));
  max-height: calc(2 * 1em * var(--site-subtitle-line));
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  position: relative;
  z-index: 1;
  white-space: normal;
}

.system .feature .feature-title .nowrap {
  white-space: normal;
}

.home-page .system .feature .feature-title,
.solutions-overview-page .system .feature .feature-title {
  width: 100%;
  text-align: left;
  justify-self: start;
  text-transform: capitalize;
  letter-spacing: 0;
  min-height: 0;
  max-height: none;
  display: block;
}

.system .feature .feature-text {
  min-height: 90px;
}

@media (hover: hover) and (pointer: fine) {
  .system .feature.is-media-hover .feature-media {
    transform: translateZ(0) scale(1.06);
  }

  .system .feature.is-media-hover {
    z-index: 1;
  }
}

.system .feature-media {
  transition: transform 220ms ease;
  transform: translateZ(0) scale(1);
  will-change: transform;
  transform-origin: center;
  position: relative;
  z-index: 0;
  box-shadow: 0 22px 56px -34px rgba(0, 0, 0, 0.28), 0 10px 24px -20px rgba(0, 0, 0, 0.2) !important;
}

.system .feature-media::before,
.system .feature-media::after {
  transition: opacity 220ms ease;
}

@media (hover: hover) and (pointer: fine) {
  .system .feature.is-media-hover .feature-media::before,
  .system .feature.is-media-hover .feature-media::after {
    opacity: 0 !important;
  }
}

.system-feature-image {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  object-position: center;
}

.system-feature-image--inhouse {
  object-position: 36% 50%;
}

.system-feature-image--data-ip {
  object-position: 34% 50%;
}

.system-feature-image--innovation {
  object-position: 38% 50%;
}

.home-page .system .feature-media,
.solutions-overview-page .system .feature-media {
  box-shadow: 0 28px 68px -38px rgba(0, 0, 0, 0.34), 0 12px 28px -20px rgba(0, 0, 0, 0.22) !important;
}

@keyframes system-ltr {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(-50%);
  }
}

.hero-title {
  margin: 0;
  font-family: var(--serif);
  font-weight: 700;
  letter-spacing: -0.02em;
  font-size: clamp(58px, 8.2vw, 132px);
  line-height: 0.92;
}

.hero-subtitle {
  margin: 0;
  font-size: clamp(16px, 2vw, 22px);
  color: var(--muted);
  letter-spacing: 0.02em;
}

/* Home hero: align subtitle start with the visual start of "Meet Max". */
.home-page .hero-subtitle {
  padding-left: clamp(8px, 0.55vw, 12px) !important;
}

.hero-subtitle-break {
  display: inline;
}

.full-bleed {
  width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-top: 0;
}

.overview-page .full-bleed {
  margin-bottom: clamp(44px, 7vw, 96px);
}

.overview-page .video-band {
  padding: 0;
  min-height: 100svh;
}

.overview-page .video-band .video-shell {
  width: 100%;
  min-height: 100svh;
}

.video-shell {
  position: relative;
  width: min(var(--container), calc(100% - (var(--page-gutter) * 2)));
  margin-inline: auto;
  border-radius: 0;
  overflow: hidden;
  background: #0d0d0d;
  min-height: 260px;
}

.video-shell::before {
  content: none;
}

.video-placeholder,
.video-embed {
  position: relative;
  z-index: 1;
  aspect-ratio: auto;
  min-height: 100%;
  height: 100%;
}

.video-placeholder {
  display: grid;
  place-items: center;
  background: radial-gradient(700px 240px at 40% 55%, rgba(255, 255, 255, 0.12), transparent 60%),
    linear-gradient(135deg, rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0.02));
}

.video-placeholder-inner {
  width: min(520px, calc(100% - (var(--page-gutter) * 2)));
  color: rgba(255, 255, 255, 0.92);
  text-align: center;
  display: grid;
  gap: 10px;
}

.video-label {
  margin: 0;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  opacity: 0.8;
}

.video-help {
  margin: 0;
  opacity: 0.82;
}

.video-embed iframe {
  width: 100%;
  height: 100%;
  border: 0;
  display: block;
}

.pillbar {
  position: absolute;
  left: 50%;
  bottom: 22px;
  transform: translateX(-50%);
  z-index: 3;
  display: inline-flex;
  gap: 12px;
  align-items: center;
  padding: 12px 16px;
  border-radius: 999px;
  background: rgba(0, 0, 0, 0.72);
  color: rgba(255, 255, 255, 0.92);
  backdrop-filter: blur(10px);
  border: 1px solid rgba(255, 255, 255, 0.14);
}

.pillbar--static {
  position: static;
  transform: none;
  margin: 6px auto 0;
  bottom: auto;
  left: auto;
  width: fit-content;
  max-width: 100%;
}

.pillbar--static .pillbar-text {
  white-space: normal;
  text-align: center;
}

.pillbar--static .pillbar-link {
  white-space: nowrap;
}

.pillbar-text {
  font-size: 14px;
  white-space: nowrap;
}

.pillbar-sep {
  opacity: 0.6;
}

.pillbar-link {
  font-size: 14px;
  font-weight: 600;
  color: #ffffff;
  padding: 6px 10px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.12);
}

.pillbar-link:hover,
.pillbar-link:focus-visible {
  outline: none;
  background: rgba(255, 255, 255, 0.18);
}

button,
.button,
.security-cta,
.security-architecture-marquee-cta,
.button {
  border: 1px solid rgba(255, 255, 255, 0.22);
  border-radius: var(--site-button-radius);
  background: transparent;
  color: inherit;
  cursor: pointer;
  justify-self: center;
  transition: border-color 180ms ease, background-color 180ms ease, transform 180ms ease, filter 180ms ease;
  will-change: transform;
}

.button,
.security-cta,
.security-architecture-marquee-cta {
  border-radius: var(--site-button-radius) !important;
}

.button-primary {
  border-color: transparent;
  background: #111111;
  color: #ffffff;
}

.button-invert {
  background: #ffffff;
  color: #111111;
  border-color: transparent;
}

.button:hover,
.button:focus-visible {
  outline: none;
  filter: brightness(0.98);
  transform: translateY(-1px);
}

.button:active {
  transform: translateY(0);
}

.security-cta:active,
.security-architecture-marquee-cta:active {
  transform: translateY(0);
}

.solutions-litigation-right .button {
  justify-self: start;
}

.site-footer {
  border-top: 1px solid var(--hairline);
  padding-block: 78px 42px;
  background: var(--bg);
}

.security-page .site-footer .button-primary {
  background: #ffffff;
  color: #111111;
  border-color: transparent;
}

.security-page .site-footer .button-primary:hover,
.security-page .site-footer .button-primary:focus-visible {
  background: #f2f2f2;
  color: #111111;
}

.footer-top {
  display: grid;
  grid-template-columns: 1fr;
  gap: 44px;
  align-items: start;
  padding-bottom: 38px;
  border-bottom: 1px solid var(--hairline);
}

.footer-brand {
  display: grid;
  gap: 22px;
}

.footer-brand-link {
  min-width: auto;
}

.site-footer .brand {
  gap: 0;
  min-width: auto;
}

.site-footer .brand-mark {
  display: none;
}

.site-footer .brand-name {
  font-size: 21px;
  font-weight: 700;
  letter-spacing: 0.01em;
  line-height: 1.1;
}

.footer-tagline {
  margin: 0;
  font-family: var(--serif);
  font-weight: 400;
  letter-spacing: -0.01em;
  color: color-mix(in srgb, var(--text) 85%, transparent);
  font-size: 20px;
}

.footer-cta {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-top: 28px;
}

.footer-nav {
  --footer-title-h: 12px;
  --footer-link-h: 24px;
  --footer-nav-gap-y: 10px;
  --footer-nav-gap-x: 16px;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--footer-nav-gap-y) var(--footer-nav-gap-x);
}

.footer-col {
  min-width: 0;
  flex: 1 1 0;
  display: grid;
  align-content: start;
  grid-template-rows: var(--footer-title-h);
  grid-auto-rows: var(--footer-link-h);
  gap: 0;
}

.footer-col-title {
  margin: 0;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  color: var(--muted);
  min-height: 12px;
  height: var(--footer-title-h);
  display: flex;
  align-items: flex-end;
}

.footer-link {
  display: block !important;
  padding: 0;
  color: color-mix(in srgb, var(--text) 78%, transparent);
  font-size: 12px;
  line-height: 1.2;
  width: 100%;
  height: var(--footer-link-h);
  display: flex !important;
  align-items: center;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.footer-link:hover,
.footer-link:focus-visible {
  color: var(--text);
  text-decoration: underline;
  text-underline-offset: 3px;
}

@media (min-width: 980px) {
  .site-footer .footer-nav {
    --footer-nav-gap-x: clamp(20px, 1.6vw, 30px);
    grid-template-columns: repeat(5, minmax(0, 1fr));
    column-gap: var(--footer-nav-gap-x);
  }

  .site-footer .footer-nav > .footer-col {
    justify-self: stretch;
  }

  .site-footer .footer-nav > .footer-col:nth-of-type(1) {
    justify-self: stretch;
  }

  .site-footer .footer-nav > .footer-col:nth-of-type(3) {
    grid-column: 3;
    grid-template-rows: var(--footer-title-h);
    grid-auto-rows: var(--footer-link-h);
    gap: 0;
  }

  .site-footer .footer-nav > .footer-col:nth-of-type(3) .footer-col-title {
    grid-column: auto;
  }

  .site-footer .footer-nav > .footer-col:nth-of-type(4) {
    grid-column: 4;
    justify-self: stretch;
  }
}

.footer-bottom {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding-top: 32px;
}

.footer-muted {
  margin: 0;
  color: var(--muted);
  font-size: 14px;
}

.footer-toplink {
  font-size: 14px;
  color: color-mix(in srgb, var(--text) 70%, transparent);
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid transparent;
}

.footer-toplink:hover,
.footer-toplink:focus-visible {
  color: var(--text);
  border-color: var(--hairline);
  background: #ffffff;
  outline: none;
}

.footer-toplink,
.footer-top-link {
  display: none !important;
}

.mobile-drawer {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.35);
  opacity: 0;
  pointer-events: none;
  transition: opacity 180ms ease;
  z-index: 60;
}

.mobile-drawer[data-open="true"] {
  opacity: 1;
  pointer-events: auto;
}

.mobile-drawer-inner {
  position: absolute;
  right: 12px;
  top: 12px;
  bottom: 12px;
  width: min(420px, calc(100% - 24px));
  background: #ffffff;
  border-radius: 18px;
  border: 1px solid var(--hairline);
  box-shadow: var(--shadow);
  transform: translateX(10px);
  transition: transform 220ms ease;
  padding: 16px;
  overflow: auto;
}

.mobile-drawer[data-open="true"] .mobile-drawer-inner {
  transform: translateX(0);
}

.mobile-drawer-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--hairline);
  margin-bottom: 10px;
}

.mobile-title {
  margin: 0;
  font-weight: 700;
}

.icon-btn {
  width: 40px;
  height: 40px;
  border-radius: 12px;
  border: 1px solid var(--hairline);
  background: #ffffff;
  cursor: pointer;
}

.mobile-list {
  margin: 0;
  padding: 0;
  display: grid;
  gap: 10px;
}

.mobile-item {
  border: 1px solid var(--hairline);
  border-radius: 14px;
  overflow: hidden;
}

.mobile-link,
.mobile-trigger {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  padding: 12px 14px;
  background: #ffffff;
  border: none;
  cursor: pointer;
}

.mobile-panel {
  display: grid;
  gap: 8px;
  padding: 12px 14px;
  background: color-mix(in srgb, #111111 4%, #ffffff);
}

.mobile-kicker {
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: color-mix(in srgb, #111111 65%, #ffffff);
  padding: 6px 2px 0;
}

.mobile-panel a {
  padding: 10px 12px;
  border-radius: 12px;
  background: #ffffff;
  border: 1px solid var(--hairline);
}

.mobile-panel a:hover,
.mobile-panel a:focus-visible {
  outline: none;
  background: color-mix(in srgb, #111111 6%, #ffffff);
}

@media (max-width: 979px) {
  html:has(.mobile-drawer[data-open="true"]),
  body:has(.mobile-drawer[data-open="true"]) {
    overflow-x: hidden;
  }

  .mobile-drawer {
    background: rgba(0, 0, 0, 0.5);
    backdrop-filter: blur(2px);
    -webkit-backdrop-filter: blur(2px);
    overflow-x: hidden;
    overscroll-behavior-x: none;
  }

  .mobile-drawer-inner {
    right: 0;
    top: 0;
    bottom: 0;
    width: 100%;
    border-radius: 0;
    border: 0;
    box-shadow: none;
    background: #ffffff;
    padding: 24px 22px 14px;
    transform: translateX(100%);
    display: flex;
    flex-direction: column;
    overflow: hidden;
    overflow-x: hidden;
    overscroll-behavior-x: none;
    touch-action: pan-y;
  }

  .mobile-drawer[data-open="true"] .mobile-drawer-inner {
    transform: translateX(0);
  }

  .mobile-drawer-top {
    padding-bottom: 18px;
    margin-bottom: 14px;
    border-bottom: 0;
  }

  .mobile-title {
    font-family: var(--serif);
    font-weight: 700;
    font-size: clamp(20px, 6.4vw, 28px);
    line-height: 0.98;
    letter-spacing: -0.015em;
    color: #111111;
  }

  .icon-btn {
    width: 44px;
    height: 44px;
    border: 0;
    border-radius: 10px;
    background: transparent;
    color: #111111;
    display: grid;
    place-items: center;
    font-size: 34px;
    line-height: 1;
  }

  .mobile-list {
    gap: 8px;
    list-style: none;
  }

  .mobile-nav {
    flex: 1 1 auto;
    min-height: 0;
    overflow: auto;
    overflow-x: hidden;
    padding-right: 2px;
    margin-right: -2px;
    overscroll-behavior-x: none;
  }

  .mobile-item {
    border: 0;
    border-radius: 0;
    overflow: visible;
  }

  .mobile-link,
  .mobile-trigger {
    padding: 8px 0;
    background: transparent;
    color: #111111;
    font-family: var(--serif);
    font-size: clamp(16px, 5.9vw, 24px);
    line-height: 1.1;
    letter-spacing: -0.015em;
  }

  .mobile-trigger .nav-plus {
    width: 16px;
    height: 16px;
    margin-left: 12px;
    border-right: 2px solid currentColor;
    border-bottom: 2px solid currentColor;
    transform: translateY(0) rotate(-45deg);
    opacity: 0.9;
    transition: transform 180ms ease;
  }

  .mobile-trigger[aria-expanded="true"] .nav-plus {
    transform: translateY(1px) rotate(45deg);
  }

  .mobile-panel {
    gap: 10px;
    padding: 4px 0 14px;
    background: transparent;
    overflow-x: hidden;
  }

  .mobile-panel[hidden] {
    display: none !important;
  }

  .mobile-kicker {
    padding: 14px 0 4px;
    color: rgba(17, 17, 17, 0.5);
  }

  .mobile-panel a {
    padding: 6px 0 8px;
    border: 0;
    border-radius: 0;
    background: transparent;
    color: rgba(17, 17, 17, 0.78);
    font-size: clamp(16px, 4.4vw, 21px);
    line-height: 1.3;
    display: grid;
    gap: 6px;
    align-content: start;
    text-decoration: none;
  }

  .mobile-panel a .mobile-subtitle {
    color: rgba(17, 17, 17, 0.96);
    font-size: clamp(12px, 4.3vw, 16px);
    line-height: 1.2;
    font-weight: 600;
    letter-spacing: -0.01em;
  }

  .mobile-panel a .mobile-subdesc {
    color: rgba(17, 17, 17, 0.6);
    font-size: clamp(11px, 3.7vw, 14px);
    line-height: 1.35;
    font-weight: 500;
    letter-spacing: -0.003em;
    text-wrap: pretty;
  }

  .mobile-panel a:hover,
  .mobile-panel a:focus-visible {
    background: transparent;
    color: #111111;
  }

  .mobile-drawer-footer {
    margin-top: 12px;
    padding-top: 14px;
    padding-bottom: calc(env(safe-area-inset-bottom, 0px) + 4px);
    border-top: 1px solid rgba(17, 17, 17, 0.14);
    display: grid;
    grid-template-columns: 1fr;
    gap: 10px;
  }

  .mobile-drawer-btn {
    min-height: 48px;
    border-radius: 10px;
    border: 1px solid rgba(17, 17, 17, 0.22);
    font-family: var(--sans);
    font-size: 18px;
    font-weight: 550;
    letter-spacing: -0.01em;
    display: grid;
    place-items: center;
    text-decoration: none;
    transition: opacity 160ms ease, background-color 160ms ease, color 160ms ease;
  }

  .mobile-drawer-btn--primary {
    background: #111111;
    color: #ffffff;
  }

  .mobile-drawer-btn--ghost {
    background: transparent;
    color: #111111;
  }

  .mobile-drawer-btn:hover,
  .mobile-drawer-btn:focus-visible {
    opacity: 0.9;
    outline: none;
  }
}

@media (min-width: 980px) {
  .site-header .header-inner {
    padding-block: 8px;
  }

  .site-header .brand {
    gap: 8px;
    min-width: 140px;
  }

  .site-header .brand-mark {
    width: 10px;
    height: 10px;
  }

  .site-header .brand-name {
    line-height: 1.1;
    font-size: 21px;
  }

  .site-header .header-actions {
    gap: 13px;
  }

  .site-header .nav-list {
    gap: 15px;
  }

  .site-header .nav-link {
    padding: 6px 4px;
    line-height: 1.15;
  }

  .site-header .nav-plus {
    width: 6px;
    height: 6px;
    margin-left: 4px;
    border-right-width: 1.1px;
    border-bottom-width: 1.1px;
  }

  .site-header .header-cta {
    padding: 8px 16px !important;
  }

  .nav {
    display: block;
  }

  .header-actions {
    display: flex;
  }

  .nav-toggle {
    display: none;
  }

  .mobile-drawer {
    display: none;
  }

  .hero {
    padding-top: 38px;
  }

  .features-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 34px 28px;
  }

		  .home-page .features .features-grid {
		    grid-template-columns: repeat(2, minmax(0, 1fr));
		    column-gap: 22px;
		  }

		  .features .feature-media {
		    min-height: 360px;
		  }

				  .home-page .features .feature-media {
				    min-height: clamp(340px, 40vh, 500px);
				  }

  .intro-inner {
    position: static;
    grid-template-columns: 1fr;
    grid-template-areas: none;
    gap: 38px;
    min-height: auto;
    place-items: start;
  }

  .ticker {
    position: relative;
    top: auto;
    left: auto;
    right: auto;
    margin-bottom: 36px;
  }

  .intro-copy {
    grid-area: auto;
    justify-items: center;
  }

		  .features-cta {
		    grid-template-columns: 1fr auto;
		    grid-template-rows: auto auto;
		    gap: 26px;
		    align-items: start;
		  }

  .home-page .features-cta {
    align-items: center;
  }

	  .features-cta-left {
	    display: grid;
	    grid-column: 1;
	    grid-row: 1 / span 2;
	    gap: var(--title-subtitle-gap);
	    justify-items: start;
	  }

	  .features-cta-title {
	    grid-column: 1;
	    grid-row: 1;
	    white-space: nowrap;
	  }

		  .features-cta-right {
		    grid-column: 2;
		    grid-row: 1;
		    justify-items: end;
		    align-content: start;
		    text-align: right;
		    align-self: start;
		  }

	  .features-cta-button {
	    justify-self: end;
	    margin-top: 0;
	  }

	  .features-cta-subtitle {
	    grid-column: 1;
	    grid-row: 2;
	  }

  .home-page .features-cta-left {
    grid-column: 2 !important;
    grid-row: 1 / span 2 !important;
    justify-items: end !important;
    text-align: right !important;
  }

  .home-page .features-cta-title {
    grid-column: 2 !important;
    grid-row: 1 !important;
    text-align: right !important;
  }

  .home-page .features-cta-subtitle {
    grid-column: 2 !important;
    grid-row: 2 !important;
    text-align: right !important;
  }

  .home-page .features-cta-right {
    grid-column: 1 !important;
    grid-row: 1 !important;
    justify-items: start !important;
    text-align: left !important;
  }

  .home-page .features-cta-button {
    justify-self: start !important;
  }

  .journey-inner {
    grid-template-columns: minmax(260px, 0.9fr) minmax(0, 1.4fr);
    gap: clamp(28px, 5vw, 64px);
    align-items: start;
  }

  .journey-left {
    position: sticky;
    top: 120px;
  }

		  .journey-right {
		    padding-bottom: 40px;
		  }

	  .home-page .journey-panel {
	    align-content: start;
	  }

	  .home-page .journey-panel:last-child {
	    padding-top: clamp(44px, 6vw, 76px);
	  }

	  .home-page .journey-panel:first-child {
	    padding-top: 0;
	  }

	  .why-max-page .journey-panel {
	    align-content: start;
	  }

	  .why-max-page .journey-panel:first-child {
	    padding-top: 0;
	  }

  .security-grid {
    grid-template-columns: repeat(1, minmax(0, 1fr));
  }

  .security-card {
    border-bottom: none;
  }

  .security-card:last-child {
    border-right: 1px solid color-mix(in srgb, #ffffff 18%, transparent);
  }

  .vision-inner {
    grid-template-columns: minmax(260px, 0.9fr) 2.1fr;
    grid-template-rows: auto auto;
    column-gap: 64px;
    row-gap: 0;
    align-items: start;
  }

  .vision-left {
    grid-column: 1;
    grid-row: 1;
    display: grid;
    gap: 18px;
    align-content: start;
  }

  .home-page .vision-inner {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    grid-template-rows: auto auto auto;
    column-gap: 64px;
    row-gap: clamp(24px, 2.6vw, 40px);
    align-items: start;
    min-height: auto;
    align-content: start;
  }

  .home-page .vision-left {
    grid-column: 1 / -1;
    grid-row: 1;
    display: grid;
    gap: var(--title-subtitle-gap);
    align-content: start;
    justify-items: center;
    text-align: center;
  }

  .home-page .vision-title {
    grid-column: auto;
    grid-row: 1;
    justify-self: center;
  }

  .home-page .vision-subtitle {
    grid-column: 1;
    grid-row: 2;
  }

  .home-page .vision-blocks {
    grid-column: 2;
	    grid-row: 2;
    width: 100%;
    max-width: 700px;
    justify-self: center;
    align-self: start;
    height: auto;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    grid-template-rows: auto auto auto;
    gap: 24px 36px;
    align-items: start;
    align-content: start;
    margin-top: clamp(10px, 1.2vw, 18px);
  }

  .home-page .vision-wide {
    grid-column: 1;
    grid-row: 2;
    align-self: start;
    justify-self: stretch;
    min-width: 0;
    margin-top: clamp(10px, 1.2vw, 18px);
  }

  .home-page .vision-quotes {
    grid-column: 1 / -1;
    grid-row: 3;
    margin-top: clamp(20px, 3vw, 42px);
    transform: none;
  }

	  .vision-figure {
	    grid-column: 1;
	    grid-row: 2;
	    align-self: start;
	  }

  .vision-portrait {
    height: var(--vision-portrait-h, auto);
    width: auto;
  }

  .vision-right {
    display: contents;
  }

  .vision-wide {
    grid-column: 2;
    grid-row: 1;
    margin-top: 0;
    align-self: end;
  }

  .vision-title {
    margin-bottom: 0;
  }

  .vision-copy {
    grid-column: 2;
    grid-row: 2;
    align-self: end;
  }

  .security-hero-inner {
    grid-template-columns: minmax(320px, 0.9fr) minmax(0, 1.3fr);
    gap: clamp(32px, 6vw, 72px);
    align-items: start;
  }

  .security-standards-grid {
    grid-template-columns: repeat(1, minmax(0, 1fr));
  }

  .security-standards-bottom {
    grid-template-columns: 1fr;
    gap: 32px;
  }

  .security-standards-content {
    grid-template-columns: minmax(260px, 0.65fr) minmax(0, 1.35fr);
    gap: 48px;
  }

  .security-pillars-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .security-architecture-flow {
    flex-wrap: nowrap;
  }

  .security-architecture-inner {
    grid-template-columns: 1fr;
  }

		  .system-head {
		    grid-template-columns: 1fr auto;
		    grid-template-areas:
		      "title button"
		      "kicker .";
		    align-items: baseline;
		    column-gap: 26px;
		    row-gap: var(--title-subtitle-gap);
		  }

  .system-head-left {
    display: contents;
  }

  .system-title {
    grid-area: title;
  }

			  .system-head-right {
			    grid-area: button;
			    justify-items: end;
			    align-content: start;
			    text-align: right;
			    align-self: baseline;
			  }

  .system-button {
    justify-self: end;
    margin-top: 0;
  }

  .system-kicker {
    grid-area: kicker;
  }

  .home-page .system-head {
    grid-template-columns: auto 1fr;
    grid-template-areas:
      "button title"
      ". kicker";
  }

  .home-page .system-head-right {
    grid-area: button;
    justify-items: start;
    text-align: left;
  }

  .home-page .system-button {
    justify-self: start;
  }

  .home-page .system-title,
  .home-page .system-kicker {
    justify-self: end;
    text-align: right;
  }

	  .system-track {
	    gap: 0;
	  }

	  .system-row {
	    gap: var(--system-carousel-gap);
	    padding-right: var(--system-carousel-gap);
	  }

  .footer-top {
    grid-template-columns: minmax(180px, 0.8fr) minmax(0, 2.2fr);
    gap: 44px;
  }

  .footer-nav {
    grid-template-columns: repeat(5, minmax(0, 1fr));
    --footer-nav-gap-y: 10px;
    --footer-nav-gap-x: 16px;
  }

  .footer-col {
    min-width: 0;
  }
}

@media (min-width: 1200px) {
  .features-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 34px 22px;
  }

  .home-page .features .features-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
    column-gap: clamp(22px, 3vw, 34px);
  }

  .home-page .features .feature-media {
    min-height: 340px;
  }

  .features-grid .feature {
    grid-template-rows: auto 2.4em 1.35em 1fr;
    align-content: start;
  }

  .features-grid .feature-kicker {
    min-height: 2.4em;
    line-height: 1.2;
    display: flex;
    align-items: flex-end;
  }

  .features-grid .feature-title {
    line-height: 1.2;
    display: flex;
    align-items: flex-start;
  }

	  .system-track {
	    gap: 0;
	  }

	  .system-row {
	    gap: var(--system-carousel-gap);
	    padding-right: var(--system-carousel-gap);
	  }
}

@media (max-width: 979px) {
  html,
  body {
    width: 100%;
    max-width: 100%;
    overflow-x: hidden;
    overscroll-behavior-x: none;
  }

  body > .site-header,
  body > main,
  body > .site-footer {
    max-width: 100%;
    overflow-x: clip;
  }

  /* Mobile: remove side fade on scrolling system cards to maximize visibility. */
  .system-carousel,
  .home-page .system-carousel {
    -webkit-mask-image: none !important;
    mask-image: none !important;
  }

  .home-page .system-carousel,
  .solutions-overview-page .system-carousel {
    --system-carousel-duration: 44s;
    overflow-x: auto;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
    overscroll-behavior-x: contain;
    touch-action: pan-x;
  }

  .home-page .system-carousel.is-mobile-drag-carousel .system-track,
  .solutions-overview-page .system-carousel.is-mobile-drag-carousel .system-track {
    animation: none !important;
  }

  .home-page .system-carousel::-webkit-scrollbar,
  .solutions-overview-page .system-carousel::-webkit-scrollbar {
    display: none;
  }

  .site-header.is-hidden-near-footer {
    transform: translateY(-110%);
    opacity: 0;
    pointer-events: none;
  }

  .mega-wrap,
  .mega-layer,
  .mega {
    display: none;
  }

  .home-page .features {
    min-height: auto;
    padding-block: 24px 56px;
  }

  .home-page .features .features-grid {
    grid-template-columns: 1fr;
    gap: 30px;
  }

  .home-page .features .feature {
    gap: 12px;
  }

  .home-page .features .feature-media {
    aspect-ratio: 16 / 10;
    min-height: 0;
  }

  .home-page .features .feature-title {
    font-size: clamp(34px, 8.4vw, 48px);
    line-height: 0.96;
    letter-spacing: -0.03em;
  }

  .home-page .features .feature-text {
    font-size: clamp(19px, 4.4vw, 27px);
    line-height: 1.46;
  }

  .home-page .features .feature-media--reasoning .home-feature-video,
  .home-page .features .feature-media--drafting .home-feature-video,
  .home-page .features .feature-media--review .home-feature-video,
  .home-page .features .feature-media--knowledge .home-feature-video {
    width: 100% !important;
    height: 100% !important;
    aspect-ratio: auto !important;
    object-fit: cover !important;
  }

  .home-page .features .home-feature-video--reasoning-center,
  .home-page .features .home-feature-video--drafting-crop,
  .home-page .features .home-feature-video--review-crop,
  .home-page .features .home-feature-video--knowledge-crop {
    transform: none !important;
    -webkit-clip-path: none !important;
    clip-path: none !important;
  }

  .why-max-overview-page .whymax-magnet-line {
    transform-origin: left center;
    transform: none !important;
  }

  .why-max-overview-page .whymax-magnet-line:nth-child(1) {
    animation: whymax-magnet-master-mobile 4.6s ease-in-out infinite;
  }

  .why-max-overview-page .whymax-magnet-line:nth-child(2) {
    animation: whymax-magnet-follow-1-mobile 4.6s ease-in-out infinite;
  }

  .why-max-overview-page .whymax-magnet-line:nth-child(3) {
    animation: whymax-magnet-follow-2-mobile 4.6s ease-in-out infinite;
  }

  .why-max-overview-page .whymax-magnet-line:nth-child(4) {
    animation: whymax-magnet-follow-3-mobile 4.6s ease-in-out infinite;
  }

  .why-max-overview-page .whymax-magnet-line:nth-child(5) {
    animation: whymax-magnet-follow-4-mobile 4.6s ease-in-out infinite;
  }

  .why-max-overview-page .whymax-magnet-line:nth-child(6) {
    animation: whymax-magnet-follow-5-mobile 4.6s ease-in-out infinite;
  }

  .pillbar {
    width: calc(100% - 32px);
    justify-content: center;
    flex-wrap: wrap;
  }

  .pillbar-text {
    text-align: center;
    white-space: normal;
  }

  .pillbar--static {
    width: calc(100% - 12px);
  }

  .home-page .journey-inner {
    grid-template-columns: 1fr;
    gap: 22px;
  }

  .home-page .journey-left {
    position: static;
    top: auto;
  }

  .home-page .journey-list {
    display: none;
  }

  .home-page .journey-right {
    display: flex;
    gap: 14px;
    overflow-x: auto;
    overflow-y: hidden;
    padding-bottom: 10px;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: thin;
  }

  .home-page .journey-panel {
    flex: 0 0 min(86vw, 420px);
    min-height: 0;
    padding: 18px;
    border: 1px solid var(--hairline);
    border-radius: 18px;
    scroll-snap-align: start;
    gap: 12px;
    align-content: start;
  }

  .home-page .journey-panel:first-child {
    border-top: 1px solid var(--hairline);
  }

  .home-page .journey-panel-media {
    aspect-ratio: 16 / 10;
  }

  .home-page .vision {
    padding-block: 28px 44px;
  }

  .home-page .vision-inner {
    grid-template-columns: 1fr !important;
    grid-template-rows: auto;
    row-gap: 18px;
  }

  .home-page .vision-left,
  .home-page .vision-wide,
  .home-page .vision-blocks,
  .home-page .vision-quotes {
    grid-column: 1 !important;
    grid-row: auto !important;
  }

  .home-page .vision-title {
    white-space: normal;
    text-wrap: balance;
    font-size: clamp(32px, 9vw, 46px);
    line-height: 1.02;
  }

  .home-page .vision-wide {
    aspect-ratio: 16 / 9;
    min-height: 0;
  }

  .home-page .vision-blocks {
    display: grid;
    grid-template-columns: 1fr;
    gap: 14px;
    margin-top: 0;
  }

  .home-page .vision-blocks .vision-paragraph {
    font-size: clamp(16px, 4vw, 19px);
    line-height: 1.5;
  }

  .home-page .vision-quotes {
    margin-top: 4px;
    min-height: 120px;
    padding-bottom: 2px;
  }

  .home-page .vision-quote {
    font-size: clamp(16px, 4.2vw, 20px);
    line-height: 1.32;
    max-width: 100%;
  }

  .overview-page .overview-capabilities-grid {
    display: flex;
    gap: 14px;
    overflow-x: auto;
    overflow-y: hidden;
    padding-bottom: 8px;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: thin;
  }

  .overview-page .overview-capability {
    flex: 0 0 min(84vw, 380px);
    scroll-snap-align: start;
  }

  .overview-page .overview-icon {
    transform: scale(0.72);
    margin-top: calc(34px + 1cm);
    padding-bottom: 18px;
  }

  .overview-page .system-brings-card-overlay--with-foot .overview-icon {
    margin-top: 0 !important;
    justify-self: center !important;
    align-self: start !important;
    justify-items: center !important;
    width: auto !important;
    margin-left: auto !important;
    margin-right: auto !important;
    padding-left: 0 !important;
    transform-origin: center top !important;
    transform: translateY(1.5cm) scale(0.72) !important;
  }

  .overview-page .system-brings-card-overlay--with-foot .overview-icon--bullet-growth {
    transform: translateY(1cm) scale(0.72) !important;
  }

  .overview-page .system-brings-card-overlay--with-foot .overview-icon--features-ring {
    transform: translateY(2cm) scale(0.72) !important;
  }

  .overview-page .system-brings-card-overlay--with-foot .overview-icon--ms-orbit {
    margin-left: 0 !important;
    padding-left: 0 !important;
    transform: translateY(1.5cm) scale(0.72) !important;
  }

  .overview-page .system-brings-card-overlay--with-foot .overview-icon--ms-orbit .overview-icon-ms-orbit {
    --overview-ms-orbit-shift: 0px !important;
    transform: translateX(0) !important;
  }

  .overview-page .overview-icon-features-ring,
  .overview-page .overview-icon-ms-orbit,
  .overview-page .overview-icon-bullet-growth {
    margin-inline: auto !important;
    justify-self: center !important;
    margin-left: auto !important;
    margin-right: auto !important;
    transform-origin: center top !important;
  }

  .overview-page .system-brings-card-overlay--with-foot {
    gap: 18px;
    padding-bottom: 22px;
  }

  .overview-page .system-brings-card-body {
    padding-bottom: 10px;
  }

  .overview-page .overview-icon-features-ring {
    width: 182px;
    height: 112px;
    transform: none;
  }

  .overview-page .overview-icon-pill {
    font-size: 12px;
    padding: 6px 10px;
  }

  .overview-page .overview-icon-features-ring.is-fade-sequence {
    transform: none !important;
  }

  .overview-page .overview-icon-features-ring.is-fade-sequence .overview-icon-pill {
    padding: 0 !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    font-size: clamp(20px, 6.2vw, 30px) !important;
    font-weight: 600 !important;
    letter-spacing: -0.01em !important;
    opacity: 0;
    left: 0 !important;
    top: 0 !important;
    text-align: left !important;
    transform: none !important;
    animation: overview-pill-fade-sequence 12s ease-in-out infinite;
    animation-delay: calc(var(--overview-pill-index, 0) * 3s);
  }

  .overview-page .overview-icon-ms-orbit {
    width: 250px;
    height: 96px;
    transform: none;
  }

  .overview-page .overview-icon-ms-badge {
    width: 54px;
    height: 54px;
    margin: -27px 0 0 -27px;
    font-size: 30px;
    border-radius: 14px;
  }

  .solutions-overview-page .system-brings-card-overlay--with-foot {
    gap: 16px;
    padding-bottom: 20px;
  }

  .solutions-overview-page .system-brings-card-body {
    padding-bottom: 6px;
  }

  .solutions-overview-page .system-brings-card-overlay--with-foot .solutions-overview-icon {
    margin-top: auto !important;
    justify-self: center !important;
    align-self: end !important;
    justify-items: center !important;
    width: auto !important;
    margin-left: auto !important;
    margin-right: auto !important;
    padding-left: 0 !important;
    margin-bottom: 0 !important;
    transform-origin: center top !important;
  }

  .solutions-overview-page .system-brings-card-overlay--with-foot .solutions-overview-icon--compass {
    width: 280px !important;
    height: 120px !important;
    transform: translate(0, 0.5cm) scale(0.72) !important;
  }

  .solutions-overview-page .system-brings-card-overlay--with-foot .solutions-overview-icon--context {
    width: 280px !important;
    height: 120px !important;
    transform: translate(0, 0.5cm) scale(0.72) !important;
  }

  .solutions-overview-page .system-brings-card-overlay--with-foot .solutions-overview-icon--adoption {
    width: 280px !important;
    height: 120px !important;
    transform: translate(0, 0.5cm) scale(0.72) !important;
  }

  .why-max-overview-page .system-brings-card-overlay--with-foot {
    gap: 16px;
    padding-bottom: 20px;
  }

  .why-max-overview-page .system-brings-card-body {
    padding-bottom: 6px;
  }

  .why-max-overview-page .system-brings-card-overlay--with-foot .whymax-icon {
    --whymax-icon-shift-y: 0px !important;
    margin-top: auto !important;
    justify-self: center !important;
    align-self: end !important;
    justify-items: center !important;
    width: auto !important;
    margin-left: auto !important;
    margin-right: auto !important;
    padding-left: 0 !important;
    transform-origin: center top !important;
    transform: none !important;
    overflow: visible !important;
  }

  .why-max-overview-page .system-brings-card-overlay--with-foot .whymax-icon--puzzle {
    width: 220px !important;
    height: 132px !important;
    transform: translateY(1cm) scale(0.5) !important;
    transform-origin: center top !important;
  }

  .why-max-overview-page .system-brings-card-overlay--with-foot .whymax-icon--magnet {
    width: 230px !important;
    height: 132px !important;
    transform: translateY(1cm) scale(0.5) !important;
    transform-origin: center top !important;
  }

  .why-max-overview-page .system-brings-card-overlay--with-foot .whymax-icon--network {
    width: 280px !important;
    height: 140px !important;
    min-width: 280px !important;
    min-height: 140px !important;
    transform: translateY(1cm) scale(0.62) !important;
    transform-origin: center top !important;
    overflow: visible !important;
  }

  /* Mobile precise centering for the two cards flagged by QA:
     - Overview > Embedded in Existing Workflows
     - Why Max > Aligned with Firm Structures */
  .overview-page .system-brings-grid > .system-brings-card:nth-child(2) .overview-icon--ms-orbit {
    width: 100% !important;
    justify-self: center !important;
    justify-items: center !important;
    margin-left: auto !important;
    margin-right: auto !important;
    transform: translate(16px, 1.5cm) scale(0.72) !important;
  }

  .overview-page .system-brings-grid > .system-brings-card:nth-child(2) .overview-icon--ms-orbit .overview-icon-ms-orbit {
    --overview-ms-orbit-shift: 0px !important;
    transform: translateX(0) !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }

  .why-max-overview-page .system-brings-grid > .system-brings-card:nth-child(3) .whymax-icon--network {
    width: 100% !important;
    min-width: 0 !important;
    display: grid !important;
    place-items: center !important;
    transform: translate(-0.5cm, 1cm) scale(0.62) !important;
  }

  .why-max-overview-page .system-brings-grid > .system-brings-card:nth-child(3) .whymax-icon--network .whymax-network-scene {
    margin-left: auto !important;
    margin-right: auto !important;
  }

  .why-max-overview-page .system-brings-card-overlay--with-foot .whymax-icon--network .whymax-network-scene {
    width: 100% !important;
    height: 100% !important;
  }

  .site-footer .footer-nav > .footer-col:nth-of-type(3),
  .site-footer .footer-nav > .footer-col:nth-of-type(4) {
    margin-top: 1cm;
  }
}

@media (max-width: 620px) {
  .home-page .features .feature-media {
    aspect-ratio: 4 / 3;
  }
}

@media (max-width: 900px) {
  .system-brings-subtitle {
    white-space: normal;
  }

  .security-architecture-arrow {
    display: none;
  }
}

.faq-main {
  background: var(--bg);
  color: var(--text);
  padding-block: clamp(34px, 5vw, 72px) clamp(72px, 10vw, 140px);
}

.faq-layout {
  display: grid;
  gap: clamp(28px, 4vw, 52px);
}

.faq-section {
  display: grid;
  gap: clamp(14px, 2vw, 22px);
}

.faq-section-title {
  margin: 0;
  font-family: var(--serif);
  font-weight: 700;
  font-size: var(--site-heading-size);
  line-height: var(--site-heading-line);
  letter-spacing: -0.02em;
}

.faq-item {
  position: relative;
  display: grid;
  gap: 0;
  padding: clamp(24px, 3.2vw, 42px);
  border: 1px solid color-mix(in srgb, var(--text) 40%, transparent);
  background: color-mix(in srgb, var(--bg) 96%, #ffffff 4%);
  cursor: pointer;
}

.faq-toggle {
  width: 100%;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: start;
  gap: 18px;
  margin: 0;
  padding: 0;
  border: 0;
  background: transparent;
  color: inherit;
  text-align: left;
  cursor: pointer;
}

.faq-chevron {
  width: 16px;
  height: 16px;
  margin-top: clamp(8px, 1vw, 12px);
  border-top: 2px solid color-mix(in srgb, var(--text) 72%, transparent);
  border-right: 2px solid color-mix(in srgb, var(--text) 72%, transparent);
  transform: rotate(135deg);
  transition: transform 180ms ease;
}

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

.faq-question {
  margin: 0;
  font-family: var(--sans);
  font-weight: 600;
  font-size: clamp(18px, 1.28vw, 24px);
  line-height: 1.22;
  letter-spacing: -0.015em;
  padding-right: 0;
}

.faq-content {
  display: grid;
  gap: clamp(20px, 2.8vw, 34px);
  margin-top: clamp(18px, 2.2vw, 30px);
}

.faq-content[hidden] {
  display: none;
}

.faq-answer {
  margin: 0;
  max-width: none;
  font-size: var(--body-copy-size);
  line-height: var(--body-copy-line);
  letter-spacing: 0;
  color: color-mix(in srgb, var(--text) 86%, transparent);
}

.faq-list {
  margin: 2px 0 0;
  padding-left: 30px;
  display: grid;
  gap: 12px;
  color: color-mix(in srgb, var(--text) 86%, transparent);
  font-size: var(--body-copy-size);
  line-height: var(--body-copy-line);
  letter-spacing: 0;
}

@media (max-width: 980px) {
  .faq-main {
    padding-block: clamp(30px, 6vw, 52px) clamp(52px, 10vw, 88px);
  }

  .faq-item {
    padding: clamp(18px, 4vw, 24px);
    gap: clamp(14px, 2.8vw, 22px);
  }

  .faq-question {
    font-size: clamp(17px, 4vw, 22px);
  }

  .faq-answer {
    font-size: clamp(16px, 3vw, 18px);
    line-height: 1.55;
  }

  .faq-list {
    font-size: clamp(16px, 3vw, 18px);
    padding-left: 24px;
  }
}

.faq-page .site-header {
  background: var(--bg);
}

.faq-page .faq-main {
  background: #050505;
  color: #ffffff;
}

.faq-page .faq-section-title,
.faq-page .faq-question {
  color: #ffffff;
}

.faq-page .faq-item {
  background: #050505;
  border-color: rgba(255, 255, 255, 0.38);
}

.faq-page .faq-chevron {
  border-top-color: rgba(255, 255, 255, 0.88);
  border-right-color: rgba(255, 255, 255, 0.88);
}

.faq-page .faq-answer,
.faq-page .faq-list {
  color: color-mix(in srgb, #ffffff 84%, transparent);
}

/* Global frame shadow consistency across the site */
:root {
  --global-frame-shadow: 0 34px 86px -38px rgba(0, 0, 0, 0.38), 0 14px 34px -22px rgba(0, 0, 0, 0.24);
}

.feature-media,
.overview-capability-frame,
.journey-panel-media,
.system-context-media,
.system-scale-media,
.system-brings-card,
.system-hero-media,
.system-hero-image,
.solutions-spotlight-frame,
.solutions-usage-visual,
.solutions-stack-card,
.mega-media-block,
.video-shell {
  box-shadow: var(--global-frame-shadow) !important;
}

/* Home features: remove frame shadows behind the 4 system videos/cards */
.home-page .features .feature-media {
  box-shadow: none !important;
}

/* Transactional intro hero-video: remove top gap under section 1 */
.transactional-page .solutions-intro.solutions-intro--video-overlay {
  padding-top: 0 !important;
  padding-bottom: 0 !important;
  margin-top: 0 !important;
  min-height: 0 !important;
  display: block !important;
}

/* All Solutions detail pages: full-width intro video + left overlay copy + no gap below */
.solutions-page:not(.solutions-overview-page) .solutions-intro {
  padding-top: 0 !important;
  padding-bottom: 0 !important;
  margin-top: 0 !important;
  min-height: 0 !important;
  display: block !important;
  background: transparent !important;
}

.solutions-page:not(.solutions-overview-page) .solutions-intro .solutions-intro-inner {
  max-width: none !important;
  width: 100vw !important;
  margin-left: calc(50% - 50vw) !important;
  margin-right: calc(50% - 50vw) !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
}

.solutions-page:not(.solutions-overview-page) .solutions-intro .solutions-intro-top {
  display: block !important;
  position: relative !important;
  margin: 0 !important;
  padding: 0 !important;
}

.solutions-page:not(.solutions-overview-page) .solutions-intro .solutions-spotlight-media {
  width: 100% !important;
  margin: 0 !important;
}

.solutions-page:not(.solutions-overview-page) .solutions-intro .solutions-spotlight-frame {
  position: relative !important;
  width: 100% !important;
  min-height: clamp(360px, 48vw, 680px) !important;
  padding: 0 !important;
  border-radius: 0 !important;
  overflow: hidden !important;
  border: 0 !important;
  outline: 0 !important;
  box-shadow: none !important;
}

.solutions-page:not(.solutions-overview-page) .solutions-intro .solutions-spotlight-frame::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(
    90deg,
    rgba(8, 10, 14, 0.82) 0%,
    rgba(8, 10, 14, 0.66) 18%,
    rgba(8, 10, 14, 0.42) 34%,
    rgba(8, 10, 14, 0.18) 48%,
    rgba(8, 10, 14, 0) 58%,
    rgba(8, 10, 14, 0) 100%
  );
  pointer-events: none;
}

.solutions-page:not(.solutions-overview-page) .solutions-intro .solutions-spotlight-video {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  display: block !important;
  margin-bottom: -1px !important;
}

.solutions-page:not(.solutions-overview-page) .solutions-intro .solutions-intro-copy {
  position: absolute !important;
  left: clamp(24px, 6vw, 88px) !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  z-index: 2 !important;
  max-width: min(560px, 46vw) !important;
  color: #ffffff !important;
  gap: 16px !important;
}

.solutions-page:not(.solutions-overview-page) .solutions-intro .solutions-hero-subtitle {
  color: #ffffff !important;
  max-width: 16ch !important;
  text-wrap: balance;
}

.solutions-page:not(.solutions-overview-page) .solutions-intro .solutions-hero-text {
  color: rgba(255, 255, 255, 0.9) !important;
  max-width: 48ch !important;
  text-wrap: balance;
}

@media (min-width: 981px) {
  .solutions-page:not(.solutions-overview-page) .solutions-intro .solutions-hero-subtitle,
  .solutions-page:not(.solutions-overview-page) .solutions-intro .solutions-hero-text {
    max-width: none !important;
    white-space: nowrap !important;
  }
}

.innovation-page .solutions-intro .solutions-hero-text {
  max-width: 36ch !important;
}

.inhouse-page .solutions-intro .solutions-hero-text {
  max-width: 36ch !important;
}

.litigation-page .solutions-intro .solutions-hero-text {
  max-width: 40ch !important;
}

@media (max-width: 960px) {
  .solutions-page .site-footer .footer-cta {
    display: none !important;
  }

  .solutions-page:not(.solutions-overview-page) .solutions-usage-top {
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 14px !important;
  }

  .solutions-page:not(.solutions-overview-page) .solutions-usage-title {
    font-size: clamp(44px, 11vw, 58px) !important;
    line-height: 0.98 !important;
    letter-spacing: -0.025em !important;
    max-width: 100% !important;
  }

  .solutions-page:not(.solutions-overview-page) .solutions-usage-tags {
    width: 100% !important;
    max-width: 100% !important;
    justify-content: flex-start !important;
    overflow-x: auto !important;
    overflow-y: hidden !important;
    -webkit-overflow-scrolling: touch !important;
    padding-right: 0 !important;
    padding-bottom: 8px !important;
    margin-top: 0 !important;
    gap: 8px !important;
    white-space: nowrap !important;
  }

  .solutions-page:not(.solutions-overview-page) .solutions-usage-tag {
    font-size: 12px !important;
    padding: 7px 11px !important;
  }

  .solutions-page:not(.solutions-overview-page) .solutions-usage-body {
    grid-template-columns: 1fr !important;
    gap: 16px !important;
    margin-top: 18px !important;
  }

  .solutions-page:not(.solutions-overview-page) .solutions-usage-visual {
    min-height: clamp(220px, 56vw, 340px) !important;
    border: none !important;
    box-shadow: none !important;
    border-radius: 0 !important;
    background: transparent !important;
  }

  .solutions-page:not(.solutions-overview-page) .solutions-usage-visual-doc {
    object-fit: cover !important;
    object-position: center !important;
    background: transparent !important;
  }

  .solutions-page:not(.solutions-overview-page) .solutions-usage-panel {
    min-height: 0 !important;
    height: auto !important;
    align-self: stretch !important;
    align-content: start !important;
    justify-content: start !important;
    padding: 0 !important;
  }

  .solutions-page:not(.solutions-overview-page) .solutions-hero-title {
    font-size: clamp(22px, 6.6vw, 30px) !important;
    line-height: 1.02 !important;
    letter-spacing: -0.02em !important;
  }

  .solutions-page:not(.solutions-overview-page) .solutions-intro .solutions-hero-subtitle {
    font-size: clamp(13px, 4.2vw, 18px) !important;
    line-height: 1.08 !important;
  }

  .solutions-page:not(.solutions-overview-page) .solutions-intro .solutions-hero-text {
    font-size: clamp(11px, 3.8vw, 15px) !important;
    line-height: 1.38 !important;
  }

  .solutions-page:not(.solutions-overview-page) .solutions-intro .solutions-intro-inner {
    width: 100% !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
  }

  .solutions-page:not(.solutions-overview-page) .solutions-intro .solutions-spotlight-frame {
    border-radius: var(--media-radius-lg) !important;
    min-height: clamp(240px, 68vw, 420px) !important;
    border: none !important;
    box-shadow: none !important;
    background: transparent !important;
  }

  .solutions-page:not(.solutions-overview-page) .solutions-intro .solutions-intro-copy {
    left: 22px !important;
    right: 22px !important;
    max-width: none !important;
    top: auto !important;
    bottom: 26px !important;
    transform: none !important;
  }

  .solutions-page:not(.solutions-overview-page) .solutions-intro .solutions-spotlight-frame::after {
    background: linear-gradient(
      90deg,
      rgba(8, 10, 14, 0.7) 0%,
      rgba(8, 10, 14, 0.5) 28%,
      rgba(8, 10, 14, 0.22) 48%,
      rgba(8, 10, 14, 0) 62%,
      rgba(8, 10, 14, 0) 100%
    );
  }

  .solutions-intro-fullscreen-btn {
    position: absolute;
    right: 10px;
    bottom: 10px;
    width: 36px;
    height: 36px;
    border: 1px solid rgba(255, 255, 255, 0.98);
    border-radius: 10px;
    background: linear-gradient(180deg, rgba(182, 182, 182, 0.72), rgba(158, 158, 158, 0.66));
    color: rgba(255, 255, 255, 1);
    display: grid;
    place-items: center;
    padding: 0;
    z-index: 6;
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
    cursor: pointer;
  }

  .solutions-intro-fullscreen-btn svg {
    width: 17px;
    height: 17px;
    display: block;
    filter: drop-shadow(0 0 1.1px rgba(255, 255, 255, 1));
  }
}

/* Square corners for all main frames/cards */
.feature-media,
.overview-capability-frame,
.journey-panel-media,
.system-context-media,
.system-scale-media,
.system-brings-card,
.system-brings-card-media,
.system-brings-card-photo,
.system-hero-media,
.system-hero-image,
.solutions-spotlight-frame,
.solutions-usage-visual,
.solutions-usage-panel,
.solutions-stack-card,
.mega-media-block,
.video-shell,
.journey-panel,
.overview-capability,
.feature {
  border-radius: 0 !important;
}

/* Compact frames on System pages: keep only the space needed by content */
:is(.reasoning-page, .drafting-system-page, .review-page, .knowledge-page) .system-hero-media {
  min-height: clamp(220px, 24vw, 320px) !important;
}

:is(.reasoning-page, .drafting-system-page, .review-page, .knowledge-page) .system-brings-grid {
  align-items: stretch !important;
  grid-auto-rows: 1fr !important;
}

:is(.reasoning-page, .drafting-system-page, .review-page, .knowledge-page) .system-brings-card,
:is(.reasoning-page, .drafting-system-page, .review-page, .knowledge-page) .system-brings-card--stacked,
:is(.reasoning-page, .drafting-system-page, .review-page, .knowledge-page) .system-brings-card--handle-matters {
  min-height: clamp(180px, 14vw, 220px) !important;
  height: clamp(180px, 14vw, 220px) !important;
  overflow: hidden !important;
  background: color-mix(in srgb, var(--bg) 97%, #000000 3%) !important;
  border: 1px solid color-mix(in srgb, var(--bg) 90%, #000000 10%) !important;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.36),
    0 16px 36px -24px rgba(0, 0, 0, 0.22) !important;
}

:is(.reasoning-page, .drafting-system-page, .review-page, .knowledge-page) .system-brings-card-media {
  display: none !important;
}

:is(.reasoning-page, .drafting-system-page, .review-page, .knowledge-page) .system-brings-card-overlay {
  position: relative !important;
  inset: auto !important;
  min-height: 100% !important;
  display: grid !important;
  grid-template-rows: auto 1fr !important;
  align-content: start !important;
  padding: clamp(12px, 1.2vw, 16px) !important;
  padding-top: clamp(12px, 1.2vw, 16px) !important;
  background: transparent !important;
}

:is(.reasoning-page, .drafting-system-page, .review-page, .knowledge-page)
  .system-brings-card-overlay:not(.system-brings-card-overlay--with-foot)
  .system-brings-card-body {
  min-height: 0 !important;
}

:is(.reasoning-page, .drafting-system-page, .review-page, .knowledge-page) .system-brings-card-title {
  min-height: 0 !important;
  height: auto !important;
  display: block !important;
  -webkit-line-clamp: initial !important;
  white-space: normal !important;
  overflow-wrap: anywhere !important;
  word-break: normal !important;
  hyphens: none;
  font-size: clamp(18px, 1.4vw, 20px) !important;
  line-height: 1.25 !important;
}

:is(.reasoning-page, .drafting-system-page, .review-page, .knowledge-page) .system-brings-card-foot {
  min-height: 0 !important;
}

:is(.reasoning-page, .drafting-system-page, .review-page, .knowledge-page) .system-brings-card-text {
  font-size: var(--body-copy-size) !important;
  line-height: var(--body-copy-line) !important;
  overflow-wrap: anywhere;
  hyphens: none;
}

:is(.reasoning-page, .drafting-system-page, .review-page, .knowledge-page) .system-context-media,
:is(.reasoning-page, .drafting-system-page, .review-page, .knowledge-page) .system-scale-media {
  min-height: clamp(170px, 16vw, 230px) !important;
  aspect-ratio: 16 / 9 !important;
}

/* System pages: one full section per viewport */
:is(.reasoning-page, .drafting-system-page, .review-page, .knowledge-page) .system-brings {
  min-height: calc(100svh - var(--header-offset)) !important;
  padding-top: clamp(32px, 4svh, 56px) !important;
  padding-bottom: clamp(32px, 4svh, 56px) !important;
  align-content: center !important;
}

:is(.reasoning-page, .drafting-system-page, .review-page, .knowledge-page) .system-practice-heading {
  margin-top: clamp(90px, 12svh, 170px) !important;
  padding-top: clamp(8px, 1.2svh, 14px) !important;
  padding-bottom: clamp(0px, 0.3svh, 4px) !important;
}

:is(.reasoning-page, .drafting-system-page, .review-page, .knowledge-page) .system-practice-heading + .system-context {
  margin-top: 0 !important;
  padding-top: clamp(10px, 1.4svh, 18px) !important;
  align-content: start !important;
}

:is(.reasoning-page, .drafting-system-page, .review-page, .knowledge-page) .system-context,
:is(.reasoning-page, .drafting-system-page, .review-page, .knowledge-page) .system-scale {
  min-height: calc(100svh - var(--header-offset)) !important;
  padding-top: clamp(18px, 2.4svh, 34px) !important;
  padding-bottom: clamp(18px, 2.4svh, 34px) !important;
  display: grid !important;
  align-content: center !important;
}

/* Reasoning page: keep hero/overview sections full-height only. */
.reasoning-page main > section:not(.system-practice-heading):not(.system-context):not(.system-scale) {
  min-height: 100vh !important;
  min-height: 100svh !important;
}

.reasoning-page .system-brings {
  min-height: 100vh !important;
  min-height: 100svh !important;
}

.reasoning-page .system-practice-heading {
  min-height: auto !important;
  margin-top: 0 !important;
  padding-top: 0 !important;
  padding-bottom: 0 !important;
}

.reasoning-page .system-practice-heading + .system-context {
  padding-top: 0 !important;
}

/* Reasoning: keep full-height sections but remove inter-section gaps. */
.reasoning-page .system-practice-heading {
  margin-top: 0 !important;
  padding-bottom: 0 !important;
}

.reasoning-page .system-practice-heading + .system-context,
.reasoning-page .system-context + .system-scale,
.reasoning-page .system-scale + .system-scale {
  margin-top: 0 !important;
  padding-top: 0 !important;
}

.reasoning-page main > .system-scale:last-of-type {
  margin-bottom: 189px !important;
}

.reasoning-page .system-context,
.reasoning-page .system-scale {
  min-height: auto !important;
  padding-top: 0 !important;
  padding-bottom: 0 !important;
}

.reasoning-page .system-practice-heading .system-brings-subtitle.is-context-title {
  transform: translateY(37px);
}

.reasoning-page .system-practice-heading + .system-context {
  margin-top: 10px !important;
}

/* Reasoning: tighten spacing between How It Works cards (media/text pairs). */
.reasoning-page .system-context-inner,
.reasoning-page .system-scale-inner,
.reasoning-page .system-scale--reverse .system-scale-inner {
  column-gap: clamp(16px, 1.8vw, 28px) !important;
  row-gap: clamp(10px, 1.2vw, 18px) !important;
}

/* Reasoning: keep a fixed 3cm gap between How It Works cards/sections. */
.reasoning-page .system-practice-heading + .system-context,
.reasoning-page .system-context + .system-scale,
.reasoning-page .system-scale + .system-scale {
  margin-top: 189px !important;
}

/* Match Reasoning spacing/positioning on other System pages. */
:is(.drafting-system-page, .review-page, .knowledge-page) main > section:not(.system-practice-heading):not(.system-context):not(.system-scale) {
  min-height: 100vh !important;
  min-height: 100svh !important;
}

:is(.drafting-system-page, .review-page, .knowledge-page) .system-brings {
  min-height: 100vh !important;
  min-height: 100svh !important;
}

:is(.drafting-system-page, .review-page, .knowledge-page) .system-practice-heading {
  min-height: auto !important;
  margin-top: 0 !important;
  padding-top: 0 !important;
  padding-bottom: 0 !important;
}

:is(.drafting-system-page, .review-page, .knowledge-page) .system-practice-heading .system-brings-subtitle.is-context-title {
  transform: translateY(37px);
}

:is(.drafting-system-page, .review-page, .knowledge-page) .system-context,
:is(.drafting-system-page, .review-page, .knowledge-page) .system-scale {
  min-height: auto !important;
  padding-top: 0 !important;
  padding-bottom: 0 !important;
}

:is(.drafting-system-page, .review-page, .knowledge-page) .system-context-inner,
:is(.drafting-system-page, .review-page, .knowledge-page) .system-scale-inner,
:is(.drafting-system-page, .review-page, .knowledge-page) .system-scale--reverse .system-scale-inner {
  column-gap: clamp(16px, 1.8vw, 28px) !important;
  row-gap: clamp(10px, 1.2vw, 18px) !important;
}

:is(.drafting-system-page, .review-page, .knowledge-page) .system-practice-heading + .system-context,
:is(.drafting-system-page, .review-page, .knowledge-page) .system-context + .system-scale,
:is(.drafting-system-page, .review-page, .knowledge-page) .system-scale + .system-scale {
  margin-top: 189px !important;
  padding-top: 0 !important;
}

:is(.drafting-system-page, .review-page, .knowledge-page) main > .system-scale:last-of-type {
  margin-bottom: 189px !important;
}

/* Reasoning only: move the full How It Works stack up by ~1cm without changing inter-section gaps. */
.reasoning-page .system-context,
.reasoning-page .system-scale {
  transform: translateY(-38px);
}

.drafting-system-page .system-context,
.drafting-system-page .system-scale,
.review-page .system-context,
.review-page .system-scale,
.knowledge-page .system-context,
.knowledge-page .system-scale {
  transform: translateY(-38px);
}

/* Home feature cards: enforce seamless bottom blend inside each video frame. */
.home-page .features .feature-media--reasoning {
  --home-card-bg: #bdb2a8;
  background: var(--home-card-bg) !important;
  background-image: url("images/MARRON FOND REASONING VIDEO.png") !important;
  background-size: cover !important;
  background-position: center !important;
  background-repeat: no-repeat !important;
  border: none !important;
  position: relative;
  overflow: hidden;
}

.home-page .features .feature-media--drafting {
  --home-card-bg: #e5d5bc;
  background: var(--home-card-bg) !important;
  background-image: url("images/JAUNE FOND DRAFTING VIDEO.png") !important;
  background-size: cover !important;
  background-position: center !important;
  background-repeat: no-repeat !important;
  border: none !important;
  position: relative;
  overflow: hidden;
}

.home-page .features .feature-media--review {
  --home-card-bg: #d8ae9f;
  background: var(--home-card-bg) !important;
  background-image: url("images/TERRACOTA FOND REVIEW VIDEO.png") !important;
  background-size: cover !important;
  background-position: center !important;
  background-repeat: no-repeat !important;
  border: none !important;
  position: relative;
  overflow: hidden;
  box-shadow: none !important;
}

.home-page .features .feature-media--knowledge {
  --home-card-bg: #b7bca6;
  background: var(--home-card-bg) !important;
  background-image: url("images/NOUVEAU FOND VERT KNOWLEDGE.png") !important;
  background-size: cover !important;
  background-position: center !important;
  background-repeat: no-repeat !important;
  border: none !important;
  box-shadow: none !important;
  position: relative;
  overflow: hidden;
}

.home-page .features .feature-media--review .home-feature-video,
.home-page .features .feature-media--knowledge .home-feature-video {
  box-shadow: none !important;
  filter: none !important;
}

.home-page .features .feature-media--review .home-feature-video {
  box-shadow:
    0 -2px 0 0 rgba(216, 174, 159, 0.98),
    0 2px 0 0 rgba(216, 174, 159, 0.98) !important;
}

/* Knowledge card: force full-bleed video to avoid a horizontal seam line */
.home-page .features .feature-media--knowledge .home-feature-video {
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  aspect-ratio: auto !important;
  object-fit: cover !important;
  object-position: 50% 18% !important;
  display: block !important;
}

.home-page .features .feature-media--reasoning .home-feature-video,
.home-page .features .feature-media--drafting .home-feature-video,
.home-page .features .feature-media--review .home-feature-video,
.home-page .features .feature-media--knowledge .home-feature-video {
  position: relative;
  inset: auto !important;
  width: 100% !important;
  height: auto !important;
  aspect-ratio: 16 / 9 !important;
  display: block !important;
  object-fit: contain !important;
  object-position: 50% 50% !important;
  z-index: 1;
  background: var(--home-card-bg) !important;
}

.home-page .features .feature-media--drafting .home-feature-video {
  position: relative !important;
  inset: auto !important;
  width: 100% !important;
  height: auto !important;
  aspect-ratio: 16 / 9 !important;
  display: block !important;
  object-fit: contain !important;
  object-position: 50% 50% !important;
}

.home-feature-video--reasoning-center {
  width: 100% !important;
  max-width: none !important;
  margin-left: 0 !important;
  transform: none !important;
  transform-origin: center !important;
  object-fit: contain !important;
  object-position: 50% 50% !important;
  -webkit-clip-path: none !important;
  clip-path: none !important;
}

@media (max-width: 960px) {
  :is(.reasoning-page, .drafting-system-page, .review-page, .knowledge-page) .system-brings-card,
  :is(.reasoning-page, .drafting-system-page, .review-page, .knowledge-page) .system-brings-card--stacked,
  :is(.reasoning-page, .drafting-system-page, .review-page, .knowledge-page) .system-brings-card--handle-matters {
    min-height: auto !important;
    height: auto !important;
  }

  :is(.reasoning-page, .drafting-system-page, .review-page, .knowledge-page) .system-brings-card-overlay {
    display: flex !important;
    flex-direction: column !important;
    justify-content: flex-start !important;
    gap: 14px !important;
    padding: 24px !important;
  }

  :is(.reasoning-page, .drafting-system-page, .review-page, .knowledge-page) .system-brings-card-title,
  :is(.reasoning-page, .drafting-system-page, .review-page, .knowledge-page) .system-brings-card-text {
    margin: 0 !important;
  }

  :is(.reasoning-page, .drafting-system-page, .review-page, .knowledge-page) .system-brings-card-body {
    display: block !important;
    align-content: initial !important;
    place-self: auto !important;
  }

  :is(.reasoning-page, .drafting-system-page, .review-page, .knowledge-page) .system-brings-card-overlay {
    padding: 24px !important;
    justify-content: flex-start !important;
  }

  :is(.reasoning-page, .drafting-system-page, .review-page, .knowledge-page) .system-brings-card-title,
  :is(.reasoning-page, .drafting-system-page, .review-page, .knowledge-page) .system-brings-card-text {
    margin: 0 !important;
  }

  /* Reasoning mobile: keep How-It-Works sections single-column and readable. */
  .reasoning-page .system-context-inner,
  .reasoning-page .system-scale-inner,
  .reasoning-page .system-scale--reverse .system-scale-inner {
    grid-template-columns: 1fr !important;
    column-gap: 0 !important;
    row-gap: 16px !important;
    align-items: start !important;
  }

  .drafting-system-page .system-context-inner,
  .drafting-system-page .system-scale-inner,
  .drafting-system-page .system-scale--reverse .system-scale-inner {
    grid-template-columns: 1fr !important;
    column-gap: 0 !important;
    row-gap: 16px !important;
    align-items: start !important;
  }

  .review-page .system-context-inner,
  .review-page .system-scale-inner,
  .review-page .system-scale--reverse .system-scale-inner,
  .knowledge-page .system-context-inner,
  .knowledge-page .system-scale-inner,
  .knowledge-page .system-scale--reverse .system-scale-inner {
    grid-template-columns: 1fr !important;
    column-gap: 0 !important;
    row-gap: 16px !important;
    align-items: start !important;
  }

  .reasoning-page .system-context-left,
  .reasoning-page .system-scale-copy,
  .reasoning-page .system-context-right,
  .reasoning-page .system-context-media,
  .reasoning-page .system-scale-media {
    width: 100% !important;
    max-width: none !important;
    justify-self: stretch !important;
  }

  .drafting-system-page .system-context-left,
  .drafting-system-page .system-scale-copy,
  .drafting-system-page .system-context-right,
  .drafting-system-page .system-context-media,
  .drafting-system-page .system-scale-media {
    width: 100% !important;
    max-width: none !important;
    justify-self: stretch !important;
  }

  .review-page .system-context-left,
  .review-page .system-scale-copy,
  .review-page .system-context-right,
  .review-page .system-context-media,
  .review-page .system-scale-media,
  .knowledge-page .system-context-left,
  .knowledge-page .system-scale-copy,
  .knowledge-page .system-context-right,
  .knowledge-page .system-context-media,
  .knowledge-page .system-scale-media {
    width: 100% !important;
    max-width: none !important;
    justify-self: stretch !important;
  }

  .reasoning-page .system-scale-inner > .system-scale-copy {
    order: 1;
  }

  .drafting-system-page .system-scale-inner > .system-scale-copy {
    order: 1;
  }

  .review-page .system-scale-inner > .system-scale-copy,
  .knowledge-page .system-scale-inner > .system-scale-copy {
    order: 1;
  }

  .reasoning-page .system-scale-inner > .system-scale-media {
    order: 2;
  }

  .drafting-system-page .system-scale-inner > .system-scale-media {
    order: 2;
  }

  .review-page .system-scale-inner > .system-scale-media,
  .knowledge-page .system-scale-inner > .system-scale-media {
    order: 2;
  }

  .reasoning-page main > .system-scale:last-of-type {
    margin-bottom: 0 !important;
    padding-bottom: 0 !important;
  }

  .drafting-system-page main > .system-scale:last-of-type {
    margin-bottom: 0 !important;
    padding-bottom: 0 !important;
  }

  .review-page main > .system-scale:last-of-type,
  .knowledge-page main > .system-scale:last-of-type {
    margin-bottom: 0 !important;
    padding-bottom: 0 !important;
  }
}

.home-feature-video--drafting-crop {
  object-fit: contain !important;
  width: 100% !important;
  max-width: none !important;
  margin-left: 0 !important;
  transform: none !important;
  transform-origin: center !important;
  object-position: 50% 50% !important;
  -webkit-clip-path: none !important;
  clip-path: none !important;
}

.home-feature-video--review-crop {
  object-fit: contain !important;
  transform: none !important;
  transform-origin: center !important;
  object-position: 50% 50% !important;
  -webkit-clip-path: none !important;
  clip-path: none !important;
}

/* Home / Review: slight zoom to remove encoded dark edge contours. */
.home-page .features .feature-media--review .home-feature-video--review-crop {
  transform: scale(1.09) !important;
  transform-origin: center !important;
  object-position: 56% 50% !important;
  -webkit-clip-path: inset(4px 0 4px 12px) !important;
  clip-path: inset(4px 0 4px 12px) !important;
}

.overview-page .overview-capabilities .feature-media--review .home-feature-video--review-crop {
  transform: scale(1.09) !important;
  transform-origin: center !important;
  object-position: 56% 50% !important;
  -webkit-clip-path: inset(4px 0 6px 12px) !important;
  clip-path: inset(4px 0 6px 12px) !important;
}

.home-feature-video--knowledge-crop {
  --home-knowledge-zoom-start: 1.24;
  --home-knowledge-zoom-end: 1;
  object-fit: cover !important;
  width: 100% !important;
  height: 100% !important;
  max-width: none !important;
  margin-left: 0 !important;
  transform: scale(var(--home-knowledge-zoom-end)) !important;
  transform-origin: center !important;
  object-position: 50% 18% !important;
  filter: none !important;
  -webkit-mask-image: none !important;
  mask-image: none !important;
  -webkit-clip-path: none !important;
  clip-path: none !important;
  animation: home-knowledge-intro-zoom 1s ease-out 1 both !important;
}

.home-page .features .feature-media--reasoning::before,
.home-page .features .feature-media--drafting::before,
.home-page .features .feature-media--review::before,
.home-page .features .feature-media--knowledge::before {
  content: none !important;
  display: none !important;
}

.home-page .features .feature-media--reasoning::after,
.home-page .features .feature-media--drafting::after,
.home-page .features .feature-media--review::after,
.home-page .features .feature-media--knowledge::after {
  content: none !important;
  display: none !important;
}

/* Reasoning only: ultra-subtle blend veil to hide the horizontal seam lines. */
.home-page .features .feature-media--reasoning::after {
  content: "" !important;
  display: block !important;
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 2;
  background:
    linear-gradient(
      to bottom,
      rgba(189, 178, 168, 0) 0%,
      rgba(189, 178, 168, 0) 24%,
      rgba(189, 178, 168, 0.06) 27.5%,
      rgba(189, 178, 168, 0) 31%,
      rgba(189, 178, 168, 0) 69%,
      rgba(189, 178, 168, 0.06) 72.5%,
      rgba(189, 178, 168, 0) 76%,
      rgba(189, 178, 168, 0) 100%
    ),
    repeating-linear-gradient(
      45deg,
      rgba(255, 255, 255, 0.009) 0 1px,
      rgba(0, 0, 0, 0.006) 1px 2px
    );
}

/* Knowledge card only: stronger tonal veil to remove remaining seam lines. */
.home-page .features .feature-media--knowledge::before,
.home-page .features .feature-media--knowledge::after {
  content: none !important;
  display: none !important;
}

/* Review only: seam blend veil at 16:9 junctions (no full-frame tint). */
.home-page .features .feature-media--review::after {
  content: "" !important;
  display: block !important;
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 2;
  background: linear-gradient(
    to bottom,
    rgba(220, 181, 168, 0) 0%,
    rgba(220, 181, 168, 0) 23%,
    rgba(220, 181, 168, 0.12) 27.5%,
    rgba(220, 181, 168, 0) 32%,
    rgba(220, 181, 168, 0) 68%,
    rgba(220, 181, 168, 0.12) 72.5%,
    rgba(220, 181, 168, 0) 77%,
    rgba(220, 181, 168, 0) 100%
  );
}

@media (min-width: 980px) {
  .home-page .features .home-feature-video--knowledge-crop {
    --home-knowledge-zoom-start: 1.34;
    --home-knowledge-zoom-end: 1.1;
    object-fit: cover !important;
    transform: scale(var(--home-knowledge-zoom-end)) !important;
    object-position: 50% 18% !important;
  }

  .overview-page .overview-capabilities .feature-media--knowledge .home-feature-video--knowledge-crop {
    object-fit: contain !important;
    height: auto !important;
    aspect-ratio: 16 / 9 !important;
    transform: none !important;
    object-position: 50% 50% !important;
  }
}

@keyframes home-knowledge-intro-zoom {
  0% {
    transform: scale(var(--home-knowledge-zoom-start));
  }
  100% {
    transform: scale(var(--home-knowledge-zoom-end));
  }
}

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    scroll-behavior: auto !important;
    transition-duration: 0.01ms !important;
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
  }

  .ticker-viewport {
    animation: none !important;
    transform: none !important;
    width: 100%;
    display: block;
  }

  .home-feature-video--knowledge-crop {
    animation: none !important;
  }

  .ticker-track {
    flex-wrap: wrap;
    white-space: normal;
    gap: 10px 18px;
  }

  .system-track {
    animation: none !important;
    transform: none !important;
    width: 100%;
    display: block;
  }

  .system-row {
    flex-wrap: wrap;
    gap: 18px;
  }

  .security-architecture-marquee-track {
    transform: translate3d(0, -50%, 0) !important;
  }
}

/* Home / System cards: keep videos in 16:9 and rely only on background fill images. */
.home-page .features .feature-media--reasoning::after,
.home-page .features .feature-media--drafting::after,
.home-page .features .feature-media--review::after,
.home-page .features .feature-media--knowledge::after {
  content: none !important;
  display: none !important;
  background: none !important;
}

.home-page .features .feature-media--reasoning .home-feature-video,
.home-page .features .feature-media--drafting .home-feature-video,
.home-page .features .feature-media--review .home-feature-video,
.home-page .features .feature-media--knowledge .home-feature-video {
  position: relative !important;
  inset: auto !important;
  width: 100% !important;
  height: auto !important;
  aspect-ratio: 16 / 9 !important;
  object-fit: contain !important;
  transform: none !important;
  -webkit-clip-path: none !important;
  clip-path: none !important;
  box-shadow: none !important;
  filter: none !important;
}

/* Transactional hero: same text, better word distribution across lines. */
.transactional-page .solutions-intro .solutions-hero-subtitle {
  max-width: 14ch !important;
  text-wrap: balance !important;
  white-space: normal !important;
}

.transactional-page .solutions-intro .solutions-hero-text {
  max-width: 48ch !important;
  text-wrap: balance !important;
  white-space: normal !important;
}

/* Drafting card seam fix: hide encoded dark bottom edge only. */
.home-page .features .feature-media--drafting .home-feature-video--drafting-crop,
.overview-page .overview-capabilities .feature-media--drafting .home-feature-video--drafting-crop {
  -webkit-clip-path: inset(0 0 2px 0) !important;
  clip-path: inset(0 0 2px 0) !important;
}

.overview-page .overview-capabilities .feature-media--drafting .home-feature-video--drafting-crop {
  -webkit-clip-path: inset(0 0 4px 0) !important;
  clip-path: inset(0 0 4px 0) !important;
}

/* Overview pages: remove any residual sub-pixel seam between video and frame. */
.overview-page .overview-capabilities .feature-media .home-feature-video,
.overview-page .overview-capabilities .home-feature-video--reasoning-center,
.overview-page .overview-capabilities .home-feature-video--drafting-crop,
.overview-page .overview-capabilities .home-feature-video--review-crop,
.overview-page .overview-capabilities .home-feature-video--knowledge-crop {
  border: 0 !important;
  outline: 0 !important;
  box-shadow: none !important;
  -webkit-clip-path: none !important;
  clip-path: none !important;
}

/* Banking hero: keep 3 lines, improve word balance without changing text. */
.banking-page .solutions-intro .solutions-hero-text {
  max-width: 46ch !important;
  text-wrap: balance !important;
  white-space: normal !important;
}

/* Employment hero: keep 3 lines, improve word balance without changing text. */
.employment-page .solutions-intro .solutions-hero-text {
  max-width: 47ch !important;
  text-wrap: balance !important;
  white-space: normal !important;
}

/* Home / System: hard-fix seam lines under REVIEW + KNOWLEDGE videos. */
.home-page .features .feature-media--review,
.home-page .features .feature-media--knowledge {
  isolation: isolate;
}

.home-page .features .feature-media--review {
  --home-card-bg: #d8ae9f;
}

.home-page .features .feature-media--knowledge {
  --home-card-bg: #b7bca6;
}

.home-page .features .feature-media--review .home-feature-video,
.home-page .features .feature-media--knowledge .home-feature-video {
  background: transparent !important;
  -webkit-clip-path: none !important;
  clip-path: none !important;
}

.home-page .features .feature-media--review::after,
.home-page .features .feature-media--knowledge::after {
  content: none !important;
  display: none !important;
  background: none !important;
}

.overview-page .overview-capabilities .feature-media--review,
.overview-page .overview-capabilities .feature-media--knowledge {
  isolation: isolate;
}

.overview-page .overview-capabilities .feature-media--review {
  --home-card-bg: #d8ae9f;
}

.overview-page .overview-capabilities .feature-media--knowledge {
  --home-card-bg: #b7bca6;
}

.overview-page .overview-capabilities .feature-media--review .home-feature-video,
.overview-page .overview-capabilities .feature-media--knowledge .home-feature-video {
  background: transparent !important;
  -webkit-clip-path: none !important;
  clip-path: none !important;
}

.overview-page .overview-capabilities .feature-media--review::after,
.overview-page .overview-capabilities .feature-media--knowledge::after {
  content: none !important;
  display: none !important;
  background: none !important;
}

/* Teaser (Home + Overview): remove bottom black seam under video */
.home-page .video-shell,
.overview-page .video-shell {
  background: transparent !important;
  box-shadow: none !important;
  line-height: 0 !important;
  font-size: 0 !important;
}

.home-page .video-shell::before,
.overview-page .video-shell::before {
  content: none !important;
  display: none !important;
}

.home-page .system-overview-loop-video,
.overview-page .system-overview-loop-video {
  display: block !important;
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  vertical-align: top !important;
  transform: scale(1.002) translateY(0.5px) !important;
  transform-origin: center center !important;
}

/* Mobile pass (phase 1): layout/readability only, desktop untouched */
@media (max-width: 979px) {
  .home-page .vision-wide {
    animation: home-vision-mobile-swap 10s steps(1, end) infinite;
    transition: none;
  }

  .home-page .vision-wide:hover {
    background-color: inherit;
    background-image: inherit;
  }

  .hero-subtitle-break {
    display: block;
  }

  .teaser-controls {
    display: grid;
    position: absolute;
    left: 12px;
    right: 12px;
    bottom: 29px;
    z-index: 4;
    grid-template-columns: auto 1fr auto;
    gap: 10px;
    align-items: center;
  }

  .teaser-control-btn {
    width: 40px;
    height: 40px;
    border: 1px solid rgba(255, 255, 255, 0.98);
    border-radius: 12px;
    background: linear-gradient(180deg, rgba(180, 180, 180, 0.72), rgba(156, 156, 156, 0.68));
    color: rgba(255, 255, 255, 1);
    font: inherit;
    font-size: 14px;
    font-weight: 600;
    line-height: 1;
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
    cursor: pointer;
    display: grid;
    place-items: center;
  }

  .teaser-control-btn .teaser-icon {
    width: 19px;
    height: 19px;
    display: block;
    opacity: 1;
    filter: drop-shadow(0 0 1.1px rgba(255, 255, 255, 1));
  }

  .teaser-control-btn .teaser-icon path,
  .teaser-control-btn .teaser-icon rect {
    fill: currentColor;
    stroke: currentColor;
  }

  .teaser-control-btn--play .teaser-icon--pause {
    display: none;
  }

  .teaser-control-btn--play.is-playing .teaser-icon--play {
    display: none;
  }

  .teaser-control-btn--play.is-playing .teaser-icon--pause {
    display: block;
  }

  .teaser-control-btn:active {
    transform: scale(0.98);
  }

  .teaser-progress {
    height: 4px;
    border: 0;
    padding: 0;
    margin: 0;
    border-radius: 999px;
    background: rgba(255, 249, 236, 0.58);
    position: relative;
    cursor: pointer;
  }

  .teaser-progress-fill {
    position: absolute;
    inset: 0 auto 0 0;
    width: 0%;
    border-radius: inherit;
    background: rgba(255, 253, 246, 1);
  }

  .home-page .video-band {
    min-height: auto !important;
    padding-block: 0 !important;
  }

  .home-page .video-band .video-shell {
    min-height: 0 !important;
    aspect-ratio: 16 / 9 !important;
    width: 100% !important;
  }

  .home-page .system-overview-loop-video {
    width: 100% !important;
    height: 100% !important;
    object-fit: contain !important;
    transform: none !important;
  }

  .why-max-overview-page .whymax-overview-mobile-hero-media {
    display: block;
    width: 100%;
    margin-top: 8px;
    border: 1px solid var(--hairline);
    background: color-mix(in srgb, var(--text) 6%, var(--bg));
    overflow: hidden;
    box-shadow: var(--global-frame-shadow);
  }

  .why-max-overview-page .whymax-overview-mobile-hero-media img {
    width: 100%;
    height: auto;
    display: block;
  }

  .home-page main > section.hero {
    min-height: auto !important;
    padding-top: 16px !important;
    padding-bottom: 18px !important;
    align-content: start !important;
  }

  .home-page .hero-inner {
    gap: 20px !important;
  }

  .home-page .intro {
    min-height: auto !important;
    padding-top: 20px !important;
    padding-bottom: 38px !important;
    align-items: flex-start !important;
  }

  .home-page .intro-inner {
    min-height: 0 !important;
    align-content: start !important;
  }

  .home-page .hero-title {
    font-size: clamp(44px, 15vw, 72px) !important;
    line-height: 0.94 !important;
  }

  .home-page .hero-subtitle {
    padding-left: 0 !important;
    font-size: clamp(14px, 4.8vw, 20px) !important;
  }

  .home-page .features .feature-title,
  .overview-page .overview-capabilities .feature-title {
    font-size: clamp(28px, 9vw, 40px) !important;
    line-height: 1.02 !important;
  }

  .home-page .features .feature-text,
  .overview-page .overview-capabilities .feature-text {
    font-size: clamp(16px, 4.8vw, 21px) !important;
    line-height: 1.5 !important;
  }

  /* Mobile: keep the same 4 System card frame backgrounds as desktop. */
  .home-page .features .feature-media--reasoning {
    --home-card-bg: #bdb2a8;
    background: var(--home-card-bg) !important;
    background-image: url("images/MARRON FOND REASONING VIDEO.png") !important;
    background-size: cover !important;
    background-position: center !important;
    background-repeat: no-repeat !important;
  }

  .home-page .features .feature-media--drafting {
    --home-card-bg: #e5d5bc;
    background: var(--home-card-bg) !important;
    background-image: url("images/JAUNE FOND DRAFTING VIDEO.png") !important;
    background-size: cover !important;
    background-position: center !important;
    background-repeat: no-repeat !important;
  }

  .home-page .features .feature-media--review {
    --home-card-bg: #d8ae9f;
    background: var(--home-card-bg) !important;
    background-image: url("images/TERRACOTA FOND REVIEW VIDEO.png") !important;
    background-size: cover !important;
    background-position: center !important;
    background-repeat: no-repeat !important;
  }

  .home-page .features .feature-media--knowledge {
    --home-card-bg: #b7bca6;
    background: var(--home-card-bg) !important;
    background-image: url("images/NOUVEAU FOND VERT KNOWLEDGE.png") !important;
    background-size: cover !important;
    background-position: center !important;
    background-repeat: no-repeat !important;
  }

  .home-page .features .feature-media--reasoning .home-feature-video,
  .home-page .features .feature-media--drafting .home-feature-video,
  .home-page .features .feature-media--review .home-feature-video,
  .home-page .features .feature-media--knowledge .home-feature-video {
    width: 100% !important;
    height: 100% !important;
    aspect-ratio: auto !important;
    object-fit: cover !important;
    object-position: 50% 50% !important;
    background: transparent !important;
    transform: scale(1.002) !important;
  }

  /* Mobile: Overview System cards use the same frame backgrounds as Home. */
  .overview-page .overview-capabilities .feature-media--reasoning {
    --home-card-bg: #bdb2a8;
    background: var(--home-card-bg) !important;
    background-image: url("images/MARRON FOND REASONING VIDEO.png") !important;
    background-size: cover !important;
    background-position: center !important;
    background-repeat: no-repeat !important;
  }

  .overview-page .overview-capabilities .feature-media--drafting {
    --home-card-bg: #e5d5bc;
    background: var(--home-card-bg) !important;
    background-image: url("images/JAUNE FOND DRAFTING VIDEO.png") !important;
    background-size: cover !important;
    background-position: center !important;
    background-repeat: no-repeat !important;
  }

  .overview-page .overview-capabilities .feature-media--review {
    --home-card-bg: #d8ae9f;
    background: var(--home-card-bg) !important;
    background-image: url("images/TERRACOTA FOND REVIEW VIDEO.png") !important;
    background-size: cover !important;
    background-position: center !important;
    background-repeat: no-repeat !important;
  }

  .overview-page .overview-capabilities .feature-media--knowledge {
    --home-card-bg: #b7bca6;
    background: var(--home-card-bg) !important;
    background-image: url("images/NOUVEAU FOND VERT KNOWLEDGE.png") !important;
    background-size: cover !important;
    background-position: center !important;
    background-repeat: no-repeat !important;
  }

  .overview-page .overview-capabilities .feature-media--reasoning .home-feature-video,
  .overview-page .overview-capabilities .feature-media--drafting .home-feature-video,
  .overview-page .overview-capabilities .feature-media--review .home-feature-video,
  .overview-page .overview-capabilities .feature-media--knowledge .home-feature-video {
    width: 100% !important;
    height: 100% !important;
    aspect-ratio: auto !important;
    object-fit: cover !important;
    object-position: 50% 50% !important;
    background: transparent !important;
    transform: scale(1.002) !important;
  }

  .home-page .security-top {
    gap: 22px;
  }

  .home-page .security-title {
    font-size: clamp(34px, 11vw, 52px);
  }

  .home-page .security-right .security-body {
    font-size: clamp(16px, 4.3vw, 19px);
    line-height: 1.55;
  }

  .home-page .security-standards-row {
    grid-template-columns: 1fr;
    gap: 22px;
    --security-standard-icon-size: clamp(96px, 28vw, 122px);
  }

  .home-page .security-standard {
    min-height: auto;
    gap: 10px;
  }

  .home-page .security-standard-icon {
    color: rgba(255, 255, 255, 0.72) !important;
    filter: drop-shadow(0 0 8px rgba(255, 255, 255, 0.24));
  }

  .home-page .security-standard .security-standards-icon--soc2 svg {
    color: rgba(255, 255, 255, 0.92) !important;
    filter: drop-shadow(0 0 1.2px rgba(255, 255, 255, 0.5)) !important;
  }

  .overview-page .video-band,
  .overview-page .video-band .video-shell {
    min-height: 62svh;
  }

  .overview-page .overview-capabilities {
    padding-block: clamp(28px, 8vw, 56px);
  }

  .overview-page .overview-capabilities .features-grid {
    grid-template-columns: 1fr;
    gap: 28px;
  }

  .overview-page .overview-capabilities .feature {
    gap: 10px;
  }

  .overview-page .overview-capabilities .feature-media {
    aspect-ratio: 16 / 10;
    min-height: 0;
  }

  .security-page .security-standards-content,
  .security-page .security-pillars-grid {
    grid-template-columns: 1fr;
  }

  .security-page .security-standards-left .security-standards-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    align-items: start;
    column-gap: clamp(8px, 2.2vw, 14px);
    row-gap: 16px;
  }

  .security-page .security-standards-left .security-standards-card {
    grid-template-rows: auto minmax(2.5em, auto) auto auto;
    align-content: start;
    gap: 8px;
  }

  .security-page .security-standards-left .security-standards-label {
    width: 100%;
    min-height: 2.5em;
    margin: 0;
    display: flex;
    align-items: flex-start;
    justify-content: center;
    text-align: center;
    font-size: clamp(11px, 3.5vw, 14px);
    line-height: 1.2;
    letter-spacing: 0.04em;
  }

  .security-page .security-standards-left .security-standards-statusline,
  .security-page .security-standards-left .security-standards-link {
    min-height: 1.2em;
    display: flex;
    align-items: flex-start;
    justify-content: center;
    text-align: center;
    width: 100%;
  }

  /* Security mobile: architecture marquee displays one phrase at a time */
  .security-page .security-architecture-marquee {
    padding-top: clamp(78px, 18vw, 132px);
    padding-bottom: clamp(62px, 14vw, 104px);
  }

  .security-page .security-architecture-marquee-inner {
    --marquee-window-height: auto;
    grid-template-columns: 1fr;
    gap: 14px;
    min-height: 0;
  }

  .security-page .security-architecture-marquee-copy {
    height: auto;
    min-height: 0;
    align-content: start;
    justify-items: center;
    text-align: center;
    gap: 10px;
    padding-top: 0;
    padding-right: 0;
  }

  .security-page .security-architecture-marquee-words,
  .security-page .security-architecture-marquee-window {
    height: auto;
  }

  .security-page .security-architecture-marquee-words {
    margin-top: clamp(24px, 6.4vw, 40px);
    margin-bottom: clamp(34px, 8.8vw, 58px);
  }

  .security-page .security-architecture-marquee-window {
    overflow: hidden;
    -webkit-mask-image: none;
    mask-image: none;
    min-height: 1.6em;
  }

  .security-page .security-architecture-marquee-track.is-mobile-single {
    position: relative;
    width: 100%;
    min-height: 1.6em;
    transform: none !important;
    transition: none !important;
    display: block;
  }

  .security-page .security-architecture-marquee-track.is-mobile-single .security-architecture-marquee-item {
    position: absolute;
    left: 0;
    top: 0;
    right: 0;
    flex: none;
    width: 100% !important;
    min-width: 0 !important;
    padding-inline: 0;
    justify-content: center;
    text-align: center;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    font-size: clamp(15px, 4.8vw, 19px);
    line-height: 1.24;
    opacity: 0;
    color: rgba(229, 234, 242, 0.9);
    transform: translate3d(0, 7px, 0);
    transition: opacity 190ms ease, transform 190ms ease;
  }

  .security-page .security-architecture-marquee-track.is-mobile-single .security-architecture-marquee-item.is-active {
    opacity: 0.94;
    transform: translate3d(0, 0, 0);
  }

  .security-page .security-architecture-marquee-track.is-mobile-single .security-architecture-marquee-item.is-exit {
    opacity: 0;
    transform: translate3d(0, -7px, 0);
  }

  .security-page .security-architecture-marquee-track.is-mobile-single
    .security-architecture-marquee-item.is-side,
  .security-page .security-architecture-marquee-track.is-mobile-single
    .security-architecture-marquee-item.is-near,
  .security-page .security-architecture-marquee-track.is-mobile-single
    .security-architecture-marquee-item.is-far {
    opacity: 0.94;
    filter: none;
  }
}

@media (max-width: 620px) {
  .home-page .video-band .video-shell {
    aspect-ratio: 16 / 10 !important;
  }

  .overview-page .video-band,
  .overview-page .video-band .video-shell {
    min-height: 54svh;
  }
}

@media (max-width: 979px) and (prefers-reduced-motion: reduce) {
  .home-page .vision-wide {
    animation: none;
    background-color: #ffffff;
    background-image: url("images/Max bleu.png");
  }
}

@media (max-width: 960px) {
  /* Final mobile lock for System pages: no brown/white frame around video containers. */
  :is(.reasoning-page, .drafting-system-page, .review-page, .knowledge-page) .system-hero-media,
  :is(.reasoning-page, .drafting-system-page, .review-page, .knowledge-page) .system-context-media,
  :is(.reasoning-page, .drafting-system-page, .review-page, .knowledge-page) .system-scale-media {
    background: transparent !important;
    background-image: none !important;
    border: none !important;
    box-shadow: 0 24px 44px -30px rgba(0, 0, 0, 0.42) !important;
  }

  :is(.reasoning-page, .drafting-system-page, .review-page, .knowledge-page) .system-hero-media {
    background: transparent !important;
    min-height: 0 !important;
    height: auto !important;
    aspect-ratio: auto !important;
    line-height: 0 !important;
    font-size: 0 !important;
  }

  :is(.reasoning-page, .drafting-system-page, .review-page, .knowledge-page) .system-hero-video {
    width: 100% !important;
    height: auto !important;
    margin: 0 !important;
    object-fit: contain !important;
    object-position: 50% 50% !important;
    -webkit-clip-path: none !important;
    clip-path: none !important;
    background: transparent !important;
    display: block !important;
    vertical-align: top !important;
  }

  :is(.reasoning-page, .drafting-system-page, .review-page, .knowledge-page) .system-context-video,
  :is(.reasoning-page, .drafting-system-page, .review-page, .knowledge-page) .system-scale-video {
    width: 100% !important;
    height: 100% !important;
    display: block !important;
    object-fit: cover !important;
    object-position: 50% 50% !important;
    background: transparent !important;
  }

  :is(.reasoning-page, .drafting-system-page, .review-page, .knowledge-page) .system-hero-media,
  :is(.reasoning-page, .drafting-system-page, .review-page, .knowledge-page) .system-context-media,
  :is(.reasoning-page, .drafting-system-page, .review-page, .knowledge-page) .system-scale-media {
    position: relative;
  }

  .reasoning-fullscreen-btn {
    position: absolute;
    right: 10px;
    bottom: 10px;
    width: 36px;
    height: 36px;
    border: 1px solid rgba(255, 255, 255, 0.98);
    border-radius: 10px;
    background: linear-gradient(180deg, rgba(182, 182, 182, 0.72), rgba(158, 158, 158, 0.66));
    color: rgba(255, 255, 255, 1);
    display: grid;
    place-items: center;
    padding: 0;
    z-index: 6;
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
    cursor: pointer;
  }

  .reasoning-fullscreen-btn svg {
    width: 17px;
    height: 17px;
    display: block;
    filter: drop-shadow(0 0 1.1px rgba(255, 255, 255, 1));
  }
}

/* Final override: overview cards without decorative icons + tighter height. */
.overview-page .system-brings-card :is(
  .overview-icon,
  .whymax-icon,
  .solutions-overview-icon,
  [class*="overview-icon"],
  [class*="whymax-icon"],
  [class*="solutions-overview-icon"]
) {
  display: none !important;
  visibility: hidden !important;
  opacity: 0 !important;
  width: 0 !important;
  height: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
}

.overview-page .system-brings-card {
  min-height: clamp(303px, 30vw, 403px) !important;
  height: 100% !important;
}

.why-max-overview-page .system-brings-card {
  min-height: clamp(303px, 30vw, 403px) !important;
  height: 100% !important;
}

.overview-page .system-brings-grid {
  align-items: stretch !important;
}

.overview-page .system-brings-card-overlay {
  position: absolute !important;
  inset: 0 !important;
  background: color-mix(in srgb, var(--bg) 75%, #d2cdc6 25%) !important;
}

.overview-page .system-brings-card-overlay--with-foot {
  position: absolute !important;
  inset: 0 !important;
  display: grid !important;
  grid-template-rows: auto 1fr !important;
  align-items: start !important;
  align-content: flex-start !important;
  gap: 12px !important;
  min-height: 100% !important;
}

.overview-page .system-brings-card-body {
  display: block !important;
  min-height: 0 !important;
  padding: 0 !important;
  margin: 0 !important;
  overflow: visible !important;
  align-content: start !important;
  align-self: start !important;
  place-self: stretch !important;
  max-height: none !important;
}

.overview-page .system-brings-card-title {
  line-height: 1.25 !important;
  min-height: calc(1.25em * 2) !important;
  height: auto !important;
  display: block !important;
  -webkit-line-clamp: unset !important;
  overflow: visible !important;
}

.overview-page .system-brings-card-foot {
  display: none !important;
}

/* Home + Overview System only: remove white seam lines on Review/Knowledge cards. */
.home-page .features .feature-media--review,
.home-page .features .feature-media--knowledge,
.overview-page .overview-capabilities .feature-media--review,
.overview-page .overview-capabilities .feature-media--knowledge {
  background-image: none !important;
  border: none !important;
  box-shadow: none !important;
}

.home-page .features .feature-media--review,
.overview-page .overview-capabilities .feature-media--review {
  background-color: #d8ae9f !important;
}

.home-page .features .feature-media--review {
  background-color: #e4c2b6 !important;
  background-image: url("images/FOND TERRACOTA REVIEW.png") !important;
  background-size: cover !important;
  background-position: center !important;
  background-repeat: no-repeat !important;
}

.overview-page .overview-capabilities .feature-media--review {
  background-color: #e4c2b6 !important;
  background-image: url("images/FOND TERRACOTA REVIEW.png") !important;
  background-size: cover !important;
  background-position: center !important;
  background-repeat: no-repeat !important;
}

.home-page .features .feature-media--knowledge,
.overview-page .overview-capabilities .feature-media--knowledge {
  background-color: #b7bca6 !important;
}

.home-page .features .feature-media--knowledge {
  background-image: url("images/FOND VERT KNOWLEDGE.png") !important;
  background-size: cover !important;
  background-position: center !important;
  background-repeat: no-repeat !important;
}

.overview-page .overview-capabilities .feature-media--knowledge {
  background-image: url("images/FOND VERT KNOWLEDGE.png") !important;
  background-size: cover !important;
  background-position: center !important;
  background-repeat: no-repeat !important;
}

.home-page .features .feature-media--review::before,
.home-page .features .feature-media--review::after,
.home-page .features .feature-media--knowledge::before,
.home-page .features .feature-media--knowledge::after,
.overview-page .overview-capabilities .feature-media--review::before,
.overview-page .overview-capabilities .feature-media--review::after,
.overview-page .overview-capabilities .feature-media--knowledge::before,
.overview-page .overview-capabilities .feature-media--knowledge::after {
  content: none !important;
  display: none !important;
  background: none !important;
}

.home-page .features .feature-media--review .home-feature-video,
.home-page .features .feature-media--knowledge .home-feature-video,
.overview-page .overview-capabilities .feature-media--review .home-feature-video,
.overview-page .overview-capabilities .feature-media--knowledge .home-feature-video {
  border: 0 !important;
  outline: 0 !important;
  box-shadow: none !important;
  background: transparent !important;
  -webkit-clip-path: none !important;
  clip-path: none !important;
}

.overview-page .overview-capabilities .home-feature-video--reasoning-center {
  transform: scale(1.22) !important;
  transform-origin: center !important;
  object-position: 60% 58% !important;
}

.overview-page .overview-capabilities .feature-media--knowledge .home-feature-video--knowledge-crop {
  -webkit-clip-path: inset(0 0 3px 0) !important;
  clip-path: inset(0 0 3px 0) !important;
}

 

.legal-page .system-context-inner {
  grid-template-columns: minmax(0, 1fr);
  justify-items: center;
  align-items: center;
}

.legal-page .solutions-hero {
  min-height: var(--meet-max-banner-min-height);
  padding-block: clamp(36px, 6vw, 72px);
  display: grid;
  align-items: center;
  background: #f3f1eb;
}

.legal-page .system-context {
  min-height: calc(100svh - var(--header-offset));
  padding-block: clamp(24px, 3vw, 40px);
  display: grid;
  align-items: center;
}

.legal-page main .container {
  width: calc(100% - (var(--page-gutter) * 2));
  max-width: none;
}

.legal-page .system-context-left {
  width: 100%;
  max-width: none;
  margin-inline: auto;
  min-height: 0;
  text-align: center;
  display: grid;
  justify-items: center;
  align-content: center;
}

.legal-page .system-context-title,
.legal-page .system-context-text {
  text-align: center;
}

.legal-page .system-context-title {
  margin: 0 0 clamp(12px, 1.6vw, 18px);
}

.legal-page .system-context-text {
  margin: 0;
  line-height: 1.68;
  max-width: min(100%, 980px);
}

.legal-page .system-context-text + .system-context-text {
  margin-top: clamp(10px, 1.2vw, 14px);
}

.legal-page .system-context-text + .system-context-title {
  margin-top: clamp(22px, 3vw, 38px);
}

.legal-page .system-context-right,
.legal-page .system-context-media {
  display: none !important;
}

.legal-page .legal-terms-text,
.legal-page .legal-terms-bullet {
  max-width: 100%;
}

.legal-page .legal-terms-text + .legal-terms-text,
.legal-page .legal-terms-bullet + .legal-terms-text,
.legal-page .legal-terms-text + .legal-terms-bullet,
.legal-page .legal-terms-bullet + .legal-terms-bullet {
  margin-top: 0.7rem;
}

.legal-page .legal-terms-bullet {
  color: var(--text);
  font-weight: 600;
}

.privacy-policy-page .system-context-inner {
  grid-template-columns: minmax(0, 1fr);
}

.privacy-policy-page main .container {
  width: calc(100% - (var(--page-gutter) * 2));
  max-width: none;
}

.privacy-policy-page .system-context-left {
  width: 100%;
  max-width: none;
  min-height: 0;
}

.privacy-policy-page .system-context {
  padding-block: clamp(12px, 1.4vw, 22px) clamp(28px, 4vw, 56px);
}

.privacy-policy-page .privacy-notice-text + .privacy-notice-text,
.privacy-policy-page .privacy-notice-bullet + .privacy-notice-text,
.privacy-policy-page .privacy-notice-text + .privacy-notice-bullet,
.privacy-policy-page .privacy-notice-bullet + .privacy-notice-bullet {
  margin-top: 0.7rem;
}

.privacy-policy-page .privacy-notice-bullet {
  color: var(--text);
  font-weight: 600;
}

.privacy-policy-page .solutions-hero {
  min-height: var(--meet-max-banner-min-height);
  padding-block: clamp(36px, 6vw, 72px);
  display: grid;
  align-items: center;
  background: #f3f1eb;
}

.terms-page .terms-links {
  padding-block: clamp(14px, 2vw, 28px) clamp(6px, 0.9vw, 14px);
  min-height: calc(100svh - var(--header-offset));
  display: grid;
  align-items: center;
}

.terms-page .solutions-hero {
  min-height: var(--meet-max-banner-min-height);
  padding-block: clamp(36px, 6vw, 72px);
  display: grid;
  align-items: center;
  background: #f3f1eb;
}

.terms-page .system-context {
  padding-top: 0;
}

.terms-doc-page .system-context {
  padding-block: clamp(8px, 1.2vw, 18px) clamp(28px, 4vw, 56px);
}

.terms-doc-page .terms-doc-back {
  padding-top: clamp(6px, 1vw, 14px);
  min-height: auto;
  padding-bottom: 0;
}

.terms-doc-page .terms-doc-back-link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: clamp(14px, 1vw, 16px);
  line-height: 1.2;
  color: color-mix(in srgb, var(--text) 72%, transparent);
  text-decoration: none;
}

.terms-doc-page .terms-doc-back-link:hover,
.terms-doc-page .terms-doc-back-link:focus-visible {
  color: var(--text);
  text-decoration: underline;
}

.terms-page .terms-links-title {
  margin: 0 0 clamp(14px, 2vw, 24px);
  font-family: var(--serif);
  font-weight: 700;
  font-size: clamp(28px, 3.2vw, 46px);
  line-height: 1.08;
}

.terms-page .terms-links-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: clamp(12px, 1.6vw, 20px);
}

.terms-page .terms-link-card {
  display: flex;
  flex-direction: column;
  justify-content: center;
  background: color-mix(in srgb, var(--bg) 86%, #ffffff 14%);
  border: 1px solid var(--hairline);
  border-radius: 10px;
  padding: clamp(24px, 2.4vw, 34px);
  min-height: clamp(220px, 24vw, 300px);
  text-decoration: none;
}

.terms-page .terms-link-card-title {
  margin: 0;
  font-family: var(--serif);
  font-size: clamp(22px, 2.1vw, 34px);
  line-height: 1.15;
  color: var(--text);
}

.terms-page .terms-link-card-cta {
  margin: clamp(22px, 2.6vw, 34px) 0 0;
  font-size: clamp(18px, 1.55vw, 26px);
  line-height: 1.2;
  color: color-mix(in srgb, var(--text) 75%, transparent);
}

.terms-page .terms-link-card:hover,
.terms-page .terms-link-card:focus-visible {
  border-color: color-mix(in srgb, var(--text) 20%, transparent);
  background: color-mix(in srgb, var(--bg) 80%, #ffffff 20%);
}

.terms-page .system-context-inner,
.terms-doc-page .system-context-inner {
  grid-template-columns: minmax(0, 1fr);
}

.terms-page main .container,
.terms-doc-page main .container {
  width: calc(100% - (var(--page-gutter) * 2));
  max-width: none;
}

.terms-page .system-context-left,
.terms-doc-page .system-context-left {
  width: 100%;
  max-width: none;
  min-height: 0;
}

.terms-page .legal-terms-text + .legal-terms-text,
.terms-page .legal-terms-bullet + .legal-terms-text,
.terms-page .legal-terms-text + .legal-terms-bullet,
.terms-page .legal-terms-bullet + .legal-terms-bullet {
  margin-top: 0.7rem;
}

.terms-page .legal-terms-bullet {
  color: var(--text);
  font-weight: 600;
}

.terms-doc-page .terms-doc-text + .terms-doc-text,
.terms-doc-page .terms-doc-bullet + .terms-doc-text,
.terms-doc-page .terms-doc-text + .terms-doc-bullet,
.terms-doc-page .terms-doc-bullet + .terms-doc-bullet {
  margin-top: 0.7rem;
}

.terms-doc-page .terms-doc-bullet {
  color: var(--text);
  font-weight: 600;
}

.terms-doc-page .docx-import > * + * {
  margin-top: clamp(10px, 1.1vw, 16px);
}

.policy-page .docx-import p + p {
  margin-top: 0.75em !important;
}

.policy-page .docx-import p + ul.ul1,
.policy-page .docx-import ul.ul1 + p,
.policy-page .docx-import ul.ul1 + ul.ul1 {
  margin-top: 1em !important;
}

.policy-page .docx-import table.t1 {
  margin-top: 1em;
}

.policy-page .docx-import p + table.t1,
.policy-page .docx-import ul.ul1 + table.t1,
.policy-page .docx-import table.t1 + p,
.policy-page .docx-import table.t1 + ul.ul1 {
  margin-top: 1.15em !important;
}

.privacy-policy-page .docx-import > p.p1:first-child,
.terms-doc-page .docx-import > p.p1:first-child {
  display: none;
}

.privacy-policy-page .docx-import > p.p2:nth-child(2),
.terms-doc-page .docx-import > p.p2:nth-child(2) {
  display: none;
}

.policy-page .docx-import p,
.policy-page .docx-import li,
.policy-page .docx-import td,
.policy-page .docx-import th {
  font-family: var(--sans) !important;
  font-size: var(--body-copy-size) !important;
  line-height: var(--body-copy-line) !important;
  color: var(--text) !important;
}

.policy-page .docx-import p {
  margin: 0 !important;
}

.policy-page .docx-import ul.ul1,
.policy-page .docx-import ol {
  margin: 0 !important;
  padding-left: 1.2em;
}

.policy-page .docx-import li {
  margin: 0 !important;
}

.policy-page .docx-import li + li {
  margin-top: 0.34em !important;
}

.terms-doc-page .docx-import p.p2,
.terms-doc-page .docx-import p.p4,
.terms-doc-page .docx-import p.p5,
.terms-doc-page .docx-import p.p6,
.privacy-policy-page .docx-import p.p2,
.privacy-policy-page .docx-import p.p4,
.privacy-policy-page .docx-import p.p5,
.privacy-policy-page .docx-import p.p6 {
  margin: 0 !important;
  min-height: 0 !important;
  line-height: 0 !important;
  font-size: 0 !important;
}

.terms-doc-page .docx-import p.p2 br,
.terms-doc-page .docx-import p.p4 br,
.terms-doc-page .docx-import p.p5 br,
.terms-doc-page .docx-import p.p6 br,
.privacy-policy-page .docx-import p.p2 br,
.privacy-policy-page .docx-import p.p4 br,
.privacy-policy-page .docx-import p.p5 br,
.privacy-policy-page .docx-import p.p6 br {
  display: none !important;
}

.privacy-policy-page .docx-import table.t1 {
  width: 100%;
  table-layout: fixed;
  border-collapse: collapse;
}

.privacy-policy-page .docx-import table.t1 td.td1 {
  vertical-align: top;
  padding: 10px 12px !important;
}

.privacy-policy-page .docx-import table.t1 tr > td.td1:nth-child(1) {
  width: 30%;
}

.privacy-policy-page .docx-import table.t1 tr > td.td1:nth-child(2) {
  width: 36%;
}

.privacy-policy-page .docx-import table.t1 tr > td.td1:nth-child(3) {
  width: 34%;
}

.privacy-policy-page .docx-import table.t1 td.td1 p {
  margin: 0;
  text-align: left !important;
  overflow-wrap: anywhere;
}

.support-sla-page .docx-import table.t1 {
  width: 100%;
  table-layout: fixed;
  border-collapse: collapse;
}

.support-sla-page .docx-import table.t1 td.td1 {
  vertical-align: top;
  padding: 10px 12px !important;
}

.support-sla-page .docx-import table.t1 tr > td.td1:nth-child(1) {
  width: 30%;
}

.support-sla-page .docx-import table.t1 tr > td.td1:nth-child(2) {
  width: 36%;
}

.support-sla-page .docx-import table.t1 tr > td.td1:nth-child(3) {
  width: 34%;
}

.support-sla-page .docx-import table.t1 td.td1 p {
  margin: 0;
  text-align: left !important;
  overflow-wrap: anywhere;
}

/* Final hard override: zoom/crop only for Reasoning "Work Across Multi Document Matters" media. */
.reasoning-page .system-context-media--handle-matters {
  overflow: hidden !important;
}

.reasoning-page .system-context-media--handle-matters .system-context-video {
  transform: scale(1.56) !important;
  transform-origin: center !important;
  object-position: 71% 68% !important;
}

/* Home mobile: reduce perceived zoom in the 4 System cards. */
@media (max-width: 980px) {
  .home-page .features .feature-media {
    min-height: clamp(220px, 52vw, 280px);
    aspect-ratio: 16 / 10;
  }

  .home-page .features .home-feature-video--reasoning-center {
    transform: scale(1.01) !important;
    object-position: 50% 50% !important;
    -webkit-clip-path: inset(0) !important;
    clip-path: inset(0) !important;
  }

  .home-page .features .home-feature-video--drafting-crop {
    transform: scale(1) !important;
    object-position: 50% 50% !important;
  }

  .home-page .features .feature-media--review .home-feature-video--review-crop {
    transform: scale(1.02) !important;
    object-position: 52% 50% !important;
    -webkit-clip-path: inset(2px 0 2px 4px) !important;
    clip-path: inset(2px 0 2px 4px) !important;
  }

  .home-page .features .home-feature-video--knowledge-crop {
    --home-knowledge-zoom-start: 1.08;
    --home-knowledge-zoom-end: 1;
    object-position: 50% 24% !important;
  }
}

/* Contact page: final clean overrides */
.contact-page .contact-side .contact-pricing-features,
.contact-page .contact-side .contact-pricing-note,
.contact-page .contact-side .contact-pricing-benefits,
.contact-page .contact-side .contact-pricing-features .contact-pricing-feature,
.contact-page .contact-side .contact-pricing-benefits li {
  text-align: left !important;
}

.contact-page .contact-side .contact-pricing-cta {
  margin-top: 6px !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

.contact-page main > section.contact-section {
  position: relative;
  padding-bottom: clamp(28px, 4vw, 56px) !important;
}

@media (min-width: 981px) {
  .contact-page main > section.contact-section {
    overflow: hidden !important;
  }

  .contact-page main > section.contact-section::before {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    width: 50%;
    background: url("images/PHOTO OFFICIELLE BANKING.png") right center / cover no-repeat;
    pointer-events: none;
    z-index: 0;
  }

  .contact-page main > section.contact-section > .container {
    position: relative;
    z-index: 1;
  }

  .contact-page .contact-grid {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) !important;
    gap: clamp(28px, 3vw, 48px) !important;
    align-items: stretch !important;
  }

  .contact-page .contact-side,
  .contact-page .contact-pane--form {
    width: 100% !important;
    max-width: none !important;
    margin: 0 !important;
    padding: 0 !important;
    display: flex !important;
    flex-direction: column !important;
    align-self: stretch !important;
  }

  .contact-page .contact-side .contact-side-intro,
  .contact-page .contact-pane--form .contact-form-intro {
    width: 100% !important;
    min-height: clamp(190px, 14vw, 250px) !important;
    margin: 0 0 clamp(14px, 1.6vw, 22px) !important;
    padding: 0 !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important;
    align-items: center !important;
    text-align: center !important;
    overflow: visible !important;
  }

  .contact-page .contact-side .contact-pricing-kicker,
  .contact-page .contact-pane--form .contact-kicker {
    font-size: clamp(24px, 2vw, 38px) !important;
    line-height: 1.04 !important;
    white-space: normal !important;
    text-wrap: balance;
  }

  .contact-page .contact-side .contact-pricing-sub,
  .contact-page .contact-pane--form .contact-title {
    font-size: clamp(20px, 1.7vw, 32px) !important;
    line-height: 1.08 !important;
    margin-bottom: clamp(6px, 0.8vw, 12px) !important;
  }

  .contact-page .contact-side .contact-pricing-copy,
  .contact-page .contact-pane--form .contact-subtitle {
    font-size: clamp(14px, 0.95vw, 17px) !important;
    line-height: 1.32 !important;
    max-width: min(94%, 38ch) !important;
    margin: 0 auto !important;
    text-wrap: balance;
  }

  .contact-page .contact-side .contact-pricing-card,
  .contact-page .contact-pane--form .contact-card {
    width: 100% !important;
    max-width: none !important;
    margin: 0 !important;
    flex: 1 1 auto !important;
    min-height: 0 !important;
    height: 100% !important;
  }

  .contact-page .contact-pane--form {
    position: relative !important;
    overflow: visible !important;
    background: none !important;
  }

  .contact-page .contact-pane--form .contact-card {
    background-image: none !important;
    background-color: rgba(255, 255, 255, 0.9) !important;
    border: 1px solid rgba(17, 17, 17, 0.12) !important;
  }

  .contact-page .contact-pane--form .contact-form {
    background: transparent !important;
  }

  .contact-page .contact-pane--form .contact-form-intro {
    background: rgba(248, 247, 244, 0.44) !important;
  }

  /* Final alignment lock: remove legacy horizontal offsets and keep strict column edges. */
  .contact-page .contact-form-intro,
  .contact-page .contact-side-intro,
  .contact-page .contact-pane--form .contact-card,
  .contact-page .contact-side .contact-pricing-card {
    transform: none !important;
  }

  .contact-page .contact-pane--form .contact-form-intro,
  .contact-page .contact-pane--form .contact-card,
  .contact-page .contact-side .contact-side-intro,
  .contact-page .contact-side .contact-pricing-card {
    width: 100% !important;
    max-width: 100% !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
  }

  .contact-page .contact-side .contact-pricing-top {
    display: grid !important;
    grid-template-columns: 1fr auto 1fr !important;
    align-items: end !important;
    column-gap: 12px !important;
    text-align: center !important;
  }

  .contact-page .contact-side .contact-pricing-currency {
    justify-self: end !important;
  }

  .contact-page .contact-side .contact-pricing-top strong {
    justify-self: center !important;
  }

  .contact-page .contact-side .contact-pricing-period {
    justify-self: start !important;
    text-align: left !important;
  }

  .contact-page .contact-side .contact-pricing-line--lead {
    text-align: center !important;
  }

  .contact-page .contact-side .contact-pricing-cta {
    display: flex !important;
    width: fit-content !important;
    margin-top: 14px !important;
    margin-left: auto !important;
    margin-right: auto !important;
    justify-content: center !important;
  }

.contact-page .contact-side .contact-pricing-card {
    width: min(100%, 84%) !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }
}

/* Final lock: Why Max hero videos must stay wide and never crop. */
.strategic-legal-advice-page .system-hero-media,
.confidence-trust-page .system-hero-media,
.zero-fracture-workflow-page .system-hero-media {
  aspect-ratio: 16 / 9 !important;
  background: #000000 !important;
  overflow: hidden !important;
  display: grid !important;
  place-items: center !important;
}

.strategic-legal-advice-page .system-hero-media .system-hero-video,
.confidence-trust-page .system-hero-media .system-hero-video,
.zero-fracture-workflow-page .system-hero-media .system-hero-video {
  width: 100% !important;
  height: 100% !important;
  max-width: 100% !important;
  max-height: 100% !important;
  object-fit: contain !important;
  object-position: center center !important;
  transform: none !important;
}
